9

最近、Android API レベル 14 および 15 に対してアプリケーションをテストしました。最小限の SKD バージョン 8 を対象とし、タブレット (3.x) を除く開発を開始しました。
2.x ではすべて問題なく動作しますが、4.x ドロイドでアプリを実行すると、ユーザーの位置情報を取得する時点でクラッシュします。

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() 経由)、それらは null ではありません。

この質問から来て、未解決の問題が見つかりました。しかし、アイスクリームサンドに自信がある人はどのようにユーザーのコーディネートを求めているのだろうと思っていました。
私が知っているチュートリアルでは、上記と同じアプローチを使用しています。

4

2 に答える 2

4

これは現在Androidエミュレーターの問題かもしれないと思います。

http://code.google.com/p/android/issues/detail?id=21237を参照してください

于 2012-04-26T21:02:50.567 に答える
2
locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 300000, 500, locationListener);

コードでこれを使用LocationManager.NETWORK_PROVIDER して、WIFIなどの使用しているネットワークが利用可能であること、またはデバイスにSIMカードが挿入され、ネットワークが利用可能であることを確認します。

を使用してテストすることもできますがLocationManager.GPS_PROVIDER、使用する前に、デバイスのGPSがオンになっていることを確認してください

于 2012-04-03T09:51:49.567 に答える