como guardar la direccion y coordenadas del gps a una base de datos en android studio

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.

¿Que vamos a utilizar?:
Un servicio Apache con Mysql
Un WebService
Una base de datos”bdgps” 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 bdgpsluego 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 ="localhost";  //nuestro servidor
$database_localhost ="bdgps";//Nombre de nuestra base de datos
$username_localhost ="root";//Nombre de usuario de nuestra base de datos (yo utilizo el valor por defecto)
$password_localhost ="12345";//Contraseña de nuestra base de datos (yo utilizo por defecto)
$localhost = mysql_connect($hostname_localhost,$username_localhost,$password_localhost)//Conexión a nuestro servidor mysql
or
trigger_error(mysql_error(),E_USER_ERROR); //mensaaje de error si no se puede conectar
mysql_select_db($database_localhost, $localhost);//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 = mysql_query($query_search) or die(mysql_error());//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 

<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:

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/gpsbd.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:
  Link de la descarga
Programador alfa, lomo plateado, barba de clavos, mentón de roca, no descarga la aplicación sigue el tutorial. Clic para DESCARGAR
   
ENLACES DE INTERÉS:

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!

0

7 pensamientos sobre “como guardar la direccion y coordenadas del gps a una base de datos en android studio

  1. Eduardo Cañarte

    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?

    0

  2. raymundo

    que tal me pueden orientar para conectar la bases de datos online, estoy atorado en este paso gracias, por su pronta respuesta,,

    0

  3. cristian

    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.

    0

    1. Miguel S Chehade Duran

      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

      0

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *