Android上的简单地图应用程序(API谷歌V2)。不工作。错误 [英] Simple map app on Android(google api v2). Doesnt work. Error

查看:133
本文介绍了Android上的简单地图应用程序(API谷歌V2)。不工作。错误的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我尝试编写Android上的一个简单的地图应用程序,但唯一的结果是错误的。我想它的方式应该是程序,但它仍然无法正常工作。

mainactivity

 包com.example.guidebook;进口android.os.Bundle;
进口android.app.Activity;
进口android.view.Menu;公共类GuidebookActivity延伸活动{    @覆盖
     保护无效的onCreate(捆绑savedInstanceState){
      super.onCreate(savedInstanceState);
      的setContentView(R.layout.guidebook);
     }    @覆盖
    公共布尔onCreateOptionsMenu(菜单菜单){
        //充气菜单;如果是present这增加了项目操作栏。
        。getMenuInflater()膨胀(R.menu.guidebook,菜单);
        返回true;
    }}

的.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
    工具:上下文=MainActivity。>    <的TextView
        机器人:layout_width =WRAP_CONTENT
        机器人:layout_height =WRAP_CONTENT
        机器人:layout_centerHorizo​​ntal =真
        机器人:layout_centerVertical =真
        机器人:文字=@字符串/参考hello world/>
    <片段
        机器人:ID =@ + ID /图
        机器人:layout_width =match_parent
        机器人:layout_height =match_parent
        类=com.google.android.gms.maps.MapFragment/>< / RelativeLayout的>

清单

 <?XML版本=1.0编码=UTF-8&GT?;
<清单的xmlns:机器人=htt​​p://schemas.android.com/apk/res/android
    包=com.example.guidebook
    安卓版code =1
    机器人:=的versionName1.0>    <用途-SDK
        安卓的minSdkVersion =8
        机器人:targetSdkVersion =19/>
   <许可
       机器人:名字=com.example.guidebook.permission.MAPS_RECEIVE
       安卓的ProtectionLevel =签名/>  <使用许可权的android:NAME =com.example.guidebook.permission.MAPS_RECEIVE/>
  <使用许可权的android:NAME =android.permission.ACCESS_NETWORK_STATE/>
  <使用许可权的android:NAME =android.permission.INTERNET对/>
  <使用许可权的android:NAME =com.google.android.providers.gsf.permission.READ_GSERVICES/>
  <使用许可权的android:NAME =android.permission.WRITE_EXTERNAL_STORAG​​E/>
  <使用许可权的android:NAME =android.permission.ACCESS_COARSE_LOCATION/>
  <使用许可权的android:NAME =android.permission.ACCESS_FINE_LOCATION/>
  <! - Maps API需要OpenGL ES 2.0的。 - >
  <用途特征
    机器人:glEsVersion =0x00020000
    机器人:要求=真/>    <应用
        机器人:allowBackup =真
        机器人:图标=@绘制/ ic_launcher
        机器人:标签=@字符串/ APP_NAME
        机器人:主题=@风格/ AppTheme>
    <元数据机器人:名字=com.google.android.maps.v2.API_KEY
    机器人:值=AI -------------------/>
        <活动
            机器人:名字=com.example.guidebook.GuidebookActivity
            机器人:标签=@字符串/ APP_NAME>
            &所述;意图滤光器>
                <作用机器人:名字=android.intent.action.MAIN/>                <类机器人:名字=android.intent.category.LAUNCHER/>
            &所述; /意图滤光器>
        < /活性GT;
    < /用途>< /清单>

我对这个领域的新,因此要求详细的帮助。

 日志:10月12日至9日:35:44.200:D / AndroidRuntime(24663):关闭VM
