web-dev-qa-db-ja.com

クラスcom.google.ads.AdViewの膨張中にエラーが発生しました

こんにちはAndroid devとadmobの初心者です。ボタンと2、3ページの下部にAdMobを使用して簡単なテストアプリを作成しようとしています。AdMobを実装するまで、すべてが正常に機能します。これが私のコードです:

HelloAndroid.Java:

package com.manny.HelloAndroid;

import Android.app.Activity;
import Android.content.Intent;
import Android.os.Bundle;
import Android.view.View;
import Android.widget.ImageView;

public class HelloAndroid extends Activity {
    /** Called when the activity is first created. */
    private static final int ACTIVITY_CREATE = 0;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);


        setContentView(R.layout.main);
        ImageView image = (ImageView) findViewById(R.id.test_image);
        //image.setScaleType(ImageView.ScaleType.FIT_XY);

    }
    public void onClick(View v){
        Intent i = new Intent(this, HelloPage2.class);
        startActivityForResult(i, ACTIVITY_CREATE);
    }
}

main.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:ads="http://schemas.Android.com/apk/lib/com.google.ads"
    Android:layout_width="fill_parent"
    Android:layout_height="fill_parent"
    Android:orientation="vertical" >

    <ImageView 
        Android:id="@+id/test_image"
        Android:src="@drawable/bak_vert_480x800"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_centerHorizontal="true"
        Android:scaleType="fitXY"
        />

    <TextView
        Android:layout_width="fill_parent"
        Android:layout_height="wrap_content"
        Android:text="@string/hello" />
    <ImageButton 
        Android:id="@+id/test_button"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:src="@drawable/btn_arrow"
        Android:layout_marginLeft="100dp"
        Android:layout_marginTop="200dp"
        Android:onClick="onClick"
        />
     <com.google.ads.AdView Android:id="@+id/adView"
                         Android:layout_width="wrap_content"
                         Android:layout_height="wrap_content"
                         ads:adUnitId="b14be806e9ddf1f"
                         ads:adSize="BANNER"
                         ads:testDevices="TEST_EMULATOR, TEST_DEVICE_ID"
                         ads:loadAdOnCreate="true"/>

</RelativeLayout>

こんにちはAndroidマニフェスト:

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

    <uses-sdk Android:minSdkVersion="7" 
        Android:targetSdkVersion="13"/>

    <application
        Android:icon="@drawable/ic_launcher"
        Android:label="@string/app_name" 
        Android:theme="@Android:style/Theme.NoTitleBar.Fullscreen">
        <activity
            Android:name=".HelloAndroid"
            Android:label="@string/app_name" >
            <intent-filter>
                <action Android:name="Android.intent.action.MAIN" />

                <category Android:name="Android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            Android:name=".HelloPage2">
        </activity>
    <activity Android:name="com.google.ads.AdActivity"
                    Android:configChanges="keyboard|keyboardHidden|orientation|screenLayout|uiMode|screenSize|s    mallestScreenSize"/>
  </application>
  <uses-permission Android:name="Android.permission.INTERNET"/>
  <uses-permission Android:name="Android.permission.ACCESS_NETWORK_STATE"/>
</manifest>

logcat出力:

05-09 13:12:00.859: D/dalvikvm(24278): GC_EXTERNAL_ALLOC freed 51K, 44% free 3054K/5379K, external 2357K/2773K, paused 94ms
05-09 13:12:00.937: D/dalvikvm(24278): GC_EXTERNAL_ALLOC freed 1K, 44% free 3053K/5379K, external 3857K/4816K, paused 31ms
05-09 13:12:01.085: D/AndroidRuntime(24278): Shutting down VM
05-09 13:12:01.085: W/dalvikvm(24278): threadid=1: thread exiting with uncaught exception (group=0x4001e560)
05-09 13:12:01.109: E/AndroidRuntime(24278): FATAL EXCEPTION: main
05-09 13:12:01.109: E/AndroidRuntime(24278): Java.lang.RuntimeException: Unable to start activity ComponentInfo{com.manny.HelloAndroid/com.manny.HelloAndroid.HelloAndroid}: Android.view.InflateException: Binary XML file line #30: Error inflating class com.google.ads.AdView
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:1702)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:1722)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread.access$1500(ActivityThread.Java:124)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:974)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.os.Handler.dispatchMessage(Handler.Java:99)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.os.Looper.loop(Looper.Java:130)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread.main(ActivityThread.Java:3821)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Java.lang.reflect.Method.invokeNative(Native Method)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Java.lang.reflect.Method.invoke(Method.Java:507)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:839)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:597)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at dalvik.system.NativeStart.main(Native Method)
05-09 13:12:01.109: E/AndroidRuntime(24278): Caused by: Android.view.InflateException: Binary XML file line #30: Error inflating class com.google.ads.AdView
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.createViewFromTag(LayoutInflater.Java:581)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.rInflate(LayoutInflater.Java:623)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:408)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:320)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.inflate(LayoutInflater.Java:276)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at com.Android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.Java:253)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.Activity.setContentView(Activity.Java:1716)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at com.manny.HelloAndroid.HelloAndroid.onCreate(HelloAndroid.Java:17)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.Instrumentation.callActivityOnCreate(Instrumentation.Java:1047)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:1666)
05-09 13:12:01.109: E/AndroidRuntime(24278):    ... 11 more
05-09 13:12:01.109: E/AndroidRuntime(24278): Caused by: Java.lang.ClassNotFoundException: com.google.ads.AdView in loader dalvik.system.PathClassLoader[/data/app/com.manny.HelloAndroid-2.apk]
05-09 13:12:01.109: E/AndroidRuntime(24278):    at dalvik.system.PathClassLoader.findClass(PathClassLoader.Java:240)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Java.lang.ClassLoader.loadClass(ClassLoader.Java:551)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Java.lang.ClassLoader.loadClass(ClassLoader.Java:511)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.createView(LayoutInflater.Java:471)
05-09 13:12:01.109: E/AndroidRuntime(24278):    at Android.view.LayoutInflater.createViewFromTag(LayoutInflater.Java:570)
05-09 13:12:01.109: E/AndroidRuntime(24278):    ... 20 more
05-09 13:12:11.593: I/Process(24278): Sending signal. PID: 24278 SIG: 9

