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 Münzen oder Extraleben 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
- Führen Sie die Schritte im Startleitfaden aus.
Implementierung
Die wichtigsten Schritte zum Integrieren von Interstitials mit Prämie sind:
- Anzeige laden
- Callbacks für Vollbildereignisse registrieren
- Callback zur Freigabe der Prämie verarbeiten
- Anzeige einblenden
- [Optional] SSV-Callbacks validieren
Anzeige laden
Das Laden einer Anzeige erfolgt mit der statischen Methode load()
für die Klasse RewardedInterstitialAd
. Für die Lademethode sind ein Kontext, Ihre Anzeigenblock-ID, ein AdRequest
-Objekt und ein RewardedInterstitialAdLoadCallback
erforderlich, um benachrichtigt zu werden, wenn das Laden der Anzeige erfolgreich ist oder fehlschlägt. Das geladene RewardedInterstitialAd
-Objekt wird als Parameter im onRewardedInterstitialAdLoaded()
-Callback bereitgestellt.
Das folgende Beispiel zeigt, wie Sie eine RewardedInterstitialAd
in Ihre MainActivity
laden.
Java
Kotlin
Ersetzen Sie AD_UNIT_ID durch Ihre Anzeigenblock-ID.
Callbacks registrieren
Damit Sie Benachrichtigungen zu Präsentationsereignissen erhalten, müssen Sie dem Setter in Ihrer Anzeige ein FullScreenContentCallback
-Objekt ü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. Der folgende Code zeigt, 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 einblenden
Wenn Sie eine Interstitial-Anzeige mit Prämie präsentieren, verwenden Sie ein OnUserEarnedRewardListener
-Objekt, um Prämienevents 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] SSV-Callbacks (serverseitige Überprüfung) validieren
Apps, für die zusätzliche Daten in serverseitigen Bestätigungs-Callbacks erforderlich sind, sollten die Funktion für benutzerdefinierte Daten von Anzeigen mit Prämie verwenden. Alle Stringwerte, die für ein Objekt für Anzeigen mit Prämie festgelegt sind, werden an den Abfrageparameter custom_data
des SSV-Callbacks übergeben. Wenn kein benutzerdefinierter Datenwert festgelegt ist, ist der Wert des custom_data
-Abfrageparameters nicht im SSV-Callback enthalten.
Das folgende Codebeispiel zeigt, wie benutzerdefinierte Daten für ein Objekt für Interstitials mit Prämie festgelegt werden, bevor eine Anzeige angefordert wird.
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 die Anzeige ausgeliefert wird.
Beispiele auf GitHub
Nächste Schritte
Sehen Sie sich die folgenden Themen an: