8

我想在我的android应用程序上实现奖励视频,我第一次点击显示视频,效果很好,但之后第二次或第三次我再次点击显示它,它不起作用,并抛出日志:

W/MessageQueue: Handler (com.google.android.gms.ads.exoplayer2.upstream.u) {1e5487c} sending message to a Handler on a dead thread
                                                                     java.lang.IllegalStateException: Handler (com.google.android.gms.ads.exoplayer2.upstream.u) {1e5487c} sending message to a Handler on a dead thread
                                                                         at android.os.MessageQueue.enqueueMessage(MessageQueue.java:543)
                                                                         at android.os.Handler.enqueueMessage(Handler.java:631)
                                                                         at android.os.Handler.sendMessageAtTime(Handler.java:600)
                                                                         at android.os.Handler.sendMessageDelayed(Handler.java:570)
                                                                         at android.os.Handler.sendEmptyMessageDelayed(Handler.java:534)
                                                                         at android.os.Handler.sendEmptyMessage(Handler.java:519)
                                                                         at com.google.android.gms.ads.exoplayer2.upstream.u.run(:com.google.android.gms.DynamiteModulesA:212)
                                                                         at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:423)
                                                                         at java.util.concurrent.FutureTask.run(FutureTask.java:237)
                                                                         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
                                                                         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
                                                                         at java.lang.Thread.run(Thread.java:818)


Could not show rewarded video ad from adapter.
                                                          java.lang.NullPointerException: Attempt to read from field 'com.google.android.gms.ads.internal.client.bq ip.a' on a null object reference
                                                              at com.google.ads.mediation.a.g(:com.google.android.gms.DynamiteModulesA:17227)
                                                              at com.google.android.gms.ads.internal.mediation.client.u.f(:com.google.android.gms.DynamiteModulesA:436)
                                                              at com.google.android.gms.ads.internal.reward.b.a(:com.google.android.gms.DynamiteModulesA:1314)
                                                              at com.google.android.gms.ads.internal.reward.client.e.onTransact(:com.google.android.gms.DynamiteModulesA:65)
                                                              at android.os.Binder.transact(Binder.java:387)
                                                              at com.google.android.gms.internal.zznu$zza$zza.show(Unknown Source)
                                                              at com.google.android.gms.internal.zzoc.show(Unknown Source)
                                                              at com.reperfection.monopoly.MainActivity$1.onClick(MainActivity.java:70)
                                                              at android.view.View.performClick(View.java:5702)
                                                              at android.view.View$PerformClick.run(View.java:22546)
                                                              at android.os.Handler.handleCallback(Handler.java:739)
                                                              at android.os.Handler.dispatchMessage(Handler.java:95)
                                                              at android.os.Looper.loop(Looper.java:158)
                                                              at android.app.ActivityThread.main(ActivityThread.java:7237)
                                                              at java.lang.reflect.Method.invoke(Native Method)
                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Could not call showVideo.
                                                          android.os.RemoteException
                                                              at com.google.android.gms.ads.internal.mediation.client.u.f(:com.google.android.gms.DynamiteModulesA:439)
                                                              at com.google.android.gms.ads.internal.reward.b.a(:com.google.android.gms.DynamiteModulesA:1314)
                                                              at com.google.android.gms.ads.internal.reward.client.e.onTransact(:com.google.android.gms.DynamiteModulesA:65)
                                                              at android.os.Binder.transact(Binder.java:387)
                                                              at com.google.android.gms.internal.zznu$zza$zza.show(Unknown Source)
                                                              at com.google.android.gms.internal.zzoc.show(Unknown Source)
                                                              at com.reperfection.monopoly.MainActivity$1.onClick(MainActivity.java:70)
                                                              at android.view.View.performClick(View.java:5702)
                                                              at android.view.View$PerformClick.run(View.java:22546)
                                                              at android.os.Handler.handleCallback(Handler.java:739)
                                                              at android.os.Handler.dispatchMessage(Handler.java:95)
                                                              at android.os.Looper.loop(Looper.java:158)
                                                              at android.app.ActivityThread.main(ActivityThread.java:7237)
                                                              at java.lang.reflect.Method.invoke(Native Method)
                                                              at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
                                                              at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)

这是我的代码:

public class MainActivity extends AppCompatActivity implements RewardedVideoAdListener {

TextView counterTV;
ImageView clickerBoard;
int counter;
int step = 1;
RelativeLayout parentRl;
LinearLayout ln1;
LinearLayout ln2;
private RewardedVideoAd mAd;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    overridePendingTransition(R.anim.slide_in_left, R.anim.slide_out_left);
    setContentView(R.layout.activity_main);

    counterTV = (TextView) findViewById(R.id.counter);
    parentRl = (RelativeLayout) findViewById(R.id.parentRl);
    clickerBoard = (ImageView) findViewById(R.id.clickerBoard);
    ln1 = (LinearLayout) findViewById(R.id.ln1);
    ln2 = (LinearLayout) findViewById(R.id.ln2);

    // Init rewarded video
    mAd = MobileAds.getRewardedVideoAdInstance(this);
    mAd.setRewardedVideoAdListener(this);
    loadRewardedVideoAd();

    ln1.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            if (mAd.isLoaded()) {
                mAd.show();
            }
        }
    });
}

private void loadRewardedVideoAd() {
    mAd.loadAd("ca-app-pub-3940256099942544/5224354917", new AdRequest.Builder().build());
}
@Override
public void onRewarded(RewardItem reward) {
    Toast.makeText(this, "onRewarded! currency: " + reward.getType() + "  amount: " +
            reward.getAmount(), Toast.LENGTH_SHORT).show();
    // Reward the user.
}

// The following listener methods are optional.
@Override
public void onRewardedVideoAdLeftApplication() {
    Toast.makeText(this, "onRewardedVideoAdLeftApplication",
            Toast.LENGTH_SHORT).show();
}

@Override
public void onRewardedVideoAdClosed() {
    Toast.makeText(this, "onRewardedVideoAdClosed", Toast.LENGTH_SHORT).show();
    loadRewardedVideoAd();
}

@Override
public void onRewardedVideoAdFailedToLoad(int errorCode) {
    Toast.makeText(this, "onRewardedVideoAdFailedToLoad", Toast.LENGTH_SHORT).show();
}

@Override
public void onRewardedVideoAdLoaded() {
    Toast.makeText(this, "onRewardedVideoAdLoaded", Toast.LENGTH_SHORT).show();
}

@Override
public void onRewardedVideoAdOpened() {
    Toast.makeText(this, "onRewardedVideoAdOpened", Toast.LENGTH_SHORT).show();
}

@Override
public void onRewardedVideoStarted() {
    Toast.makeText(this, "onRewardedVideoStarted", Toast.LENGTH_SHORT).show();
}

@Override
public void onResume() {
    mAd.resume(this);
    super.onResume();
}

@Override
public void onPause() {
    mAd.pause(this);
    super.onPause();
}

@Override
public void onDestroy() {
    mAd.destroy(this);
    super.onDestroy();
}}

你能帮忙找出问题所在吗?谢谢

4

6 回答 6

3

解决方案

我遇到了同样的问题,查看官方示例,我发现他们没有打电话

RewardedVideoAd.destroy(Context)

虽然他们告诉在他们的官方教程中调用它。因此,删除它后,它起作用了。

于 2017-12-14T16:24:23.030 回答
1

我正在放置一个admob视频,当您进入活动时执行,我在第二次进入活动时遇到了同样的问题。就我而言,我放置了一个可执行循环来在视频已经加载时启动它。

if (mRewardedVideoAd.isLoaded()) {
        mRewardedVideoAd.show();
    }else{
        loadRewardedVideoAd();
    }

这是我所有代码的一部分

private boolean started = false;
private Handler handler = new Handler();

private void initializeAdMob() {
    mRewardedVideoAd = MobileAds.getRewardedVideoAdInstance(this);
    mRewardedVideoAd.setRewardedVideoAdListener(this);
    loadRewardedVideoAd();
}

private void loadRewardedVideoAd() {
    if (!mRewardedVideoAd.isLoaded()) {
        mRewardedVideoAd.loadAd(getString(R.string.id_block_activity), new AdRequest.Builder().build());
    }
}

private void showRewardedVideoAd() {
    if (BaseInteractor.isNetworkAvailable(this)) {
        showProgressBar(true);
        start();
    }
}

private Runnable runnable = new Runnable() {
    @Override
    public void run() {
        if (mRewardedVideoAd.isLoaded()) {
            mRewardedVideoAd.show();
        }else{
            loadRewardedVideoAd();
        }
        if (started) {
            start();
        }
    }
};

public void stop() {
    started = false;
    handler.removeCallbacks(runnable);
}

public void start() {
    started = true;
    handler.postDelayed(runnable, 2000);
}

最后我停止了可运行的

@Override
public void onRewardedVideoAdOpened() {
    showProgressBar(false);
    stop();
}

我希望这可以帮助你。

于 2018-02-07T15:26:25.287 回答
0

根据新的激励视频广告的谷歌文档(链接)

RewardedAd 是一次性使用对象。这意味着一旦展示了激励广告,该对象就不能用于加载另一个广告。要请求另一个激励广告,您需要创建一个新的 RewardedAd 对象。

因此,如果您需要第二个广告,您需要处置现有的奖励广告对象并创建一个新对象。你可以这样做:

rewardedAd=null;
rewardedAd = new RewardedAd(this,"ca-app-pub-3940256099942544/5224354917");
于 2020-09-17T12:47:07.950 回答
0

我面临着完全相同的问题,经过几天的调查,我找到了解决方案。

你必须非常小心你的RewardedVideoAd生命周期。在我的例子中,我将我的活动生命周期绑定到这个对象。但我知道调用onResume()对象RewardedVideoAd会“重新初始化”它,因此即使您之前加载了广告,也需要重新加载广告。

正如您可能在其他线程中发现的那样,即使 SDK 允许,也不要尝试同时加载广告。请确保在您的流程中,只有在没有预加载广告或者您只是调用onResume()您的RewardedVideoAd对象时才加载广告。

不要犹豫,记录您的RewardedVideoAd回调方法,以帮助您了解和优化您的广告加载流程。

于 2018-01-05T08:45:27.390 回答
0

如果您请求从 admob 获取广告,当您已经收到另一个从 admob 获取广告的 admob 视频请求并且您发出的第一个请求返回响应广告并且您决定显示()广告时,您将得到无法显示来自适配器的奖励视频广告。错误。

我认为这是关于单例的。您提出的第二个请求破坏了第一个请求中的某些内容。这会让人们感到困惑,因为您可以创建多个com.google.android.gms.ads.reward.RewardedVideoAdListener(). 就我而言,如果您已经在等待第一个请求的响应,我们必须阻止对 admob 的第二个请求。

于 2017-09-20T13:17:24.890 回答
0

关于手册,您似乎必须重新加载视频:覆盖此方法

onRewardedVideoAdClosed() {
loadRewardedVideoAd();
}
于 2017-05-18T23:51:38.600 回答