2013-06-27 33 views
4

我做了一個簡單的FragmentActivity,顯示谷歌地圖並使用標記來顯示當前位置和附近的地方。但是現在我需要在另一個應用程序中使用該代碼,並且我遇到了這個問題。Android谷歌地圖添加標記時出現空指針異常

這是活動

private void updatePlaces(JSONArray jDestinationArray) throws JSONException{ 

    locMan = (LocationManager)getSystemService(Context.LOCATION_SERVICE); 
    Location lastLoc = locMan.getLastKnownLocation(LocationManager.NETWORK_PROVIDER); 
    double lat = lastLoc.getLatitude(); 
    double lng = lastLoc.getLongitude(); 
    lastLatLng = new LatLng(lat, lng); 

    Display display = getWindowManager().getDefaultDisplay(); 
    Point size = new Point(); 
    display.getSize(size); 
    int width = size.x; 
    int height = size.y; 

    Builder boundsBuilder = new LatLngBounds.Builder(); 
    boundsBuilder.include(lastLatLng); 

    markers = new HashMap<Marker,Object>(); 
    userMarker = map.addMarker(new MarkerOptions() 
     .position(lastLatLng) 
     .title("You are here") 
     .icon(BitmapDescriptorFactory.fromResource(userIcon)) 
     .snippet("This is your last recorded location")); 


    markers.put(userMarker, lastLatLng); 
    for(int i=0; i<jDestinationArray.length(); i++){ 
     JSONObject destinationObject = jDestinationArray.getJSONObject(i); 
     LatLng latlng = new LatLng(destinationObject.getDouble("latitude"), destinationObject.getDouble("longitude")); 
     Marker destinationMarker= 
       map.addMarker(new MarkerOptions() 
       .position(latlng) 
       .title(destinationObject.getString("name")) 
       .icon(BitmapDescriptorFactory.fromResource(destinationIcon)) 
       .snippet(destinationObject.getString("street")) 
       ); 
     markers.put(destinationMarker, latlng); 
     boundsBuilder.include(latlng); 
    } 

    // pan to see all markers on map: 
    LatLngBounds bounds = boundsBuilder.build(); 
    map.moveCamera(CameraUpdateFactory.newLatLngBounds(bounds, width, height, 30)); 
    //map.animateCamera(CameraUpdateFactory.newLatLng(lastLatLng), 3000, null); 
} 

和日誌,當我打開地圖:

