尝试在空对象引用上调用虚拟方法 'void com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener'
Attempt to invoke virtual method 'void com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener' on a null object reference
当我长按地图时,它应该会在该位置添加标记。但它不起作用。当我尝试 运行 时,我的应用程序崩溃了。请帮帮我
这是我的代码
package inandroid.jeetna.memorableplaces;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.MenuItem;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
public class MapsActivity extends AppCompatActivity implements OnMapReadyCallback,GoogleMap.OnMapLongClickListener {
private GoogleMap mMap;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_maps);
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
mMap.setOnMapLongClickListener(this);
android.support.v7.app.ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
Intent i = getIntent();
Log.i("locationInfo", Integer.toString(i.getIntExtra("locationinfo", -1)));
}
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
// Add a marker in Sydney and move the camera
LatLng sydney = new LatLng(-34, 151);
mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
this.finish();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
@Override
public void onMapLongClick(LatLng point) {
mMap.addMarker(new MarkerOptions()
.position(point)
.title("You are here")
.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED)));
}
}
这是我收到的错误信息
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces
E/AndroidRuntime: FATAL EXCEPTION: main
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: Process: inandroid.jeetna.memorableplaces, PID: 7519
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity
ComponentInfo{inandroid.jeetna.memorableplaces/inandroid.jeetna.memorableplaces.MapsActivity}:
java.lang.NullPointerException: Attempt to invoke virtual method 'void
com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener(com.google.android.gms.maps.GoogleMap$OnMapLongClickListener)'
on a null object reference
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.access0(ActivityThread.java:144)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.os.Handler.dispatchMessage(Handler.java:102)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.main(ActivityThread.java:5221)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native
Method)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
java.lang.reflect.Method.invoke(Method.java:372)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt
to invoke virtual method 'void
com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener(com.google.android.gms.maps.GoogleMap$OnMapLongClickListener)'
on a null object reference
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
inandroid.jeetna.memorableplaces.MapsActivity.onCreate(MapsActivity.java:33)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.Activity.performCreate(Activity.java:5937)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.access0(ActivityThread.java:144)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.os.Handler.dispatchMessage(Handler.java:102)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
android.app.ActivityThread.main(ActivityThread.java:5221)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native
Method)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
java.lang.reflect.Method.invoke(Method.java:372)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
首先,我们需要错误发生的代码。我的意思是你只是把你的 logcat 输出,没有格式化,这是不够的。
然后你的 logcat 说 NullPointerException
。这意味着您正试图在具有 null value
的对象上设置侦听器。
因此,我们所能做的就是在调用之前检查您为其设置 setOnMapLongClickListener
的对象是否为 null。
编辑
好的,您的代码似乎由于某些原因地图可能尚未初始化。您可以做的是在设置监听器之前检查地图是否可用。否则,您将尝试将您的侦听器设置为空对象,这将导致崩溃。
这一行之前:
mMap.setOnMapLongClickListener(this);
确保您的mMap已经初始化。因为在设置侦听器之前未调用将值设置为 mMap 对象的方法。
在您的长按方法中执行如下代码
public void onMapLongClick(LatLng point) {
if(mMap != null){
mMap.addMarker(new MarkerOptions()
.position(point)
.title("You are here")
.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED)));
}
}
并将 mMap.setOnMapLongClickListener(this);
行从 onCreate()
方法移动到 onMapReady()
方法,如下所示:
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
mMap.setOnMapLongClickListener(this);
//your code
}
这是因为您的 mMap
在从 onMapReady()
方法
分配 googleMap
对象之前是空的
据我所知,您需要在与地图交互之前对其进行初始化。
创建 activity 时会调用 onCreate 方法。 onMapReady 没有。所以请先初始化地图,然后尝试注册一个事件监听器。
当我长按地图时,它应该会在该位置添加标记。但它不起作用。当我尝试 运行 时,我的应用程序崩溃了。请帮帮我
这是我的代码
package inandroid.jeetna.memorableplaces;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.MenuItem;
import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
public class MapsActivity extends AppCompatActivity implements OnMapReadyCallback,GoogleMap.OnMapLongClickListener {
private GoogleMap mMap;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_maps);
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
mMap.setOnMapLongClickListener(this);
android.support.v7.app.ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayHomeAsUpEnabled(true);
Intent i = getIntent();
Log.i("locationInfo", Integer.toString(i.getIntExtra("locationinfo", -1)));
}
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
// Add a marker in Sydney and move the camera
LatLng sydney = new LatLng(-34, 151);
mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case android.R.id.home:
this.finish();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
@Override
public void onMapLongClick(LatLng point) {
mMap.addMarker(new MarkerOptions()
.position(point)
.title("You are here")
.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED)));
}
}
这是我收到的错误信息
12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: FATAL EXCEPTION: main 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: Process: inandroid.jeetna.memorableplaces, PID: 7519 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity ComponentInfo{inandroid.jeetna.memorableplaces/inandroid.jeetna.memorableplaces.MapsActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener(com.google.android.gms.maps.GoogleMap$OnMapLongClickListener)' on a null object reference 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2298) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.access0(ActivityThread.java:144) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5221) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:372) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void com.google.android.gms.maps.GoogleMap.setOnMapLongClickListener(com.google.android.gms.maps.GoogleMap$OnMapLongClickListener)' on a null object reference 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at inandroid.jeetna.memorableplaces.MapsActivity.onCreate(MapsActivity.java:33) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.Activity.performCreate(Activity.java:5937) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.access0(ActivityThread.java:144) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5221) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:372) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899) 12-29 12:42:07.118 7519-7519/inandroid.jeetna.memorableplaces E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
首先,我们需要错误发生的代码。我的意思是你只是把你的 logcat 输出,没有格式化,这是不够的。
然后你的 logcat 说 NullPointerException
。这意味着您正试图在具有 null value
的对象上设置侦听器。
因此,我们所能做的就是在调用之前检查您为其设置 setOnMapLongClickListener
的对象是否为 null。
编辑
好的,您的代码似乎由于某些原因地图可能尚未初始化。您可以做的是在设置监听器之前检查地图是否可用。否则,您将尝试将您的侦听器设置为空对象,这将导致崩溃。
这一行之前:
mMap.setOnMapLongClickListener(this);
确保您的mMap已经初始化。因为在设置侦听器之前未调用将值设置为 mMap 对象的方法。
在您的长按方法中执行如下代码
public void onMapLongClick(LatLng point) {
if(mMap != null){
mMap.addMarker(new MarkerOptions()
.position(point)
.title("You are here")
.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_RED)));
}
}
并将 mMap.setOnMapLongClickListener(this);
行从 onCreate()
方法移动到 onMapReady()
方法,如下所示:
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
mMap.setOnMapLongClickListener(this);
//your code
}
这是因为您的 mMap
在从 onMapReady()
方法
googleMap
对象之前是空的
据我所知,您需要在与地图交互之前对其进行初始化。
创建 activity 时会调用 onCreate 方法。 onMapReady 没有。所以请先初始化地图,然后尝试注册一个事件监听器。