Reklama pełnoekranowa z nagrodą to format reklamy zachęcającej użytkownika do jej obejrzenia. Umożliwia uzyskanie nagród w aplikacji, takich jak monety lub dodatkowe życia. Reklamy tego typu wyświetlają się automatycznie w naturalnych momentach przejściowych w aplikacji. W przeciwieństwie do reklam z nagrodą użytkownicy nie muszą wyrazić zgody na wyświetlenie reklamy pełnoekranowej z nagrodą.
Wymagania wstępne
- Google Mobile Ads SDK 19.2.0 lub nowszej.
Zanim przejdziesz dalej, skonfiguruj Google Mobile Ads SDK.
Implementacja
Główne kroki integracji reklam pełnoekranowych z nagrodą:
- Wczytaj reklamę.
- Zarejestruj wywołania zwrotne zdarzeń pełnoekranowych.
- Obsłuż wywołanie zwrotne nagrody.
- Wyświetl reklamę.
- [Opcjonalnie] Zweryfikuj wywołania zwrotne SSV.
Wczytaj reklamę
Reklamę wczytuje się za pomocą statycznej metody load() w klasie RewardedInterstitialAd. Metoda wczytywania wymaga kontekstu, identyfikatora jednostki reklamowej, obiektu AdRequest i RewardedInterstitialAdLoadCallback, aby otrzymywać powiadomienia o powodzeniu lub niepowodzeniu wczytywania reklamy. Wczytany obiekt RewardedInterstitialAd jest przekazywany jako parametr w
wywołaniu zwrotnym onRewardedInterstitialAdLoaded().
Poniższy przykład pokazuje, jak wczytać RewardedInterstitialAd w MainActivity.
Java
Kotlin
Zastąp AD_UNIT_ID identyfikatorem jednostki reklamowej.
Zarejestruj wywołania zwrotne
Aby otrzymywać powiadomienia o zdarzeniach wyświetlania, musisz przekazać obiekt FullScreenContentCallback do ustawienia reklamy. Obiekt FullScreenContentCallback obsługuje wywołania zwrotne, gdy reklama wyświetla się lub nie wyświetla się prawidłowo oraz gdy zostanie zamknięta. Poniższy kod pokazuje, jak ustawić anonimowy obiekt FullScreenContentCallback w 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.");
}
});
Kotlin
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.")
}
}
Wyświetl reklamę
Gdy wyświetlasz reklamę pełnoekranową z nagrodą, używasz obiektu OnUserEarnedRewardListener do obsługi zdarzeń związanych z nagrodą.
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();
}
});
Kotlin
rewardedInterstitialAd?.show(this) { rewardItem ->
Log.d(TAG, "User earned the reward.")
// Handle the reward.
val rewardAmount = rewardItem.amount
val rewardType = rewardItem.type
}
[Opcjonalnie] Zweryfikuj wywołania zwrotne weryfikacji po stronie serwera (SSV)
Aplikacje, które wymagają dodatkowych danych w weryfikacji
po stronie serwera wywołaniach zwrotnych, powinny korzystać z funkcji danych niestandardowych w reklamach z nagrodą. Każda wartość ciągu znaków ustawiona w obiekcie reklamy z nagrodą jest przekazywana do parametru zapytania custom_data wywołania zwrotnego SSV. Jeśli nie ustawiono wartości danych niestandardowych, wartość parametru zapytania custom_data nie będzie obecna w wywołaniu zwrotnym SSV.
Poniższy przykład kodu pokazuje, jak ustawić dane niestandardowe w obiekcie reklamy pełnoekranowej z nagrodą przed wysłaniem prośby o reklamę.
Java
Kotlin
Zastąp SAMPLE_CUSTOM_DATA_STRING swoimi danymi niestandardowymi.
Jeśli chcesz ustawić niestandardowy ciąg znaków nagrody, musisz to zrobić przed wyświetleniem reklamy.
Przykłady na GitHubie
Dalsze kroki
Zapoznaj się z tymi tematami: