Los intersticiales recompensados son un tipo de formato de anuncio incentivado que te permite ofrecer recompensas por los anuncios que aparecen automáticamente durante las transiciones naturales de la app. A diferencia de los anuncios recompensados, no se requiere que los usuarios habiliten ninguna función para ver un intersticial recompensado.
Requisitos previos
- SDK de anuncios de Google para dispositivos móviles 19.2.0 o una versión posterior
- Completa la guía de introducción.
Implementación
Los pasos principales para integrar los anuncios intersticiales recompensados son los siguientes:
- Carga un anuncio
- Regístrate para recibir devoluciones de llamada de eventos de pantalla completa
- Controla la devolución de llamada de recompensa
- Muestra el anuncio
- Valida las devoluciones de llamada de SSV (opcional).
Carga un anuncio
Para cargar un anuncio, se usa el método estático load()
en la clase RewardedInterstitialAd
. El método de carga requiere un objeto Context, tu ID de unidad de anuncios, un objeto AdRequest
y un objeto RewardedInterstitialAdLoadCallback
para recibir notificaciones cuando la carga de anuncios se realice correctamente o falle. El objeto RewardedInterstitialAd
cargado se incluye como parámetro en la devolución de llamada onRewardedInterstitialAdLoaded()
.
En el siguiente ejemplo, se muestra cómo cargar un RewardedInterstitialAd
en tu MainActivity
.
Java
Kotlin
Reemplaza AD_UNIT_ID por tu ID de unidad de anuncios.
Regístrate para recibir devoluciones de llamada
Para recibir notificaciones de eventos de presentación, debes pasar un objeto FullScreenContentCallback
al método setter de tu anuncio. El objeto FullScreenContentCallback
controla las devoluciones de llamada para cuando el anuncio se presenta correctamente o con errores, y cuando se descarta. En el siguiente código, se muestra cómo establecer un objeto FullScreenContentCallback
anónimo dentro de tu 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.")
}
}
Muestra el anuncio
Cuando muestres un anuncio intersticial recompensado, usarás un objeto OnUserEarnedRewardListener
para controlar los eventos de recompensa.
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
}
[Opcional] Valida las devoluciones de llamada de verificación del servidor (SSV)
Las apps que requieren datos adicionales en las devoluciones de llamada de la verificación del servidor deben usar la función de datos personalizados de los anuncios recompensados. Todos los valores de cadena establecidos en un objeto de anuncio recompensado se pasan al parámetro de consulta custom_data
de la devolución de llamada de la SSV. Si no se establece ningún valor de datos personalizados, el valor del parámetro de consulta custom_data
no estará presente en la devolución de llamada de la SSV.
La siguiente muestra de código indica cómo establecer datos personalizados en un objeto de anuncio intersticial recompensado antes de solicitar un anuncio.
Java
Kotlin
Reemplaza SAMPLE_CUSTOM_DATA_STRING por tus datos personalizados.
Si deseas establecer la cadena de recompensa personalizada, debes hacerlo antes de mostrar el anuncio.
Ejemplos en GitHub
Próximos pasos
Explora los siguientes temas:
- Privacidad del usuario
- Optimización relacionada con la inicialización del SDK y la carga de anuncios (beta)