IllegalArgumentException, созданный requestLocationUpdate()

Недавно мы протестировали наше приложение на Android API уровня 14 и 15. Мы начали разработку с минимальной SKD версии 8 и исключая планшеты (3.x).
С 2.x все работает хорошо, но при запуске приложения на 4.x droid падает в тот момент, когда мы получаем местоположение пользователя.

FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to create service  java.lang.IllegalArgumentException: provider=network  
at android.app.ActivityThread.handleCreateService(ActivityThread.java:2263)  
at android.app.ActivityThread.access$1600(ActivityThread.java:123)  
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1201)  
at android.os.Handler.dispatchMessage(Handler.java:99)  
at android.os.Looper.loop(Looper.java:137)  
at android.app.ActivityThread.main(ActivityThread.java:4424)  
at java.lang.reflect.Method.invokeNative(Native Method)  
at java.lang.reflect.Method.invoke(Method.java:511)  
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)  
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)  
at dalvik.system.NativeStart.main(Native Method)  

Caused by: java.lang.IllegalArgumentException: provider=network  
at android.os.Parcel.readException(Parcel.java:1331)  
at android.os.Parcel.readException(Parcel.java:1281)  
at android.location.ILocationManager$Stub$Proxy.requestLocationUpdates(ILocationManager.java:646)  
at android.location.LocationManager._requestLocationUpdates(LocationManager.java:582)   
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:446)  
at package.name.LocationGetter.onCreate(LocationGetter.java:63)  
at android.app.ActivityThread.handleCreateService(ActivityThread.java:2253)  
...

Источник:

public void onCreate() {
  locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
  locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 300000, 500, locationListener);
  super.onCreate();
 }

Согласно документация выдается IAE if provider or listener is null. Однако я зарегистрировал провайдера и слушателя. (последний через toString() ), и они не равны нулю.

Исходя из этот вопрос, я нашел открытая проблема. Однако мне было интересно, как люди, которые более уверены в сэндвиче с мороженым, запрашивают координаты пользователя.
Учебник, о котором я знаю, использует тот же подход, что описан выше.


comment
Я думаю, вы должны сделать super() первым вызовом вашего onCreate()... Я бы попробовал это :)   -  person Ovidiu Latcu    schedule 03.04.2012
comment
Да, всегда мучаюсь, куда его положить. Так или иначе - проблема все еще существует.   -  person nuala    schedule 03.04.2012
comment
Имея ту же проблему. Интересно, это проблема эмулятора или реальная проблема с устройством ICS?   -  person Michał Klimczak    schedule 24.04.2012


Ответы (2)


Я думаю, что это может быть проблемой с эмулятором Android в настоящее время.

См. http://code.google.com/p/android/issues/detail?id=21237

person TStu    schedule 26.04.2012
comment
Да, спасибо, что указали. Также комментарий № 5 предлагает очевидный обходной путь: поймать исключение и жить с ним на данный момент. ‹.‹ code.google.com/p/android/ проблемы/подробности?id=21237#c5 - person nuala; 03.05.2012

locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 300000, 500, locationListener);

В своем коде используйте этот LocationManager.NETWORK_PROVIDER при тестировании, чтобы убедиться, что сеть, которую вы используете, например WIFI, доступна или вы вставили сим-карту в свое устройство, и сеть доступна на нем.

Вы также можете проверить с помощью LocationManager.GPS_PROVIDER, но перед использованием убедитесь, что GPS на устройстве включен.

person Zumbarlal Saindane    schedule 03.04.2012
comment
Да Wi-Fi доступен. (Иначе я не мог бы опубликовать это: P). - person nuala; 04.04.2012