2013-06-28 85 views
0

我正在使用我的老板的手机来测试我们在iOS上开发的应用程序,然后转移到android。谷歌地图V2'应用程序意外停止'android SDK v9

我跟着this教程,当在手机上运行给出了标题中提到的错误。我已经读过10个以下的SDK不支持地图是不是?相当不确定从这里做什么。代码:

我有3个标签,我加载的片段,并在讨论的片段是:

注:所有的进口都正确

public class EventFragment extends Fragment { 
    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 

     // Inflate the layout for this fragment 
     View V = inflater.inflate(R.layout.event_layout, container, false); 

     return V; 
    } 
} 

在视图中的XML文件:

<fragment xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:map="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/the_map" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:name="com.google.android.gms.maps.MapFragment" 
    map:cameraTilt="45" 
    map:cameraZoom="14" 
    /> 

一切都在应该是清单。当我删除它运行良好。有这种事情的修复吗?

编辑:

logcat的错误:

06-28 11:25:51.230: E/AndroidRuntime(3405): FATAL EXCEPTION: main 
06-28 11:25:51.230: E/AndroidRuntime(3405): android.view.InflateException: Binary XML file line #1: Error inflating class fragment 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:587) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.view.LayoutInflater.inflate(LayoutInflater.java:386) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at co.uk.dwdks.kendalmintfest.KendalInfoFragment.onCreateView(KendalInfoFragment.java:16) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.Fragment.performCreateView(Fragment.java:1460) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:911) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1088) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1444) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:429) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.os.Handler.handleCallback(Handler.java:587) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.os.Handler.dispatchMessage(Handler.java:92) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.os.Looper.loop(Looper.java:143) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.app.ActivityThread.main(ActivityThread.java:4196) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at java.lang.reflect.Method.invokeNative(Native Method) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at java.lang.reflect.Method.invoke(Method.java:507) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at dalvik.system.NativeStart.main(Native Method) 
06-28 11:25:51.230: E/AndroidRuntime(3405): Caused by: android.support.v4.app.Fragment$InstantiationException: Unable to instantiate fragment com.google.android.gms.maps.MapFragment: make sure class name exists, is public, and has an empty constructor that is public 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.Fragment.instantiate(Fragment.java:401) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.Fragment.instantiate(Fragment.java:369) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:272) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  ... 18 more 
06-28 11:25:51.230: E/AndroidRuntime(3405): Caused by: java.lang.ClassNotFoundException: com.google.android.gms.maps.MapFragment in loader dalvik.system.PathClassLoader[/data/app/co.uk.dwdks.kendalmintfest-2.apk] 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:240) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at java.lang.ClassLoader.loadClass(ClassLoader.java:551) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  at android.support.v4.app.Fragment.instantiate(Fragment.java:391) 
06-28 11:25:51.230: E/AndroidRuntime(3405):  ... 21 more 
+0

此错误消息说没有。请添加从你的logcat的堆栈跟踪... – WarrenFaith

+0

嗨@WarrenFaith我更新了我的问题与logcat,这是唯一显示从这个建设和它的绿色 –

+0

这不能是你的logcat ... – WarrenFaith

回答

2

我认为你需要实现SupportFragment和碎片类需要是:类=“com.google.android.gms.maps.SupportMapFragment”

+0

嗨,感谢您的评论!这已经消除了错误,它说:“这个应用程序不会运行没有谷歌播放服务”现在,我可以安全地下载这个? –

+0

如果您收到一个新的异常,例如:R $ stylable中的NoClassDefFound比您需要添加地图programmaticaly :-) – Informatic0re

+0

您是否执行了此操作:https://developers.google.com/maps/documentation/android/start – Informatic0re

0

地图工作(AFAIR)开始形式API8。但是,您需要将您的应用与google-play-servces_lib关联起来,这很可能在您的情况下不会完成。同时确保你获得了在Manifest中设置的所有权限。最后,检查的官方文档:https://developers.google.com/maps/documentation/android/