谷歌地图api v2崩溃

时间:2014-10-01 17:12:13

标签: java android eclipse google-maps google-maps-api-3

伙计们我试图通过eclipse将谷歌地图添加到Android应用程序我刚刚创建了新项目并按照这里的系列教程 Google Maps API v2

当我运行应用程序时,它崩溃了,这就是logcat

  

10-01 20:00:19.911:E / AndroidRuntime(24614):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:277)   10-01 20:00:19.911:E / AndroidRuntime(24614):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:691)   10-01 20:00:19.911:E / AndroidRuntime(24614):... 23更多   10-01 20:00:19.911:E / AndroidRuntime(24614):引起:java.lang.ClassNotFoundException:没找到类" com.google.android.gms.maps.MapFragment"在路径上:/data/app/com.example.maptest-2.apk   10-01 20:00:19.911:E / AndroidRuntime(24614):at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:64)   10-01 20:00:19.911:E / AndroidRuntime(24614):at java.lang.ClassLoader.loadClass(ClassLoader.java:501)   10-01 20:00:19.911:E / AndroidRuntime(24614):at java.lang.ClassLoader.loadClass(ClassLoader.java:461)   10-01 20:00:19.911:E / AndroidRuntime(24614):在android.support.v4.app.Fragment.instantiate(Fragment.java:399)   10-01 20:00:19.911:E / AndroidRuntime(24614):... 26更多   10-01 20:01:22.546:E / AndroidRuntime(25503):致命异常:主要   10-01 20:01:22.546:E / AndroidRuntime(25503):java.lang.RuntimeException:无法启动活动ComponentInfo {com.example.maptest / com.example.maptest.MainActivity}:android.view.InflateException:Binary XML文件行#2:错误膨胀类片段   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2308)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2362)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread.access $ 700(ActivityThread.java:168)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1329)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.os.Handler.dispatchMessage(Handler.java:99)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.os.Looper.loop(Looper.java:137)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread.main(ActivityThread.java:5493)   10-01 20:01:22.546:E / AndroidRuntime(25503):at java.lang.reflect.Method.invokeNative(Native Method)   10-01 20:01:22.546:E / AndroidRuntime(25503):at java.lang.reflect.Method.invoke(Method.java:525)   10-01 20:01:22.546:E / AndroidRuntime(25503):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1209)   10-01 20:01:22.546:E / AndroidRuntime(25503):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025)   10-01 20:01:22.546:E / AndroidRuntime(25503):at dalvik.system.NativeStart.main(Native Method)   10-01 20:01:22.546:E / AndroidRuntime(25503):引起:android.view.InflateException:二进制XML文件行#2:错误膨胀类片段   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:719)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.view.LayoutInflater.inflate(LayoutInflater.java:470)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.view.LayoutInflater.inflate(LayoutInflater.java:398)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.view.LayoutInflater.inflate(LayoutInflater.java:354)   10-01 20:01:22.546:E / AndroidRuntime(25503):at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:361)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.Activity.setContentView(Activity.java:1956)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v7.app.ActionBarActivity.superSetContentView(ActionBarActivity.java:208)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v7.app.ActionBarActivityDelegateICS.setContentView(ActionBarActivityDelegateICS.java:111)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v7.app.ActionBarActivity.setContentView(ActionBarActivity.java:76)   10-01 20:01:22.546:E / AndroidRuntime(25503):at com.example.maptest.MainActivity.onCreate(MainActivity.java:13)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.Activity.performCreate(Activity.java:5372)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2270)   10-01 20:01:22.546:E / AndroidRuntime(25503):... 11更多   10-01 20:01:22.546:E / AndroidRuntime(25503):引起:android.support.v4.app.Fragment $ InstantiationException:无法实例化片段com.google.android.gms.maps.MapFragment:确保课程name存在,是public,并且具有一个公共的空构造函数   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v4.app.Fragment.instantiate(Fragment.java:409)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v4.app.Fragment.instantiate(Fragment.java:377)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:277)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:691)   10-01 20:01:22.546:E / AndroidRuntime(25503):......还有23个   10-01 20:01:22.546:E / AndroidRuntime(25503):引起:java.lang.ClassNotFoundException:未找到类" com.google.android.gms.maps.MapFragment"在路径上:/data/app/com.example.maptest-1.apk   10-01 20:01:22.546:E / AndroidRuntime(25503):at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:64)   10-01 20:01:22.546:E / AndroidRuntime(25503):at java.lang.ClassLoader.loadClass(ClassLoader.java:501)   10-01 20:01:22.546:E / AndroidRuntime(25503):at java.lang.ClassLoader.loadClass(ClassLoader.java:461)   10-01 20:01:22.546:E / AndroidRuntime(25503):在android.support.v4.app.Fragment.instantiate(Fragment.java:399)   10-01 20:01:22.546:E / AndroidRuntime(25503):......还有26个   10-01 20:02:52.021:E / AndroidRuntime(25864):致命异常:主要   10-01 20:02:52.021:E / AndroidRuntime(25864):java.lang.RuntimeException:无法启动活动ComponentInfo {com.example.maptest / com.example.maptest.MainActivity}:android.view.InflateException:Binary XML文件行#2:错误膨胀类片段   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2308)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2362)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread.access $ 700(ActivityThread.java:168)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1329)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.os.Handler.dispatchMessage(Handler.java:99)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.os.Looper.loop(Looper.java:137)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread.main(ActivityThread.java:5493)   10-01 20:02:52.021:E / AndroidRuntime(25864):at java.lang.reflect.Method.invokeNative(Native Method)   10-01 20:02:52.021:E / AndroidRuntime(25864):at java.lang.reflect.Method.invoke(Method.java:525)   10-01 20:02:52.021:E / AndroidRuntime(25864):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1209)   10-01 20:02:52.021:E / AndroidRuntime(25864):at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025)   10-01 20:02:52.021:E / AndroidRuntime(25864):at dalvik.system.NativeStart.main(Native Method)   10-01 20:02:52.021:E / AndroidRuntime(25864):引起:android.view.InflateException:二进制XML文件行#2:错误膨胀类片段   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:719)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.view.LayoutInflater.inflate(LayoutInflater.java:470)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.view.LayoutInflater.inflate(LayoutInflater.java:398)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.view.LayoutInflater.inflate(LayoutInflater.java:354)   10-01 20:02:52.021:E / AndroidRuntime(25864):at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:361)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.Activity.setContentView(Activity.java:1956)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v7.app.ActionBarActivity.superSetContentView(ActionBarActivity.java:208)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v7.app.ActionBarActivityDelegateICS.setContentView(ActionBarActivityDelegateICS.java:111)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v7.app.ActionBarActivity.setContentView(ActionBarActivity.java:76)   10-01 20:02:52.021:E / AndroidRuntime(25864):at com.example.maptest.MainActivity.onCreate(MainActivity.java:13)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.Activity.performCreate(Activity.java:5372)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2270)   10-01 20:02:52.021:E / AndroidRuntime(25864):... 11更多   10-01 20:02:52.021:E / AndroidRuntime(25864):引起:android.support.v4.app.Fragment $ InstantiationException:无法实例化片段com.google.android.gms.maps.MapFragment:确保课程name存在,是public,并且具有一个公共的空构造函数   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v4.app.Fragment.instantiate(Fragment.java:409)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v4.app.Fragment.instantiate(Fragment.java:377)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:277)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:691)   10-01 20:02:52.021:E / AndroidRuntime(25864):......还有23个   10-01 20:02:52.021:E / AndroidRuntime(25864):引起:java.lang.ClassNotFoundException:没找到类" com.google.android.gms.maps.MapFragment"在路径上:/data/app/com.example.maptest-2.apk   10-01 20:02:52.021:E / AndroidRuntime(25864):at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:64)   10-01 20:02:52.021:E / AndroidRuntime(25864):at java.lang.ClassLoader.loadClass(ClassLoader.java:501)   10-01 20:02:52.021:E / AndroidRuntime(25864):at java.lang.ClassLoader.loadClass(ClassLoader.java:461)   10-01 20:02:52.021:E / AndroidRuntime(25864):在android.support.v4.app.Fragment.instantiate(Fragment.java:399)   10-01 20:02:52.021:E / AndroidRuntime(25864):... 26更多

2 个答案:

答案 0 :(得分:1)

确保已在布局中声明了片段。喜欢以下。

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

此外,您已在项目中添加了Google Play服务库。

一步一步地遵循以下说明:https://developers.google.com/maps/documentation/android/start

答案 1 :(得分:0)

我遇到了同样的问题,我犯了错误,只添加了以下2个标签中的一个。 请注意,您也缺少其中一个

        <meta-data
            android:name="com.google.android.geo.API_KEY"
            android:value="<YOUR VALUE>"/>
        <meta-data
            android:name="com.google.android.gms.version"
            android:value="@integer/google_play_services_version" />

实际错误确实具有误导性,因为您可能会考虑一些API级别的UI问题。