9

Niedawno przetestowaliśmy naszą aplikację pod kątem poziomu API Android 14 i 15. Rozpoczęliśmy programowanie ukierunkowane na minimalną wersję SKD w wersji 8 i wykluczając tablety (3.x).
Z 2.x wszystko działa dobrze, ale po uruchomieniu aplikacji na droidzie 4.x zawiesza się w punkcie, w którym uzyskujemy lokalizację użytkownika.IllegalArgumentException zgłoszony przez requestLocationUpdate()

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) 
... 

Źródło:

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

Według documentation IAE jest wyrzucane if provider or listener is null. Jednak zalogowałem się jako dostawca i słuchacz. (te ostatnie za pomocą toString()) i nie są puste.

Pochodzę z this question Znalazłem open issue. Jednak zastanawiałem się, jak ludzie, którzy są bardziej pewni siebie z kanapkami lodów, proszą o współrzędne użytkownika.
Wiem, że używa tego samego podejścia opisanego powyżej.

+1

myślę, że należy dokonać 'super()' pierwszego połączenia z twoich 'onCreate()' ... Chciałbym spróbować :) –

+0

Tak, zawsze walczą gdzie go umieścić. W każdym razie - problem nadal istnieje. – yoshi

+0

Mając ten sam problem. Zastanawiam się, czy to problem emulatora, czy też rzeczywisty problem z urządzeniem ICS. –

Odpowiedz

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

W użytku kodu tego LocationManager.NETWORK_PROVIDER podczas testowania że upewnić się, że sieć używasz jak bezprzewodowy dostęp do Internetu, albo są włożone karty SIM w urządzeniu, a sieć jest dostępna na niego.

Można również przetestować za pomocą LocationManager.GPS_PROVIDER ale upewnij się, że przed użyciem GPS jest włączony urządzenia

+0

Tak, jest dostępne WiFi. (W przeciwnym razie nie mógłbym opublikować tego: P). – yoshi