2013-12-17 9 views
2

Я пытаюсь создать простое приложение для просмотра карты. Я прошел через android developers documentation и скопировал MyActivity.java класс и activity_main.xml макет. Приложение сокрушительно, когда я запускаю свое настоящее устройство (Android v2.3.6). Ниже приведены ошибки проводника пакета, файла манифеста и ошибок logcat.Приложение для Android-карт разбивается

enter image description here

MainActivity.java:

package com.timur.mapapplication; 

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

public class MainActivity extends Activity { 

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

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?> 
<fragment xmlns:android="http://schemas.android.com/apk/res/android" 
      android:id="@+id/map" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:name="com.google.android.gms.maps.MapFragment"/> 

AndroidManifest.xml:

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

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

    <uses-permission android:name="android.permission.INTERNET" /> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
    <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" /> 

    <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.gms.version" 
      android:value="@integer/google_play_services_version" /> 

     <activity 
      android:name="com.timur.mapapplication.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> 
    </application> 

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

</manifest> 

LogCat ОШИБКИ:

12-18 00:03:05.626: E/AndroidRuntime(18591): FATAL EXCEPTION: main 
12-18 00:03:05.626: E/AndroidRuntime(18591): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.timur.mapapplication/com.timur.mapapplication.MainActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class fragment 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.os.Handler.dispatchMessage(Handler.java:99) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.os.Looper.loop(Looper.java:130) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread.main(ActivityThread.java:3693) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at java.lang.reflect.Method.invokeNative(Native Method) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at java.lang.reflect.Method.invoke(Method.java:507) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at dalvik.system.NativeStart.main(Native Method) 
12-18 00:03:05.626: E/AndroidRuntime(18591): Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class fragment 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:581) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.inflate(LayoutInflater.java:386) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:215) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.Activity.setContentView(Activity.java:1663) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at com.timur.mapapplication.MainActivity.onCreate(MainActivity.java:11) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615) 
12-18 00:03:05.626: E/AndroidRuntime(18591): ... 11 more 
12-18 00:03:05.626: E/AndroidRuntime(18591): Caused by: java.lang.ClassNotFoundException: android.view.fragment in loader dalvik.system.PathClassLoader[/data/app/com.timur.mapapplication-1.apk] 
12-18 00:03:05.626: E/AndroidRuntime(18591): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:240) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at java.lang.ClassLoader.loadClass(ClassLoader.java:551) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.createView(LayoutInflater.java:471) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.onCreateView(LayoutInflater.java:549) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:66) 
12-18 00:03:05.626: E/AndroidRuntime(18591): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:568) 
12-18 00:03:05.626: E/AndroidRuntime(18591): ... 19 more 

Спасибо за помощь.

+0

Пожалуйста, разместите свой класс активности и макет xml-кода – Prem

+1

Возможно, эта запись stackoverflow поможет: http://stackoverflow.com/questions/16437798/binary-xml-file-line-2-error-inflating-class – kovica

+0

** SOLVED: ** Я использовал 'SupportMapFragment' вместо' MapFragment' и 'FragmentActivity' вместо' Activity'. Другая ошибка была местом API_KEY. Я поместил его в '' вместо' '. – samet

ответ

3

Вы используете MapFragment, когда ваш minSdkVersion установлен на 8. Вы должны использовать SupportMapFragment вместо примерно так:

<?xml version="1.0" encoding="utf-8"?> 
<fragment xmlns:android="http://schemas.android.com/apk/res/android" 
      android:id="@+id/map" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:name="com.google.android.gms.maps.SupportMapFragment"/> 

Кроме того, только предложение, не публикуйте свой ключ API, он должен храниться в тайне, чтобы кто разрабатывает приложение.

+0

Спасибо, но он не меняется, все еще заставляя остановиться. – samet

+0

google-play-services_lib уже находится в библиотеках и выбран на вкладке «Заказ и экспорт». – samet

+0

Извините, вы получаете то же самое «Исключение»? – Emmanuel

1

Как предложил Эммануил, измените MapFragment на SupportMapFragment.

Добавление к нему расширения FragmentActivity вместо Activity в вашем классе java. Посмотрите, работает ли это сейчас.

Смежные вопросы