【问题标题】:Error inflating class com.google.ads.AdView膨胀类 com.google.ads.AdView 时出错
【发布时间】:2012-05-09 20:34:09
【问题描述】:

您好,我是 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>

你好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?
  • Eclipse 版本:Helios Service Release 2

标签: java android eclipse admob


【解决方案1】:

您最近是否将您的 Android 工具更新到 r17 或更高版本?如果是这样,您需要在项目中创建一个 libs/ 文件夹,并将 SDK 物理放入项目中。或者,在 Java 构建路径中,您必须订购和导出 SDK jar。

否则,当您的 apk 被编译时,jar 不会被包含在内,而当您在运行时运行 AdMob 代码时,一切都会崩溃。

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

【讨论】:

【解决方案2】:

对我来说是这样的。

  • 关闭日食
  • 在项目的“libs”文件夹中手动添加 sdk 广告 jar 文件
  • 打开日食
  • 刷新您的项目,直到 sdk jar 出现在 libs 文件夹中
  • 转到您项目的属性> Java 构建路径> 库选项卡并选择“添加罐子”而不是外部罐子。并从下面的列表中选择 sdk。
  • 转到“订购和导出”选项卡并再次选择 SDK
  • 点击确定,完成。

然后只需在清单和 xml 中添加正确的代码。

【讨论】:

  • 在做了所有的事情之后,重新启动 eclipse 终于帮助了我。
【解决方案3】:

我也遇到过这种情况。无论我做什么,构建路径似乎都不起作用。所以我退出了 Eclipse,在工作台包目录中创建了一个新的 libs 文件夹。将 GoogleAdMobAdsSdk-6.0.1.jar 添加到该文件夹​​。我没有添加整个 SDK,只是添加了 jar 文件。然后重新启动 Eclipse。我不得不刷新项目检查器列以显示我在 Eclipse 之外所做的更改。它显示了新的 libs 文件夹和 jar 文件,但它仍然无法正常工作......然后我右键单击新的 libs 文件夹并将其设置为 SOURCE FOLDER。现在一切正常!

我正在使用 Eclipse 版本:Indigo Service Release 2 内部版本号:20120216-1857

Android 开发工具 18.0.0.v201203301601-306762

似乎工具领先于文档……或者某种 Eclipse 错误……非常恼人!

【讨论】:

    【解决方案4】:

    我遇到了同样的问题,并注意到排序导出列表也很重要。
    这是我的,它是这样工作的:

    【讨论】:

    • 我从 Admob 6.2.1 更新到 6.3.1(修订版 10),我看到了崩溃 Error inflating class com.google.ads.AdView,这并不能通过简单地在 GoogleAdMobAdsSdk 旁边打勾来解决“订购和出口”列表的底部。谢谢你的截图!将 AdMobAds SDK 移至列表顶部有效!
    【解决方案5】:

    我所做的 - 现在对我有用 - API 级别 17 对于 admob:
    - 使用适当的 ID 将 adview 代码添加到您的布局中
    - 将 Admob 清单代码添加到您的项目清单文件
    - 将外部 GoogleAdmobAdsSDK..jar Jar 文件添加到您的库中(在 Properties\Java Build 路径中)
    - 检查以选择 GoogleAdmobAdsSDK..jar 在选项卡 Order and Export
    - 重新启动您的 ADT

    DEGUB = 正在工作。

    【讨论】:

      【解决方案6】:

      在 Android Studio 中: 1. 将 Google AdMob SDK 粘贴到项目的 libs 文件夹中 2. 为指向 jar 的项目添加一个条目到 build.gradle 的依赖项部分。 3. 重建你的项目

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

      请注意,编译文件需要多个 jar 条目。如果您已经有一个编译文件条目,您可以通过用逗号分隔条目来添加它。

      【讨论】:

        【解决方案7】:

        同样的错误出现在我面前,我通过几个简单的步骤解决了 您需要从项目中删除 appcombat 依赖项 删除右键单击您的项目-> android->删除应用程序战斗并确保您选择了android 4.2.2 然后将 google admob jar 导入到您的项目中。

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2013-07-28
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2019-11-29
          • 2017-02-28
          相关资源
          最近更新 更多