06-27 14:18:28.530: D/dalvikvm(3545): GC_CONCURRENT freed 755K, 10% free 10520K/11655K, paused 13ms+4ms, total 50ms 
06-27 14:18:28.530: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 33ms 
06-27 14:18:28.580: D/dalvikvm(3545): GC_FOR_ALLOC freed 756K, 11% free 10396K/11655K, paused 26ms, total 26ms 
06-27 14:18:28.680: D/dalvikvm(3545): GC_CONCURRENT freed 690K, 11% free 10437K/11655K, paused 2ms+14ms, total 56ms 
06-27 14:18:28.680: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 21ms 
06-27 14:18:28.710: W/ResourceType(3545): No package identifier when getting value for resource number 0x00000000 
06-27 14:18:28.710: D/AndroidRuntime(3545): Shutting down VM 
06-27 14:18:28.710: W/dalvikvm(3545): threadid=1: thread exiting with uncaught exception (group=0x40c42318) 
06-27 14:18:28.730: E/AndroidRuntime(3545): FATAL EXCEPTION: main 
06-27 14:18:28.730: E/AndroidRuntime(3545): java.lang.NullPointerException 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at maps.aj.bk.a(Unknown Source) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at maps.aj.bk.a(Unknown Source) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at maps.aj.al.a(Unknown Source) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at bcn.onTransact(SourceFile:167) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.Binder.transact(Binder.java:326) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.google.android.gms.maps.internal.IGoogleMapDelegate$a$a.addMarker(Unknown Source) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.google.android.gms.maps.GoogleMap.addMarker(Unknown Source) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.example.foodexp03a.MainActivity.updatePlaces(MainActivity.java:330) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.example.foodexp03a.MainActivity.access$1(MainActivity.java:312) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.example.foodexp03a.MainActivity$LongRunningGetIO.onPostExecute(MainActivity.java:394) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.example.foodexp03a.MainActivity$LongRunningGetIO.onPostExecute(MainActivity.java:1) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.AsyncTask.finish(AsyncTask.java:631) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.AsyncTask.access$600(AsyncTask.java:177) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.Handler.dispatchMessage(Handler.java:99) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.os.Looper.loop(Looper.java:137) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at android.app.ActivityThread.main(ActivityThread.java:4744) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at java.lang.reflect.Method.invokeNative(Native Method) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at java.lang.reflect.Method.invoke(Method.java:511) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
06-27 14:18:28.730: E/AndroidRuntime(3545):  at dalvik.system.NativeStart.main(Native Method) 
06-27 14:18:28.900: D/dalvikvm(3545): GC_FOR_ALLOC freed 274K, 7% free 10937K/11655K, paused 62ms, total 62ms 
06-27 14:18:28.980: D/dalvikvm(3545): GC_CONCURRENT freed 65K, 7% free 10945K/11655K, paused 12ms+14ms, total 82ms 
06-27 14:18:28.980: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 1ms 
06-27 14:18:29.010: D/dalvikvm(3545): GC_FOR_ALLOC freed 26K, 7% free 10918K/11655K, paused 31ms, total 31ms 
06-27 14:18:29.020: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.700MB for 1048592-byte allocation 
06-27 14:18:29.050: D/dalvikvm(3545): GC_FOR_ALLOC freed <1K, 7% free 11942K/12743K, paused 30ms, total 30ms 
06-27 14:18:29.110: D/dalvikvm(3545): GC_CONCURRENT freed <1K, 6% free 11981K/12743K, paused 2ms+23ms, total 57ms 
06-27 14:18:29.201: D/dalvikvm(3545): GC_FOR_ALLOC freed 1219K, 15% free 10945K/12743K, paused 38ms, total 38ms 
06-27 14:18:29.211: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.725MB for 1048592-byte allocation 
06-27 14:18:29.231: D/dalvikvm(3545): GC_FOR_ALLOC freed 1K, 7% free 11967K/12743K, paused 28ms, total 28ms 
06-27 14:18:29.321: D/dalvikvm(3545): GC_CONCURRENT freed 1136K, 12% free 11290K/12743K, paused 13ms+20ms, total 82ms 
06-27 14:18:29.461: D/dalvikvm(3545): GC_CONCURRENT freed 48K, 4% free 12305K/12743K, paused 27ms+14ms, total 93ms 
06-27 14:18:29.461: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 33ms 
06-27 14:18:29.641: D/dalvikvm(3545): GC_FOR_ALLOC freed 2623K, 22% free 10873K/13831K, paused 31ms, total 32ms 
06-27 14:18:29.641: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.656MB for 1048592-byte allocation 
06-27 14:18:29.671: D/dalvikvm(3545): GC_FOR_ALLOC freed 1K, 15% free 11895K/13831K, paused 37ms, total 37ms 
06-27 14:18:29.721: D/dalvikvm(3545): GC_CONCURRENT freed 75K, 14% free 11898K/13831K, paused 2ms+4ms, total 45ms 
06-27 14:18:29.801: D/dalvikvm(3545): GC_FOR_ALLOC freed 2113K, 22% free 10892K/13831K, paused 26ms, total 26ms 
06-27 14:18:29.801: I/dalvikvm-heap(3545): Grow heap (frag case) to 11.674MB for 1048592-byte allocation 
06-27 14:18:29.831: D/dalvikvm(3545): GC_FOR_ALLOC freed 4K, 14% free 11912K/13831K, paused 26ms, total 26ms 
06-27 14:18:29.891: D/dalvikvm(3545): GC_CONCURRENT freed 21K, 14% free 11917K/13831K, paused 13ms+7ms, total 63ms 
06-27 14:18:30.021: D/dalvikvm(3545): GC_CONCURRENT freed 2261K, 21% free 10952K/13831K, paused 12ms+8ms, total 66ms 
06-27 14:18:30.021: D/dalvikvm(3545): WAIT_FOR_CONCURRENT_GC blocked 1ms 
06-27 14:18:31.443: I/Process(3545): Sending signal. PID: 3545 SIG: 9 

活動的佈局:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 

    <fragment android:name="com.example.foodexp03a.HomeFragment" 
      android:id="@+id/homeFragment" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" /> 
    <fragment android:name="com.example.foodexp03a.LoginFragment" 
      android:id="@+id/loginFragment" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" /> 
    <fragment android:name="com.example.foodexp03a.SettingsFragment" 
      android:id="@+id/settingsFragment" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" /> 

    <fragment android:name="com.example.foodexp03a.DestinationFragment" 
      android:id="@+id/destinationFragment" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" /> 
    <fragment 
      android:id="@+id/mapFragment" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:name="com.google.android.gms.maps.SupportMapFragment"/> 
</LinearLayout> 
+0

發佈您的堆棧跟蹤並將您的代碼縮小到相關部分。 – Raghunandan

+0

哪一行是「MainActivity.java:330」? – yahya

回答

5

我沒有看到你在哪裏分配userIcon任何值,因此BitmapDescriptorFactory.fromResource(userIcon)可能會返回null作爲結果。

+0

你是對的!下次我會更加關注地導入代碼。非常感謝! – ezy

1
  1. 首先檢查谷歌地圖爲空或NOTNULL使用此方法 - >如果(!GMAP = NULL)
  2. 無論你要下載標記圖標形式的URL(或)加標記圖像標記信息窗口直接從url.its中獲取網絡主線程異常。
  3. 網絡主線程異常導致標記圖像空這樣你就可以在谷歌地圖獲得空指針異常

解決方案:

添加以下行您的onCreate方法

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

StrictMode.setThreadPolicy(policy);

相關問題