座標のペアがあり、Geocoder.getFromLocationを使用して住所の詳細を取得しています。ただし、このメソッドは同期的であり、アプリがしばらくフリーズします。AsyncTask 内に配置しようとしましたが、java.lang.IllegalStateException: Not on the main thread
.
このメソッドを非同期で呼び出す方法はありますか?
アドレスを取得するメソッドは次のとおりです (MapUtil クラス内)。
public static Address getAddress(Context context, Marker marker) {
Geocoder geocoder = new Geocoder(context);
Address address = null;
try {
List<Address> addressList = geocoder.getFromLocation(marker.getPosition().latitude, marker.getPosition().longitude, 1);
if (addressList != null && addressList.size() > 0) {
address = addressList.get(0);
}
} catch (Exception e) {
e.printStackTrace();
}
return address;
}
MainActivity での私の AsyncTask は次のとおりです。
new AsyncTask<Void, Void, Void>() {
Address address = null;
@Override
protected Void doInBackground(Void... params) {
address = MapUtil.getAddress(MainActivity.this, marker);
return null;
}
@Override
protected void onPostExecute(Void result) {
super.onPostExecute(result);
System.out.println("Address = " + address);
}
}.execute();
完全なスタック トレースは次のとおりです。
11-13 06:36:12.423: W/System.err(17247): java.lang.IllegalStateException: Not on the main thread
11-13 06:36:12.423: W/System.err(17247): at maps.aq.o.b(Unknown Source)
11-13 06:36:12.423: W/System.err(17247): at maps.ak.g.b(Unknown Source)
11-13 06:36:12.423: W/System.err(17247): at maps.af.bk.c(Unknown Source)
11-13 06:36:12.423: W/System.err(17247): at cpd.onTransact(SourceFile:80)
11-13 06:36:12.423: W/System.err(17247): at android.os.Binder.transact(Binder.java:347)
11-13 06:36:12.423: W/System.err(17247): at com.google.android.gms.maps.model.internal.d$a$a.getPosition(Unknown Source)
11-13 06:36:12.423: W/System.err(17247): at com.google.android.gms.maps.model.Marker.getPosition(Unknown Source)
11-13 06:36:12.423: W/System.err(17247): at com.example.util.MapUtil.getAddress(MapUtil.java:17)
11-13 06:36:12.423: W/System.err(17247): at com.example.MainActivity$3.doInBackground(MainActivity.java:102)
11-13 06:36:12.423: W/System.err(17247): at com.example.MainActivity$3.doInBackground(MainActivity.java:1)
11-13 06:36:12.423: W/System.err(17247): at android.os.AsyncTask$2.call(AsyncTask.java:287)
11-13 06:36:12.423: W/System.err(17247): at java.util.concurrent.FutureTask.run(FutureTask.java:234)
11-13 06:36:12.423: W/System.err(17247): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
11-13 06:36:12.423: W/System.err(17247): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
11-13 06:36:12.423: W/System.err(17247): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
11-13 06:36:12.423: W/System.err(17247): at java.lang.Thread.run(Thread.java:841)