Ir al contenido principal

Geolocalización con PhoneGap y poner marcadores usando un servicio web

Geolocalización con PhoneGap y poner marcadores usando un servicio web

En esta entrada quiero mostrarte como funciona la geolocalización con PhoneGap. Si no sabes lo que es PhoneGap, aquí te dejo la descripción de Wikipedia ¿Qué es PhoneGap ? , pero en pocas líneas , es un framework que permite hacer aplicaciones multiplataforma , para distintos sistemas operativos de smartphone utilizando JavaScript, HTML 5 y CSS3. Una vez esta pequeña introducción paso a la explicación.


¿Cómo funciona?

Bien, te explico como va esto, pero en este ejemplo asumo que controlas un mínimo de javaScript ya que no quiero  entrar en detalles de código fuente del ejemplo , solo en como podemos usar la geolocalización usando phoneGap.

PhoneGap, dispone de dos métodos muy sencillos en su API que setean un objeto Position con parámetros como la latitud , longitud , y otros como altura, velocidad , etc, que accederemos a ellos en el método onSuccess() . Pero en este caso solo vamos a necesitar la latitud y lontigud. 

Los métodos getCurrentPosition() y watchPosition(), tienen parámetros opcionales para personalizar la respuesta de la geolocalización:

Las propiedades opcionales disponibles para el objeto Position son:

{ maximumAge: 3000, timeout: 5000, enableHighAccuracy: true };
  • maximumAge: Son los milisegundos máximos que se almacena una posición en caché.
  • timeout: Al poner milisegundos a este parámetro , lo que hacemos es dar un márgen de tiempo máximo que tiene que transcurrir desde que la función getCurrentPosition() o watchPosition() finaliza hasta que ejecuta el método callback onSuccess(). Si este tiempo es sobrepasado , se ejecutará el método onError().
  • enableHighAccuracy: Indicamos que queremos los datos de localización sean los más precisos posibles.

Los métodos son los siguientes:

  • navigator.geolocation.getCurrentPosition: Este método obtiene los datos de la posición actual.
  • navigator.geolocation.watchPosition: Este método obtiene los datos de la posición cuando se detecta un cambio de posición , es decir, cuando nos movemos.
  • navigator.geolocation.clearWatch: Este método detiene la búsqueda de nuestra posición, para el método watchPosition .

Una vez estos métodos ejecuten su función callback onSuccess() u onError() será lanzada y ya habrá terminado la geolocalización. Si todo ha ido bien , ya tenemos nuestro objeto Position con sus atributos seteados, y dentro del método onSuccess() ya podremos acceder a ellos.

Para ver los datos solo tenemos que acceder a los atributos del objeto Position de la siguiente manera:

Console.log("Longitud : "+ Position.coords.longitude);
Console.log("Longitud : "+ Position.coords.latitude);

Ya con eso tenemos los datos necesarios para crear un marcador de google.


Un ejemplo sencillo y real para verlo en práctica.

Datos que envía el web service


En el siguiente ejemplo lo que hago es obtener mi localización ( será el marcador verde ) y las distintas localizaciones de los Centros de información turistica de Tenerife. Los datos los he sacado de OpenData Canarias. Una vez obtenidos los datos que ofrece el web service (http://www.gabrielglez.com/phonegap/ , situo las oficinas en el mapa con los marcadores de google.

Puedes descargar el ejemplo aquí y probarlo en tu móvil. (LocalizatorGabriel.zip)




Utilizando JQueryMobile pues vamos accediendo a los distintos datos que nos ofrece el web service y vamos marcando los puntos en el mapa, los markers. 

Pues hasta aquí ha sido todo. No quería entrar en detalles de código , eso lo puedes ver en el código fuente del proyecto, quería centrarme en la explicación de geolocalización con phoneGap, explicar sus métodos que nos ofrece la API , sus propiedades y como consumir un servicio web para utilizarlo para dibujar marcadores en un mapa de google.

Espero que esto te sirva de ayuda y haya aclarado algun duda si la tenías. Gracias.









Entradas populares de este blog

LPIC-1 101 y 102

Certificación LPIC-1 101-102. Linux Certification Institute. Esta entrada es especial para mi porque he aprobado el certificado LPIC-1 de Linux. Al buscar información sobre las certificaciones , pues encontré información confusa y sé de algunas personas que quieren prepararse el exámen para un futuro , y si las bases de los exámenes no cambian quería aclararle las dudas. Quien no sepa lo que es LPIC-1 , es una certificación del Linux Professional Institute  la cual avala que tienes los conocimientos mínimos para gestionar un sistema operativo Linux independientemente de su distribución, como siempre te pongo la información más extendida   aquí .  El LPIC-1 es el primer exámen de todos y te digo desde ya que tiene su dificultad. Esto lo digo porque yo mismo al llevar un par de años con Linux , creía que mis conocimientos en Linux eran suficientes y solo había visto la punta del iceberg. Y en el primer nivel tocas muchas cosas. Lo que te quiero decir con esto es que e

Juego de la Serpiente con Java Swing

En esta entrada les voy a mostrar como hice el juego de la serpiente. Cuando tenía 15 años lo intente hacer y en ese momento lo ví como algo extremadamente complejo.  En su momento no vi mucha información de como hacer el juego ( o no supe encontrar ) , y por si alguien está en esta situación , aquí va mi aportación para intentar aclarar sus dudas.    He visto muchos códigos que lo han hecho mucho mejor, dibujando en el Frame y mucho más trabajado, pero yo personalmente soy partidiario de que siempre es mejor ver las cosas desde su nivel más simple, y una vez entendida la idea, ya luego pasarla a otra cosa, darle mejor aspecto y adornos son valores añadidos. Para el que no sepa como funciona el juego de la serpiente ( cosa que dudo , todos tuvimos un Nokia ) , es una serpientita a la que le van apareciendo frutas , ella va comiendo y se va haciendo grande, hasta que llega un momento que se hace muy difícil controlarla porque es demasiado grande y chocamos con nosotros mismos.

Añadiendo autocompletado a un JTextField de Java Swing

Esta vez para un trabajo de clase en  Java Swing  me vi con la necesidad de tener un JTextField con autocompletado ( como la caja de texto de Google cuando buscas algo ) y como no viene por defecto el JTextField con esta característica , pues tuve que hacerme uno. Pero en este caso no me hacía falta consultar una base de datos para rellenarlo según vas escribiendo en él, sino que a este ya le doy los datos a filtrar de antemano. Tú dirás ... pero si hay miles en internet ya hechos , por qué reinventar la rueda ...,  Ya , ya lo sé , pero en algunos de los que ví , no me gustaba la manera de como se implementaban en el código para poder usarlo , otros no me gustaban como se veían visualmente , y lo más importante ... yo no me podía quedar con la duda de como se hacía uno ( esta última era la que más me podía jeje , yo y mi curiosidad ). ¿Cómo lo uso ? Te explico como funciona el componente GTextField , tan simple como instanciarlo y en su constructor pasarle t