簡體   English   中英

Admob測試廣告未顯示

[英]Admob test ads not showing

這是我的第一個Android應用程序,我正在嘗試使用我的應用程序的admob廣告,但它不工作,盡管我已經完成了所有。

這是與廣告相關的活動中的代碼

     protected void onCreate(Bundle savedInstanceState) {
........

    LinearLayout rootLayout = (LinearLayout) findViewById(R.id.ForViewAd);

    AdView adView = new AdView(this);
    adView.setAdSize(AdSize.SMART_BANNER);
   //i've gotten the test ad id by first setting this as 'abc'
   //and then reading off the logcat
    adView.setAdUnitId("XXXXXXXXX");

    rootLayout.addView(adView, 0);

    AdRequest adRequest = new AdRequest.Builder()
        .addTestDevice(AdRequest.DEVICE_ID_EMULATOR)
        .addTestDevice("XXXXXXXXXX")
        .build();
    adView.loadAd(adRequest);

以下是我的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"
     xmlns:tools="http://schemas.android.com/tools"
     android:layout_width="fill_parent"
     android:layout_height="fill_parent"
     .......

     <LinearLayout
     android:layout_width="match_parent"
     android:layout_height="wrap_content"
     android:layout_alignParentBottom="true"
     android:layout_centerHorizontal="true"
     android:orientation="horizontal" >


     <com.google.ads.AdView 
                android:id="@+id/ForViewAd"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
                 /> 
     </LinearLayout>
    </RelativeLayout>

在模擬器上運行應用程序時的logcat讀數既奇怪又令人困惑

      09-28 15:28:21.076: E/Trace(968): error opening trace file: No such file or directory (2)
       09-28 15:28:21.120: W/GooglePlayServicesUtil(968): Google Play services is missing.
       09-28 15:28:21.140: I/Ads(968): Starting ad request.
       09-28 15:28:21.140: I/Ads(968): 
       Use AdRequest.Builder.addTestDevice ("XXXXXXXXX") to get test ads on this device.
       09-28 15:28:21.200: D/dalvikvm(968): DexOpt: --- BEGIN 'ads326198251.jar' (bootstrap=0) ---
       09-28 15:28:21.216: D/dalvikvm(968): GC_CONCURRENT freed 155K, 3% free 10994K/11271K, paused 19ms+11ms, total 36ms
       09-28 15:28:21.324: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x519 dp.
       09-28 15:28:21.340: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x499 dp.
       09-28 15:28:21.356: D/libEGL(968): loaded /system/lib/egl/libEGL_emulation.so
       09-28 15:28:21.372: D/(968): HostConnection::get() New Host Connection established 0xb975ff68, tid 968
       09-28 15:28:21.380: D/libEGL(968): loaded /system/lib/egl/libGLESv1_CM_emulation.so
       09-28 15:28:21.380: D/libEGL(968): loaded /system/lib/egl/libGLESv2_emulation.so
       09-28 15:28:21.432: W/EGL_emulation(968): eglSurfaceAttrib not implemented
       09-28 15:28:21.448: D/OpenGLRenderer(968): Enabling debug mode 0
       09-28 15:28:21.476: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb95468e0): name, size, mSize = 1, 1048576, 1048576
       09-28 15:28:21.532: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb953e248): name, size, mSize = 2, 9216, 1057792
       09-28 15:28:21.572: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb954fcb8): name, size, mSize = 4, 36864, 1094656
       09-28 15:28:21.576: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb976f528): name, size, mSize = 5, 16384, 1111040
       09-28 15:28:21.576: D/dalvikvm(968): DexOpt: --- END 'ads326198251.jar' (success) ---
       09-28 15:28:21.576: D/dalvikvm(968): DEX prep  '/data/data/com.example.testapp/cache/ads326198251.jar': unzip in 0ms, rewrite 375ms
       09-28 15:28:21.704: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb954edf8): name, size, mSize = 8, 16384, 1127424
       09-28 15:28:21.704: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb955e380): name, size, mSize = 9, 4096, 1131520
       09-28 15:28:21.776: D/dalvikvm(968): GC_CONCURRENT freed 214K, 4% free 11181K/11527K, paused 14ms+1ms, total 22ms
       09-28 15:28:21.780: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x519 dp.
       09-28 15:28:21.788: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x499 dp.
       09-28 15:28:22.040: W/Ads(968): Invalid unknown request error: [Cannot determine request type. Is your ad unit id correct?]
       09-28 15:28:22.048: W/Ads(968): There was a problem getting an ad response. ErrorCode: 1
       09-28 15:28:22.060: W/Ads(968): Failed to load ad: 1
       09-28 15:38:01.600: D/dalvikvm(968): GC_CONCURRENT freed 398K, 5% free 11181K/11719K, paused 10ms+1ms, total 18ms
      09-28 15:38:01.604: D/webviewglue(968): nativeDestroy view: 0xb97947e8
      09-28 15:38:01.608: D/webviewglue(968): nativeDestroy view: 0xb97da500

如您所見,logcat中至少顯示3個錯誤。 首先,谷歌播放服務已導入該項目。 我可以在android私有庫文件夾中看到它(但不在libs文件夾中)。

還有錯誤說沒有足夠的空間,但我已將relativelayout左右填充設置為0sp。 所以橫向應該有足夠的空間?

最后,錯誤代碼1,或“無效的未知請求錯誤”? 我不明白那一個。

除了logcat以及廣告未在活動的任何位置顯示的事實外,應用程序按正常方式運行沒有問題。

有人可以告訴我我做錯了什么嗎?

以下是建議后的logcat

    09-29 17:31:47.290: D/jdwp(1025): Got wake-up signal, bailing out of select
    09-29 17:31:47.290: D/dalvikvm(1025): Debugger has detached; object registry had 1 entries
    09-29 17:31:47.302: W/GooglePlayServicesUtil(968): Google Play services is missing.
    09-29 17:31:47.302: I/AndroidRuntime(1025): NOTE: attach of thread 'Binder_3' failed
    09-29 17:31:47.318: I/Ads(968): Starting ad request.
    09-29 17:31:47.318: I/Ads(968): Use AdRequest.Builder.addTestDevice("XXXXXX") to get test ads on this device.
    09-29 17:31:47.418: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x519 dp.
    09-29 17:31:47.422: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x499 dp.
    09-29 17:31:47.446: W/EGL_emulation(968): eglSurfaceAttrib not implemented
    09-29 17:31:47.454: D/OpenGLRenderer(968): TextureCache::get: create texture(0xb820e8e0): name, size, mSize = 38, 1048576, 1131520
    09-29 17:31:47.526: I/ActivityManager(324): Displayed com.example.testapp/com.example.testapp.MainActivity: +249ms
    09-29 17:31:47.530: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x519 dp.
    09-29 17:31:47.530: W/Ads(968): Not enough space to show ad. Needs 360x50 dp, but only has 340x499 dp.
    09-29 17:31:47.606: W/Ads(968): Invalid unknown request error: [Cannot determine request type. Is your ad unit id correct?]
    09-29 17:31:47.610: W/Ads(968): There was a problem getting an ad response. ErrorCode: 1
    09-29 17:31:47.610: W/Ads(968): Failed to load ad: 1
    09-29 17:31:47.622: D/dalvikvm(968): GC_CONCURRENT freed 256K, 4% free 11580K/11975K, paused 1ms+1ms, total 15ms
    09-29 17:31:47.622: D/webviewglue(968): nativeDestroy view: 0xb85bfb60

smart_banner存在問題//沒有足夠的空間來展示廣告。 需要360x50 dp

BANNER廣告很好用,

我解決這個問題...從布局中刪除廣告並放入根布局,刪除根布局的邊距

<RelativeLayout>
  <LinearLayout>
   </LinearLayout>
  <layout>
   </layout>
 //here
 <com.google.android.gms.ads.AdView />
 </RelativeLayout>

您還沒有正確添加testdevice ID,我在您的日志中找到了您的設備ID並更新了代碼。

AdRequest adRequest = new AdRequest.Builder()
        .addTestDevice(AdRequest.DEVICE_ID_EMULATOR)
        .addTestDevice("5C2521D171291728A381823D5ACC9B8D")
        .build();
    adView.loadAd(adRequest);

接下來,在您的布局文件中,只需以下就足夠了,因為您的java代碼正在設置adunitid,testdeviceid和adsize。 您可以將其放在Java代碼或布局文件中。

<com.google.ads.AdView 
                android:id="@+id/ForViewAd"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"/>

包括google官方網頁以獲取更多信息https://developers.google.com/mobile-ads-sdk/docs/admob/android/quick-start

添加@ Ranjith的答案,因為你通過谷歌播放服務使用admob,你應該修改你的布局如下:

 <?xml version="1.0" encoding="utf-8"?>
<RelativeLayout   
 xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:ads="http://schemas.android.com/apk/res-auto"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 .......

 <LinearLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_alignParentBottom="true"
 android:layout_centerHorizontal="true"
 android:orientation="horizontal" >

您可以按照從舊的admob遷移到新的admob的官方指南

順便說一下,將來不要在互聯網上發布你正確的adunit ID。 我掩蓋了它

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM