Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

raptor-droid

Package Overview
Dependencies
Maintainers
1
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

raptor-droid

tool for create android embedded web apps

  • 0.1.2
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
9
Maintainers
1
Weekly downloads
 
Created
Source

Raptor droid

Raptor Droid es una herramienta perteneciente al Proyecto Raptor, está orientada a la creación de aplicaciones android con tecnologías web de forma embebida.

En pocos pasos podras poner operativa una aplicación android utilizando HTML, CSS y Javascript, puedes comunicarte con los principales servicios del backend de la aplicación.

  • Servicio de Geolocalización
  • Reproducir sonidos
  • Tomar fotos
  • Ejecutar Intents nativos
  • Soporte a Base de Datos

Comenzando

Lo primero que haremos será instalar Node.js en nuestro equipo, una vez instalado utilizaremos el gestor de paquetes de node npm para instalar raptor-droid utilizando el paquete tar descargado(Pronto estará en el npm registry). Indicaremos que la instalación sera de forma global así que especificaremos el siguiente comando.

Con conexión a internet:

$npm install raptor-droid -g

Sin conexión a internet y teniendo el paquete offline:

$npm install /direccion/local/al/paquete/raptor-droid-0.0.3.tgz -g

Una vez instalado crearemos un nuevo proyecto en forma de paquete node en un directorio de nuestro equipo:

$mkdir holamundoapp
$cd /holamundoapp
$npm init

Npm pedirá un conjunto de datos de configuración iniciales de nuestro paquete y luego en nuestro directorio holamundoapp podrás ver un archivo package.json con la información configurada por el npm. Hasta este punto ya estamos listos para crear nuestra aplicación embebida de android.

Para crear un nuevo proyecto android abre la consola cmd en el directorio recién creado y escribe el comando:

$raptor-droid create holamundo cu.miweb.apphola

Esta opción crea un nuevo proyecto, donde el nombre de la aplicación sería holamundo y el paquete definido cu.miweb.apphola

Por defecto el proyecto se creará con los siguientes directorios:

  • app Contiene las fuentes de la aplicación android.
  • www Contiene nuestros recursos HTML, CSS, JS, Imágenes y configuración.

Una vez creado el proyecto debemos modificar el archivo de configuración ubicado en el directorio www para establecer el SDK de android y el wrapper gradle para compilar nuestra aplicación. El archivo aparecerá con la siguiente configuración:

{
  "name": "holamundo",
  "icon": "@mipmap/raptor",
  "pkg": "cu.miweb.apphola",
  "permissions": [],
  "gradleDistributionUrl": "wrapper gradle ej. file:///C:/android/gradle-4.1-all.zip",
  "sdk": "Directorio del sdk",
  "version":{
    "name":"0.0.1",
    "code":1
  }
}

Para configurar nuestra app debemos descargar el SDK android y descompromirlo en cualquier parte de nuestra PC. Si contamos con conexión a internet podemos dejar el campo gradleDistributionUrl vacío para que automaticamente se descargue, de lo contrario descargamos gradle-4.1-all.zip de forma manual y lo descomprimimos en nuestra pc. La configuración quedaría de la siguiente forma:

{
  "name": "holamundo",
  "icon": "@mipmap/raptor",
  "pkg": "cu.miweb.apphola",
  "permissions": [],
  "gradleDistributionUrl": "file:///C:/android/gradle-4.1-all.zip",
  "sdk": "C:/android/sdk",
  "version":{
    "name":"0.0.1",
    "code":1
  }
}

Compilando

Para compilar nuestra aplicación abrimos la consola cmd en el directorio de nuestra app y escribimos el comando:

$raptor-droid build

En modo de desarrollo podremos conectar nuestro dispositivo y correr nuestra app a través del comando raptor-droid run. (Recuerde habilitar el modo de desarrollo en su dispositivo)

Modo liberación

Para crear nuestra apk en modo liberación abrimos la consola cmd en el directorio de nuestra app y escribimos el comando:

$raptor-droid release <keystore>

El <keystore> especificado es el nombre del archivo jks que se utilizará en el proceso de firma de nuestra apk.

Este comando detecta si existe un jks con ese nombre en el directorio home de nuestra pc, si no existe le pedirá un conjunto de datos para crear uno y finalmente compilará nuestra apk.

La apk firmada se encontrará en el directorio app\app\build\outputs\apk\release de nuestro proyecto.

Referencia

$d

Recepción de Eventos

Los eventos podrán ser escuchados a través de la función on:

droid:ready

Evento disparado cuando el dispositivo se encuentra listo para ejecutarse.

$d.on("droid:ready", function(e,data) {
	console.log("Mobile ready")
})
droid:photo.result

Evento disparado cuando el resultado de la toma de la foto está listo, devuelve la toma codificada en base64. Requiere el permiso [android.permission.CAMERA]

$d.send('droid:photo','thumbnail')

$d.on('droid:photo.result',function(e,result){
  $('#photo').attr('src',result)
})
droid:gps.location

Evento disparado cuando el dispositivo ha fijado la posición gps, devuelve un objeto {lat: -45.235555, lon:36.256522}. Requiere el permiso [android.permission.ACCESS_FINE_LOCATION]

$d.send('droid:gps.init')

$d.on('droid:gps.location',function(e,location){
   $('#gps').html(location)
})
droid:gps.status

Evento disparado cuando el dispositivo comienza la busqueda de posición gps, devuelve un objeto con los datos busqueda ej. {status:true,satelliteCount:10,satelliteUsed:7}. Requiere el permiso [android.permission.ACCESS_FINE_LOCATION]

$d.send('droid:gps.init')

$d.on('droid:gps.status',function(e,status){
  $('#status').html(status)
})

Funciones

.send(String: nombre, Object: datos|String: datos): void

Envía una señal hacia el backend para ejecutar el nombre de evento especificado así como el parámetro datos en forma de objeto o string.

$d.send('droid:gps.init')

.sendGetString(String: nombre, Object: datos|String: datos): String

Envía una señal hacia el backend para ejecutar el nombre de evento especificado así como el parámetro datos en forma de objeto o string.

var result=$d.sendGetString('example1')

.on(String: nombre, Function: callbak): void

Registra la función callback para el evento especificado.

$d.on('droid:gps.location',function(e,location){
	console.log(location)
})

Envío de eventos

Los eventos enviados indican al backend realizar una función nativa, raptor-droid tiene eventos definidos que pueden ser llamados a través de la función $d.send(...). Entre las funciones se encuentra la ejecución de Intents nativos, inicialización del GPS, reprodución de audio etc.

droid:photo

Indica que se levante el intent para la toma de una imagen a través de camara, el resultado de la toma podrá ser recogido a través de la recepción del evento droid:photo.result.

$d.send('droid:photo','thumbnail')

droid:openurl

Indica que se levante el intent para abrir una url en el navegador del dispositivo.

$d.send('droid:openurl','http://google.com')

droid:loadurl

Indica que se cargue en la propia ventana la página local indicada, relativa al directorio www.

$d.send('droid:loadurl','miDirectorio/index.html')

droid:intent

Indica que se levante el intent especificado en el atributo action del parámetro Object especificado.

Object:

  • action: String, nombre del intent a levantar.
  • extras: Array, extras especificados
  • result: Integer(opcional), identificador entero del resultado esperado del intent
$d.send('droid:intent',{
	action:"com.google.zxing.client.android.SCAN",
    extras:[{
		name:'SCAN_MODE',
        value:'QR_CODE_MODE'
    }],
	result:106
})
droid:notification

Muestra un mensaje en la barra de notificaciones.

Object:

  • title: String, Título del mensaje de notificación.
  • text: String, Texto del mensaje de notificación.
$d.send('droid:notification',{
	title:"Hola mundo",
	text:"texto de notificación del mensaje"
})

droid:playsound

Reproduce un sonido en el dispositivo.

fileSound: String, Url local del archivo a reproducir relativo a www.

$d.send('droid:playsound','/sounds/efecto.mp3')

Comandos y herramientas

Los comandos y herramientas son utilitarios que te ayudarn a configurar y desplegar la aplicación movil.

genicon

El comando genicon levanta la herramienta utilitaria Android Asset Studio en nuestro navegador para la generación de los iconos de nuestra apk.

$raptor-droid genicon

Una vez configurado el icono le especificamos un Name y pulsamos en el ícono exportar, la herramienta exportará un archivo ZIP con los iconos generados para todas las resoluciones. Descargamos el archivo en la carpeta www y le damos descomprimir, dentro del directorio se creará un nuevo directorio res con la estructura requerida.

En nuestro archivo de configuración (config.json) en el directorio www cambiaremos el icono de nuestra apk al generado anteriormente.

{
  "name": "holamundo",
  "icon": "@mipmap/miicono",
  "pkg": "cu.miweb.apphola",
  "permissions": [],
  "gradleDistributionUrl": "wrapper gradle ej. file:///C:/android/gradle-4.1-all.zip",
  "sdk": "Directorio del sdk",
  "version":{
    "name":"0.0.1",
    "code":1
  }
}

Terceros

db.js

db.js es un wrapper para IndexedDB permitiendo una interfaz más próxima a la gestión de base de datos mediante querys.

Ver API

Proyecto Raptor

Raptor Droid

© 2014, 2019, Proyecto Raptor Cuba MIT License.

Raptor Droid es mantenido por el Proyecto Raptor con ayuda de los contribuidores.

FAQs

Package last updated on 14 Jan 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc