Полосатая реклама с вознаграждением — это тип рекламы с вознаграждением, позволяющий предлагать вознаграждение за рекламу, которая автоматически появляется при естественном переходе между приложениями. В отличие от рекламы с вознаграждением, пользователям не требуется давать согласие на просмотр полноэкранной рекламы с вознаграждением.
Предпосылки
- Google Mobile Ads SDK 19.2.0 или выше.
- Заполните руководство по началу работы .
Выполнение
Основные шаги по интеграции вознагражденной межстраничной рекламы следующие:
- Загрузить объявление
- Зарегистрируйтесь для обратных вызовов событий на весь экран
- Обработка обратного вызова вознаграждения
- Показывать рекламу
- [Необязательно] Проверка обратных вызовов SSV
Загрузить объявление
 Загрузка рекламы осуществляется с помощью статического метода load() класса RewardedInterstitialAd . Методу load требуются Context, идентификатор вашего рекламного блока, объект AdRequest и RewardedInterstitialAdLoadCallback для получения уведомлений об успешной или неудачной загрузке рекламы. Загруженный объект RewardedInterstitialAd предоставляется в качестве параметра в обратном вызове onRewardedInterstitialAdLoaded() .
 В следующем примере показано, как загрузить RewardedInterstitialAd в MainActivity . 
Ява
Котлин
Замените AD_UNIT_ID на идентификатор вашего рекламного блока.
Зарегистрируйтесь для обратных звонков
 Чтобы получать уведомления о событиях показа, необходимо передать объект FullScreenContentCallback сеттеру вашего объявления. Объект FullScreenContentCallback обрабатывает обратные вызовы при успешном или неудачном показе рекламы, а также при её закрытии. Следующий код показывает, как задать анонимный объект FullScreenContentCallback в RewardedInterstitialAdLoadCallback : 
Ява
rewardedInterstitialAd.setFullScreenContentCallback(
    new FullScreenContentCallback() {
      @Override
      public void onAdDismissedFullScreenContent() {
        // Called when fullscreen content is dismissed.
        Log.d(TAG, "The ad was dismissed.");
        // Make sure to set your reference to null so you don't
        // show it a second time.
        rewardedInterstitialAd = null;
        if (googleMobileAdsConsentManager.canRequestAds()) {
          loadRewardedInterstitialAd();
        }
      }
      @Override
      public void onAdFailedToShowFullScreenContent(AdError adError) {
        // Called when fullscreen content failed to show.
        Log.d(TAG, "The ad failed to show.");
        // Make sure to set your reference to null so you don't
        // show it a second time.
        rewardedInterstitialAd = null;
      }
      @Override
      public void onAdShowedFullScreenContent() {
        // Called when fullscreen content is shown.
        Log.d(TAG, "The ad was shown.");
      }
      @Override
      public void onAdImpression() {
        // Called when an impression is recorded for an ad.
        Log.d(TAG, "The ad recorded an impression.");
      }
      @Override
      public void onAdClicked() {
        // Called when ad is clicked.
        Log.d(TAG, "The ad was clicked.");
      }
    });
Котлин
rewardedInterstitialAd?.fullScreenContentCallback =
  object : FullScreenContentCallback() {
    override fun onAdDismissedFullScreenContent() {
      // Called when fullscreen content is dismissed.
      Log.d(TAG, "Ad was dismissed.")
      // Don't forget to set the ad reference to null so you
      // don't show the ad a second time.
      rewardedInterstitialAd = null
    }
    override fun onAdFailedToShowFullScreenContent(adError: AdError) {
      // Called when fullscreen content failed to show.
      Log.d(TAG, "Ad failed to show.")
      // Don't forget to set the ad reference to null so you
      // don't show the ad a second time.
      rewardedInterstitialAd = null
    }
    override fun onAdShowedFullScreenContent() {
      // Called when fullscreen content is shown.
      Log.d(TAG, "Ad showed fullscreen content.")
    }
    override fun onAdImpression() {
      // Called when an impression is recorded for an ad.
      Log.d(TAG, "Ad recorded an impression.")
    }
    override fun onAdClicked() {
      // Called when an ad is clicked.
      Log.d(TAG, "Ad was clicked.")
    }
  }
Показывать рекламу
 При показе рекламного объявления с вознаграждением вы используете объект OnUserEarnedRewardListener для обработки событий вознаграждения. 
Ява
rewardedInterstitialAd.show(
    MainActivity.this,
    new OnUserEarnedRewardListener() {
      @Override
      public void onUserEarnedReward(@NonNull RewardItem rewardItem) {
        Log.d(TAG, "The user earned the reward.");
        // Handle the reward.
        int rewardAmount = rewardItem.getAmount();
        String rewardType = rewardItem.getType();
      }
    });
Котлин
rewardedInterstitialAd?.show(this) { rewardItem ->
  Log.d(TAG, "User earned the reward.")
  // Handle the reward.
  val rewardAmount = rewardItem.amount
  val rewardType = rewardItem.type
}
[Необязательно] Проверка обратных вызовов проверки на стороне сервера (SSV)
 Приложения, которым требуются дополнительные данные в обратных вызовах проверки на стороне сервера, должны использовать функцию пользовательских данных объявлений с вознаграждением. Любое строковое значение, заданное для объекта объявления с вознаграждением, передается в параметр запроса custom_data обратного вызова SSV. Если пользовательское значение данных не задано, значение параметра запроса custom_data не будет присутствовать в обратном вызове SSV.
В следующем примере кода показано, как задать пользовательские данные для объекта вознагражденной межстраничной рекламы перед запросом рекламы.
Ява
Котлин
Замените SAMPLE_CUSTOM_DATA_STRING вашими пользовательскими данными.
Если вы хотите задать пользовательскую строку вознаграждения, это необходимо сделать до показа рекламы.
Примеры на GitHub
Следующие шаги
Изучите следующие темы: