2

今日の大きなプロジェクトは、アプリを新しい Google Maps API V2 に移行することでした。ただし、根本的な原因が見つからないように見えるため、エラーが発生しています。

私のスタック トレースは次のようになります。

12-17 17:16:20.366: E/AndroidRuntime(3634): FATAL EXCEPTION: main
12-17 17:16:20.366: E/AndroidRuntime(3634): java.lang.RuntimeException: Unable to start        activity ComponentInfo{com.mobile.barwatch/com.mobile.barwatch.TestActivity}:     android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2088)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2113)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread.access$700(ActivityThread.java:139)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1224)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.os.Handler.dispatchMessage(Handler.java:99)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.os.Looper.loop(Looper.java:137)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread.main(ActivityThread.java:4918)
12-17 17:16:20.366: E/AndroidRuntime(3634): at java.lang.reflect.Method.invokeNative(Native Method)
12-17 17:16:20.366: E/AndroidRuntime(3634): at java.lang.reflect.Method.invoke(Method.java:511)
12-17 17:16:20.366: E/AndroidRuntime(3634): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
12-17 17:16:20.366: E/AndroidRuntime(3634): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
12-17 17:16:20.366: E/AndroidRuntime(3634): at dalvik.system.NativeStart.main(Native Method)
12-17 17:16:20.366: E/AndroidRuntime(3634): Caused by: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.view.LayoutInflater.inflate(LayoutInflater.java:466)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
12-17 17:16:20.366: E/AndroidRuntime(3634): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:306)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.Activity.setContentView(Activity.java:1901)
12-17 17:16:20.366: E/AndroidRuntime(3634): at com.mobile.barwatch.TestActivity.onCreate(TestActivity.java:18)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.Activity.performCreate(Activity.java:5048)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094)
12-17 17:16:20.366: E/AndroidRuntime(3634): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2052)
12-17 17:16:20.366: E/AndroidRuntime(3634):     ... 11 more
12-17 17:16:20.366: E/AndroidRuntime(3634): Caused by: java.lang.RuntimeException: API key not found.  Check that <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="your API key"/> is in the <application> element of AndroidManifest.xml
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.z.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.z.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.z.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.ae.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.bu.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at maps.y.p.onCreateView(Unknown  Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.maps.internal.IMapFragmentDelegate$Stub.onTransact(IMapFragmentDelegate.java:107)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.os.Binder.transact(Binder.java:326)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.maps.internal.IMapFragmentDelegate$a$a.onCreateView(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.maps.MapFragment$b.onCreateView(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.internal.d$4.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.internal.d.a(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.internal.d.onCreateView(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at com.google.android.gms.maps.MapFragment.onCreateView(Unknown Source)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:807)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1013)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.app.FragmentManagerImpl.addFragment(FragmentManager.java:1112)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.app.Activity.onCreateView(Activity.java:4704)
12-17 17:16:20.366: E/AndroidRuntime(3634):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:680)
12-17 17:16:20.366: E/AndroidRuntime(3634):     ... 20 more

私のアクティビティクラスは次のようになります。

package com.mobile.barwatch;

import android.app.Activity;
import android.os.Bundle;
import com.google.android.gcm.GCMRegistrar;
import com.google.android.gms.common.*;
import com.mobile.barwatch.tasks.*;
import com.mobile.barwatch.models.Constants;

public class TestActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {           
        super.onCreate(savedInstanceState);
        setContentView(R.layout.map_screen);              
    }
}

私のレイアウトファイルは次のようになります。

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

そして、私のマニフェストの関連部分は次のようになります。

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.mobile.barwatch"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="11"
        android:targetSdkVersion="15" />
    <uses-feature
        android:glEsVersion="0x00020000"
    android:required="true"/>
    <permission android:name="com.mobile.barwatch.permission.MAPS_RECEIVE"
            android:protectionLevel="signature"/>
    <permission android:name="com.mobile.barwatch.permission.C2D_MESSAGE"
                android:protectionLevel="signature" />    
    <uses-permission android:name="com.mobile.barwatch.permission.MAPS_RECEIVE"/>
    <uses-permission android:name="com.mobile.barwatch.permission.C2D_MESSAGE" />
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <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="com.google.android.c2dm.permission.RECEIVE" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />

    <application    
        android:allowBackup="true"    
        android:icon="@drawable/ic_launcher_barwatch"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
    ....
    <activity android:name="TestActivity" 
              android:label="@string/app_name">
    </activity>
    <meta-data android:name="com.google.android.maps.v2.xx"
               android:value="xx"/>       
    </application>       
</manifest>

私は本当にこれで壁に頭をぶつけているので、どんな助けも大歓迎です。

4

4 に答える 4

6

A--C と qzikl の回答のおかげで、自分の問題が何であるかを知ることができました。私のマニフェストに記入するとき、私は持っていました:

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

xx は私の API キーです。実際には、次のようにする必要があります。

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

したがって、すべてのエラーの原因は、値に対してのみ行うはずだった API キーを API_KEY に入力していたことです。

于 2012-12-17T22:50:20.763 に答える
1

LogCat には、次のような別のエラーが表示されました。

12-17 17:16:20.366: E/AndroidRuntime(3634): 原因: android.view.InflateException: バイナリ XML ファイル行 #2: クラス フラグメントの膨張エラー

そしてそれはすべての問題の手がかりです。ご覧のとおり、に含まれる「クラス」の表現が間違っていますが、現時点では解決策がわかりません。

于 2013-04-10T12:12:44.203 に答える
0

スタック トレースには、回答が含まれています。

12-17 17:16:20.366: E/AndroidRuntime(3634): 原因: java.lang.RuntimeException: API キーが見つかりません。AndroidManifest.xml の要素にあることを確認します

API キーを取得してマニフェストに含める必要があります。そのための何かがそこにあるように見えますが、おそらく編集されていますか?

于 2012-12-17T22:28:37.910 に答える
0

新しい API キーを取得するには、これに従ってください https://docs.google.com/document/pub?id=19nQzvKP-CVLd7_VrpwnHfl-AE9fjbJySowONZZtNHzw

于 2012-12-18T09:33:08.280 に答える