Interstitials mit Prämie sind ein auf Incentives basierendes Anzeigenformat, das automatisch an natürlichen Übergangspunkten in einer App ausgeliefert wird. Sie können damit Nutzer, die sich die Werbung ansehen, mit Prämien belohnen. Anders als bei Anzeigen mit Prämie müssen Nutzer nicht zustimmen, sich Interstitials mit Prämie anzusehen.
Vorbereitung
- Google Mobile Ads SDK 19.2.0 oder höher.
Richten Sie Google Mobile Ads SDK ein, bevor Sie fortfahren.
Implementierung
Die wichtigsten Schritte zum Einbinden von Interstitials mit Prämie sind:
- Anzeige laden
- Für Vollbild-Ereignis-Callbacks registrieren
- Callback zur Freigabe der Prämie verarbeiten
- Anzeige präsentieren
- [Optional] SSV-Callbacks validieren
Anzeige laden
Eine Anzeige wird mit der statischen Methode load() in der Klasse RewardedInterstitialAd geladen. Für die Methode „load“ sind ein Kontext, Ihre Anzeigenblock-ID, ein AdRequest-Objekt und ein RewardedInterstitialAdLoadCallback erforderlich, um benachrichtigt zu werden, wenn das Laden der Anzeige erfolgreich war oder fehlgeschlagen ist. Das geladene RewardedInterstitialAd-Objekt wird als Parameter in
dem onRewardedInterstitialAdLoaded()-Callback bereitgestellt.
Im folgenden Beispiel wird gezeigt, wie Sie eine RewardedInterstitialAd in Ihrer MainActivity laden.
Java
Kotlin
Ersetzen Sie AD_UNIT_ID durch Ihre Anzeigenblock-ID.
Für Callbacks registrieren
Damit Sie Benachrichtigungen zu Präsentationsereignissen erhalten, müssen Sie ein FullScreenContentCallback-Objekt an den Setter Ihrer Anzeige übergeben. Das FullScreenContentCallback-Objekt verarbeitet Callbacks für den Fall, dass die Anzeige erfolgreich oder nicht erfolgreich präsentiert wird und wenn sie geschlossen wird. Im folgenden Code wird gezeigt, wie Sie ein anonymes FullScreenContentCallback-Objekt in Ihrem RewardedInterstitialAdLoadCallback festlegen:
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.")
}
}
Anzeige präsentieren
Wenn Sie eine Interstitial-Anzeige mit Prämie präsentieren, verwenden Sie ein OnUserEarnedRewardListener-Objekt, um Prämienereignisse zu verarbeiten.
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
}
[Optional] Serverseitige Überprüfungs-Callbacks (SSV) validieren
Apps, für die zusätzliche Daten in serverseitigen
Überprüfungs Callbacks erforderlich sind, sollten die
Funktion für benutzerdefinierte Daten von Anzeigen mit Prämie verwenden. Jeder Stringwert, der für ein Objekt für Anzeigen mit Prämie festgelegt wurde, wird an den Abfrageparameter custom_data des SSV-Callbacks übergeben. Wenn kein Wert für benutzerdefinierte Daten festgelegt ist, ist der Wert des Abfrageparameters custom_data im SSV-Callback nicht vorhanden.
Im folgenden Codebeispiel wird gezeigt, wie Sie benutzerdefinierte Daten für ein Objekt für Interstitial-Anzeigen mit Prämie festlegen, bevor Sie eine Anzeige anfordern.
Java
Kotlin
Ersetzen Sie SAMPLE_CUSTOM_DATA_STRING durch Ihre benutzerdefinierten Daten.
Wenn Sie den benutzerdefinierten Prämienstring festlegen möchten, müssen Sie dies tun, bevor Sie die Anzeige präsentieren.
und muss möglicherweise decodiert werden, wenn er aus dem SSV-Callback geparst wird.Beispiele auf GitHub
Nächste Schritte
Weitere Informationen finden Sie in den folgenden Themen: