Android - использование LocationManager не дает гео исправления - PullRequest
3 голосов
/ 02 июня 2009

Я пытаюсь определить местоположение GPS моего G1, используя следующий код

В действии

MyLocationListener myListener = new MyLocationListener();
LocationManager myManager = (LocationManager)getSystemService(LOCATION_SERVICE);
myManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 2000, 0, myListener);

Это класс LocationListener

public class MyLocationListener implements LocationListener {

  private static double latitude;
  private static double longitude;

  @Override
  public void onLocationChanged(Location arg0) {
    latitude = arg0.getLatitude();
    longitude = arg0.getLongitude();
  }

  @Override
  public void onProviderDisabled(String provider) {
  }

  @Override
  public void onProviderEnabled(String provider) {
  }

  @Override
  public void onStatusChanged(String provider, int status, Bundle extras) {}

  public static double getLatitude() {
    return latitude;
  }

  public static double getLongitude() {
    return longitude;
  }

}

Я ждал целых 30 секунд, но ни один из методов слушателя не был вызван. Значок GPS появляется, остается там в течение некоторого времени, но по какой-то причине я не могу исправить, даже на улице при ярком солнечном свете. Я тестирую на G1 с 1,5 SDK.

Может кто-нибудь сказать, что не так с кодом? Спасибо.

Добавление журнала

06-02 18:30:43.143: ERROR/System(52): java.lang.SecurityException
06-02 18:30:43.143: ERROR/System(52):     at android.os.BinderProxy.transact(Native Method)
06-02 18:30:43.143: ERROR/System(52):     at android.os.ServiceManagerProxy.addService(ServiceManagerNative.java:146)
06-02 18:30:43.143: ERROR/System(52):     at android.os.ServiceManager.addService(ServiceManager.java:72)
06-02 18:30:43.143: ERROR/System(52):     at com.android.server.ServerThread.run(SystemServer.java:155)
06-02 18:30:43.152: ERROR/AndroidRuntime(52): Crash logging skipped, no checkin service

06-02 18:30:43.382: ERROR/SystemServer(52): Failure starting StatusBarService
06-02 18:30:43.382: ERROR/SystemServer(52): java.lang.NullPointerException
06-02 18:30:43.382: ERROR/SystemServer(52):     at com.android.server.status.StatusBarPolicy.updateBluetooth(StatusBarPolicy.java:749)
06-02 18:30:43.382: ERROR/SystemServer(52):     at com.android.server.status.StatusBarPolicy.<init>(StatusBarPolicy.java:282)
06-02 18:30:43.382: ERROR/SystemServer(52):     at com.android.server.status.StatusBarPolicy.installIcons(StatusBarPolicy.java:337)
06-02 18:30:43.382: ERROR/SystemServer(52):     at com.android.server.ServerThread.run(SystemServer.java:186)
06-02 18:30:43.382: ERROR/AndroidRuntime(52): Crash logging skipped, no checkin service

Ответы [ 3 ]

13 голосов
/ 06 июня 2009

Во-первых, в вашей деятельности, когда вы звоните requestLocationUpdates(), вторым аргументом является минимальное время, а не запланированное время. В настоящее время вы запрашиваете обновление НА САМЫЕ САМЫЕ каждые 2 секунды. На самом деле он ничего не сообщает, пока не сможет ... иногда это занимает немного времени.

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

Кроме того, это не должно иметь значения, но вы сказали, что используете 1.5 SDK, но не упомянули, собирались ли вы против него (в отличие от 1.1). Я поднял этот вопрос только потому, что в Cupcake GPS работает лучше / быстрее, поэтому мне было интересно, что на самом деле работает ваш телефон.

UPDATE:

Я сам написал небольшой тест, чтобы посмотреть, смогу ли я продублировать вашу проблему. Он состоит всего из трех пользовательских файлов, и я протестировал его с SDK 1.1 и 1.5

В основной деятельности (я просто использовал Main.java):

package org.example.LocationTest;

import android.app.Activity;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;

public class Main extends Activity implements LocationListener{
    private LocationManager myManager;
    private TextView tv;


    /********************************************************************** 
     * Activity overrides below 
     **********************************************************************/
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        // get a handle to our TextView so we can write to it later
        tv = (TextView) findViewById(R.id.TextView01);

        // set up the LocationManager
        myManager = (LocationManager) getSystemService(LOCATION_SERVICE);   
    }

    @Override
    protected void onDestroy() {
        stopListening();
        super.onDestroy();
    }

    @Override
    protected void onPause() {
        stopListening();
        super.onPause();
    }

    @Override
    protected void onResume() {
        startListening();
        super.onResume();
    }



    /**********************************************************************
     * helpers for starting/stopping monitoring of GPS changes below 
     **********************************************************************/
    private void startListening() {
        myManager.requestLocationUpdates(
            LocationManager.GPS_PROVIDER, 
            0, 
            0, 
            this
        );
    }

    private void stopListening() {
        if (myManager != null)
            myManager.removeUpdates(this);
    }




    /**********************************************************************
     * LocationListener overrides below 
     **********************************************************************/
    @Override
    public void onLocationChanged(Location location) {
        // we got new location info. lets display it in the textview
        String s = "";
        s += "Time: "        + location.getTime() + "\n";
        s += "\tLatitude:  " + location.getLatitude()  + "\n";
        s += "\tLongitude: " + location.getLongitude() + "\n";
        s += "\tAccuracy:  " + location.getAccuracy()  + "\n";

        tv.setText(s);
    }    

    @Override
    public void onProviderDisabled(String provider) {}    

    @Override
    public void onProviderEnabled(String provider) {}    

    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {}
}

В вашем "основном" файле макета (я использовал main.xml):

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" 
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <TextView 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" 
        android:id="@+id/TextView01"
        android:text="Waiting for location information..." 
    />
</LinearLayout>

Тогда в вашем AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="org.example.LocationTest"
    android:versionCode="1"
    android:versionName="1.0">
    <application 
        android:icon="@drawable/icon" 
        android:label="@string/app_name">
        <activity 
            android:name=".Main"
            android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
    <uses-sdk android:minSdkVersion="3" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
</manifest> 

Вы должны быть в состоянии скомпилировать / запустить это очень хорошо. Если, используя это, вы все еще не можете получить решение, это не проблема программного обеспечения. У вас либо плохой GPS, либо он не может заблокировать спутники.

Вы можете скачать исходный код здесь .

1 голос
/ 01 декабря 2009

Вот хороший пример с исходным кодом http://marakana.com/forums/android/android_examples/42.html

1 голос
/ 02 июня 2009
  1. Ваш GPS включен в настройках вашего устройства? Я полагаю, так как вы получаете значок GPS, но я решил проверить.
  2. onProviderDisabled () будет вызываться только в том случае, если вы отключите GPS в настройках, и поэтому вряд ли будет вызван код.
  3. Вы пробовали расстояние 0 вместо 2000?
  4. Вы уверены, что ваш вызов requestLocationUpdates () действительно выполняется?
  5. Ваш журнал показывает ошибки? Вы можете проверить свой журнал через adb logcat, DDMS или перспективу DDMS в Eclipse.
  6. Вы пробовали какой-либо существующий код, опубликованный, который должен работать? Например, вы можете получить исходный код в моей книге Android , где примеры Weather и WeatherPlus показывают использование LocationManager.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...