0

我想用下面的例子,但是當我啓動它,我得到這些錯誤:二進制XML文件行#14:錯誤充氣類片段 - 地圖V2

例如鏈接:

http://wptrafficanalyzer.in/blog/driving-distance-and-travel-time-duration-between-two-locations-in-google-map-android-api-v2/

在MainActivity

> 09-03 12:46:33.936: E/AndroidRuntime(15207): FATAL EXCEPTION: main 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): 
> java.lang.RuntimeException: Unable to start activity 
> ComponentInfo{in.wptrafficanalyzer.locationdistancetimemapv2/in.wptrafficanalyzer.locationdistancetimemapv2.MainActivity}: 
> android.view.InflateException: Binary XML file line #14: Error 
> inflating class fragment 09-03 12:46:33.936: E/AndroidRuntime(15207): 
> at 
> android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2247) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2297) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.ActivityThread.access$700(ActivityThread.java:152) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.ActivityThread$H.handleMessage(ActivityThread.java:1282) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.os.Handler.dispatchMessage(Handler.java:99) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.os.Looper.loop(Looper.java:137) 09-03 12:46:33.936: 
> E/AndroidRuntime(15207): at 
> android.app.ActivityThread.main(ActivityThread.java:5328) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> java.lang.reflect.Method.invokeNative(Native Method) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> java.lang.reflect.Method.invoke(Method.java:511) 09-03 12:46:33.936: 
> E/AndroidRuntime(15207): at 
> com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> dalvik.system.NativeStart.main(Native Method) 09-03 12:46:33.936: 
> E/AndroidRuntime(15207): Caused by: android.view.InflateException: 
> Binary XML file line #14: Error inflating class fragment 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:710) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.rInflate(LayoutInflater.java:752) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.inflate(LayoutInflater.java:495) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.inflate(LayoutInflater.java:397) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.inflate(LayoutInflater.java:353) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:327) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.Activity.setContentView(Activity.java:1928) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> in.wptrafficanalyzer.locationdistancetimemapv2.MainActivity.onCreate(MainActivity.java:42) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.Activity.performCreate(Activity.java:5250) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1097) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): ... 11 more 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): Caused by: 
> java.lang.IllegalStateException: The meta-data tag in your app's 
> AndroidManifest.xml does not have the right value. Expected 5089000 
> 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" /> 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.common.GooglePlayServicesUtil.A(Unknown Source) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.common.GooglePlayServicesUtil.isGooglePlayServicesAvailable(Unknown 
> Source) 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.internal.u.I(Unknown Source) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.internal.u.H(Unknown Source) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.MapsInitializer.initialize(Unknown Source) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.SupportMapFragment$b.jz(Unknown Source) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.SupportMapFragment$b.a(Unknown Source) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.dynamic.a.a(Unknown Source) 09-03 12:46:33.936: 
> E/AndroidRuntime(15207): at 
> com.google.android.gms.dynamic.a.onInflate(Unknown Source) 09-03 
> 12:46:33.936: E/AndroidRuntime(15207): at 
> com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown 
> Source) 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:279) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): at 
> android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:682) 
> 09-03 12:46:33.936: E/AndroidRuntime(15207): ... 21 more 
在我的佈局XML

SupportMapFragment fm = 
(SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map); 

我的manifest.xml:

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

    <permission 
     android:name="info.androidhive.googlemapsv2.permission.MAPS_RECEIVE" 
     android:protectionLevel="signature" /> 

    <uses-permission android:name="info.androidhive.googlemapsv2.permission.MAPS_RECEIVE" /> 

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

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

    <!-- Required to show current location --> 
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> 
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> 

    <!-- Required OpenGL ES 2.0. for Maps V2 --> 
    <uses-feature 
     android:glEsVersion="0x00020000" 
     android:required="true" /> 

    <!-- Requires OpenGL ES version 2 --> 
    <uses-feature 
     android:glEsVersion="0x00020000" 
     android:required="true" /> 

    <application 
     android:allowBackup="true" 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name"> 
     <activity 
      android:name="info.androidhive.googlemapsv2.MainActivity" 
      android:label="@string/app_name" 
      android:theme="@style/AppBaseTheme"> 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 

       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 

     <!-- Goolge API Key --> 
     <meta-data 
      android:name="com.google.android.maps.v2.API_KEY" 
      android:value="AIzaSyBZ*****9p6wksdax4TEjDVLgo" /> 
    </application> 

