【问题标题】:Null pointer exception in android google mapsandroid谷歌地图中的空指针异常
【发布时间】:2015-08-13 21:47:37
【问题描述】:

我正在尝试将谷歌地图添加到我的应用程序中。 logcat 窗口显示此错误: 引起:在 com.example.mymaps.MainActivity.onCreate(MainActivity.java:27) 在 android.app.Activity.performCreate(Activity.java:5104) 的 java.lang.NullPointerException 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)。

如何消除这个错误?

   Main xml:
   <RelativeLayout     
   xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context=".MainActivity" >

  <fragment
    android:id="@+id/map"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    class="com.google.android.gms.maps.MapFragment" />

 </RelativeLayout>

主 Java 导入android.app.Activity; 导入android.os.Bundle; 导入android.view.Menu;

  import com.google.android.gms.maps.CameraUpdateFactory;

  import com.google.android.gms.maps.GoogleMap;
  import com.google.android.gms.maps.MapFragment;
  import com.google.android.gms.maps.model.BitmapDescriptorFactory;
  import com.google.android.gms.maps.model.LatLng;
  import com.google.android.gms.maps.model.Marker;
  import com.google.android.gms.maps.model.MarkerOptions;

  public class MainActivity extends Activity {
  static final LatLng HAMBURG = new LatLng(53.558, 9.927);
  static final LatLng KIEL = new LatLng(53.551, 9.993);
  private GoogleMap map;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
     map = ((MapFragment) getFragmentManager().findFragmentById(R.id.map))
    .getMap();
     Marker hamburg = map.addMarker(new MarkerOptions().position(HAMBURG)
    .title("Hamburg"));
     Marker kiel = map.addMarker(new MarkerOptions()
    .position(KIEL)
    .title("Kiel")
    .snippet("Kiel is cool")
    .icon(BitmapDescriptorFactory
        .fromResource(R.drawable.ic_launcher)));

    // Move the camera instantly to hamburg with a zoom of 15.
    map.moveCamera(CameraUpdateFactory.newLatLngZoom(HAMBURG, 15));

    // Zoom in, animating the camera.
   map.animateCamera(CameraUpdateFactory.zoomTo(10), 2000, null);
   }

    @Override
   public boolean onCreateOptionsMenu(Menu menu) {
   getMenuInflater().inflate(R.menu.activity_main, menu);
   return true;
   }

  } 

LogCat 窗口:

08-13 23:32:27.279: E/AndroidRuntime(1010): 致命异常: main 08-13 23:32:27.279: E/AndroidRuntime(1010): java.lang.RuntimeException: 无法启动活动 ComponentInfo{com.example.mymaps/com.example.mymaps.MainActivity}: java.lang.NullPointerException 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread.access$600(ActivityThread.java:141) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.os.Handler.dispatchMessage(Handler.java:99) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.os.Looper.loop(Looper.java:137) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread.main(ActivityThread.java:5039) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 java.lang.reflect.Method.invokeNative(Native Method) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 java.lang.reflect.Method.invoke(Method.java:511) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 dalvik.system.NativeStart.main(Native Method) 08-13 23:32:27.279:E/AndroidRuntime(1010):由:java.lang.NullPointerException 引起 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 com.example.mymaps.MainActivity.onCreate(MainActivity.java:27) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.Activity.performCreate(Activity.java:5104) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 08-13 23:32:27.279: E/AndroidRuntime(1010): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 08-13 23:32:27.279: E/AndroidRuntime(1010): ... 11 更多

【问题讨论】:

  • onCreate 方法中的第 27 行是哪一行?
  • 该问题已解决。但是我在手机里看不到任何地图。仅在左下角显示“放大”和“缩小”符号以及“Google”。但是没有地图。为什么会这样?

标签: android google-maps nullpointerexception mapfragment


【解决方案1】:

可能是播放服务问题。所以在使用地图之前检查地图对象是否为空,这样它会自动要求在设备中下载地图。请尝试回复

    @Override
       protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
         map = ((MapFragment) getFragmentManager().findFragmentById(R.id.map))
        .getMap();
if(map!=null){
         Marker hamburg = map.addMarker(new MarkerOptions().position(HAMBURG)
        .title("Hamburg"));
         Marker kiel = map.addMarker(new MarkerOptions()
        .position(KIEL)
        .title("Kiel")
        .snippet("Kiel is cool")
        .icon(BitmapDescriptorFactory
            .fromResource(R.drawable.ic_launcher)));

        // Move the camera instantly to hamburg with a zoom of 15.
        map.moveCamera(CameraUpdateFactory.newLatLngZoom(HAMBURG, 15));

        // Zoom in, animating the camera.
       map.animateCamera(CameraUpdateFactory.zoomTo(10), 2000, null);
}
       }

【讨论】:

  • 非常感谢。它不再显示该异常。但是当我在手机上安装 apk 时,我看不到任何地图。只有放大和缩小标志,左侧显示“Google”。但是没有地图。为什么会这样?
  • 您的手机有平台服务。请下载google playservice for map
  • 我的手机中有 google play 服务。还是不行?
  • 对我来说,这是某些设备由于播放服务而出现的问题。您是在某些设备上还是在所有设备上都面临这个问题?请在出现空指针异常时粘贴 logcat
  • 它无法在任何设备上运行。有没有其他选择>?
【解决方案2】:
  1. 首先使用此方法检查谷歌地图是nullnot null

    If(gMap!=null)
    
  2. 您是否必须从 URL 下载标记图标(或)直接从 URL 将标记图像添加到标记信息窗口。有可能得到网络主线程异常。

  3. 网络主线程异常导致标记图像null,所以你可能会在谷歌地图中得到空指针异常

解决方案:

在您的 onCreate 方法中添加以下行

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

StrictMode.setThreadPolicy(policy);

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-07-21
    • 2016-07-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多