繁体   English   中英

谷歌地图错误膨胀类片段Android

[英]Google Maps Error Inflating Class Fragment Android

我一直在网上搜索,似乎找不到适合我的答案。 我最近在 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

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

<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" />

在我的清单中的</application>标签之外。 一旦我把它移到里面,那个错误就消失了。

好的,我有时也遇到过同样类型的错误。 但是我实现的不是使用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应用程序与我联系以获取详细信息。 刚刚完成了一个简单的构建。

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

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

XML 是错误的。 你应该使用

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

不是

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

除了在 Google API 更新后,我创建了一个有效的新项目之外,我还没有找到解决问题的真正答案。 我无法解释此错误的原因,但发现对我来说唯一的解决方法是等待下一次 Google API 更新并启动一个新项目。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM