Hoy veremos un nuevo tutorial de como guardar la dirección y coordenadas del GPS a una base de datos en android studio, para este ejercicio debes tener conocimientos básicos sobre web services y base de datos.
como guardar la dirección y coordenadas del GPS a una base de datos en android studio
¿Que vamos a utilizar?:
Un servicio Apache con Mysql
Un WebService
Una base de datos»gpsbd» para almacenar datos
NOTA: Al final del post les dejare los archivos
Primero crearemos nuestra base de datos en mi caso le puse de nombre gpsbd, luego creamos nuestra tabla gps.
CREATE TABLE IF NOT EXISTS `gps` ( `id` int NOT NULL AUTO_INCREMENT, `direccion` varchar(100) NOT NULL, `coordenadas` varchar(150) NOT NULL, PRIMARY KEY (`id`) )
Creamos nuestro insertar.php
?php $hostname ="localhost"; //nuestro servidor $database ="gpsbd";//Nombre de nuestra base de datos $username ="root";//Nombre de usuario de nuestra base de datos (yo utilizo el valor por defecto) $password ="12345";//Contraseña de nuestra base de datos (yo utilizo por defecto) $conexion = mysqli_connect($hostname,$username,$password)//Conexión a nuestro servidor mysql //mysqli_select_db($conexion,$dbname); or trigger_error(mysql_error(),E_USER_ERROR); //mensaaje de error si no se puede conectar mysqli_select_db($conexion, $database);//seleccion de la base de datos con la qu se desea trabajar //variables que almacenan los valores que enviamos por nuestra app, (observar que se llaman igual en nuestra app y aqui) $direccion=$_POST['direccion']; $coordenadas=$_POST['coordenadas']; if (empty($_POST["coordenadas"]) AND $_POST["direccion"]!==''){ echo "Faltan DATOS los campos estan vacios"; }else{ $query_search = "insert into gps(direccion,coordenadas) values ('".$direccion."','".$coordenadas."')";//Sentencia sql a realizar $query_exec = mysqli_query($conexion,$query_search) or die(mysqli_error($conexion));//Ejecuta la sentencia sql. } ?>
ya tenemos nuestra BD y nuestra parte php que servirá para la web service. Si todo han configurado y creado bien deben ir a su navegador en la siguiente ruta localhost/gpsbd/insertar.php Aclaro que mi web services lo he creado en mi pc de forma local con xampp pero también podría subirlo a un hosting y debe salirse lo siguiente. Los errores son porque no están enviando ningún dato para registrarse.
Ahora toca la parte Android. debemos dar unos permisos, para que funcione:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
creamos una aplicación nueva y agregamos los siguientes en nuestro activity_main
activity_main
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context="com.androidmorefast.pc.appguardargpsbd.MainActivity"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:layout_alignParentTop="true" android:layout_alignParentLeft="true" android:layout_alignParentStart="true"> <TextView android:text="MIS COORDENADAS SON:" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_alignParentLeft="true" android:layout_alignParentStart="true" android:id="@+id/textView" /> <TextView android:id="@+id/mensaje_id" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="TextView" /> <TextView android:text="MI DIRECCION ES:" android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/textView2" /> <TextView android:id="@+id/mensaje_id2" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="TextView" /> <Button android:id="@+id/btnGuardar" android:text="GUARDAR" android:layout_width="match_parent" android:layout_height="wrap_content" android:elevation="1dp"></Button> </LinearLayout> </RelativeLayout>
Debemos agregar una librería apache en nuestro buil.gradle, esta debe ir dentro de dependencies
compile 'org.jbundle.util.osgi.wrapped:org.jbundle.util.osgi.wrapped.org.apache.http.client:4.1.2'
Ahora debemos ir a nuestro MainActivity y agregar lo siguiente:
MainActivity
package com.androidmorefast.pc.appguardargpsbd; import android.Manifest; import android.app.Activity; import android.content.Context; import android.content.Intent; import android.content.pm.PackageManager; import android.location.Address; import android.location.Geocoder; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.location.LocationProvider; import android.os.AsyncTask; import android.provider.Settings; import android.support.v4.app.ActivityCompat; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.TextView; import android.widget.Toast; import org.apache.http.NameValuePair; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.HttpClient; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.message.BasicNameValuePair; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.ArrayList; import java.util.List; import java.util.Locale; public class MainActivity extends AppCompatActivity { TextView mensaje1; TextView mensaje2; private Button botonGuardar; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mensaje1 = (TextView) findViewById(R.id.mensaje_id); mensaje2 = (TextView) findViewById(R.id.mensaje_id2); botonGuardar = (Button) this.findViewById(R.id.btnGuardar); botonGuardar.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { new Insertar(MainActivity.this).execute(); } }); if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION,}, 1000); } else { locationStart(); } } //Insertamos los datos a nuestra webService private boolean insertar(){ HttpClient httpClient; List<NameValuePair> nameValuePairs; HttpPost httpPost; httpClient = new DefaultHttpClient(); httpPost = new HttpPost("http://192.168.8.118/gpsbd/insertar.php");//url del servidor //empezamos añadir nuestros datos nameValuePairs = new ArrayList<NameValuePair>(4); nameValuePairs.add(new BasicNameValuePair("coordenadas",mensaje1.getText().toString().trim())); nameValuePairs.add(new BasicNameValuePair("direccion",mensaje2.getText().toString().trim())); try { httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs)); httpClient.execute(httpPost); return true; } catch(UnsupportedEncodingException e){ e.printStackTrace(); }catch (ClientProtocolException e){ e.printStackTrace(); }catch (IOException e){ e.printStackTrace(); } return false; } //AsyncTask para insertar Datos class Insertar extends AsyncTask<String,String,String> { private Activity context; Insertar(Activity context){ this.context=context; } protected String doInBackground(String... params) { // TODO Auto-generated method stub if(insertar()) context.runOnUiThread(new Runnable(){ @Override public void run() { // TODO Auto-generated method stub Toast.makeText(context, "Datos insertado con éxito", Toast.LENGTH_LONG).show(); mensaje1.setText(""); mensaje2.setText(""); } }); else context.runOnUiThread(new Runnable(){ @Override public void run() { // TODO Auto-generated method stub Toast.makeText(context, "Datos no insertado con éxito", Toast.LENGTH_LONG).show(); } }); return null; } } //Apartir de aqui empezamos a obtener la direciones y coordenadas private void locationStart() { LocationManager mlocManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); Localizacion Local = new Localizacion(); Local.setMainActivity(this); final boolean gpsEnabled = mlocManager.isProviderEnabled(LocationManager.GPS_PROVIDER); if (!gpsEnabled) { Intent settingsIntent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS); startActivity(settingsIntent); } if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) { ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION,}, 1000); return; } mlocManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, (LocationListener) Local); mlocManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, (LocationListener) Local); mensaje1.setText("Localizacion agregada"); mensaje2.setText(""); } public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { if (requestCode == 1000) { if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { locationStart(); return; } } } public void setLocation(Location loc) { //Obtener la direccion de la calle a partir de la latitud y la longitud if (loc.getLatitude() != 0.0 && loc.getLongitude() != 0.0) { try { Geocoder geocoder = new Geocoder(this, Locale.getDefault()); List<Address> list = geocoder.getFromLocation( loc.getLatitude(), loc.getLongitude(), 1); if (!list.isEmpty()) { Address DirCalle = list.get(0); mensaje2.setText(DirCalle.getAddressLine(0)); } } catch (IOException e) { e.printStackTrace(); } } } /* Aqui empieza la Clase Localizacion */ public class Localizacion implements LocationListener { MainActivity mainActivity; public MainActivity getMainActivity() { return mainActivity; } public void setMainActivity(MainActivity mainActivity) { this.mainActivity = mainActivity; } @Override public void onLocationChanged(Location loc) { // Este metodo se ejecuta cada vez que el GPS recibe nuevas coordenadas // debido a la deteccion de un cambio de ubicacion loc.getLatitude(); loc.getLongitude(); String Text = "Lat = "+ loc.getLatitude() + "\n Long = " + loc.getLongitude(); mensaje1.setText(Text); this.mainActivity.setLocation(loc); } @Override public void onProviderDisabled(String provider) { // Este metodo se ejecuta cuando el GPS es desactivado mensaje1.setText("GPS Desactivado"); } @Override public void onProviderEnabled(String provider) { // Este metodo se ejecuta cuando el GPS es activado mensaje1.setText("GPS Activado"); } @Override public void onStatusChanged(String provider, int status, Bundle extras) { switch (status) { case LocationProvider.AVAILABLE: Log.d("debug", "LocationProvider.AVAILABLE"); break; case LocationProvider.OUT_OF_SERVICE: Log.d("debug", "LocationProvider.OUT_OF_SERVICE"); break; case LocationProvider.TEMPORARILY_UNAVAILABLE: Log.d("debug", "LocationProvider.TEMPORARILY_UNAVAILABLE"); break; } } } }
Ahora si ustedes quieren detallar en el código de como obtener el gps los invito a que revisen el siguiente enlace asiendo clic aqui -> como obtener la ubicación del gps .
Yo estoy poniendo la ip de mi computadora y mi celular esta conectado vía wifi por el mismo moden así que no tengo problemas, pero ustedes pueden poner el dominio de algún hosting que termine en .com en ves de poner la ip, eso queda a su criterio.
httpPost = new HttpPost("http://192.168.8.118/gpsbd/insertar.php")
También hay las siguientes lineas, donde deben fijarse la parte en rosado, debe estar escrita igual como esta en la web services, de lo contrario no llamara dichos atributos
(new BasicNameValuePair("coordenadas",mensaje1.getText().toString().trim()));
(new BasicNameValuePair("direccion",mensaje2.getText().toString().trim()));
En nuestra base de datos se guardaría de la siguiente forma como muestro en la imagen:
Igual si piensas que hablo escribo en chino te dejo el ejercicio:
ENLACES DE INTERÉS:
Hola soy Alex Céspedes fundador de ANDROFAST, programo algunas cosas por diversión, me gusta aprender cosas nuevas y estoy pendiente de todo lo que tenga que ver con tecnología. Este blog lo cree para todas las personas que tengan dificultades en la programación, para ser sincero nunca fui bueno y reprobé algunos cursos de programación, pero mis ganas de aprender pudieron más. SI YO PUEDO TU PUEDES ANIMO!
Hola necesito una ayuda, estoy haciendo una aplicación android, quiero guardar ubicaciones, mostrarlas en el mapa cuando quiera, es para canchas de fútbol de alquiler, luego al dar click en una cancha (lista en un list view o maker en el mapa) debe reflejar los contactos, ubicación lógicamente, dimensiones; todo esto guardado en una base de datos sea local para pruebas o en un hosting, tengo todos estos servicios, pero si tuvieras un material que sea similar te lo podría comprar?
Hola Eduardo, es poca la información que das puedes escribirnos a: [email protected] o crear un tema en nuestro foro para ayudarte mejor, Saludos.
que tal me pueden orientar para conectar la bases de datos online, estoy atorado en este paso gracias, por su pronta respuesta,,
Hola, Al final lo arreglaste? A mí tampoco me funciona…
Un saludo!
hola, me puedes ayudar con información, necesito capturar las coordenadas de un teléfono, enviarlo a un servidor, y desde una aplicación android leer esas coordenadas y mostrarlo en el mapa.
revise lo siguiente: https://www.androfast.com/2017/11/como-registrar-las-coordenadas-en.html https://www.androfast.com/2017/03/como-obtener-coordenadas-del-gps-y.html
hola christian, no se si te sirva pero hice algo similar a lo que quieres pero yo leo las coordenadas directamente en la web, usando php y mysql
Miguel me podrias ayudar con eso ? escribeme [email protected]
Hola, he visto que también hay otra persona que está como yo…
En el móvil me aparece que se subieron, pero luego en la bbdd o me aparecen los datos.. ¿Que es lo que puedo estar haciendo mal?
Ya que he seguido el tutorial paso a paso y copiando y pegando todo…
Gracias
Hola te contare algo, veras este ejercicio funciona 100% con el mysql que trae los gestores de xampp, wamp y appserver pero si usas una aplicación como mysql installer no te va funcionar , solo te enviara null…ahora dime cual estas usando tu?
Como podría utilizar los archivos php con un dominio de hostinger, adapte los archivos php para hacerlos con la plataforma mysql de hostinger y nada no logro conectar la base de datos alguien quien me ayude :’v.
Muchísimas gracias!!!
yo tengo un servidor de pago y a mi me funciona bien, tienes que checar que los datos que estas mandando a tu base de datos no vayan null, si quieren los que tengan problemas con el php y el mysql, les puedo compartir mis archivos mi correo es
mchehade2000@hotmail,.com
hola disculpa me puedes ayudar en la conexion de php me manda un error
Parse error: syntax error, unexpected ‘DATOS’ (T_STRING), expecting ‘,’ or ‘;’ in C:\xampp\htdocs\gpsbd\insertar.php on line 15
y ya me quede atorado porfis. o escribeme al correo [email protected]
Pingback: Como implementar un Place Picker (selector de lugares) en android studio | ANDROFAST
Parse error: syntax error, unexpected ‘DATOS’ (T_STRING), expecting ‘,’ or ‘;’ in C:\xampp\htdocs\gpsbd\insertar.php on line 15
Hola, me sale tambien ese error no se si me puedas ayudar
Era un error de las comillas, algo sencillo pero ya se arreglo, saludos.
Hola, mysql_connect esta desfasado, tienes el script en php actualizado a php 7.*, te lo agradeceré muchisimo. Gracias.
Pingback: Android: Guardar coordenadas en mysql con volley - ANDROFAST
ayuda he hecho al pie de la letra estoy trababajando con hosting pero no guarda me aparece el mensaje datos insertados correctamente pero en la base de datos no se guardo nada ayuda
Hola buenas tardes, esta muy interesante tu blog realmente me esta ayudando, sin embargo me gustaría crear una aplicación que guarde los datos del gps de manera constate, aun que el usuario no tenga la app a la vista, he leido algo de los servicios en segundo plano, no se si por aquí tengas algún ejemplo queme pueda ayudar. De ante mano gracias.