【发布时间】:2015-08-03 05:36:42
【问题描述】:
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 在 android.app.ActivityThread.performResumeActivity(ActivityThread.java:2596) 在 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.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:511) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556) 在 dalvik.system.NativeStart.main(本机方法) 引起: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.Method.invokeNative(Native Method) 在 java.lang.reflect.Method.invoke(Method.java:511) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556) 在 dalvik.system.NativeStart.main(Native Method)
我正在尝试获取location应用程序一打开,它将设置为TextView,但我在line no.38 上收到错误,正如LogCat 所指出的那样 p>
那一行是:
lm.requestLocationUpdates(LocationManager.NETWORK_PROVIDER,0,0,locationListener);
我在phone 和emulator 上都尝试了gps 和network,但它仍然给出同样的错误java.lang.IllegalArgumentException: listener==null
【问题讨论】:
-
您的活动正在实现 LocationListener 接口。使用它而不是 locationListener
标签: java android gps location illegalargumentexception