GoogleAdMobAdsSdkAndroid-6.0.0を使用しています。繰り返しますが、私はこれに非常に慣れていないため、複数のサイトの例を使用してみましたが、admobが含まれているページにヒットすると、アプリがクラッシュし続けます。誰かが私を助けることができればそれは大いに感謝されるでしょう。ありがとうございました。さらにコードが必要な場合はお知らせください。

21
classyhobo

Android Toolsをr17以降に更新しましたか?その場合は、プロジェクトにlibs /フォルダーを作成し、SDKをプロジェクトに物理的に配置する必要があります。または、= Javaビルドパス。SDKjarを注文してエクスポートする必要があります。

そうしないと、apkがコンパイルされたときにjarが含まれず、実行時にAdMobコードを実行すると、すべての問題が解決されます。

注:これは、プロジェクトが参照するすべてのライブラリに適用されます。

58

私にとってはこのように機能しました。

  • 日食を閉じる
  • プロジェクトの「libs」フォルダーに手動でSDK広告jarファイルを追加します
  • eclipseを開く
  • sdk jarがlibsフォルダーに表示されるまでプロジェクトを更新します
  • プロジェクトのプロパティに移動> Javaビルドパス>ライブラリタブ]をクリックし、外部の代わりに「ジャーを追加」を選択し、以下のリストからSDKを選択します。
  • [注文とエクスポート]タブに移動し、SDKをもう一度選択します
  • [OK]をクリックして、完了します。

次に、マニフェストとxmlに適切なコードを追加します。

10
fromhead

私もこれを経験していました。ビルドパスは、私が何をしても機能しなかったようです。そこで、Eclipseを終了し、ワークベンチパッケージディレクトリに新しいlibsフォルダーを作成しました。そのフォルダにGoogleAdMobAdsSdk-6.0.1.jarを追加しました。 DID jarファイルだけではなく、SDK全体を追加しません。次にEclipseを再起動しました。Eclipseの外部で行った変更を表示するには、プロジェクトインスペクターの列を更新する必要がありました。新しいlibsフォルダーが表示されましたとjarファイルですが、それでも機能しませんでした...次に、新しいlibsフォルダーを右クリックし、それをソースフォルダーとして設定しました。

私はEclipseバージョンを使用しています:Indigo Service Release 2ビルドID:20120216-1857

Android開発ツール18.0.0.v201203301601-306762

おそらく、ツールがドキュメンテーションよりも先に進んでいるようです...または何らかのEclipseバグ..。非常に悪化しています!

2
Barry

同じ問題があり、エクスポートリストの順序も重要であることに気付きました。
これは私のもので、このように機能します:

enter image description here

1
h3r3b

私がしたこと-私のために今働いています-AdMobのAPIレベル17:
-適切なIDでレイアウトにadviewコードを追加します
-Admobマニフェストコードをプロジェクトマニフェストファイルに追加します
-外部のGoogleAdmobAdsSDK .... jar Jarファイルをライブラリに追加します(Properties\Javaビルドパス内)
-[注文とエクスポート]タブでGoogleAdmobAdsSDK .... jarを選択してチェックします
-ADTを再起動します

DEGUB =現在機能しています。

0
Hanh Bui Sy

Android Studio:1. Google AdMob SDKをプロジェクトのlibsフォルダーに貼り付けます。2。jarを指すプロジェクトのbuild.gradleの依存関係セクションにエントリを追加します。3。プロジェクトを再構築する

dependencies {
...
compile files('libs/GoogleAdMobAdsSdk-6.4.1.jar', '... other entries...')
}

ファイルのコンパイルには複数のjarエントリが必要です。コンパイルファイルのエントリが既にある場合は、エントリをコンマで区切って、そこに追加できます。

0
mcohen75

同じエラーが私に表示され、いくつかの簡単な手順で解決しましたプロジェクトからappcombat依存関係を削除して、プロジェクトを右クリックし、[Android]-> [アプリの戦闘を削除]を選択して、Android 4.2.2次に、google admob jarをプロジェクトにインポートします。

0
rajesh v