Android的谷歌地图V2停止 [英] Android Google Map V2 Stopped

查看:189
本文介绍了Android的谷歌地图V2停止的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我试图建立地图应用程序并按照此链接一步一步。我发现了类似的主题这里,但没有帮助我。我想说明的地图,但是当我运行它,它返回部队密切和我的Andr​​oid设备。我看到了很多关于这个错误的问题,但没有人真正回答我的问题。这里是我的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:在应用的Andr​​oidManifest.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:机器人=htt​​p://schemas.android.com/apk/res/android
的xmlns:工具=htt​​p://schemas.android.com/tool​​s
机器人:ID =@ + ID /容器
机器人:layout_width =match_parent
机器人:layout_height =match_parent
工具:上下文=com.example.map.MainActivity
工具:忽略=MergeRootFrame/>

和这里是我的fragment_main.xml

 <的RelativeLayout的xmlns:机器人=htt​​p://schemas.android.com/apk/res/android
的xmlns:工具=htt​​p://schemas.android.com/tool​​s
机器人:layout_width =match_parent
机器人:layout_height =match_parent
机器人:paddingBottom会=@扪/ activity_vertical_margin
机器人:paddingLeft =@扪/ activity_horizo​​ntal_margin
机器人:paddingRight =@扪/ activity_horizo​​ntal_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:机器人=htt​​p://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_STORAG​​E/>
<使用许可权的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:在元数据标签的
  应用的Andr​​oidManifest.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;
 < /用途>


  

这是正确的,写的Andr​​oid @整数/ 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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