2

我正在使用Google maps API V2,它运行良好。我有一个2.2.2 Android设备,我用它来调试我的应用程序。API级别8的Google Maps API V2 android应用程序最多17个

现在我刚刚得到了一个Galaxy Note 2,当我尝试在该设备上进行调试时,该应用程序正在亚马逊崩溃“项目已停止工作”。

所以我只是做了一个小例子来测试。并且它在2.2.2上运行得很好,但在4.1.1上运行得并不好。

这是代码我对小例子锻炼

任何建议,将不胜感激

我的布局

<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" > 

    <TextView 
     android:id="@+id/tv_location" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" /> 

    <fragment xmlns:android="http://schemas.android.com/apk/res/android" 
     android:id="@+id/map" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_below="@id/tv_location" 
     class="com.google.android.gms.maps.SupportMapFragment" /> 
</RelativeLayout> 

我的清单

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.example.ss" 
    android:versionCode="1" 
    android:versionName="1.0" > 

    <uses-sdk 
     android:minSdkVersion="8" 
     android:targetSdkVersion="17" /> 

    <permission 
     android:name="com.example.ss.permission.MAPS_RECEIVE" 
     android:protectionLevel="signature"/> 


    <uses-permission android:name="com.example.ss.permission.MAPS_RECEIVE"/> 
    <uses-permission android:name="android.permission.INTERNET"/> 
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/> 
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> 

    <uses-feature 
     android:glEsVersion="0x00020000" 
     android:required="true"/> 


    <application 
     android:allowBackup="true" 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" > 

     <uses-library android:name="com.google.android.maps" /> 
     <activity 
      android:name="com.example.ss.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> 

     <meta-data 
      android:name="com.google.android.maps.v2.API_KEY" 
      android:value="my key"/> 
    </application> 

</manifest> 

和我的测试代码

public class MainActivity extends FragmentActivity implements LocationListener{ 

private GoogleMap googleMap; 
private LatLng source; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    int status = GooglePlayServicesUtil.isGooglePlayServicesAvailable(getBaseContext()); 

     if(status!=ConnectionResult.SUCCESS){ 
      int requestCode = 10; 
      Dialog dialog = GooglePlayServicesUtil.getErrorDialog(status, this, requestCode); 
      dialog.show(); 
     }else{ 
      SupportMapFragment fm = (SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map); 

      googleMap = fm.getMap(); 

      googleMap.setMyLocationEnabled(false); 

      LocationManager locManager = (LocationManager) getSystemService(LOCATION_SERVICE); 

      Criteria criteria = new Criteria(); 

      String provider = locManager.getBestProvider(criteria, true); 

      Location loc = locManager.getLastKnownLocation(provider); 


      if(loc!=null){ 
       onLocationChanged(loc); 
      } 
      source = new LatLng(loc.getLatitude(), loc.getLongitude()); 
      //makeUrl = new MakeUrl(source, destination); 
      //String url = makeUrl.makeLocationUrl(); 
      googleMap.moveCamera(CameraUpdateFactory.newLatLng(source)); 
      googleMap.animateCamera(CameraUpdateFactory.zoomTo(15)); 
     } 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.activity_main, menu); 
    return true; 
} 

@Override 
public void onLocationChanged(Location arg0) { 
    // TODO Auto-generated method stub 

} 

@Override 
public void onProviderDisabled(String arg0) { 
    // TODO Auto-generated method stub 

} 

@Override 
public void onProviderEnabled(String arg0) { 
    // TODO Auto-generated method stub 

} 

@Override 
public void onStatusChanged(String arg0, int arg1, Bundle arg2) { 
    // TODO Auto-generated method stub 

} 

}

,我得到我的注意2

02-17 13:03:23.135: D/dalvikvm(9527): Late-enabling CheckJNI 
02-17 13:03:23.170: E/Trace(9527): error opening trace file: No such file or directory (2) 
02-17 13:03:23.345: D/dalvikvm(9527): GC_CONCURRENT freed 179K, 6% free 12453K/13191K, paused 2ms+1ms, total 33ms 
02-17 13:03:23.345: D/dalvikvm(9527): WAIT_FOR_CONCURRENT_GC blocked 26ms 
02-17 13:03:23.575: D/dalvikvm(9527): GC_CONCURRENT freed 279K, 7% free 12634K/13511K, paused 12ms+1ms, total 24ms 
02-17 13:03:23.665: D/dalvikvm(9527): GC_CONCURRENT freed 276K, 7% free 12862K/13703K, paused 2ms+12ms, total 29ms 
02-17 13:03:23.705: D/AbsListView(9527): Get MotionRecognitionManager 
02-17 13:03:23.740: D/dalvikvm(9527): GC_CONCURRENT freed 194K, 6% free 13206K/13959K, paused 2ms+2ms, total 20ms 
02-17 13:03:23.740: D/dalvikvm(9527): WAIT_FOR_CONCURRENT_GC blocked 9ms 
02-17 13:03:23.745: D/dalvikvm(9527): WAIT_FOR_CONCURRENT_GC blocked 9ms 
02-17 13:03:23.760: D/AndroidRuntime(9527): Shutting down VM 
02-17 13:03:23.760: W/dalvikvm(9527): threadid=1: thread exiting with uncaught exception (group=0x41c802a0) 
02-17 13:03:23.760: E/AndroidRuntime(9527): FATAL EXCEPTION: main 
02-17 13:03:23.760: E/AndroidRuntime(9527): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.mm/com.example.mm.MainActivity}: java.lang.NullPointerException 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2100) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread.access$600(ActivityThread.java:140) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.os.Looper.loop(Looper.java:137) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread.main(ActivityThread.java:4898) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at java.lang.reflect.Method.invokeNative(Native Method) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at java.lang.reflect.Method.invoke(Method.java:511) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1008) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:775) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at dalvik.system.NativeStart.main(Native Method) 
02-17 13:03:23.760: E/AndroidRuntime(9527): Caused by: java.lang.NullPointerException 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at com.example.mm.MainActivity.onCreate(MainActivity.java:82) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.Activity.performCreate(Activity.java:5191) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2064) 
02-17 13:03:23.760: E/AndroidRuntime(9527):  ... 11 more 
02-17 13:03:23.955: D/dalvikvm(9527): GC_CONCURRENT freed 233K, 6% free 13394K/14215K, paused 14ms+1ms, total 44ms 
+0

请同时发布logcat的堆栈跟踪或错误消息。 – mdiener 2013-02-17 09:46:09

+0

@mdiener Stacktrace已被添加 – Michael 2013-02-17 12:07:18

+0

由于在源代码中没有可见的行号,这是MainActivity中的第82行? – mdiener 2013-02-17 15:38:15

回答

2

堆栈跟踪看起来有该位置提供商没有最后已知的位置。如果该位置提供商从未进行位置修复,则可能会发生这种情况。 只需尝试更好地解决loc == null的情况。