21

こんにちは、Android dev と admob は初めてです。ボタン、いくつかのページ、および下部にある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>

こんにちはアンドロイド マニフェスト:

<?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 を含むページにヒットすると、アプリがクラッシュし続けます。誰かが私を助けることができれば、それは大歓迎です。ありがとうございました。さらにコードが必要な場合はお知らせください。

4

7 に答える 7

58

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

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

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

于 2012-05-09T23:53:27.237 に答える
10

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

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

次に、マニフェストとxmlに適切なコードを追加するだけです。

于 2013-01-09T01:42:34.823 に答える
2

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

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

Android 開発ツール 18.0.0.v201203301601-306762

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

于 2012-05-31T18:32:21.593 に答える
1

私も同じ問題を抱えており、エクスポート リストの順序も重要であることに気付きました。
これは私のもので、このように動作します:

ここに画像の説明を入力

于 2012-12-14T13:14:47.513 に答える
0

私がやったこと - 今私のために働いています - APIレベル17 admobの場合:
- 適切なIDを使用してレイアウトにadviewコードを追加します - Admob
マニフェストコードをプロジェクトマニフェストファイル
に追加します - 外部のGoogleAdmobAdsSDK ....jar JarファイルをLibrary (Properties\Java Build path 内)
- [Order and Export] タブで GoogleAdmobAdsSDK....jar を選択するようにチェックします
- ADT を再起動します

DEGUB = 現在動作中。

于 2012-12-26T05:51:29.397 に答える
0

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

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

コンパイル ファイルは複数の jar エントリを取ることに注意してください。コンパイル ファイルのエントリが既にある場合は、エントリをカンマで区切って追加できます。

于 2013-09-01T22:09:34.613 に答える