Реклама с вознаграждением — это тип рекламного формата, предлагающий вознаграждение за автоматические показы объявлений во время естественных переходов между приложениями. В отличие от рекламы с вознаграждением, пользователям не требуется давать согласие на просмотр такой рекламы.
Предварительные требования
- Google Mobile Ads SDK версии 19.2.0 или выше.
- Пройдите руководство по началу работы .
Выполнение
Основные шаги по интеграции межстраничной рекламы с вознаграждением следующие:
- Загрузить рекламу
- Зарегистрируйтесь для участия в обратных звонках в полноэкранном режиме.
- Обработайте обратный вызов для получения вознаграждения.
- Показать объявление
- [Необязательно] Проверить обратные вызовы SSV
Загрузить рекламу
Загрузка рекламы осуществляется с помощью статического метода load() класса RewardedInterstitialAd . Метод load требует объект Context, идентификатор вашего рекламного блока, объект AdRequest и объект RewardedInterstitialAdLoadCallback для уведомления об успешной или неудачной загрузке рекламы. Загруженный объект RewardedInterstitialAd передается в качестве параметра в функцию обратного вызова onRewardedInterstitialAdLoaded() .
В следующем примере показано, как загрузить RewardedInterstitialAd в вашем MainActivity .
Java
Котлин
Замените AD_UNIT_ID на идентификатор вашего рекламного блока.
Зарегистрируйтесь для участия в обратном звонке.
Для получения уведомлений о событиях показа рекламы необходимо передать объект FullScreenContentCallback в сеттер вашего объявления. Объект FullScreenContentCallback обрабатывает обратные вызовы при успешном или неудачном показе объявления, а также при его закрытии. Следующий код показывает, как установить анонимный объект FullScreenContentCallback в вашем RewardedInterstitialAdLoadCallback :
Java
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 .
Java
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.
Приведенный ниже пример кода демонстрирует, как установить пользовательские данные для объекта межстраничной рекламы с вознаграждением перед запросом показа рекламы.
Java
Котлин
Замените SAMPLE_CUSTOM_DATA_STRING на ваши пользовательские данные.
Если вы хотите задать пользовательскую строку вознаграждения, это необходимо сделать до показа рекламы.
Примеры на GitHub
Следующие шаги
Изучите следующие темы: