Java 膨胀class com.google.ads.AdView时出错
你好,我是android开发和admob的新手。我正在尝试制作一个简单的测试应用程序,它有一个按钮、两个页面和底部的admob。在我尝试实现admob之前,一切正常。这是我的密码: HelloAndroid.java:Java 膨胀class com.google.ads.AdView时出错,java,android,eclipse,admob,Java,Android,Eclipse,Admob,你好,我是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.V
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>
我正在使用GoogledMobadSDKDAndroid-6.0.0。我还是一个新手,我尝试过使用多个网站上的示例,但当应用程序访问包含admob的页面时,它会继续崩溃。如果有人能帮助我,我将不胜感激。非常感谢。如果需要更多代码,请告诉我。您最近是否将Android工具更新为r17或更高版本?如果是这样,您需要在项目中创建一个libs/文件夹,并将SDK实际放入项目中。或者,在Java构建路径中,您必须订购并导出SDK jar 否则,在编译apk时不会包含jar,在运行时运行AdMob代码时,一切都会变得一团糟
注意:这适用于项目引用的任何库。我也经历过这种情况。无论我做了什么,构建路径似乎都不起作用。所以我退出了Eclipse,在workbench包目录中创建了一个新的libs文件夹。将GoogleedMobadSDK-6.0.1.jar添加到该文件夹中。我没有添加整个SDK,只是添加了jar文件。然后重新启动Eclipse。我必须刷新projectinspector列以显示我在Eclipse之外所做的更改。它显示了新的libs文件夹和jar文件,但仍然不起作用。。。然后我右键单击新的libs文件夹并将其设置为源文件夹。现在一切都好了 Im使用Eclipse版本:Indigo Service Release 2 构建id:20120216-1857 Android开发工具18.0.0.v201203301601-306762
似乎工具比文档更先进了。。。或者某种Eclipse bug。。。。非常恼人 我也遇到了同样的问题,并注意到排序导出列表也很重要。
这是我的,它是这样工作的:
我所做的-现在正在为我工作-API级别17 对于admob:
-使用适当的ID将adview代码添加到布局中
-将Admob清单代码添加到项目清单文件
-将外部GoogleAddMobadSDK….jar文件添加到库中(在Properties\Java构建路径中)
-选中以按选项卡顺序选择GoogleedMobadSDK…jar并导出
-重新启动ADT
DEGUB=现在工作。对我来说,它是这样工作的
- 月食
- 在项目的“libs”文件夹中手动添加sdk ad jar文件
- 开放日食
- 刷新项目,直到sdk jar出现在libs文件夹中
- 转到项目的属性>Java构建路径>库选项卡,选择“添加JAR”而不是外部JAR。然后从下面的列表中选择sdk
- 转到“订购和导出”选项卡,再次选择SDK
- 单击ok并完成它
dependencies {
...
compile files('libs/GoogleAdMobAdsSdk-6.4.1.jar', '... other entries...')
}
请注意,编译文件包含多个jar条目。如果您已经有一个compile files条目,您可以通过用逗号分隔条目来添加它。我发现了相同的错误,我只需几个简单的步骤就解决了 您需要从项目中删除appcombat依赖项 要删除,请右键单击您的项目->安卓->删除应用程序战斗,并确保您已选择安卓4.2.2
然后将google admob jar导入到您的项目中。我觉得您的admob SDK jar没有绑定到您的APK中。您使用的IDE是什么?Eclipse版本:Helios Service Release 2omg谢谢,我已经将它添加到外部JAR中,但我没有订购和导出它。yah mee,我也创建了一个libs文件夹,复制并粘贴了库,现在它工作得很好。我没有订购和导出它。先生,你能建议我亲爱的Eric,请帮我解决这个问题:我从Admob 6.2.1更新到6.3.1(rev.10),我看到崩溃
错误膨胀class com.google.ads.AdView
,这不是通过简单地在“订购和导出”列表底部的GoogledMobadDS旁边打勾来解决的。谢谢你的截图!将AdMobAds SDK移到列表的顶部成功了!在做了所有的事情之后,重新启动eclipse最终帮助了我。
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
dependencies {
...
compile files('libs/GoogleAdMobAdsSdk-6.4.1.jar', '... other entries...')
}