Ошибка раздувания класса com.google.ads.AdView

Привет, я новичок в android dev и 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 в ней. Если кто-то может мне помочь, это будет очень признательно. Спасибо. Если требуется больше кода, дайте мне знать.

Вы недавно обновили свои Android-инструменты до r17 или выше? Если это так, вам нужно создать папку libs / в вашем проекте и физически разместить SDK в проекте. Или, на пути построения Java, вы должны заказывать и экспортировать банку SDK.

В противном случае, банка не включается, когда ваш apk компилируется, и все ад разрывается, когда вы запускаете код AdMob во время выполнения.

ПРИМЕЧАНИЕ. Это относится к любой библиотеке, на которую ссылаются ваши проекты.

Для меня это сработало.

  • Закрыть eclipse
  • Добавьте вручную файл sdk ad jar в папку «libs» вашего проекта
  • Открытое затмение
  • Обновите свой проект до появления sdk jar в папке libs
  • Перейдите в свойства вашего проекта> Java Build Path> вкладка Library и выберите «add Jars» вместо внешнего. И выберите sdk из списка ниже.
  • Перейдите на вкладку «Заказ и экспорт» и снова выберите SDK
  • Нажмите ОК и ЕГО СОВЕРШЕННО.

Затем просто добавьте правильный код в манифест и xml.

Я тоже это переживал. Похоже, что путь сборки не работал независимо от того, что я сделал. Поэтому я вышел из Eclipse, создал новую папку libs в каталоге пакета workbench. Добавлен файл GoogleAdMobAdsSdk-6.0.1.jar в эту папку. Я НЕ добавил весь SDK, только файл jar. Затем перезапустите Eclipse. Мне пришлось обновить колонку инспектора проекта, чтобы показать изменения, внесенные мной вне Eclipse. Он показал новую папку libs и jar-файл, но она все еще не работала … Затем я щелкнул правой кнопкой мыши по новой папке libs и установил ее как ПАПКУ ИСТОЧНИКА. ТЕПЕРЬ ВСЕ РАБОТАЕТ!

Im, использующий Eclipse Версия: Indigo Service Release 2 Build id: 20120216-1857

Средства разработки Android 18.0.0.v201203301601-306762

Кажется, что, возможно, инструменты впереди документации … или какая-то ошибка Eclipse …. Очень усугубляет!

У меня была та же проблема, и я заметил, что также важно упорядочить список экспорта.
Это мое, так оно и работает:

Введите описание изображения здесь

Что я сделал – сейчас работает для меня – API Level 17 Для admob:
– Добавить код объявления в свой макет с соответствующим идентификатором
– Добавить код манифеста Admob в файл манифеста проекта
– Добавить внешний файл GoogleAdmobAdsSDK … jar Jar в вашу библиотеку (в свойствах \ путь сборки Java)
– Проверьте, чтобы выбрать GoogleAdmobAdsSDK …. jar в закладке Order and Export
– Перезапустите свой ADT

ДЕГУБ = РАБОТАЕТ СЕЙЧАС.

В Android Studio: 1. Вставьте SDK Google AdMob в папку libs для вашего проекта. 2. Добавьте раздел зависимости в зависимости от вашего build.gradle для проекта, указывающего на банку. 3. Перестройте свой проект

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

Обратите внимание, что файлы компиляции занимают несколько записей jar. Если у вас уже есть запись в файлах компиляции, вы можете просто добавить ее, разделив записи запятой.

Такая же ошибка появляется у меня, и я решил с помощью нескольких простых шагов. Вам нужно удалить зависимость appcombat от вашего проекта, чтобы удалить правой кнопкой мыши ваш проект -> android-> удалить сражение приложений и убедиться, что вы выбрали Android 4.2.2, а затем импортируете Google admob jar в ваш проект.