0

我正在尝试让我的 GPS 在后台运行,这样它就可以在我做其他事情时为我提供关于我在哪里的新信息。

但是每次我运行应用程序时它都会崩溃。错误要我使用 Looper.prepare(),但我怎样才能用我的 GPS 做到这一点?

public class LocationLoggerService extends Service implements LocationListener {

Location location;

String towers;
static final int uniqueID = 1394885;
Thread runner;
boolean keepRunning;

public LocationManager locationManager;

@Override
public IBinder onBind(Intent intent) {
    return null;
}

@Override
public void onCreate() {

    keepRunning = true;

    runner = new Thread(null, new Runnable() {
        public void run() {
            startGps();
        }
    });
    runner.start();
}

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    // this service will run until we stop it

    return START_STICKY;
}

@Override
public void onLocationChanged(Location location) {

    location = locationManager.getLastKnownLocation(towers);

    String hey1 = Double.toString(location.getLatitude());
    String hey2 = Double.toString(location.getLongitude());

    Toast.makeText(this,
            "TEST onLocationChanged:" + "Lat: " + hey1 + "Long: " + hey2,

            Toast.LENGTH_LONG).show();
}

@Override
public void onProviderEnabled(String s) {
}

@Override
public void onProviderDisabled(String s) {
}

@Override
public void onStatusChanged(String s, int i, Bundle b) {
}

@Override
public void onDestroy() {
    super.onDestroy();
    Toast.makeText(this, "MyAlarmService.onDestroy()", Toast.LENGTH_LONG)
            .show();

}

public void startGps() {
    locationManager = (LocationManager) this
            .getSystemService(Context.LOCATION_SERVICE);
    locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER,
            2000, 0, this);

    location = locationManager.getLastKnownLocation(towers);

    String hey1 = Double.toString(location.getLatitude());
    String hey2 = Double.toString(location.getLongitude());

    Toast.makeText(this, "StartGPS: Lat: " + hey1 + "Long: " + hey2,
            Toast.LENGTH_LONG).show();

}


}

我的清单具有以下权限,如下所示:

<uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_GPS" />

<service
            android:name="LocationLoggerService"
            android:enabled="true"
            android:exported="false"
            android:label="LocationLoggerService" />

我在 logcat 中收到此错误,如下所示:

FATAL EXCEPTION: Thread-819
java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
at android.os.Handler.<init>(Handler.java:121)
at android.location.LocationManager$ListenerTransport$1.<init>(LocationManager.java:209)
at android.location.LocationManager$ListenerTransport.<init>(LocationManager.java:209)
at android.location.LocationManager._requestLocationUpdates(LocationManager.java:687)
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:512)
at com.example.rememberforme.LocationLoggerService.startGps(LocationLoggerService.java:81)
at com.example.rememberforme.LocationLoggerService$1.run(LocationLoggerService.java:38)
at java.lang.Thread.run(Thread.java:856)
4

1 回答 1

0

嘿,

我看到您缺少服务的 onCommandStart 方法。

@Override
public int onStartCommand(Intent intent, int flags, int startId)
{
    //this service will run until we stop it

    return START_STICKY;
}

您是否在清单文件中添加了所有需要的权限?我不确定您需要哪一个,但其中一个/或多个可以做到:

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_GPS"/>
于 2013-01-09T16:06:24.910 回答