3

我正在尝试使用以下代码获取 G1 的 GPS 位置

活动中

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图标出现了,在那里停留了一段时间,但由于某种原因我没有得到修复,即使在户外明亮的阳光下也是如此。我正在使用 1.5 SDK 在 G1 上进行测试。

有人可以告诉我代码有什么问题吗?谢谢。

添加日志

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
4

3 回答 3

13

首先,在您调用的活动中,requestLocationUpdates()第二个参数是最短时间,而不是预定时间。您目前要求最多每 2 秒更新一次。它实际上不会报告任何内容,直到它可以...有时需要一点时间。

如果您的 GPS 在其他地方也没有响应/速度很慢(例如在地图中),请尝试重新启动手机(有些人声称您必须关闭手机然后拔出电池才能完全关闭 GPS 无线电)。希望这将使它恢复到正常的响应状态。

另外,没关系,但是您说您使用的是 1.5 SDK,但是您没有提及是否针对它进行编译(与 1.1 相对)。我之所以提出这个只是因为 GPS 在 Cupcake 中工作得更好/更快,所以我想知道你的手机实际上在运行什么。

更新:

我自己写了一个小测试,看看我是否可以复制你的问题。它仅包含三个用户生成的文件,我使用 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,要么就是无法锁定任何卫星。

你可以在这里下载源代码。

于 2009-06-05T23:54:50.107 回答
1
  1. 您的设备设置中是否启用了 GPS?我想是这样,因为你得到了 GPS 图标,但我想我会检查一下。
  2. 只有在设置中禁用 GPS 时才会调用 onProviderDisabled(),因此不太可能调用该代码。
  3. 您是否尝试过 0 而不是 2000 的距离?
  4. 您确定您对 requestLocationUpdates() 的调用实际上正在执行吗?
  5. 您的日志是否显示任何错误?您可以通过 adb logcat、DDMS 或 Eclipse 中的 DDMS 透视图检查您的日志。
  6. 您是否尝试过任何现有的、已发布的、应该可以工作的代码?例如,您可以获取我的 Android 书籍的源代码,其中 Weather 和 WeatherPlus 示例展示了 LocationManager 的使用。
于 2009-06-02T12:14:04.350 回答
1

这是一个很好的例子,源代码http://marakana.com/forums/android/android_examples/42.html

于 2009-12-01T13:48:06.540 回答