Android版谷歌地图V2崩溃的启动地图、Android、版谷歌

2023-09-07 02:33:58 作者:独自停留此刻寂寞

在我的Andr​​oid应用程序支持2.2及以上版本,我想使用谷歌地图API V2。

我有这个至今:

有谁知道问题是什么?

感谢。

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    工具:上下文=。Activity_Map>    <片段         机器人:ID =@ + ID /图         机器人:layout_width =match_parent         机器人:layout_height =match_parent         类=com.google.android.gms.maps.SupportMapFragment/>< / RelativeLayout的> 

Java的

 进口com.google.android.gms.maps.GoogleMap;进口com.google.android.gms.maps.SupportMapFragment;进口android.location.Geo codeR;进口android.os.Bundle;进口android.support.v4.app.FragmentActivity;进口android.view.Menu;公共类Activity_Map扩展FragmentActivity {    GoogleMap的地图= NULL;    地理codeR codeR;    @覆盖    保护无效的onCreate(捆绑savedInstanceState){        super.onCreate(savedInstanceState);        的setContentView(R.layout.activity_map);        地图=((SupportMapFragment)getSupportFragmentManager()findFragmentById(R.id.map)。)的GetMap();        codeR =新的地缘codeR(本);    }    @覆盖    公共布尔onCreateOptionsMenu(菜单菜单){        //充气菜单;如果是present这增加了项目操作栏。        。getMenuInflater()膨胀(R.menu.activity_map,菜单);        返回true;    }} 
像iOS版靠拢 Android版Google Maps更新

清单

 <许可    机器人:名字=sord.common.permission.MAPS_RECEIVE    安卓的ProtectionLevel =签名/><使用许可权的android:NAME =sord.common.permission.MAPS_RECEIVE/><使用许可权的android:NAME =android.permission.INTERNET对/><使用许可权的android:NAME =android.permission.CALL_PHONE/><使用许可权的android:NAME =android.permission.ACCESS_COARSE_LOCATION/><使用许可权的android:NAME =android.permission.ACCESS_NETWORK_STATE/><使用许可权的android:NAME =android.permission.WRITE_EXTERNAL_STORAG​​E/><使用许可权的android:NAME =com.google.android.providers.gsf.permission.READ_GSERVICES/><用途特征    机器人:glEsVersion =0x00020000    机器人:要求=真/><用途-SDK    安卓的minSdkVersion =8    机器人:targetSdkVersion =19/><应用    机器人:allowBackup =真    机器人:图标=@绘制/ ic_launcher    机器人:标签=@字符串/ APP_NAME    机器人:主题=@风格/ AppTheme>    <活动        机器人:名字=sord.ids_connect.Activity_Login        机器人:标签=@字符串/ APP_NAME        机器人:screenOrientation =画像        机器人:windowSoftInputMode =adjustResize | stateHidden>        &所述;意图滤光器>            <作用机器人:名字=android.intent.action.MAIN/>            <类机器人:名字=android.intent.category.LAUNCHER/>        &所述; /意图滤光器>    < /活性GT;    <活动        机器人:名字=sord.ids_connect.Activity_Menu        机器人:标签=@字符串/ title_activity_menu        机器人:screenOrientation =画像        机器人:主题=@风格/ Theme.AppCompat.Light.DarkActionBar>    < /活性GT;    <活动        机器人:名字=sord.ids_connect.Activity_Profile        机器人:标签=@字符串/ title_activity_profile        机器人:screenOrientation =画像        机器人:主题=@风格/ Theme.AppCompat.Light.DarkActionBar>    < /活性GT;    <活动        机器人:名字=sord.ids_connect.Activity_Map        机器人:screenOrientation =画像        机器人:标签=@字符串/ title_activity_map        机器人:主题=@安卓风格/ Theme.NoTitleBar>    < /活性GT;    &所述;元数据        机器人:名字=com.google.android.maps.v2.API_KEY        机器人:值=MY-KEY/>< /用途> 

崩溃日志

  22 12-29:44:58.103:E / AndroidRuntime(7331):致命异常:主要12-29 22:44:58.103:E / AndroidRuntime(7331):了java.lang.RuntimeException:无法启动活动ComponentInfo {sord.ids_connect / sord.ids_connect.Activity_Map}:android.view.InflateException:二进制XML文件中的行# 11:错误充气类片段12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread.access $ 700(ActivityThread.java:143)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1241)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.os.Handler.dispatchMessage(Handler.java:99)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.os.Looper.loop(Looper.java:137)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread.main(ActivityThread.java:4950)12-29 22:44:58.103:E / AndroidRuntime(7331):在java.lang.reflect.Method.invokeNative(本机方法)12-29 22:44:58.103:E / AndroidRuntime(7331):在java.lang.reflect.Method.invoke(Method.java:511)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:1004)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)12-29 22:44:58.103:E / AndroidRuntime(7331):在dalvik.system.NativeStart.main(本机方法)12-29 22:44:58.103:E / AndroidRuntime(7331):android.view.InflateException:二进制XML文件行#11:错误充气类片段产生的原因12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.rInflate(LayoutInflater.java:746)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.inflate(LayoutInflater.java:489)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.inflate(LayoutInflater.java:396)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.inflate(LayoutInflater.java:352)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:316)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.Activity.setContentView(Activity.java:1915)12-29 22:44:58.103:E / AndroidRuntime(7331):在sord.ids_connect.Activity_Map.onCreate(Activity_Map.java:18)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.Activity.performCreate(Activity.java:5177)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2074)12-29 22:44:58.103:E / AndroidRuntime(7331):11 ...更多12-29 22:44:58.103:E / AndroidRuntime(7331):java.lang.IllegalStateException:在应用的Andr​​oidManifest.xml中的元数据标签没有正确的价值所致。预计4030500但发现0您必须在&lt中的以下声明;用途>元素:其中,元数据机器人:名字=com.google.android.gms.version机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/>12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.common.GooglePlayServicesUtil.n(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.internal.q.v(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.internal.q.u(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.MapsInitializer.initialize(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.SupportMapFragment $ b.cE(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.SupportMapFragment $ b.a(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.dynamic.a.a(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.dynamic.a.onInflate(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在com.google.android.gms.maps.SupportMapFragment.onInflate(来源不明)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290)12-29 22:44:58.103:E / AndroidRuntime(7331):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)12-29 22:44:58.103:E / AndroidRuntime(7331):21 ...更多 

解决方案

这刚下&LT添加到您的清单,马塔数据/> 以上< /用途>

 <元数据机器人:名字=com.google.android.gms.version机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/> 

日志猫是明确的给你,它可以确定问题是:

  java.lang.IllegalStateException:在应用的Andr​​oidManifest.xml中的元数据标签没有正确的价值。预计4030500但发现0您必须在&lt中的以下声明;用途>元素:其中,元数据机器人:名字=com.google.android.gms.version机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/> 

告诉我,如果它的工作,快乐的节目

In my android app supporting 2.2 and higher, I am trying to use the google maps api v2.

I have this so far:

Does anyone know what the issue is?

Thanks.

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=".Activity_Map" >

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

</RelativeLayout>

java

import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import android.location.Geocoder;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.view.Menu;

public class Activity_Map extends FragmentActivity {

    GoogleMap map = null;
    Geocoder coder;

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

        map = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();
        coder = new Geocoder(this);
    }

    @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_map, menu);
        return true;
    }

}