10月12日至9日:35:44.200:W / dalvikvm(24663):主题ID = 1:螺纹未捕获的异常(组= 0x415d5ba8)退出
10月12日至9日:35:44.200:E / AndroidRuntime(24663):致命异常:主要
10月12日至9日:35:44.200:E / AndroidRuntime(24663):工艺:com.example.guidebook,PID:24663
10月12日至9日:35:44.200:E / AndroidRuntime(24663):了java.lang.RuntimeException:无法启动活动ComponentInfo {com.example.guidebook / com.example.guidebook.GuidebookActivity}:android.view.InflateException:二进制XML文件行#2:错误充气类片段
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread.access $ 800(ActivityThread.java:135)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1196)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.os.Handler.dispatchMessage(Handler.java:102)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.os.Looper.loop(Looper.java:136)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread.main(ActivityThread.java:5017)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在java.lang.reflect.Method.invokeNative(本机方法)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在java.lang.reflect.Method.invoke(Method.java:515)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:779)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在dalvik.system.NativeStart.main(本机方法)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):android.view.InflateException:二进制XML文件行#2:错误充气类片段产生的原因
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.view.LayoutInflater.inflate(LayoutInflater.java:469)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.view.LayoutInflater.inflate(LayoutInflater.java:397)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.view.LayoutInflater.inflate(LayoutInflater.java:353)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Activity.setContentView(Activity.java:1929)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在com.example.guidebook.GuidebookActivity.onCreate(GuidebookActivity.java:12)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Activity.performCreate(Activity.java:5231)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):... 11个
10月12日至9日:35:44.200:E / AndroidRuntime(24663):$ android.app.Fragment InstantiationException:产生的原因试图实例化一个类com.google.android.gms.maps.SupportMapFragment这不是一个片段
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Fragment.instantiate(Fragment.java:585)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Fragment.instantiate(Fragment.java:561)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.app.Activity.onCreateView(Activity.java:4778)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
10月12日至9日:35:44.200:E / AndroidRuntime(24663):20 ...更多
10月12日至9日:35:44.200:E / AndroidRuntime(24663):由:java.lang.ClassCastException
10月12日至9日:35:44.200:E / AndroidRuntime(24663):24 ...更多
10月12日至9日:36:10.520:D / AndroidRuntime(24870):关闭VM
10月12日至9日:36:10.520:W / dalvikvm(24870):主题ID = 1:螺纹未捕获的异常(组= 0x415d5ba8)退出
10月12日至9日:36:10.520:E / AndroidRuntime(24870):致命异常:主要
10月12日至9日:36:10.520:E / AndroidRuntime(24870):工艺:com.example.guidebook,PID:24870
10月12日至9日:36:10.520:E / AndroidRuntime(24870):了java.lang.RuntimeException:无法启动活动ComponentInfo {com.example.guidebook / com.example.guidebook.GuidebookActivity}:android.view.InflateException:二进制XML文件行#2:错误充气类片段
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread.access $ 800(ActivityThread.java:135)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1196)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.os.Handler.dispatchMessage(Handler.java:102)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.os.Looper.loop(Looper.java:136)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread.main(ActivityThread.java:5017)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.reflect.Method.invokeNative(本机方法)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.reflect.Method.invoke(Method.java:515)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:779)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在dalvik.system.NativeStart.main(本机方法)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):android.view.InflateException:二进制XML文件行#2:错误充气类片段产生的原因
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.view.LayoutInflater.inflate(LayoutInflater.java:469)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.view.LayoutInflater.inflate(LayoutInflater.java:397)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.view.LayoutInflater.inflate(LayoutInflater.java:353)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Activity.setContentView(Activity.java:1929)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在com.example.guidebook.GuidebookActivity.onCreate(GuidebookActivity.java:12)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Activity.performCreate(Activity.java:5231)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):... 11个
10月12日至9日:36:10.520:E / AndroidRuntime(24870):显示java.lang.NullPointerException:所致名== NULL
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.VMClassLoader.findLoadedClass(本机方法)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.ClassLoader.findLoadedClass(ClassLoader.java:350)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.ClassLoader.loadClass(ClassLoader.java:487)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在java.lang.ClassLoader.loadClass(ClassLoader.java:457)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Fragment.instantiate(Fragment.java:583)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Fragment.instantiate(Fragment.java:561)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.app.Activity.onCreateView(Activity.java:4778)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):在android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
10月12日至9日:36:10.520:E / AndroidRuntime(24870):20 ...更多
10月12日至9日:36:12.420:I /流程(24870):发送信号。 PID:24870 SIG:9


解决方案

检查我的回答如下:

在XML文件中的变化本类=com.google.android.gms.maps.MapFragment到Android:NAME =com.google.android.gms.maps.SupportMapFragment

拓展业务,以FragmentActivty并更改

 地图=((MapFragment)getFragmentManager()findFragmentById(R.id.map)。).getMap();至
地图=((SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map))的GetMap();

