views:

319

answers:

4

I've singled out my problem to a few lines of code

lm = (LocationManager)getSystemService(Context.LOCATION_SERVICE);
Location location = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER);
lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 1000L, 5.0f, this);
lat = location.getLatitude();
lng = location.getLongitude();
//lat = new Double(40.431682);
//lng = new Double(-74.2021819);
pLocation = new GeoPoint((int)(lat * 1000000), (int)(lng * 1000000));

My onLocationChanged if you were wondering

public void onLocationChanged(Location location) {
        if (location != null) {
        lat = location.getLatitude();
        lng = location.getLongitude();
        pLocation = new GeoPoint((int)(lat * 1000000), (int)(lng * 1000000));
        }
}

My application crashes if I try to get the LastKnownLocation

But it works fine if I feed it a Location manually

I have no idea currently whats wrong

+2  A: 

First, whenever you get a crash, use adb logcat, DDMS, or the DDMS perspective in Eclipse to get the Java stack trace associated with the crash. In this case, I suspect you will find that you have a NullPointerException when attempting to use your location object.

You cannot use getLastKnownLocation() until well after you call requestLocationUpdates(), particularly for GPS. It may take tens of seconds for GPS to start providing fixes.

Please alter your code to eliminate your use of getLastKnownLocation() and just use the logic needing the location already in your onLocationChanged() method. At minimum, look for a null location object and don't try to use it.

CommonsWare
Thanks you were spot on! I had fixed it soon after posting this on my own though
Christopher
A: 

My fix was basically to just use coarse location.

Criteria criteria = new Criteria();
criteria.setAccuracy(Criteria.ACCURACY_COARSE);
String bestProvider = lm.getBestProvider(criteria, true);
Location loc = lm.getLastKnownLocation(bestProvider);
lat = loc.getLatitude();
lng = loc.getLongitude();
Christopher
A: 

This may happen because fine location (GPS) is not enabled on your device. Or ACCESS_FINE_LOCATION permission is not specified in your manifest.

Fedor
A: 

I bet if you debug you'll see null exception. So it happens because you're trying to extract latitude and longitude from location which isn't fix yet. Surround this extraction with if (loc!=null) {} and put progressDialog to hold user there