Manifest

<permission
    android:name="sord.common.permission.MAPS_RECEIVE"
    android:protectionLevel="signature" />

<uses-permission android:name="sord.common.permission.MAPS_RECEIVE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />

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

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

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="sord.ids_connect.Activity_Login"
        android:label="@string/app_name"
        android:screenOrientation="portrait"
        android:windowSoftInputMode="adjustResize|stateHidden" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name="sord.ids_connect.Activity_Menu"
        android:label="@string/title_activity_menu"
        android:screenOrientation="portrait"
        android:theme="@style/Theme.AppCompat.Light.DarkActionBar" >
    </activity>
    <activity
        android:name="sord.ids_connect.Activity_Profile"
        android:label="@string/title_activity_profile"
        android:screenOrientation="portrait"
        android:theme="@style/Theme.AppCompat.Light.DarkActionBar" >
    </activity>
    <activity
        android:name="sord.ids_connect.Activity_Map"
        android:screenOrientation="portrait"
        android:label="@string/title_activity_map"
        android:theme="@android:style/Theme.NoTitleBar" >
    </activity>

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

CRASH LOG

12-29 22:44:58.103: E/AndroidRuntime(7331): FATAL EXCEPTION: main
12-29 22:44:58.103: E/AndroidRuntime(7331): java.lang.RuntimeException: Unable to start activity ComponentInfo{sord.ids_connect/sord.ids_connect.Activity_Map}: android.view.InflateException: Binary XML file line #11: Error inflating class fragment
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2110)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2135)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread.access$700(ActivityThread.java:143)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1241)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.os.Handler.dispatchMessage(Handler.java:99)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.os.Looper.loop(Looper.java:137)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread.main(ActivityThread.java:4950)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at java.lang.reflect.Method.invokeNative(Native Method)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at java.lang.reflect.Method.invoke(Method.java:511)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at dalvik.system.NativeStart.main(Native Method)
12-29 22:44:58.103: E/AndroidRuntime(7331): Caused by: android.view.InflateException: Binary XML file line #11: Error inflating class fragment
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:316)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.Activity.setContentView(Activity.java:1915)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at sord.ids_connect.Activity_Map.onCreate(Activity_Map.java:18)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.Activity.performCreate(Activity.java:5177)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2074)
12-29 22:44:58.103: E/AndroidRuntime(7331):     ... 11 more
12-29 22:44:58.103: E/AndroidRuntime(7331): Caused by: java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value.  Expected 4030500 but found 0.  You must have the following declaration within the <application> element:     <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.common.GooglePlayServicesUtil.n(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.internal.q.v(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.internal.q.u(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.MapsInitializer.initialize(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.SupportMapFragment$b.cE(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.SupportMapFragment$b.a(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.dynamic.a.a(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.dynamic.a.onInflate(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown Source)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:290)
12-29 22:44:58.103: E/AndroidRuntime(7331):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:676)
12-29 22:44:58.103: E/AndroidRuntime(7331):     ... 21 more

解决方案

add this to your manifest just under the <mata-data /> and above </application>

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

The log-cat was clear to you, it identified the problem as:

java.lang.IllegalStateException: The meta-data tag in your app's AndroidManifest.xml does not have the right value.  Expected 4030500 but found 0.  You must have the following declaration within the <application> element:     <meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />

inform me if it worked, happy programming