Объект местоположения, переданный в onLocationChanged, является нулем? - PullRequest
0 голосов
/ 09 августа 2010

У меня есть действие, которое реализует LocationListener в моем приложении, и мой метод onLocationChanged до недавнего времени работал отлично.По какой-то причине объект Location, передаваемый в метод, имеет значение null.Мой вопрос, почему это ноль?Проходит ли он в нулевом объекте, если он не может получить местоположение?

Мой GPS включен, и я настроен на получение местоположения из GPS, и я знаю, что мой GPS может исправить меня, когда яиспользовал Карты, и он нашел меня.

Кроме того, у меня есть разрешение для моего приложения:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.ACCESS_GPS" />
<uses-permission android:name="android.permission.ACCESS_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

Я не считаю, что разрешения - это проблема, так как моя деятельность былаработая заранее, и с тех пор я не менял разрешения.

Вот код, который определяет поставщика объекта местоположения:

String locationProvider = this.mLocationManager.getBestProvider(mLocationCriteria, true);
this.onLocationChanged(this.mLocationManager.getLastKnownLocation(locationProvider));

Вот вывод LogCat ошибки:

08-08 18:25:26.310: ERROR/MapActivity(6447): Couldn't get connection factory client
08-08 18:26:18.771: ERROR/AndroidRuntime(6447): Uncaught handler: thread main exiting due to uncaught exception
08-08 18:26:18.880: ERROR/AndroidRuntime(6447): java.lang.IllegalStateException: Could not execute method of the activity
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.View$1.onClick(View.java:2031)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.View.performClick(View.java:2364)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.View.onTouchEvent(View.java:4179)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.View.dispatchTouchEvent(View.java:3709)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.app.Activity.dispatchTouchEvent(Activity.java:2061)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1691)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.os.Looper.loop(Looper.java:123)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.app.ActivityThread.main(ActivityThread.java:4363)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at java.lang.reflect.Method.invokeNative(Native Method)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at java.lang.reflect.Method.invoke(Method.java:521)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at dalvik.system.NativeStart.main(Native Method)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447): Caused by: java.lang.reflect.InvocationTargetException
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.proto.screens.MyMapActivity.onLocateUserClick(MyMapActivity.java:147)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at java.lang.reflect.Method.invokeNative(Native Method)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at java.lang.reflect.Method.invoke(Method.java:521)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at android.view.View$1.onClick(View.java:2026)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     ... 21 more
08-08 18:26:18.880: ERROR/AndroidRuntime(6447): Caused by: java.lang.NullPointerException
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     at com.proto.screens.MyMapActivity.onLocationChanged(MyMapActivity.java:135)
08-08 18:26:18.880: ERROR/AndroidRuntime(6447):     ... 25 more

[UPDATE] Я тестировал тот же код на другом устройстве (точнее, HTC MyTouch 3G), и он безупречно работает с GPS, однако на моем Motorola Droid он вылетает.

Ответы [ 3 ]

1 голос
/ 10 августа 2010

Я исправил проблему, хотя я не уверен, почему это сработало.

Я настроил свою деятельность на запрос обновлений местоположения у лучшего поставщика местоположения (в данном случае GPS) иустановите его так, чтобы он включал мою функцию, он имеет точное местоположение до 50 метров.То, что я делал раньше, это просто попытка получить последнее известное местоположение, но теперь я настроил его на ожидание, пока GPS не сможет получить исправление.

Возможно, оно не сохраняло мое последнее известное местоположение и поэтомувозвращая ноль.

0 голосов
/ 24 марта 2012

Я наконец понял это. нет проблем в коде.

ПРОСТО ПРОСТО РАБОТАЕТ С ПРИЛОЖЕНИЕМ, КОТОРЫЕ БУДУТ ХРАНИТЬ ДАННЫЕ О ПРОШЛОСТИ И ДЛИТЕЛЬНОМ ПРОЦЕССЕ ... СКАЖИТЕ, КАК ВАШИ КАРТЫ ПОСТРОЕНЫ В ПРИЛОЖЕНИИ В ВАШЕЙ МОБИЛЬНОСТИ, И ПОТОМ, ЧТО ОНА РАБОТАЕТ, ЭТО БУДЕТ РАБОТАТЬ ШТРАФНО ...

причина, по которой он дает нулевое значение, заключается в том, что ваш телефон сохранил последние известные данные, и стек для него будет пустым, следовательно, он пропустит нулевое значение. Запуск приложения, похожего на карты или около того, поместил бы данные о местоположении в стек и вернул бы их обратно ... ура! @ Шринивас

0 голосов
/ 09 августа 2010

Я рекомендую вам запустить это приложение с помощью отладчика, чтобы найти причину нулевого указателя.Если блок кода, который получает местоположение, находится в блоке try, вы можете добавить точку прерывания в перехватчике, и исключение даст вам хорошее представление о причине (и как ее устранить).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...