Сервис недоступен - Geocoder Android
У меня есть небольшая проблема с геокодером, чтобы получить широту и долготу от адреса:
Это мой код:
for (Garage g : XMLGarage) {
List<Address> address;
address = coder.getFromLocationName(
g.getAddress(), 5);
if (address != null) {
Address location = address.get(0);
g.setLatitude(location.getLatitude());
g.setLongitude(location.getLongitude());
...
Ошибка:
08-18 14:28:56.026: WARN/System.err(359): java.io.IOException: Service not Available
08-18 14:28:56.026: WARN/System.err(359): at
android.location.Geocoder.getFromLocationName(Geocoder.java:178)
08-18 14:28:56.026: WARN/System.err(359): at
com.amt.android.garage.Garage.postData(Garage.java:269)
08-18 14:28:56.026: WARN/System.err(359): at
com.amt.android.garage.GarageForm$2.onClick(GarageForm.java:86)
08-18 14:28:56.026: WARN/System.err(359): at
android.view.View.performClick(View.java:2485)
08-18 14:28:56.026: WARN/System.err(359): at
android.view.View$PerformClick.run(View.java:9080)
08-18 14:28:56.036: WARN/System.err(359): at
android.os.Handler.handleCallback(Handler.java:587)
08-18 14:28:56.036: WARN/System.err(359): at
android.os.Handler.dispatchMessage(Handler.java:92)
08-18 14:28:56.036: WARN/System.err(359): at
android.os.Looper.loop(Looper.java:130)
08-18 14:28:56.036: WARN/System.err(359): at
android.app.ActivityThread.main(ActivityThread.java:3683)
08-18 14:28:56.036: WARN/System.err(359): at
java.lang.reflect.Method.invokeNative(Native Method)
08-18 14:28:56.036: WARN/System.err(359): at
java.lang.reflect.Method.invoke(Method.java:507)
08-18 14:28:56.036: WARN/System.err(359): at
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
08-18 14:28:56.046: WARN/System.err(359): at
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
08-18 14:28:56.046: WARN/System.err(359): at dalvik.system.NativeStart.main(Native
Method)
Спасибо и всего наилучшего, Анасс
3 ответа
Недавно возникла проблема с устройствами Android и геокодером не работает: http://code.google.com/p/android/issues/detail?id=38009
Кажется, перезагрузка решает проблему
Эта ошибка иногда появляется, если провайдер геокодирования не работает и не может геокодировать ваше местоположение.
Смотрите эти соответствующие сообщения:
Geocoder.getFromLocation выдает исключение
Geocoder.getFromLocation создает исключение IOException на эмуляторе Android
Если это не так, убедитесь, что у вас есть разрешение на Интернет в вашем манифесте:
<uses-permission android:name="android.permission.INTERNET" />
Попробуйте сначала обновить Location. Как ниже
locationManager.requestLocationUpdates(bestProvider, 20000, 1, this);
обратитесь к здесь.