【问题标题】:Googlemaps v2 'Error inflaing class fragment"谷歌地图 v2 '错误膨胀类片段'
【发布时间】:2014-05-02 11:19:21
【问题描述】:

即使是打开一个简单的地图应用程序(无论是在 AVD 虚拟设备上还是在真正的 Android 手机上),我都遇到了真正的麻烦。使用 Eclipse/ADT 最新安装。

代码或多或少直接来自 GoogleMaps v2 的一本书章节(Wei-Meng Lee / Wrox 的“Android 应用程序开发手册”)。几周前 SSD 发生故障之前,我曾短暂运行过类似的代码。我没有修改书中的代码 - 下载/导入等。其他简单的 helloworld 和其他应用程序在 AVD 等上运行良好。

我有:

  • 添加了 google-play-services-lib
  • 获得了我的 GoogleMapsv2 API 密钥 - 保持包名称不变
  • 在这里和其他地方浏览了大量文章/问题,并比较了代码/检查了错误。

似乎没有任何帮助。在经历了 4 周的挫折之后,我现在请求帮助(如果这是一个简单的错误,可能会得到宽恕!)

我的清单文件内容如下:

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

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

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

<permission
    android:name="net.learn2develop.googlemaps.permission.MAPS_RECEIVE"
    android:protectionLevel="signature" />

<uses-permission android:name="net.learn2develop.googlemaps.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" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="net.learn2develop.googlemaps.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>

    <meta-data
        android:name="com.google.android.maps.v2.API_KEY"
        android:value="my_API_Key_was_put_here"

         />

    <!-- next meta data tag added after consulting stack overflow forums -->

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



</application>

</manifest>

我的布局是这样的:

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

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


</LinearLayout>

我的Mainactivity.java如下。

package net.learn2develop.googlemaps;

import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.MapFragment;
import com.google.android.gms.maps.model.BitmapDescriptorFactory;
import com.google.android.gms.maps.model.CameraPosition;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;
import com.google.android.gms.maps.model.PolylineOptions;

@SuppressWarnings("unused")
public class MainActivity extends FragmentActivity {
GoogleMap map;

private static final LatLng GOLDEN_GATE_BRIDGE = new LatLng(37.828891,
        -122.485884);
private static final LatLng APPLE = new LatLng(37.3325004578, -122.03099823);

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

    // alt is ..map = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map)).getMap();


    map = ((SupportMapFragment) getSupportFragmentManager()
            .findFragmentById(R.id.map)).getMap();
    if (map == null) {
        Toast.makeText(this, "Google Maps not available", 
            Toast.LENGTH_LONG).show();
    }
}

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


@Override
public boolean onOptionsItemSelected(MenuItem item) {

    switch (item.getItemId()) {

    case R.id.menu_sethybrid:
        map.setMapType(GoogleMap.MAP_TYPE_HYBRID);
        break;

    case R.id.menu_showtraffic:
        map.setTrafficEnabled(true);
        break;

    case R.id.menu_zoomin:
        map.animateCamera(CameraUpdateFactory.zoomIn());
        break;

    case R.id.menu_zoomout:
        map.animateCamera(CameraUpdateFactory.zoomOut());
        break;

    case R.id.menu_gotolocation:
        CameraPosition cameraPosition = new CameraPosition.Builder()
                .target(GOLDEN_GATE_BRIDGE) // Sets the center of the map to
                // Golden Gate Bridge
                .zoom(17) // Sets the zoom
                .bearing(90) // Sets the orientation of the camera to east
                .tilt(30) // Sets the tilt of the camera to 30 degrees
                .build(); // Creates a CameraPosition from the builder
        map.animateCamera(CameraUpdateFactory
                .newCameraPosition(cameraPosition));
        break;

    case R.id.menu_addmarker:

        // ---using the default marker---
        /*
         * map.addMarker(new MarkerOptions() .position(GOLDEN_GATE_BRIDGE)
         * .title("Golden Gate Bridge") .snippet("San Francisco")
         * .icon(BitmapDescriptorFactory
         * .defaultMarker(BitmapDescriptorFactory.HUE_AZURE)));
         */

        map.addMarker(new MarkerOptions()
                .position(GOLDEN_GATE_BRIDGE)
                .title("Golden Gate Bridge")
                .snippet("San Francisco")
                .icon(BitmapDescriptorFactory
                        .fromResource(R.drawable.ic_launcher)));
        break;

    case R.id.menu_getcurrentlocation:
        // ---get your current location and display a blue dot---
        map.setMyLocationEnabled(true);

        break;

    case R.id.menu_showcurrentlocation:
        Location myLocation = map.getMyLocation();
        LatLng myLatLng = new LatLng(myLocation.getLatitude(),
                myLocation.getLongitude());

        CameraPosition myPosition = new CameraPosition.Builder()
                .target(myLatLng).zoom(17).bearing(90).tilt(30).build();
        map.animateCamera(CameraUpdateFactory.newCameraPosition(myPosition));

        break;

    case R.id.menu_lineconnecttwopoints:
        // ---add a marker at Apple---
        map.addMarker(new MarkerOptions()
                .position(APPLE)
                .title("Apple")
                .snippet("Cupertino")
                .icon(BitmapDescriptorFactory
                        .defaultMarker(BitmapDescriptorFactory.HUE_AZURE)));

        // ---draw a line connecting Apple and Golden Gate Bridge---
        map.addPolyline(new PolylineOptions()
                .add(GOLDEN_GATE_BRIDGE, APPLE).width(5).color(Color.RED));
        break;
    }

    return true;
}
}

我真的认为在在这里寻求帮助之前我已经尝试了所有方法。 (我曾经在 1980 年代初手写 Z80 汇编代码并将其手动转换为十六进制 - 与此相比,这太简单了......)

非常感谢你们的帮助!

稍后添加 - 这是我的错误日志

    05-02 07:33:32.177: I/Google Maps Android API(1058): Google Play services client version: 4323000
05-02 07:33:32.217: I/Google Maps Android API(1058): Google Play services package version: 4324036
05-02 07:33:32.267: D/dalvikvm(1058): GC_FOR_ALLOC freed 235K, 9% free 3150K/3452K, paused 27ms, total 28ms
05-02 07:33:32.357: D/AndroidRuntime(1058): Shutting down VM
05-02 07:33:32.357: W/dalvikvm(1058): threadid=1: thread exiting with uncaught exception (group=0xb1ae4ba8)
05-02 07:33:32.377: E/AndroidRuntime(1058): FATAL EXCEPTION: main
05-02 07:33:32.377: E/AndroidRuntime(1058): Process: net.learn2develop.googlemaps, PID: 1058
05-02 07:33:32.377: E/AndroidRuntime(1058): java.lang.RuntimeException: Unable to start activity ComponentInfo{net.learn2develop.googlemaps/net.learn2develop.googlemaps.MainActivity}: android.view.InflateException: Binary XML file line #6: Error inflating class fragment
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread.access$800(ActivityThread.java:135)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.os.Handler.dispatchMessage(Handler.java:102)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.os.Looper.loop(Looper.java:136)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread.main(ActivityThread.java:5017)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at java.lang.reflect.Method.invokeNative(Native Method)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at java.lang.reflect.Method.invoke(Method.java:515)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at dalvik.system.NativeStart.main(Native Method)
05-02 07:33:32.377: E/AndroidRuntime(1058): Caused by: android.view.InflateException: Binary XML file line #6: Error inflating class fragment
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:755)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.inflate(LayoutInflater.java:492)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.Activity.setContentView(Activity.java:1929)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at net.learn2develop.googlemaps.MainActivity.onCreate(MainActivity.java:32)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.Activity.performCreate(Activity.java:5231)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
05-02 07:33:32.377: E/AndroidRuntime(1058):     ... 11 more
05-02 07:33:32.377: E/AndroidRuntime(1058): Caused by: java.lang.SecurityException: The Maps API requires the additional following permissions to be set in the AndroidManifest.xml to ensure a correct behavior:
05-02 07:33:32.377: E/AndroidRuntime(1058): <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.ci.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.ay.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.ay.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.al.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.bh.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at maps.e.bg.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at etu.onTransact(SourceFile:107)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.os.Binder.transact(Binder.java:361)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.maps.internal.IMapFragmentDelegate$a$a.onCreateView(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.maps.SupportMapFragment$a.onCreateView(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.dynamic.a$4.b(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.dynamic.a.a(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.dynamic.a.onCreateView(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at com.google.android.gms.maps.SupportMapFragment.onCreateView(Unknown Source)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.support.v4.app.Fragment.performCreateView(Fragment.java:1460)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:884)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1066)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.support.v4.app.FragmentManagerImpl.addFragment(FragmentManager.java:1168)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:280)
05-02 07:33:32.377: E/AndroidRuntime(1058):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
05-02 07:33:32.377: E/AndroidRuntime(1058):     ... 21 more

【问题讨论】:

  • 授予访问网络状态权限,然后检查并告诉我

标签: android eclipse google-maps fragment


【解决方案1】:

05-02 07:33:32.377: E/AndroidRuntime(1058): 由: java.lang.SecurityException:地图 API 需要额外的 在 AndroidManifest.xml 中设置以下权限以确保 正确行为:05-02 07:33:32.377:E/AndroidRuntime(1058):

你不见了

<uses-permission
android:name="android.permission.ACCESS_NETWORK_STATE"/>

在清单文件中

你有

 android:minSdkVersion="19"

你需要改变这个

 public class MainActivity extends FragmentActivity {

到 公共类 MainActivity 扩展 Activity {

你需要使用 MapFragment

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

也需要改变

 map = ((MapFragment) getFragmentManager()
        .findFragmentById(R.id.map)).getMap();

你也不需要

<permission
android:name="net.learn2develop.googlemaps.permission.MAPS_RECEIVE"
android:protectionLevel="signature" />
<uses-permission android:name="net.learn2develop.googlemaps.permission.MAPS_RECEIVE" />

【讨论】:

  • 你确定@raghunandan
  • @sakir developers.google.com/maps/documentation/android/…。您可以检查文档,如果有错误请纠正我
  • 他已经被声明为“class="com.google.android.gms.maps.SupportMapFragment"
  • @sakir 应该是MapFragment。请再次检查文档。 MapFragment 用于 api 级别 12 及以上。 op有SupportMapFragmentclass="com.google.android.gms.maps.SupportMapFragment
  • 哎呀。在问题末尾添加了我的错误日志。之前尝试过 MapFragment,但如果我做得不对,会再试一次。让我感到困惑的是,我之前有代码工作过——也许是针对不同的 API 目标——它有那么大的不同吗?? 8 小时打字后,我会先得到一些空气!再次感谢
猜你喜欢
  • 2012-12-14
  • 1970-01-01
  • 2014-07-26
  • 2013-07-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多