【问题标题】:Google Maps Error Inflating Class Fragment Android谷歌地图错误膨胀类片段Android
【发布时间】:2016-05-14 02:57:18
【问题描述】:

我一直在网上搜索,似乎找不到适合我的答案。我最近在 Android Simulator 中做了一个新项目,并选择了 Google Maps Template。我按照https://developers.google.com/maps/documentation/android-api/start 的说明进行操作,以确保我第一次做对了所有事情。让我丢脸的是,我得到了同样的错误。

首先,这是我的MapsActivity.java:

import android.support.v4.app.FragmentActivity;
import android.os.Bundle;

import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;

public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {

    private GoogleMap mMap;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_maps);
        // Obtain the SupportMapFragment and get notified when the map is ready to be used.
        SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
                .findFragmentById(R.id.map);
        mapFragment.getMapAsync(this);
    }


    /**
     * Manipulates the map once available.
     * This callback is triggered when the map is ready to be used.
     * This is where we can add markers or lines, add listeners or move the camera. In this case,
     * we just add a marker near Sydney, Australia.
     * If Google Play services is not installed on the device, the user will be prompted to install
     * it inside the SupportMapFragment. This method will only be triggered once the user has
     * installed Google Play services and returned to the app.
     */
    @Override
    public void onMapReady(GoogleMap googleMap) {
        mMap = googleMap;

        // Add a marker in Sydney and move the camera
        LatLng sydney = new LatLng(-34, 151);
        mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
        mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
    }
}

其次,我的activity_maps.xml:

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

最后,我的错误:

05-13 19:47:40.542 3052-3052/com.xenicdev.mapstest E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.xenicdev.mapstest, PID: 3052
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.xenicdev.mapstest/com.xenicdev.mapstest.MapsActivity}: android.view.InflateException: Binary XML file line #1: Binary XML file line #1: Error inflating class fragment
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
at android.app.ActivityThread.-wrap11(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
 Caused by: android.view.InflateException: Binary XML file line #1: Binary XML file line #1: Error inflating class fragment
 at android.view.LayoutInflater.inflate(LayoutInflater.java:539)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
 at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:393)
 at android.app.Activity.setContentView(Activity.java:2166)
 at com.xenicdev.mapstest.MapsActivity.onCreate(MapsActivity.java:20)
 at android.app.Activity.performCreate(Activity.java:6237)
 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)
 at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 
 at android.app.ActivityThread.-wrap11(ActivityThread.java) 
 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 
 at android.os.Handler.dispatchMessage(Handler.java:102) 
 at android.os.Looper.loop(Looper.java:148) 
 at android.app.ActivityThread.main(ActivityThread.java:5417) 
 at java.lang.reflect.Method.invoke(Native Method) 
 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
 Caused by: android.view.InflateException: Binary XML file line #1: Error inflating class fragment
 at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:782)
 at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
 at android.view.LayoutInflater.inflate(LayoutInflater.java:423) 
 at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
 at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:393) 
 at android.app.Activity.setContentView(Activity.java:2166) 
 at com.xenicdev.mapstest.MapsActivity.onCreate(MapsActivity.java:20) 
 at android.app.Activity.performCreate(Activity.java:6237) 
 at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 
 at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 
 at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 
 at android.app.ActivityThread.-wrap11(ActivityThread.java) 
 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 
 at android.os.Handler.dispatchMessage(Handler.java:102) 
 at android.os.Looper.loop(Looper.java:148) 
 at android.app.ActivityThread.main(ActivityThread.java:5417) 
 at java.lang.reflect.Method.invoke(Native Method) 
 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
 Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'boolean java.io.File.mkdir()' on a null object reference
 at com.google.maps.api.android.lib6.gmm6.m.ad.a(Unknown Source)
 at com.google.maps.api.android.lib6.gmm6.c.h.a(Unknown Source)
 at com.google.maps.api.android.lib6.gmm6.c.y.a(Unknown Source)
 at com.google.maps.api.android.lib6.e.bd.a(Unknown Source)
 at com.google.maps.api.android.lib6.e.ev.a(Unknown Source)
 at com.google.maps.api.android.lib6.e.z.a(Unknown Source)
 at com.google.maps.api.android.lib6.e.y.a(Unknown Source)
 at com.google.android.gms.maps.internal.u.onTransact(SourceFile:107)
 at android.os.Binder.transact(Binder.java:387)
 at com.google.android.gms.maps.internal.IMapFragmentDelegate$zza$zza.onCreateView(Unknown Source)
 at com.google.android.gms.maps.SupportMapFragment$zza.onCreateView(Unknown Source)
 at com.google.android.gms.dynamic.zza$4.zzb(Unknown Source)
 at com.google.android.gms.dynamic.zza.zza(Unknown Source)
 at com.google.android.gms.dynamic.zza.onCreateView(Unknown Source)
 at com.google.android.gms.maps.SupportMapFragment.onCreateView(Unknown Source)
 at android.support.v4.app.Fragment.performCreateView(Fragment.java:1974)
 at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1036)
 at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1230)
 at android.support.v4.app.FragmentManagerImpl.addFragment(FragmentManager.java:1332)
 at android.support.v4.app.FragmentManagerImpl.onCreateView(FragmentManager.java:2288)
 at android.support.v4.app.FragmentController.onCreateView(FragmentController.java:120)
 at android.support.v4.app.FragmentActivity.dispatchFragmentsOnCreateView(FragmentActivity.java:356)
 at android.support.v4.app.BaseFragmentActivityHoneycomb.onCreateView(BaseFragmentActivityHoneycomb.java:31)
 at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:79)
 at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:754)
 ... 19 mo

【问题讨论】:

  • 您是否尝试过清理并重建项目?
  • 分享你的活动布局文件
  • 没有其他布局文件。我只有这个项目中的模板文件。它仍然应该工作。
  • 是的,我确实清理并重建了项目。

标签: java android google-maps android-fragments inflate-exception


【解决方案1】:

我有同样的问题,但对我来说这是因为我把

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

<meta-data
    android:name="com.google.android.geo.API_KEY"
    android:value="@string/google_maps_key" />

在我的清单中的 &lt;/application&gt; 标记之外。一旦我把它移到里面,这个错误就消失了。

【讨论】:

    【解决方案2】:

    好的,我以前有时也遇到过同样类型的错误。但是我实现的不是使用SupportMapFragment,而是使用下面的这段代码。

    MapFragment mapFragment = (MapFragment)getFragmentManager().findFragmentById(R.id.map);
    mapFragment.getMapAsync(this);
    

    我更改了我的 activity_maps.xml。而是使用这个;

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

    使用这个

     class="com.google.android.gms.maps.MapFragment"
    

    希望它能解决问题。如果您需要更多帮助,可以使用 googlemap 应用程序与我联系以获取详细信息。刚刚完成了一个简单的构建。

    【讨论】:

      【解决方案3】:

      我查看了错误信息,发现API_KEY的标签应该修改为:

      <meta-data android:name="com.google.android.geo.API_KEY" 
      android:value="your api key"/>
      

      【讨论】:

      • 我检查了好几次。
      【解决方案4】:

      XML 错误。你应该使用

       class="com.google.android.gms.maps.SupportMapFragment"
      

      不是

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

      【讨论】:

      • 不幸的是,这并没有解决问题。我试过了,我得到了同样的错误。
      【解决方案5】:

      除了在 Google API 更新后,我创建了一个可以正常工作的新项目之外,我还没有找到真正解决问题的方法。我无法解释导致此错误的原因是什么,但发现对我来说唯一的解决方法是等待下一次 Google API 更新并开始一个新项目。

      【讨论】:

      • 你能告诉我哪个 API 版本运行得很好吗?
      • 老实说,我不能,因为那是很久以前的事了。从那以后我再也没有遇到过这个问题,所以最新版本应该可以工作。
      • 我通过从清单文件中删除映射键解决了这个问题。我不知道如果我们使用 geo.API_KEY 我们也不需要使用 MAP_KEY。所以从清单中删除地图键解决了我的问题。无论如何,谢谢。
      猜你喜欢
      • 2013-07-02
      • 2012-12-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多