How To Get the User’s Current Location in Android? – GPS Example Help

Today I'm sharing you a working code on how to get the user's current location in Android. There are many popular apps using this feature such as Google Maps and Facebook. Remember when you checked in a place?

Knowing exactly where your users are located is really cool, but you always have to let them know you are doing it. Asking permission to get user's location is an ethical way.

One advantage of getting user's current location is customizing their experience, just like what Twitter does. If you let twitter know your location, it will show top trends or news near you, how cool is that?

how to get user's current location in android?

DOWNLOAD SOURCE CODE

I tested this code example without GPS provider which means using internet connection or wifi - it worked. I also tested it outdoors and without internet connection - it also worked. Please note that GPS provider is not working indoors.

When the START button was clicked, our program will get user's location continually in real time. It will stop when the STOP button was clicked. You can also play with it and change the logic if you just need the latitude and longitude coordinates once.

Basic Requirements - Get the User's Current Location in Android

To make this code run, we will need these five main files. All the description and explanation are provided in their own sections below.

  • MainActivity.java
  • OnClickListenerButtonStart.java
  • OnClickListenerButtonEnd.java
  • LocationHelper.java
  • AndroidManifest.xml

Your Android device must also have GPS capabilities. If you're using it outdoors, you must turn it on in your notifications area.

Complete Code on Getting the User’s Current Location in Android

MainActivity.java - this is where we initialize the buttons, classes and back press catch.

package com.example.androidgetuserlocation;

import com.example.androidgetuserlocation.LocationHelper.LocationResult;

import android.location.Location;
import android.os.Bundle;
import android.util.Log;
import android.widget.Button;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;

public class MainActivity extends Activity {

	final String TAG = "MainActivity.java";

	Button buttonStart;
	Button buttonStop;

	LocationResult locationResult;
	LocationHelper locationHelper;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		// initialize buttons
		buttonStart = (Button) findViewById(R.id.buttonStart);
		buttonStop = (Button) findViewById(R.id.buttonStop);

		// set button on click listeners
		buttonStart.setOnClickListener(new OnClickListenerButtonStart());
		buttonStop.setOnClickListener(new OnClickListenerButtonEnd());

		// to get location updates, initialize LocationResult
		this.locationResult = new LocationResult(){
		    @Override
		    public void gotLocation(Location location){

		        //Got the location!
		    	if(location!=null){

			    	double latitude = location.getLatitude();
			    	double longitude = location.getLongitude();

			    	Log.e(TAG, "lat: " + latitude + ", long: " + longitude);

			    	// here you can save the latitude and longitude values
			    	// maybe in your text file or database

		    	}else{
		    		Log.e(TAG, "Location is null.");
		    	}

		    }

		};

		// initialize our useful class,
		this.locationHelper = new LocationHelper();
	}

	// prevent exiting the app using back pressed
	// so getting user location can run in the background
	@Override
	public void onBackPressed() {

	    new AlertDialog.Builder(MainActivity.this)
        .setTitle("User Location App")
        .setMessage("This will end the app. Use the home button instead.")
        .setPositiveButton("OK", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int id) {

                dialog.cancel();
            }
        }).show();

	}
}

OnClickListenerButtonStart.java - this is the listener for the "START getting location updates" button. Once clicked, it will start listening to updates given by either GPS or NETWORK provider.

See our LocationHelper for a more detailed explanation on how it gets the user's current location.

For this simple app to look more responsive to user actions, it will also enable the START button and disable the STOP button.

package com.example.androidgetuserlocation;

import android.content.Context;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;

public class OnClickListenerButtonStart implements OnClickListener {

	final String TAG = "OnClickListenerButtonStart.java";

	MainActivity mainActivity;
	Context context;

	@Override
	public void onClick(View view) {

		Log.e(TAG, "Started getting user location.");

		// to get the context and main activity
		this.context = view.getContext();
		this.mainActivity = ((MainActivity) context);

		// disable the START button, enable the STOP button
		mainActivity.buttonStart.setEnabled(false);
		mainActivity.buttonStop.setEnabled(true);

		// start listening to location updates
		mainActivity.locationHelper.getLocation(mainActivity, mainActivity.locationResult);

	}

}

OnClickListenerButtonEnd.java - this is the listener for the "STOP getting location updates" button. Once clicked, it will stop listening to all ongoing location updates. It will save your device battery consumption, ha!

It will also enable the START button and disable the STOP button.

package com.example.androidgetuserlocation;

import android.content.Context;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;

public class OnClickListenerButtonEnd implements OnClickListener {

	final String TAG = "OnClickListenerButtonEnd.java";

	MainActivity mainActivity;
	Context context;

	@Override
	public void onClick(View view) {

		Log.e(TAG, "Ended getting user location.");

		// to get the context and main activity
		this.context = view.getContext();
		this.mainActivity = ((MainActivity) context);

		// enable the START button, disable the STOP button
		mainActivity.buttonStart.setEnabled(true);
		mainActivity.buttonStop.setEnabled(false);

		// stop the listener
		mainActivity.locationHelper.stopGettingLocationUpdates();

	}

}

LocationHelper.java - our location helper runs on a very simple logic:

1. First, it tries to detect if any of the providers are enabled - is it the GPS or Network provider?

2. If there's any provider enabled, it starts the location listener and timer. If after 20 seconds and no values were returned, it will return a null value.

3. If no values were returned, it will still try to get location updates.

package com.example.androidgetuserlocation;

import java.util.Timer;
import java.util.TimerTask;
import android.content.Context;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.util.Log;

public class LocationHelper {

	final String TAG = "LocationHelper.java";

	Timer timer1;
	LocationManager lm;
	LocationResult locationResult;
	boolean gps_enabled = false;
	boolean network_enabled = false;

	public boolean getLocation(Context context, LocationResult result) {

		// I use LocationResult callback class to pass location value from
		// LocationHelper to user code.
		locationResult = result;

		if (lm == null) {
			lm = (LocationManager) context.getSystemService(Context.LOCATION_SERVICE);
		}

		// exceptions will be thrown if provider is not permitted.
		try {
			gps_enabled = lm.isProviderEnabled(LocationManager.GPS_PROVIDER);
		} catch (Exception e) {
			e.printStackTrace();
		}

		try {
			network_enabled = lm.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
		} catch (Exception e) {
			e.printStackTrace();
		}

		// don't start listeners if no provider is enabled
		if (!gps_enabled && !network_enabled) {
			return false;
		}

		// if gps is enabled, get location updates
		if (gps_enabled) {
			Log.e(TAG, "gps_enabled, requesting updates.");
			lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, locationListenerGps);
		}

		// if network is enabled, get location updates
		if (network_enabled) {
			Log.e(TAG, "network_enabled, requesting updates.");
			lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, locationListenerNetwork);
		}

		// the timer
		timer1 = new Timer();
		timer1.schedule(new GetLastLocation(), 20000);

		return true;
	}

	LocationListener locationListenerGps = new LocationListener() {

		public void onLocationChanged(Location location) {

			// gave a location, cancel the timer
			timer1.cancel();

			// put the location value
			locationResult.gotLocation(location);

			// if you want to stop listening to gps location updates, un-comment the code below

			// lm.removeUpdates(this);
			// lm.removeUpdates(locationListenerNetwork);

		}

		public void onProviderDisabled(String provider) {}

		public void onProviderEnabled(String provider) {}

		public void onStatusChanged(String provider, int status, Bundle extras) {}
	};

	LocationListener locationListenerNetwork = new LocationListener() {

		public void onLocationChanged(Location location) {

			// gave a location, cancel the timer
			timer1.cancel();

			// put the location value
			locationResult.gotLocation(location);

			// if you want to stop listening to network location updates, un-comment the code below

			// lm.removeUpdates(this);
			// lm.removeUpdates(locationListenerGps);

		}

		public void onProviderDisabled(String provider) {
		}

		public void onProviderEnabled(String provider) {
		}

		public void onStatusChanged(String provider, int status, Bundle extras) {
		}
	};

	// stop listening to location updates
	public void stopGettingLocationUpdates(){

		try{

			lm.removeUpdates(locationListenerGps);
			lm.removeUpdates(locationListenerNetwork);

		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	class GetLastLocation extends TimerTask {

		@Override
		public void run() {

			// In my case, I do not return the last known location, so I DO NOT remove the updates, just return a location value of null
			// or else, if you need the opposite un-comment the comment below

			/*
			lm.removeUpdates(locationListenerGps);
			lm.removeUpdates(locationListenerNetwork);

			Location net_loc = null, gps_loc = null;
			if (gps_enabled){
				gps_loc = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER);
			}

			if (network_enabled){
				net_loc = lm.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
			}

			// if there are both values use the latest one
			if (gps_loc != null && net_loc != null) {

				if (gps_loc.getTime() > net_loc.getTime()){
					locationResult.gotLocation(gps_loc);
				}else{
					locationResult.gotLocation(net_loc);
				}
				return;
			}

			if (gps_loc != null) {
				locationResult.gotLocation(gps_loc);
				return;
			}
			if (net_loc != null) {
				locationResult.gotLocation(net_loc);
				return;
			}
			*/

			locationResult.gotLocation(null);
		}
	}

	public static abstract class LocationResult {
		public abstract void gotLocation(Location location);
	}

}

AndroidManifest.xml - this is where the needed permissions are stated.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.androidgetuserlocation"
    android:versionCode="1"
    android:versionName="1.0" >
 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" /> 
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
     
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="18" />
 
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.androidgetuserlocation.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
 
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
 
</manifest>

Program Ouput

Now this is another good part, seeing your code working and run without errors. We'll have two output for our code which are the "device" and "logcat" output. See them below.

On Device

Our program provides a simple user interface to be tested.

how to get user's current location in android?
get current user's location in android

On Logcat

The internal notes, latitude and longitude location update values were seen in our logcat.

latitude and longitude logcat output on getting user location in android

Online Resources

What is the simplest and most robust way to get the user's current location in Android?
Location Strategies
Retrieving the Current Location

Hi! I'm Mike Dalisay, the co-founder of codeofaninja.com, a site that helps you build web applications with PHP and JavaScript. Need support? Comment below or contact [email protected]

I'm also passionate about technology and enjoy sharing my experience and learnings online. Connect with me on LinkedIn, Twitter, Facebook, and Instagram.