在Android中创建地图。 mainactivity.java中的错误

时间:2016-02-07 03:08:54

标签: java android google-maps

当我尝试在Android App中创建地图时,我收到此错误

02-06 20:38:48.178 15186-15186/? E/AndroidRuntime: FATAL EXCEPTION: main
   java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.agupta.routebus/com.example.agupta.routebus.MainActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
       at android.app.ActivityThread.access$600(ActivityThread.java:141)
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
       at android.os.Handler.dispatchMessage(Handler.java:99)
       at android.os.Looper.loop(Looper.java:137)
       at android.app.ActivityThread.main(ActivityThread.java:5041)
       at java.lang.reflect.Method.invokeNative(Native Method)
       at java.lang.reflect.Method.invoke(Method.java:511)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
       at dalvik.system.NativeStart.main(Native Method)
    Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
       at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:466)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
       at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:256)
       at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:109)
       at com.example.agupta.routebus.MainActivity.onCreate(MainActivity.java:29)
       at android.app.Activity.performCreate(Activity.java:5104)
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
       at android.app.ActivityThread.access$600(ActivityThread.java:141) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
       at android.os.Handler.dispatchMessage(Handler.java:99) 
       at android.os.Looper.loop(Looper.java:137) 
       at android.app.ActivityThread.main(ActivityThread.java:5041) 
       at java.lang.reflect.Method.invokeNative(Native Method) 
       at java.lang.reflect.Method.invoke(Method.java:511) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
       at dalvik.system.NativeStart.main(Native Method) 
    Caused by: java.lang.RuntimeException: API key not found.  Check that <meta-data android:name="com.google.android.geo.API_KEY" android:value="your API key"/> is in the <application> element of AndroidManifest.xml
       at com.google.maps.api.android.lib6.c.ad.a(Unknown Source)
       at com.google.maps.api.android.lib6.a.e.a(Unknown Source)
       at com.google.android.gms.maps.internal.CreatorImpl.b(Unknown Source)
       at com.google.android.gms.maps.internal.CreatorImpl.b(Unknown Source)
       at com.google.android.gms.maps.internal.h.onTransact(SourceFile:62)
       at android.os.Binder.transact(Binder.java:310)
       at com.google.android.gms.maps.internal.ah.b(SourceFile:179)
       at com.google.android.gms.maps.internal.CreatorImpl.b(SourceFile:100)
       at com.google.android.gms.maps.internal.ag.onTransact(SourceFile:62)
       at android.os.Binder.transact(Binder.java:310)
       at com.google.android.gms.maps.internal.zzc$zza$zza.zzs(Unknown Source)
       at com.google.android.gms.maps.SupportMapFragment$zzb.zzzW(Unknown Source)
       at com.google.android.gms.maps.SupportMapFragment$zzb.zza(Unknown Source)
       at com.google.android.gms.dynamic.zza.zza(Unknown Source)
       at com.google.android.gms.dynamic.zza.onInflate(Unknown Source)
       at com.google.android.gms.maps.SupportMapFragment.onInflate(Unknown Source)
       at android.support.v4.app.Fragment.onInflate(Fragment.java:1129)
       at android.support.v4.app.FragmentManagerImpl.onCreateView(FragmentManager.java:2283)
       at android.support.v4.app.FragmentController.onCreateView(FragmentController.java:111)
       at android.support.v4.app.FragmentActivity.dispatchFragmentsOnCreateView(FragmentActivity.java:314)
       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:680)
       at android.view.LayoutInflater.inflate(LayoutInflater.java:466) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 
       at android.view.LayoutInflater.inflate(LayoutInflater.java:352) 
       at android.support.v7.app.AppCompatDelegateImplV7.setContentView(AppCompatDelegateImplV7.java:256) 
       at android.support.v7.app.AppCompatActivity.setContentView(AppCompatActivity.java:109) 
       at com.example.agupta.routebus.MainActivity.onCreate(MainActivity.java:29) 
       at android.app.Activity.performCreate(Activity.java:5104) 
       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 
       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 
       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
       at android.app.ActivityThread.access$600(ActivityThread.java:141) 
       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
       at android.os.Handler.dispatchMessage(Handler.java:99) 
       at android.os.Looper.loop(Looper.java:137) 
       at android.app.ActivityThread.main(ActivityThread.java:5041) 
       at java.lang.reflect.Method.invokeNative(Native Method) 
       at java.lang.reflect.Method.invoke(Method.java:511) 
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
       at dalvik.system.NativeStart.main(Native Method) 
02-06 20:38:48.198 15186-15190/? D/dalvikvm: GC_CONCURRENT freed 280K, 6% free 7594K/8020K, paused 2ms+2ms, total 20ms

2 个答案:

答案 0 :(得分:0)

您没有API密钥来访问Google地图。首先,您需要从谷歌开发者网站获取API密钥并将其保存在您的字符串资源文件中,并在您的清单文件中分配密钥。然后,只有您可以访问谷歌地图。

Caused by: java.lang.RuntimeException: API key not found.  Check that <meta-data android:name="com.google.android.geo.API_KEY" android:value="your API key"/> is in the <application> element of AndroidManifest.xml

答案 1 :(得分:0)

@ prashant-gupta的回答也是有效的。但您可能正在使用较新版本的Android版地图。如果您查看Getting Started页面,则第4步表示您创建了Android Studio已创建的google_maps_api.xml。在开发人员控制台中创建API密钥后,将其复制到xml,它应该可以正常工作。