另外,请检查如果(图== NULL){图=((SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map))的GetMap();}

检查清单文件:

 <?XML版本=1.0编码=UTF-8&GT?;
<清单的xmlns:机器人=htt​​p://schemas.android.com/apk/res/android
包=com.example.googlemapsv2
安卓版code =1
机器人:=的versionName1.0><许可
    机器人:名字=com.example.googlemapsv2.permission.MAPS_RECEIVE
    安卓的ProtectionLevel =签名/><使用许可权的android:NAME =com.example.googlemapsv2.permission.MAPS_RECEIVE/><用途-SDK
    安卓的minSdkVersion =12
    机器人:targetSdkVersion =17/><使用许可权的android:NAME =android.permission.ACCESS_NETWORK_STATE/>
<使用许可权的android:NAME =android.permission.INTERNET对/>
<使用许可权的android:NAME =com.google.android.providers.gsf.permission.READ_GSERVICES/>
<使用许可权的android:NAME =android.permission.WRITE_EXTERNAL_STORAG​​E/><! - 必须出示当前位置 - >
<使用许可权的android:NAME =android.permission.ACCESS_COARSE_LOCATION/>
<使用许可权的android:NAME =android.permission.ACCESS_FINE_LOCATION/><! - 所需的OpenGL ES 2.0。对于地图V2 - >
<用途特征
    机器人:glEsVersion =0x00020000
    机器人:要求=真/><! - 需要OpenGL ES版本2 - >
<用途特征
    机器人:glEsVersion =0x00020000
    机器人:要求=真/><应用
    机器人:allowBackup =真
    机器人:图标=@绘制/ ic_launcher
    机器人:标签=@字符串/ APP_NAME>
    <活动
        机器人:名字=com.example.googlemapsv2.MainActivity
        机器人:标签=@字符串/ APP_NAME
        机器人:主题=@风格/ AppBaseTheme>
        &所述;意图滤光器>
            <作用机器人:名字=android.intent.action.MAIN/>            <类机器人:名字=android.intent.category.LAUNCHER/>
        &所述; /意图滤光器>
    < /活性GT;    <! - Goolge的API密钥 - >
    &所述;元数据
        机器人:名字=com.google.android.gms.version
        机器人:值=@整数/ GOOGLE_PLAY_SERVICES_VERSION/>
    &所述;元数据
        机器人:名字=com.google.android.maps.v2.API_KEY
        机器人:价值=你的钥匙/>
< /用途>

希望这有助于。

I try to program an easy map app on Android but the only outcome are errors. I tried to program it the way it should be but it still doesn't work.

mainactivity

package com.example.guidebook;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

public class GuidebookActivity extends Activity {

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

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.guidebook, menu);
        return true;
    }

}

.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"
    tools:context=".MainActivity" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="@string/hello_world" />
    <fragment
        android:id="@+id/map"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        class="com.google.android.gms.maps.MapFragment"/>

</RelativeLayout>

manifest

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

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="19" />
   <permission
       android:name="com.example.guidebook.permission.MAPS_RECEIVE" 
       android:protectionLevel="signature"/>

  <uses-permission android:name="com.example.guidebook.permission.MAPS_RECEIVE"/> 
  <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"/>
  <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
  <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
  <!-- Maps API needs OpenGL ES 2.0. -->
  <uses-feature
    android:glEsVersion="0x00020000"
    android:required="true"/>

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
    <meta-data android:name="com.google.android.maps.v2.API_KEY"
    android:value="AI-------------------"/>
        <activity
            android:name="com.example.guidebook.GuidebookActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

</manifest>

I am new on this area and therefore ask for detailed help.

Log: 12-09 10:35:44.200: D/AndroidRuntime(24663): Shutting down VM
12-09 10:35:44.200: W/dalvikvm(24663): threadid=1: thread exiting with uncaught exception (group=0x415d5ba8)
12-09 10:35:44.200: E/AndroidRuntime(24663): FATAL EXCEPTION: main
12-09 10:35:44.200: E/AndroidRuntime(24663): Process: com.example.guidebook, PID: 24663
12-09 10:35:44.200: E/AndroidRuntime(24663): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.guidebook/com.example.guidebook.GuidebookActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread.access$800(ActivityThread.java:135)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.os.Handler.dispatchMessage(Handler.java:102)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.os.Looper.loop(Looper.java:136)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread.main(ActivityThread.java:5017)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at java.lang.reflect.Method.invokeNative(Native Method)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at java.lang.reflect.Method.invoke(Method.java:515)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at dalvik.system.NativeStart.main(Native Method)
12-09 10:35:44.200: E/AndroidRuntime(24663): Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.view.LayoutInflater.inflate(LayoutInflater.java:469)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Activity.setContentView(Activity.java:1929)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at com.example.guidebook.GuidebookActivity.onCreate(GuidebookActivity.java:12)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Activity.performCreate(Activity.java:5231)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
12-09 10:35:44.200: E/AndroidRuntime(24663):    ... 11 more
12-09 10:35:44.200: E/AndroidRuntime(24663): Caused by: android.app.Fragment$InstantiationException: Trying to instantiate a class com.google.android.gms.maps.SupportMapFragment that is not a Fragment
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Fragment.instantiate(Fragment.java:585)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Fragment.instantiate(Fragment.java:561)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.app.Activity.onCreateView(Activity.java:4778)
12-09 10:35:44.200: E/AndroidRuntime(24663):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
12-09 10:35:44.200: E/AndroidRuntime(24663):    ... 20 more
12-09 10:35:44.200: E/AndroidRuntime(24663): Caused by: java.lang.ClassCastException
12-09 10:35:44.200: E/AndroidRuntime(24663):    ... 24 more
12-09 10:36:10.520: D/AndroidRuntime(24870): Shutting down VM
12-09 10:36:10.520: W/dalvikvm(24870): threadid=1: thread exiting with uncaught exception (group=0x415d5ba8)
12-09 10:36:10.520: E/AndroidRuntime(24870): FATAL EXCEPTION: main
12-09 10:36:10.520: E/AndroidRuntime(24870): Process: com.example.guidebook, PID: 24870
12-09 10:36:10.520: E/AndroidRuntime(24870): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.guidebook/com.example.guidebook.GuidebookActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread.access$800(ActivityThread.java:135)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.os.Handler.dispatchMessage(Handler.java:102)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.os.Looper.loop(Looper.java:136)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread.main(ActivityThread.java:5017)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.reflect.Method.invokeNative(Native Method)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.reflect.Method.invoke(Method.java:515)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at dalvik.system.NativeStart.main(Native Method)
12-09 10:36:10.520: E/AndroidRuntime(24870): Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.view.LayoutInflater.inflate(LayoutInflater.java:469)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Activity.setContentView(Activity.java:1929)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at com.example.guidebook.GuidebookActivity.onCreate(GuidebookActivity.java:12)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Activity.performCreate(Activity.java:5231)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159)
12-09 10:36:10.520: E/AndroidRuntime(24870):    ... 11 more
12-09 10:36:10.520: E/AndroidRuntime(24870): Caused by: java.lang.NullPointerException: name == null
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.VMClassLoader.findLoadedClass(Native Method)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.ClassLoader.findLoadedClass(ClassLoader.java:350)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.ClassLoader.loadClass(ClassLoader.java:487)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Fragment.instantiate(Fragment.java:583)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Fragment.instantiate(Fragment.java:561)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.app.Activity.onCreateView(Activity.java:4778)
12-09 10:36:10.520: E/AndroidRuntime(24870):    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
12-09 10:36:10.520: E/AndroidRuntime(24870):    ... 20 more
12-09 10:36:12.420: I/Process(24870): Sending signal. PID: 24870 SIG: 9

解决方案

Check my answer below :

In your xml file change this class="com.google.android.gms.maps.MapFragment" to android:name="com.google.android.gms.maps.SupportMapFragment"

Extend your activity to FragmentActivty and change

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

Also check if (map== null) { map= ((SupportMapFragment) getSupportFragmentManager() .findFragmentById(R.id.map)).getMap();}

Check your manifest file :

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

<permission
    android:name="com.example.googlemapsv2.permission.MAPS_RECEIVE"
    android:protectionLevel="signature" />

<uses-permission android:name="com.example.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="com.example.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.gms.version"
        android:value="@integer/google_play_services_version" />
    <meta-data
        android:name="com.google.android.maps.v2.API_KEY"
        android:value="your key" />
</application>

Hope this helps.

这篇关于Android上的简单地图应用程序(API谷歌V2)。不工作。错误的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