【问题标题】:Android - Google Play Service throw IllegalStateException complaining about size and ad unit idAndroid - Google Play 服务抛出 IllegalStateException 抱怨尺寸和广告单元 ID
【发布时间】:2014-05-16 16:33:51
【问题描述】:

由于我将 Admob 库替换为 Google Play 服务库,我的 Android 应用有时会触发以下异常

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.XXX.XXX/com.XXX.XXX.ui.activity.FeedActivity}: java.lang.IllegalStateException: The ad size and ad unit ID must be set before loadAd is called.
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2328)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2386)
at android.app.ActivityThread.access$900(ActivityThread.java:169)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1277)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5476)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1268)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1084)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalStateException: The ad size and ad unit ID must be set before loadAd is called.
at com.google.android.gms.internal.ak.an(Unknown Source)
at com.google.android.gms.internal.ak.a(Unknown Source)
at com.google.android.gms.ads.AdView.loadAd(Unknown Source)
at com.XXX.newslibrary.ui.activity.FeedActivity.initActivityLayout(FeedActivity.java:255)
at com.XXX.newslibrary.ui.activity.FeedActivity.onCreate(FeedActivity.java:72)
at android.app.Activity.performCreate(Activity.java:5451)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1093)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2292)
... 11 more

基本上,例外是抱怨我没有在 loadAd 之前设置广告尺寸和单元 ID。这是我的代码:

    mAdView = new AdView(this);
    mAdView.setAdSize(AdSize.BANNER);
    mAdView.setAdUnitId(SourceActivity.APPLICATION_ADMOB_BANNER_ID);

    LinearLayout layout = (LinearLayout) findViewById(R.id.activity_view);
    layout.addView(mAdView);

    AdRequest adRequest = new AdRequest.Builder().build();
    mAdView.loadAd(adRequest);
    mAdView.setVisibility(View.GONE);

    mAdView.setAdListener(new AdListener() {
      @Override
      public void onAdLoaded() {
          Log.d(TAG, "onAdLoaded");
          mAdView.setVisibility(View.VISIBLE);
      }
    });

如您所见,一切都是正确的。正如我之前所说,异常并不总是出现,实际上它只出现了几次。

有人知道是什么原因造成的吗?

【问题讨论】:

    标签: java android google-play-services


    【解决方案1】:

    修改代码

                      <com.google.android.gms.ads.AdView android:id="@+id/adView"
                         android:layout_width="wrap_content"
                         android:layout_height="wrap_content"
                         android:layout_below="@+id/gridView1"
                         ads:adUnitId="MY ID NUMBER"
                         ads:adSize="BANNER"/>
    

                     <com.google.android.gms.ads.AdView android:id="@+id/adView"
                         xmlns:ads="http://schemas.android.com/apk/res-auto"
                         android:layout_width="match_parent"
                         android:layout_height="wrap_content"
                         ads:adUnitId="ca-app-pub-8510605212168324/8634800090"
                         ads:adSize="BANNER"
                         android:layout_alignParentBottom="true"
                         >
    
                     </com.google.android.gms.ads.AdView>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-01-12
      • 1970-01-01
      相关资源
      最近更新 更多