Android上的简单地图应用程序(API谷歌V2)。不工作。错误 [英] Simple map app on Android(google api v2). Doesnt work. Error
问题描述
我尝试编写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:机器人=http://schemas.android.com/apk/res/android
的xmlns:工具=http://schemas.android.com/tools
机器人:layout_width =match_parent
机器人:layout_height =match_parent
工具:上下文=MainActivity。> <的TextView
机器人:layout_width =WRAP_CONTENT
机器人:layout_height =WRAP_CONTENT
机器人:layout_centerHorizontal =真
机器人: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:机器人=http://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_STORAGE/>
<使用许可权的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:机器人=http://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_STORAGE/><! - 必须出示当前位置 - >
<使用许可权的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屋!