</manifest> 

更新:

我添加下面的代碼到manifest.xml中:

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

,我改變了片段元素來自:

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

到:

<fragment 
    android:name="com.google.android.gms.maps.SupportMapFragment" 
    xmlns:map="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/map" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_below="@id/tv_distance_time"/> 

我的項目運行,但我看不到我的屏幕上任何地圖(我測試了它的真實設備上)。

09-03 14:17:26.206: E/dalvikvm(8462): Could not find class 'gpq', referenced from method gpr.a 
09-03 14:17:26.206: E/dalvikvm(8462): Could not find class 'gpq', referenced from method gpr.a 
09-03 14:17:26.206: E/dalvikvm(8462): Could not find class 'gpq', referenced from method gpr.a 
09-03 14:17:26.776: E/dalvikvm(8462): Could not find class 'com.google.android.gms.location.internal.ParcelableGeofence', referenced from method gls.a 
09-03 14:17:43.591: E/Google Maps Android API(8462): Failed to load map. Error contacting Google servers. This is probably an authentication issue (but could be due to network errors). 
+0

後您的清單。 – Simas 2014-09-03 08:24:36

+0

添加了我的manifest.xml – 2014-09-03 08:25:54

+0

你鏈接了所需的'.jar's嗎? – bhargavg 2014-09-03 08:25:58

回答

3

您需要更改片段在佈局文件:

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

這幾乎顯然是錯誤陳述來自:

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

T ○:

<fragment 
    android:name="com.google.android.gms.maps.SupportMapFragment" 
    xmlns:map="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/map" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" /> 

取之間的差別了仔細看:class="com.google.android.gms.maps.SupportMapFragment"

和:

android:name="com.google.android.gms.maps.SupportMapFragment" 

也去了這個博客帖子我就這個話題寫,並確保您不會錯過任何類似於您在您中錯過的mata-data部分清單xml文件,從您收到的錯誤中可以明顯看出:

Google Maps API V2 Guide

UPDATE:

你必須在manifest文件的雙重許可:

<!-- Required OpenGL ES 2.0. for Maps V2 --> 
<uses-feature 
    android:glEsVersion="0x00020000" 
    android:required="true" /> 

<!-- Requires OpenGL ES version 2 --> 
<uses-feature 
    android:glEsVersion="0x00020000" 
    android:required="true" /> 

您應該刪除其中的一個。 並且您沒有理由使用SupportMapFragment,因爲您正在爲API編寫高於11的應用程序。因此,只需使用MapFragment,並對Activity進行相關更改。

+0

解決了,但我無法在我的屏幕上看到任何地圖。 (我正在真實設備上測試它)。 – 2014-09-03 09:22:11

+0

@ S.M_Emamian看看我已經更新了我的回答 – GrIsHu 2014-09-03 09:29:51

+0

你有沒有讀過我的所有博客文章? – 2014-09-03 09:30:40

1

你缺少這個元標記在你的清單:

> java.lang.IllegalStateException: The meta-data tag in your app's 
> AndroidManifest.xml does not have the right value. Expected 5089000 
> 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" /> 09-03 
+0

更新了我的帖子。 – 2014-09-03 09:43:45

0

只需在您的AndroidManifest.xml文件中<application>標籤

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

如果你想要得到的GoogleMap的,那麼你可以按照以下初始化它來訪問它,在你的應用程序中加載它下面添加一行。

更改你的下面的代碼行:

SupportMapFragment fm = 
(SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map); 

private GoogleMap mMap; 
mMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)) 
       .getMap(); 
+0

發佈5分鐘前已發佈的答案有什麼意義? – 2014-09-03 08:30:22

+0

不是我的回答,@ user3249477在你做完5分鐘之前已經指出了這個解決方案。實際上,我的答案也包含了這一點。更詳細地說,如果你訪問博客。但是這與你發佈已經寫好的答案無關。 – 2014-09-03 08:42:11

+0

嘗試使用'mMap =((MapFragment)getFragmentManager()。findFragmentById(R.id.map))。getMap();'檢查我的答案。 – GrIsHu 2014-09-03 09:31:35

相關問題