Android - 使用 LocationManager 不会提供地理修复
Posted
技术标签:
【中文标题】Android - 使用 LocationManager 不会提供地理修复【英文标题】:Android - using LocationManager does not give a geo fix 【发布时间】:2010-10-30 15:17:55 【问题描述】:我正在尝试使用以下代码获取我的 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
【问题讨论】:
您包含的日志中的错误与此问题无关。它们只是其他方面的一些错误。 【参考方案1】:首先,在您调用requestLocationUpdates()
的活动中,第二个参数是最短时间,而不是预定时间。您目前要求最多每 2 秒更新一次。它实际上不会报告任何内容,直到它可以...有时需要一点时间。
如果您的 GPS 在其他地方(例如在地图中)也没有响应/速度很慢,请尝试重新启动手机(有些人声称您必须关闭手机然后拔出电池才能完全关闭 GPS 无线电)。希望这将使它恢复到正常的响应状态。
另外,没关系,但您说您使用的是 1.5 SDK,但您没有提及您是否针对它进行编译(而不是 1.1)。我之所以提出这个只是因为 GPS 在 Cupcake 中运行得更好/更快,所以我想知道你的手机实际上在运行什么。
更新:
我自己写了一个小测试,看看我是否可以复制你的问题。它仅包含三个用户生成的文件,我使用 SDK 1.1 和 1.5 对其进行了测试
在主Activity中(我只是用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_
android:layout_>
<TextView
android:layout_
android:layout_
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 不好,要么就是无法锁定任何卫星。
您可以下载源代码here。
【讨论】:
谢谢。我已经等待了长达 30 秒,只是在通知栏上看到 GPS 图标而没有真正得到修复!我正在编译并运行 1.5。 地图中的情况如何?它可以在合理的时间内找到您的位置吗?你试过重启手机吗? 另外,你如何检查监听器是否有任何数据?您是否在另一个线程中运行某些东西,每隔 X 时间检查一次? 不调用监听器方法。后来意识到错误与GPS无关。除此之外没有任何错误。 Google 地图会在 5 秒内识别出我的位置【参考方案2】:-
您的设备设置中是否启用了 GPS?我想是的,因为您正在获取 GPS 图标,但我想我会检查一下。
只有在设置中禁用 GPS 时才会调用 onProviderDisabled(),因此不太可能调用该代码。
您是否尝试过使用 0 而不是 2000 的距离?
您确定您对 requestLocationUpdates() 的调用实际上正在执行吗?
您的日志是否显示任何错误?您可以通过 adb logcat、DDMS 或 Eclipse 中的 DDMS 透视图检查您的日志。
您是否尝试过任何现有的、已发布的、应该可以工作的代码?例如,您可以将源代码获取到 my Android book,其中 Weather 和 WeatherPlus 示例显示了 LocationManager 的使用。
【讨论】:
1.在设置中 - 是的 2. 它没有,没有调用任何方法 3. 试过了。仍然没有得到修复 4. 是的 5. 是的,我实际上是,但不知道为什么。在问题中发布它 只是补充一下,我在 manifest.xml 文件中拥有所有必要的权限 - INTERNET、ACCESS_COARSE_LOCATION 和 ACCESS_FINE_LOCATION 3.第二个论点不是距离,而是时间。【参考方案3】:这是一个很好的例子,源代码http://marakana.com/forums/android/android_examples/42.html
【讨论】:
以上是关于Android - 使用 LocationManager 不会提供地理修复的主要内容,如果未能解决你的问题,请参考以下文章
不适用于 Android Studio-locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, this)
没有在 NSObject 类 ios swift 中获取委托方法的回调
仅当侦听器为该提供者注册时才调用 onProviderEnabled 吗?
Android 逆向Android 权限 ( Android 逆向中使用的 android.permission 权限 | Android 系统中的 Linux 用户权限 )