繁体   English   中英

Android LocationListener 返回空值

[英]Android LocationListener return null value

主 Java 文件

public class MainActivity extends Activity implements LocationListener {
    TextView tv;
    TextView tv2;
    TextView tv3;
    LocationListener locationListener;
    static final String tag="********MAIN********";
    LocationManager lm;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lm = (LocationManager) getSystemService(LOCATION_SERVICE);
    }
    @Override
    protected void onResume() {
        super.onResume();
        lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,locationListener);
    }
    @Override
    public void onLocationChanged(Location location) {
        Log.i(tag,"Location Changed Method Called");
        String lat= String.valueOf(location.getLatitude());
        String log= String.valueOf(location.getLongitude());
        tv.setText(lat+ " " + log);
    }
    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {
    }
    @Override
    public void onProviderEnabled(String provider) {
    }
    @Override
    public void onProviderDisabled(String provider) {
    }
}

清单文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="p2p.boysjoys.com.alpha" >

    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >


        <activity
            android:name=".MainActivity"
            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>

</manifest>

错误日志:

05-21 18:51:53.970 22842-22842/p2p.boysjoys.com.alpha E/AndroidRuntime:致命异常:主要 java.lang.RuntimeException:无法恢复活动 {p2p.boysjoys.com.alpha/p2p.boysjoys com.alpha.MainActivity}: java.lang.IllegalArgumentException: listener==null at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2596) at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2624) at android。 app.ActivityThread.handleLaunchActivity(ActivityThread.java:2101) at android.app.ActivityThread.access$600(ActivityThread.java:138) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1207) at android.os。 Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:213) at android.app.ActivityThread.main(ActivityThread.java:4787) at java.lang.reflect.Method.invokeNative (本机方法)在 java.lang.reflect.Method.invoke(Method.java:511) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 在 com.android.inte 由 dalvik.system.NativeStart.main(Native Method) 引起的 rnal.os.ZygoteInit.main(ZygoteInit.java:556):java.lang.IllegalArgumentException:listener==null 在 android.location.LocationManager.requestLocationUpdates(LocationManager. java:510) 在 p2p.boysjoys.com.alpha.MainActivity.onResume(MainActivity.java:38) 在 android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1184) 在 android.app.Activity.performResume(Activity.java) :5082) 在 android.app.ActivityThread.performResumeActivity(ActivityThread.java:2586) 在 android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2624) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2101) 在 android .app.ActivityThread.access$600(ActivityThread.java:138) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1207) 在 android.os.Handler.dispatchMessage(Handler.java:99) 在 android.os .Looper.loop(Looper.java:213) 在 android.app.ActivityThread.main(ActivityThread.java:4787) 在 java.lang.reflect.Me thod.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:511) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) at com.android。 dalvik.system.NativeStart.main(Native Method) 处的 internal.os.ZygoteInit.main(ZygoteInit.java:556)

我正在尝试在应用程序打开后立即获取location并将其设置为TextView ,但正如LogCat指出的那样,我在line no.38收到错误

那一行是:

lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,locationListener);

我在phoneemulator上都尝试过gpsnetwork ,但它仍然给出相同的错误java.lang.IllegalArgumentException: listener==null

代替:

lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,locationListener);

用:

 lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,this);

改变:

lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,locationListener);

有了这个:

lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,this);

您的课程已经实现了LocationListener 就用它。 (但是,在您的代码中,您尝试使用locationListener而不对其进行初始化)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM