通常、UIスレッドで何かしている間にエラーが発生しました。私は間違っている。このエラーは、携帯電話が移動しているときにのみ表示されるように見えます。LocationManager:java.lang.RuntimeException:Looper.prepare()を呼び出していないスレッド内でハンドラを作成できません
最新の場所を保存したいので、UIには何も保存しません。私は主な活動から、次のメソッドを呼び出しています
public void getFreshDeviceLocation(long interval, final long maxtime) {
if (gps_recorder_running){return;}
gpsTimer = new Timer();
//starts location
startMillis=System.currentTimeMillis();
// receive updates
for (String s : locationManager.getAllProviders()) {
LocationListener listener=new LocationListener() {
@Override
public void onProviderEnabled(String provider) {
}
@Override
public void onProviderDisabled(String provider) {
}
@Override
public void onLocationChanged(Location location) {
// if this is a gps location, we can use it
if (location.getProvider().equals(
LocationManager.GPS_PROVIDER)) {
doLocationUpdate(location, true); //stores the location in the prefs
stopGPS();
}
}
@Override
public void onStatusChanged(String provider,
int status, Bundle extras) {
// TODO Auto-generated method stub
}
};
locationManager.requestLocationUpdates(s, interval, //line 97, error!
minDistance, listener);
myListeners.add(listener);
gps_recorder_running = true;
}
// start the gps receiver thread
gpsTimer.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
Location location = getBestLocation();
doLocationUpdate(location, false);
if ((System.currentTimeMillis()-startMillis)>maxtime){if (maxtime>0){stopGPS();}}
//Updates depend on speed of the device
float speed=pref.DeviceLocation().getSpeed();
if (speed<1){if (speedclass!=0){speedclass=0;stopGPS();getFreshDeviceLocation(300000,0);}}
if ((speed>=1)&&(speed<3)){if (speedclass!=1){speedclass=1;stopGPS();getFreshDeviceLocation(90000,0);}}
if ((speed>=3)&&(speed<17)){if (speedclass!=2){speedclass=2;stopGPS();getFreshDeviceLocation(15000,0);}}
if (speed>=17){if (speedclass!=3){speedclass=3;stopGPS();getFreshDeviceLocation(10000,0);}}
}
}, 0, interval);
}
私が手にエラーがある:
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:139)
at android.location.LocationManager$ListenerTransport.<init>(LocationManager.java:137)
at android.location.LocationManager._requestLocationUpdates(LocationManager.java:708)
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:630)
at com.appiclife.tmoflashlight.TMO_LocationManager.getFreshDeviceLocation(TMO_LocationManager.java:97)
at com.appiclife.tmoflashlight.TMO_LocationManager$2.run(TMO_LocationManager.java:116)
at java.util.Timer$TimerImpl.run(Timer.java:289)
ライン97 = locationManager.requestLocationUpdates(S、間隔、minDistance、リスナー)。 (LocationManagerクラス)
私はLooper.prepare()を呼び出さなければならないようです。とLooper.loop();どこかに見えますが、私はどこに見えませんか?それはこの質問と関係があるかもしれませんAsyncTask and Looper.prepare() error
私は 'Looper.prepare()'の呼び出しを見ません... – Collin
どこで呼びますか? – Diego