AdMob на Galaxy Nexus – приложение для Android закрылось

Я запрограммировал простое приложение для тестирования некоторых вещей. Одна вещь AdMob.

На большинстве телефонов Android это работает, но на Galaxy S3 или Galaxy Nexus или на планшетах нет. Может проблема с более высоким разрешением? Проблема в том, что приложение закрывается сразу после запуска. Я пытался интегрировать AdMob в XML, но в новой версии это не работает.

Вот мой код AdMob.

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    AdRequest adRequest = new AdRequest();
    adRequest.addTestDevice(AdRequest.TEST_EMULATOR);
    AdView adView = new AdView(this, AdSize.BANNER, "replaced id with this");
    //adView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
    LinearLayout layout = (LinearLayout)findViewById(R.id.LayoutMain);
    layout.addView(adView,0);   
    adView.loadAd(adRequest);

А вот ЛогКэт

12-20 18:39:18.056: I/dalvikvm(541):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
12-20 18:39:18.066: I/dalvikvm(541):   at dalvik.system.NativeStart.main(Native Method)
12-20 18:39:18.086: D/AndroidRuntime(541): Shutting down VM
12-20 18:39:18.096: W/dalvikvm(541): threadid=1: thread exiting with uncaught exception (group=0x409961f8)
12-20 18:39:18.206: E/AndroidRuntime(541): FATAL EXCEPTION: main
12-20 18:39:18.206: E/AndroidRuntime(541): java.lang.RuntimeException: Unable to start activity ComponentInfo{at.android.dertestloerk/at.android.dertestloerk.MainActivity}: android.view.InflateException: Binary XML file line #1: Error inflating class android.widget.RelativeLayout
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread.access$600(ActivityThread.java:122)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.os.Handler.dispatchMessage(Handler.java:99)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.os.Looper.loop(Looper.java:137)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread.main(ActivityThread.java:4340)
12-20 18:39:18.206: E/AndroidRuntime(541):  at java.lang.reflect.Method.invokeNative(Native Method)
12-20 18:39:18.206: E/AndroidRuntime(541):  at java.lang.reflect.Method.invoke(Method.java:511)
12-20 18:39:18.206: E/AndroidRuntime(541):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
12-20 18:39:18.206: E/AndroidRuntime(541):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
12-20 18:39:18.206: E/AndroidRuntime(541):  at dalvik.system.NativeStart.main(Native Method)
12-20 18:39:18.206: E/AndroidRuntime(541): Caused by: android.view.InflateException: Binary XML file line #1: Error inflating class android.widget.RelativeLayout
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.createView(LayoutInflater.java:606)
12-20 18:39:18.206: E/AndroidRuntime(541):  at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.onCreateView(LayoutInflater.java:653)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:678)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.inflate(LayoutInflater.java:466)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
12-20 18:39:18.206: E/AndroidRuntime(541):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:251)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.Activity.setContentView(Activity.java:1835)
12-20 18:39:18.206: E/AndroidRuntime(541):  at at.android.dertestloerk.MainActivity.onCreate(MainActivity.java:27)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.Activity.performCreate(Activity.java:4465)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
12-20 18:39:18.206: E/AndroidRuntime(541):  ... 11 more
12-20 18:39:18.206: E/AndroidRuntime(541): Caused by: java.lang.reflect.InvocationTargetException
12-20 18:39:18.206: E/AndroidRuntime(541):  at java.lang.reflect.Constructor.constructNative(Native Method)
12-20 18:39:18.206: E/AndroidRuntime(541):  at java.lang.reflect.Constructor.newInstance(Constructor.java:417)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.LayoutInflater.createView(LayoutInflater.java:586)
12-20 18:39:18.206: E/AndroidRuntime(541):  ... 23 more
12-20 18:39:18.206: E/AndroidRuntime(541): Caused by: java.lang.OutOfMemoryError
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.Bitmap.nativeCreate(Native Method)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.Bitmap.createBitmap(Bitmap.java:605)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.Bitmap.createBitmap(Bitmap.java:551)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.Bitmap.createScaledBitmap(Bitmap.java:437)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.BitmapFactory.finishDecode(BitmapFactory.java:524)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:499)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.BitmapFactory.decodeResourceStream(BitmapFactory.java:351)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.graphics.drawable.Drawable.createFromResourceStream(Drawable.java:773)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.content.res.Resources.loadDrawable(Resources.java:1937)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.content.res.TypedArray.getDrawable(TypedArray.java:601)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.View.<init>(View.java:2780)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.View.<init>(View.java:2717)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.view.ViewGroup.<init>(ViewGroup.java:379)
12-20 18:39:18.206: E/AndroidRuntime(541):  at android.widget.RelativeLayout.<init>(RelativeLayout.java:174)
12-20 18:39:18.206: E/AndroidRuntime(541):  ... 26 more
12-20 18:39:23.096: I/Process(541): Sending signal. PID: 541 SIG: 9

А вот мой XML-макет

<LinearLayout xmlns:tools="http://schemas.android.com/tools"
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/LayoutMain"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/hintergrund"
android:orientation="vertical"
tools:context=".MainActivity" >

<ImageView
    android:id="@+id/imageViewLoerg"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:scaleType="fitCenter"
    android:src="@drawable/animatedloerg"
    tools:ignore="ContentDescription" /> </LinearLayout>

Надеюсь, вы можете помочь.-)


person SettusBlake    schedule 20.12.2012    source источник
comment
Можете ли вы опубликовать трассировку стека, которую вы получаете в logcat?   -  person iagreen    schedule 20.12.2012
comment
Следуйте этому ответить, а также ответить на этот вопрос.   -  person Artyom Kiriliyk    schedule 20.12.2012
comment
хорошо, спасибо за подсказку   -  person SettusBlake    schedule 20.12.2012
comment
Хорошо, отключил тестовый режим и попробовал его с XML, но не работает   -  person SettusBlake    schedule 21.12.2012
comment
@SettusBlake Опубликуйте свой xml-код.   -  person Dipak Keshariya    schedule 21.12.2012
comment
Добавили xml-код для макета   -  person SettusBlake    schedule 22.12.2012
comment
Вы должны опубликовать ответ, если вы решили его, а не просто сделать заголовок «Решено».   -  person jprofitt    schedule 22.12.2012
comment
у меня есть .-) Хорошо, решено. Фоновая картинка была немного великовата. я уменьшил его, и теперь он работает на устройствах с высоким разрешением   -  person SettusBlake    schedule 22.12.2012


Ответы (1)


К Адмобу это отношения не имеет. Ошибка находится по адресу:

18:39:18.206: E/AndroidRuntime(541): Причина: android.view.InflateException: Строка двоичного XML-файла №1: Ошибка при преобразовании класса android.widget.RelativeLayout 12–20 18:39:18.206: E/AndroidRuntime( 541): в

Т.е. он крашится, пытаясь загрузить макет XML, задолго до того, как вы программно рекламируете AdMob в AdView.

Посмотрите на свой макет, там есть проблема.

person William    schedule 21.12.2012
comment
Хорошо, решено. Фоновая картинка была немного великовата. я уменьшил его, и теперь он работает на устройствах с высоким разрешением - person SettusBlake; 22.12.2012
comment
Но для меня, несмотря на то, что я уменьшил фоновое изображение, оно автоматически закрывается в GAlaxy S3. Я не программно вызываю add, вместо этого вызываю его в XML - person Amalan Dhananjayan; 29.04.2013