9

我々は最近アンドロイドAPIレベル14および15に対してアプリケーションをテストしました。最小限のSKDバージョン8をターゲットとし、タブレット(3.x)を除外した開発を開始しました。
2.xではすべてがうまくいくが、4.xドロイドでアプリを実行すると、ユーザーの所在地を取得している時点でクラッシュする。requestLocationUpdate()によってIllegalArgumentExceptionがスローされました

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(); 
} 

documentationによると、IAEはif provider or listener is nullがスローされます。 しかし、私はプロバイダとリスナーを記録しました。 (後者はtoString()を介して)、それらはnullではありません。

this questionからは、open issueが見つかりました。しかし、私はアイスクリームサンドイッチにもっと自信を持っている人々がどのようにユーザーの座標を要求しているのだろうと思っていました。
The tutorial私は上記の同じアプローチを使用していることを知っています。あなたのコードの使用では

+1

を参照してください、あなたの 'のonCreate()' ...私はいつもそれをどこに置くのに苦労し、うんこの:) –

+0

しようとするだろう。とにかく - 問題はまだ存在します。 – yoshi

+0

同じ問題があります。私はそれがエミュレータの問題か実際のICSデバイスの問題かどうか疑問に思う –

答えて

4

の上にあることを、使用前に確認しても、私はこれが現時点でのAndroidエミュレータの問題かもしれないと思います。

は、私はあなたが `スーパー()の`最初の呼び出しを行うべきだと思いhttp://code.google.com/p/android/issues/detail?id=21237

+0

はい、ありがとうございます。また#5のコメントでは、例外をキャッチしてすぐにそれに住んでいます。 gnah <。 yoshi

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

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

あなたはまたLocationManager.GPS_PROVIDERを使用してテストするが、GPSは、デバイス

+0

はいWiFiが利用可能です。 (そうでなければ、私はこれを投稿できませんでした:P)。 – yoshi

関連する問題