错误充气类com.google.ads.AdView

21

你好,我是Android开发新手,也不太了解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);
    }
}

主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的页面时,应用程序仍会崩溃。如果有人能帮帮我,我将不胜感激。谢谢。如果需要更多的代码,请告诉我。


听起来你的 AdMob SDK jar 包没有被打包到 APK 中。你使用的是哪个 IDE? - EpicOfChaos
Eclipse 版本:Helios Service Release 2 - classyhobo
7个回答

58

你最近是否将Android Tools更新到r17或更高版本?如果是,你需要在项目中创建一个名为“libs/”的文件夹,并将SDK物理放置在该项目中。或者,在Java Build Path中,您必须对SDK jar进行排序和导出。

否则,当编译apk时,jar文件不会被包含在内,运行时运行AdMob代码时就会出现各种问题。

注意:这适用于项目引用的任何库。


7
太感谢了!我已将它添加到外部JAR包中,但我忘记了对其进行排序和导出。 - classyhobo
我也是,我创建了一个libs文件夹,复制并粘贴了库文件,现在它可以正常工作了。我没有排序和导出它。 - Amalan Dhananjayan
先生,您能否建议我http://stackoverflow.com/questions/25178044/android-admob-is-there-any-violation-to-remove-resources-from-google-play-serv? - Giru Bhai
亲爱的Eric,麻烦帮我解决这个问题:http://stackoverflow.com/questions/33495499/admob-interstitial-fill-rate-is-too-low-10 - Ve Pham

10

对我而言,操作步骤如下:

  • 关闭Eclipse
  • 手动将SDK和JAR文件添加到项目的“libs”文件夹中
  • 打开Eclipse
  • 刷新项目,直至SDK JAR文件出现在“libs”文件夹中
  • 进入项目属性 > Java Build Path > Library标签页,选择"Add Jars"并从下方列表中选中SDK。
  • 进入"Order and Export"标签页,再次选中SDK
  • 点击确定即完成

然后,在清单文件和XML文件中添加正确的代码。


重启Eclipse最终帮助我解决了所有问题。 - mn0102

2
我也遇到了这个问题。不管我做什么,构建路径似乎都不起作用。所以我退出了Eclipse,在工作台包目录下创建了一个新的libs文件夹。将GoogleAdMobAdsSdk-6.0.1.jar添加到该文件夹中。我没有添加整个SDK,只是添加了jar文件。然后重新启动Eclipse。我必须刷新项目检查器列以显示我在Eclipse之外进行的更改。它显示了新的libs文件夹和jar文件,但仍然不起作用... 然后我右键单击新的libs文件夹并将其设置为源文件夹。现在一切都正常了!
我使用的是Eclipse版本:Indigo Service Release 2 Build id:20120216-1857
Android开发工具18.0.0.v201203301601-306762
看起来可能是工具超前于文档...或某种Eclipse错误...非常恼人!

1

我曾经遇到同样的问题,并注意到导出列表的排序也很重要。
这是我的排序方式,这样就可以正常工作了:

enter image description here


我从Admob 6.2.1升级到6.3.1(rev.10),然后遇到了'Error inflating class com.google.ads.AdView'的崩溃问题,但简单地在“顺序和导出”列表底部勾选GoogleAdMobAdsSdk并不能解决该问题。感谢您提供的截图!将AdMobAds SDK移动到列表顶部解决了问题! - Someone Somewhere

0

我所做的 - 现在对我有效 - API级别17 对于admob:
- 在您的布局中添加带有适当ID的广告视图代码
- 在您的项目清单文件中添加Admob清单代码
- 将外部GoogleAdmobAdsSDK....jar Jar文件添加到您的库中(在属性\Java构建路径中)
- 检查选择GoogleAdmobAdsSDK....jar选项卡中的顺序和导出
- 重新启动ADT

DEGUB = 现在工作正常。


0

我也遇到了同样的错误,但是我通过几个简单的步骤解决了它。 你需要从你的项目中移除appcombat依赖项, 右键点击你的项目->android->移除app combat,并确保你已经选择了Android 4.2.2, 然后将Google Admob jar文件导入你的项目。


0
在Android Studio中: 1. 将Google AdMob SDK粘贴到项目的libs文件夹中 2. 在项目的build.gradle文件的dependencies部分添加一个指向该jar包的条目。 3. 重新构建您的项目。
dependencies {
...
compile files('libs/GoogleAdMobAdsSdk-6.4.1.jar', '... other entries...')
}

请注意,编译文件需要多个jar条目。如果您已经有一个编译文件条目,只需用逗号分隔条目即可添加到它上面。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接