Android的谷歌地图V2停止 [英] Android Google Map V2 Stopped
问题描述
我试图建立地图应用程序并按照此链接一步一步。我发现了类似的主题这里,但没有帮助我。我想说明的地图,但是当我运行它,它返回部队密切和我的Android设备。我看到了很多关于这个错误的问题,但没有人真正回答我的问题。这里是我的LogCat中:
03-21 20:55:57.476:D / AndroidRuntime(4090):关闭VM
03-21 20:55:57.476:W / dalvikvm(4090):主题ID = 1:螺纹未捕获的异常(组= 0x417692a0)退出
03-21 20:55:57.500:E / AndroidRuntime(4090):致命异常:主要
03-21 20:55:57.500:E / AndroidRuntime(4090):了java.lang.RuntimeException:无法启动活动ComponentInfo {com.example.mapandroid / com.example.mapandroid.MainActivity}:android.view.InflateException:二进制XML文件行#11:错误充气类片段
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2122)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread.access $ 600(ActivityThread.java:140)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1228)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.os.Handler.dispatchMessage(Handler.java:99)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.os.Looper.loop(Looper.java:137)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread.main(ActivityThread.java:4895)
03-21 20:55:57.500:E / AndroidRuntime(4090):在java.lang.reflect.Method.invokeNative(本机方法)
03-21 20:55:57.500:E / AndroidRuntime(4090):在java.lang.reflect.Method.invoke(Method.java:511)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:994)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
03-21 20:55:57.500:E / AndroidRuntime(4090):在dalvik.system.NativeStart.main(本机方法)
03-21 20:55:57.500:E / AndroidRuntime(4090):android.view.InflateException:二进制XML文件行#11:错误充气类片段产生的原因
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.view.LayoutInflater.inflate(LayoutInflater.java:489)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.view.LayoutInflater.inflate(LayoutInflater.java:396)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.example.mapandroid.MainActivity $ PlaceholderFragment.onCreateView(MainActivity.java:67)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.Fragment.performCreateView(Fragment.java:1500)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1178)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.Activity.performStart(Activity.java:5173)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2070)
03-21 20:55:57.500:E / AndroidRuntime(4090):11 ...更多
03-21 20:55:57.500:E / AndroidRuntime(4090):java.lang.IllegalStateException:在应用的AndroidManifest.xml中的元数据标签没有正确的价值所致。预计4242000但发现0。你必须有该元素中的如下声明:
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.common.GooglePlayServicesUtil.n(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.internal.q.v(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.internal.q.u(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.MapsInitializer.initialize(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.SupportMapFragment $ b.ex(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.SupportMapFragment $ b.a(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.dynamic.a.a(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.dynamic.a.onInflate(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在com.google.android.gms.maps.SupportMapFragment.onInflate(来源不明)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290)
03-21 20:55:57.500:E / AndroidRuntime(4090):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)
03-21 20:55:57.500:E / AndroidRuntime(4090):24 ...更多
03-21 20:55:57.515:D / dalvikvm(4090):GC_CONCURRENT释放233K,10%免费7615K / 8455K,暂停13毫秒+ 2ms的,总39MS
03-21 21:36:53.375:W / dalvikvm(4279):VFY:未能解决LCOM /谷歌/安卓/ GMS / R $设置样式静态字段3202(MapAttrs);
03-21 21:36:53.375:D / dalvikvm(4279):VFY:在0x000e更换运code 0X62
03-21 21:36:53.375:D / AndroidRuntime(4279):关闭VM
03-21 21:36:53.375:W / dalvikvm(4279):主题ID = 1:螺纹未捕获的异常(组= 0x417692a0)退出
03-21 21:36:53.382:E / AndroidRuntime(4279):致命异常:主要
03-21 21:36:53.382:E / AndroidRuntime(4279):java.lang.NoClassDefFoundError的:com.google.android.gms.R $设置样式
03-21 21:36:53.382:E / AndroidRuntime(4279):在com.google.android.gms.maps.GoogleMapOptions.createFromAttributes(来源不明)
03-21 21:36:53.382:E / AndroidRuntime(4279):在com.google.android.gms.maps.SupportMapFragment.onInflate(来源不明)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.view.LayoutInflater.inflate(LayoutInflater.java:489)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.view.LayoutInflater.inflate(LayoutInflater.java:396)
03-21 21:36:53.382:E / AndroidRuntime(4279):在com.example.map.MainActivity $ PlaceholderFragment.onCreateView(MainActivity.java:57)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.Fragment.performCreateView(Fragment.java:1500)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1178)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.Activity.performStart(Activity.java:5173)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2070)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2122)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.ActivityThread.access $ 600(ActivityThread.java:140)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1228)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.os.Handler.dispatchMessage(Handler.java:99)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.os.Looper.loop(Looper.java:137)
03-21 21:36:53.382:E / AndroidRuntime(4279):在android.app.ActivityThread.main(ActivityThread.java:4895)
03-21 21:36:53.382:E / AndroidRuntime(4279):在java.lang.reflect.Method.invokeNative(本机方法)
03-21 21:36:53.382:E / AndroidRuntime(4279):在java.lang.reflect.Method.invoke(Method.java:511)
03-21 21:36:53.382:E / AndroidRuntime(4279):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:994)
03-21 21:36:53.382:E / AndroidRuntime(4279):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
03-21 21:36:53.382:E / AndroidRuntime(4279):在dalvik.system.NativeStart.main(本机方法)
和我在这里MainActivity.java
包com.example.map;进口android.support.v4.app.Fragment;
进口android.support.v4.app.FragmentActivity;
进口android.os.Bundle;
进口android.view.LayoutInflater;
进口android.view.Menu;
进口android.view.MenuItem;
进口android.view.View;
进口android.view.ViewGroup;
公共类MainActivity扩展FragmentActivity { @覆盖
保护无效的onCreate(捆绑savedInstanceState){
super.onCreate(savedInstanceState);
的setContentView(R.layout.activity_main); 如果(savedInstanceState == NULL){
getSupportFragmentManager()调用BeginTransaction()
。新增(R.id.container,新PlaceholderFragment())提交()。
}
} @覆盖
公共布尔onCreateOptionsMenu(菜单菜单){ //充气菜单;如果是present这增加了项目操作栏。
。getMenuInflater()膨胀(R.menu.main,菜单);
返回true;
} @覆盖
公共布尔onOptionsItemSelected(菜单项项){
//处理动作栏项目点击这里。操作栏会
//自动处理上点击主页/向上按钮,只要
//你在AndroidManifest.xml中指定一个父活动。
INT ID = item.getItemId();
如果(ID == R.id.action_settings){
返回true;
}
返回super.onOptionsItemSelected(项目);
} / **
*包含一个简单视图中的占位符片段。
* /
公共静态类PlaceholderFragment扩展片段{ 公共PlaceholderFragment(){
} @覆盖
公共查看onCreateView(LayoutInflater充气器,容器的ViewGroup,
捆绑savedInstanceState){
查看rootView = inflater.inflate(R.layout.fragment_main,集装箱,
假);
返回rootView;
}
}}
这是我的activity_main.xml中:
<的FrameLayout的xmlns:机器人=http://schemas.android.com/apk/res/android
的xmlns:工具=http://schemas.android.com/tools
机器人:ID =@ + ID /容器
机器人:layout_width =match_parent
机器人:layout_height =match_parent
工具:上下文=com.example.map.MainActivity
工具:忽略=MergeRootFrame/>
和这里是我的fragment_main.xml
<的RelativeLayout的xmlns:机器人=http://schemas.android.com/apk/res/android
的xmlns:工具=http://schemas.android.com/tools
机器人:layout_width =match_parent
机器人:layout_height =match_parent
机器人:paddingBottom会=@扪/ activity_vertical_margin
机器人:paddingLeft =@扪/ activity_horizontal_margin
机器人:paddingRight =@扪/ activity_horizontal_margin
机器人:paddingTop =@扪/ activity_vertical_margin
工具:上下文=$ com.example.map.MainActivity PlaceholderFragment><片段
机器人:名字=com.google.android.gms.maps.SupportMapFragment
机器人:ID =@ + ID /图
机器人:layout_width =match_parent
机器人:layout_height =match_parent/>< / RelativeLayout的>
和我的表现:
<?XML版本=1.0编码=UTF-8&GT?;
<清单的xmlns:机器人=http://schemas.android.com/apk/res/android
包=com.example.map
安卓版code =1
机器人:=的versionName1.0><用途-SDK
安卓的minSdkVersion =8
机器人:targetSdkVersion =19/><允许机器人:名字=com.example.map.permission.MAPS_RECEIVE安卓的ProtectionLevel =签名/>
<使用许可权的android:NAME =com.example.map.permission.MAPS_RECEIVE/>
<使用许可权的android:NAME =android.permission.INTERNET对/>
<使用许可权的android:NAME =android.permission.WRITE_EXTERNAL_STORAGE/>
<使用许可权的android:NAME =com.google.android.providers.gsf.permission.READ_GSERVICES/>
<使用许可权的android:NAME =android.permission.ACCESS_COARSE_LOCATION/>
<使用许可权的android:NAME =android.permission.ACCESS_FINE_LOCATION/><使用特征的android:glEsVersion =0x00020000机器人:所需=真/><元数据机器人:名字=com.google.android.maps.v2.API_KEY机器人:值=0123456789abcde/><元数据机器人:名字=com.google.android.gms.version机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/><应用
机器人:allowBackup =真
机器人:图标=@绘制/ ic_launcher
机器人:标签=@字符串/ APP_NAME
机器人:主题=@风格/ AppTheme>
<活动
机器人:名字=com.example.map.MainActivity
机器人:标签=@字符串/ APP_NAME>
&所述;意图滤光器>
<作用机器人:名字=android.intent.action.MAIN/> <类机器人:名字=android.intent.category.LAUNCHER/>
&所述; /意图滤光器>
< /活性GT;
< /用途>< /清单>
我读过一步从以下链接步骤,但它似乎很多错误在我的code。我错过了什么?什么建议吗?非常感谢。
com.google.android.gms.R $设置样式
块引用>这通常是由于正常不具有参考谷歌播放服务
致:java.lang.IllegalStateException:在元数据标签的
应用的AndroidManifest.xml没有正确的价值。预期
4242000但发现0您必须在下面的声明
元素:
块引用>您也失踪2 meta标签作为清单文件的应用程序标记
的孩子<应用
机器人:allowBackup =真
机器人:图标=@绘制/ ic_launcher
机器人:标签=@字符串/ APP_NAME
机器人:主题=@风格/ AppTheme>
&所述;元数据
机器人:名字=com.google.android.maps.v2.API_KEY
机器人:价值=你的API密钥/>
&所述;元数据
机器人:名字=com.google.android.gms.version
机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/>
<活动
机器人:名字=com.example.map.MainActivity
机器人:标签=@字符串/ APP_NAME>
&所述;意图滤光器>
<作用机器人:名字=android.intent.action.MAIN/> <类机器人:名字=android.intent.category.LAUNCHER/>
&所述; /意图滤光器>
< /活性GT;
< /用途>
这是正确的,写的Android @整数/ GOOGLE_PLAY_SERVICES_VERSION
值?
块引用>是的。在库项目中的RES /值检查
version.xml
。看起来像下面。<?XML版本=1.0编码=UTF-8&GT?;
<资源>
<整数NAME =GOOGLE_PLAY_SERVICES_VERSION> 4030500< /整数GT;
< /资源>所有你需要做的是参考同
的android:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/>
//这是应该在清单文件的应用程序标记是什么I'm trying to built map app and following this link step by step. I found similar topics in here but didn't help me. I want to show map, but when I run it, it return force close and my android device. I saw a lots of questions about this error but no one really answer to my problem. Here is my LogCat:
03-21 20:55:57.476: D/AndroidRuntime(4090): Shutting down VM 03-21 20:55:57.476: W/dalvikvm(4090): threadid=1: thread exiting with uncaught exception (group=0x417692a0) 03-21 20:55:57.500: E/AndroidRuntime(4090): FATAL EXCEPTION: main 03-21 20:55:57.500: E/AndroidRuntime(4090): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.mapandroid/com.example.mapandroid.MainActivity}: android.view.InflateException: Binary XML file line #11: Error inflating class fragment 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2122) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread.access$600(ActivityThread.java:140) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1228) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.os.Handler.dispatchMessage(Handler.java:99) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.os.Looper.loop(Looper.java:137) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread.main(ActivityThread.java:4895) 03-21 20:55:57.500: E/AndroidRuntime(4090): at java.lang.reflect.Method.invokeNative(Native Method) 03-21 20:55:57.500: E/AndroidRuntime(4090): at java.lang.reflect.Method.invoke(Method.java:511) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761) 03-21 20:55:57.500: E/AndroidRuntime(4090): at dalvik.system.NativeStart.main(Native Method) 03-21 20:55:57.500: E/AndroidRuntime(4090): Caused by: android.view.InflateException: Binary XML file line #11: Error inflating class fragment 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.view.LayoutInflater.inflate(LayoutInflater.java:489) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.example.mapandroid.MainActivity$PlaceholderFragment.onCreateView(MainActivity.java:67) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.Fragment.performCreateView(Fragment.java:1500) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1178) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.Activity.performStart(Activity.java:5173) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2070) 03-21 20:55:57.500: E/AndroidRuntime(4090): ... 11 more 03-21 20:55:57.500: E/AndroidRuntime(4090): Caused by: java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value. Expected 4242000 but found 0. You must have the following declaration within the element: 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.common.GooglePlayServicesUtil.n(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.internal.q.v(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.internal.q.u(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.MapsInitializer.initialize(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.SupportMapFragment$b.ex(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.SupportMapFragment$b.a(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.dynamic.a.a(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.dynamic.a.onInflate(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown Source) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290) 03-21 20:55:57.500: E/AndroidRuntime(4090): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676) 03-21 20:55:57.500: E/AndroidRuntime(4090): ... 24 more 03-21 20:55:57.515: D/dalvikvm(4090): GC_CONCURRENT freed 233K, 10% free 7615K/8455K, paused 13ms+2ms, total 39ms 03-21 21:36:53.375: W/dalvikvm(4279): VFY: unable to resolve static field 3202 (MapAttrs) in Lcom/google/android/gms/R$styleable; 03-21 21:36:53.375: D/dalvikvm(4279): VFY: replacing opcode 0x62 at 0x000e 03-21 21:36:53.375: D/AndroidRuntime(4279): Shutting down VM 03-21 21:36:53.375: W/dalvikvm(4279): threadid=1: thread exiting with uncaught exception (group=0x417692a0) 03-21 21:36:53.382: E/AndroidRuntime(4279): FATAL EXCEPTION: main 03-21 21:36:53.382: E/AndroidRuntime(4279): java.lang.NoClassDefFoundError: com.google.android.gms.R$styleable 03-21 21:36:53.382: E/AndroidRuntime(4279): at com.google.android.gms.maps.GoogleMapOptions.createFromAttributes(Unknown Source) 03-21 21:36:53.382: E/AndroidRuntime(4279): at com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown Source) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.view.LayoutInflater.inflate(LayoutInflater.java:489) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 03-21 21:36:53.382: E/AndroidRuntime(4279): at com.example.map.MainActivity$PlaceholderFragment.onCreateView(MainActivity.java:57) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.Fragment.performCreateView(Fragment.java:1500) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:927) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1178) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.Activity.performStart(Activity.java:5173) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2070) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2122) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.ActivityThread.access$600(ActivityThread.java:140) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1228) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.os.Handler.dispatchMessage(Handler.java:99) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.os.Looper.loop(Looper.java:137) 03-21 21:36:53.382: E/AndroidRuntime(4279): at android.app.ActivityThread.main(ActivityThread.java:4895) 03-21 21:36:53.382: E/AndroidRuntime(4279): at java.lang.reflect.Method.invokeNative(Native Method) 03-21 21:36:53.382: E/AndroidRuntime(4279): at java.lang.reflect.Method.invoke(Method.java:511) 03-21 21:36:53.382: E/AndroidRuntime(4279): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994) 03-21 21:36:53.382: E/AndroidRuntime(4279): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761) 03-21 21:36:53.382: E/AndroidRuntime(4279): at dalvik.system.NativeStart.main(Native Method)and here my MainActivity.java
package com.example.map; import android.support.v4.app.Fragment; import android.support.v4.app.FragmentActivity; import android.os.Bundle; import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; public class MainActivity extends FragmentActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); if (savedInstanceState == null) { getSupportFragmentManager().beginTransaction() .add(R.id.container, new PlaceholderFragment()).commit(); } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } /** * A placeholder fragment containing a simple view. */ public static class PlaceholderFragment extends Fragment { public PlaceholderFragment() { } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View rootView = inflater.inflate(R.layout.fragment_main, container, false); return rootView; } } }here is my activity_main.xml :
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.map.MainActivity" tools:ignore="MergeRootFrame" />
and here is my fragment_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" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context="com.example.map.MainActivity$PlaceholderFragment" > <fragment android:name="com.google.android.gms.maps.SupportMapFragment" android:id="@+id/map" android:layout_width="match_parent" android:layout_height="match_parent" /> </RelativeLayout>
and my manifest :
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.map" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="8" android:targetSdkVersion="19" /> <permission android:name="com.example.map.permission.MAPS_RECEIVE" android:protectionLevel="signature"/> <uses-permission android:name="com.example.map.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"/> <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="0123456789abcde" /> <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.map.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> </application> </manifest>
I've read step by step from that following link, but its seem many error in my code. What I miss? any suggestion? many thanks.
解决方案com.google.android.gms.R$styleable
This is usually due to having not referenced google play services properly
Caused by: java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value. Expected 4242000 but found 0. You must have the following declaration within the element:
You are also missing 2 meta tags as a child of application tag of manifest file
<application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="your api key"/> <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" /> <activity android:name="com.example.map.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> </application>
it is right to write @integer/google_play_services_version in android values?
Yes. Check the
version.xml
in your res/values of library project. Will look like below.<?xml version="1.0" encoding="utf-8"?> <resources> <integer name="google_play_services_version">4030500</integer> </resources>
All you need to do is reference the same as
android:value="@integer/google_play_services_version" /> // this is what should be in the application tag of manifest file
这篇关于Android的谷歌地图V2停止的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!