Los anuncios intersticiales son anuncios de pantalla completa que cubren la interfaz de una app hasta que el usuario los cierra. Por lo general, se muestran en puntos de transición naturales en el flujo de una app, como entre actividades o durante la pausa entre niveles de un juego. Cuando una app muestra un anuncio intersticial, el usuario puede presionarlo y continuar hasta su destino, o bien cerrarlo y volver a la app. Caso de éxito.
En esta guía, se muestra cómo integrar anuncios intersticiales en apps para Android y iOS con el SDK de Google Mobile Ads para C++.
Requisitos previos
- Completa Comenzar.
- (Solo para Android) Familiaridad para trabajar con referencias
jobject
de JNI (consulta las sugerencias de JNI de Android).
Siempre realiza pruebas con anuncios de prueba
Cuando compiles y pruebes tus apps, asegúrate de usar anuncios de prueba en lugar de anuncios activos en fase de producción. De lo contrario, podría suspenderse tu cuenta.
La forma más sencilla de cargar anuncios de prueba es usar nuestro ID de unidad de anuncios de prueba exclusivo para los anuncios intersticiales, que varía según la plataforma del dispositivo:
- Android:
ca-app-pub-3940256099942544/1033173712
- iOS:
ca-app-pub-3940256099942544/4411468910
Se configuraron de forma especial para mostrar anuncios de prueba para cada solicitud, y puedes usarlos en tus propias apps mientras codificas, pruebas y depuras. Solo asegúrate de reemplazarlo por tu propio ID de unidad de anuncios antes de publicar tu app.
Para obtener más información sobre cómo funcionan los anuncios de prueba del SDK de anuncios para dispositivos móviles, consulta Anuncios de prueba.
Implementación
Estos son los pasos principales para integrar anuncios intersticiales:
- Carga un anuncio.
- Regístrate para recibir devoluciones de llamada.
- Muestra el anuncio y controla sus eventos de ciclo de vida.
Configura un InterstitialAd
Los anuncios intersticiales se muestran en objetos InterstitialAd
, por lo que el primer paso para integrar anuncios intersticiales en tu app es crear e inicializar un objeto InterstitialAd
.
Agrega el siguiente encabezado al código C++ de tu app:
#include "firebase/gma/interstial_ad.h"
Declara y crea una instancia de un objeto
InterstitialAd
:firebase::gma::InterstitialAd* interstitial_ad; interstitial_ad = new firebase::gma::InterstitialAd();
Inicializa la instancia
InterstitialAd
con tu vista superior transmitida a un tipoAdParent
. La vista superior es una referenciajobject
de JNI a unActivity
de Android o un puntero a unUIView
de iOS.// my_ad_parent is a jobject reference to an Android Activity or // a pointer to an iOS UIView. firebase::gma::AdParent ad_parent = static_cast<firebase::gma::AdParent>(my_ad_parent); firebase::Future<void> result = interstitial_ad->Initialize(ad_parent);
Como alternativa a retener el futuro como una variable, puedes verificar el estado de la operación de inicialización de forma periódica invocando
InitializeLastResult()
en el objetoInterstitialAd
. Esto puede ser útil para hacer un seguimiento del proceso de inicialización en tu bucle de juego global.// Monitor the status of the future in your game loop: firebase::Future<void> result = interstitial_ad->InitializeLastResult(); if (result.status() == firebase::kFutureStatusComplete) { // Initialization completed. if(future.error() == firebase::gma::kAdErrorCodeNone) { // Initialization successful. } else { // An error has occurred. } } else { // Initialization on-going. }
Para obtener más información sobre cómo trabajar con firebase::Future
, consulta Cómo usar interfaces Future para supervisar el estado de las llamadas al método.
Carga un anuncio
Para cargar un anuncio, puedes utilizar el método LoadAd()
en el objeto InterstitialAd
. El método de carga requiere que hayas inicializado el objeto InterstitialAd
y que tengas el ID de tu unidad de anuncios y un objeto AdRequest
. Se muestra un firebase::Future
que puedes usar para supervisar el estado
y el resultado de la operación de carga.
En el siguiente código, se muestra cómo cargar un anuncio una vez que se inicializó correctamente InterstitialAd
:
firebase::gma::AdRequest ad_request;
firebase::Future<firebase::gma::AdResult> load_ad_result;
load_ad_result = interstitial_ad->LoadAd(interstitial_ad_unit_id, ad_request);
Regístrate para recibir devoluciones de llamada
Debes extender la clase FullScreenContentListener
para recibir notificaciones de presentación de anuncios intersticiales y eventos de ciclo de vida. Tu subclase personalizada de FullScreenContentListener
se puede registrar a través del método InterstitialAd::SetFullScreenContentListener()
y recibirá devoluciones de llamada cuando el anuncio se presente de forma correcta o incorrecta, así como cuando se descarte.
En el siguiente código, se muestra cómo extender la clase y asignarla al anuncio:
class ExampleFullScreenContentListener : public firebase::gma::FullScreenContentListener { public: ExampleFullScreenContentListener() {} void OnAdClicked() override { // This method is invoked when the user clicks the ad. } void OnAdDismissedFullScreenContent() override { // This method is invoked when the ad dismisses full screen content. } void OnAdFailedToShowFullScreenContent(const AdError& error) override { // This method is invoked when the ad failed to show full screen content. // Details about the error are contained within the AdError parameter. } void OnAdImpression() override { // This method is invoked when an impression is recorded for an ad. } void OnAdShowedFullScreenContent() override { // This method is invoked when the ad showed its full screen content. } }; ExampleFullScreenContentListener* full_screen_content_listener = new ExampleFullScreenContentListener(); interstitial_ad->SetFullScreenContentListener(full_screen_content_listener);
InterstitialAd
es un objeto de uso único. Esto significa que, una vez que se muestra un anuncio intersticial, no se puede volver a mostrar. Se recomienda cargar otro anuncio intersticial en el método OnAdDismissedFullScreenContent()
de tu FullScreenContentListener
para que el siguiente anuncio intersticial comience a cargarse en cuanto se cierre el anterior.
Cómo mostrar el anuncio
Los anuncios intersticiales deben mostrarse durante pausas naturales en el flujo de una app.
Un buen ejemplo es entre los niveles de un juego o después de que el usuario completa una tarea.
Si bien FullScreenContentListener
se puede usar para determinar cuándo un anuncio mostró su contenido de pantalla completa, el futuro que muestra Show()
también indicará cuándo se mostró el anuncio correctamente.
firebase::Future<void> result = interstitial_ad->Show();
Prácticas recomendadas
- Determina si los anuncios intersticiales son la clase de anuncio adecuada para tu app.
- Los anuncios intersticiales funcionan mejor en apps con puntos de transición naturales. La conclusión de una tarea dentro de una app, como compartir una imagen o completar un nivel de un juego, genera estos puntos. Debido a que el usuario espera una pausa en la acción, es fácil presentar un anuncio intersticial sin interrumpir su experiencia. Asegúrate de tener en cuenta los puntos del flujo de trabajo de tu app en los que mostrarás anuncios intersticiales y la posible respuesta del usuario.
- Recuerda pausar la acción cuando muestres un anuncio intersticial.
- Existen varios tipos de anuncios intersticiales: de texto, con imágenes, de video y mucho más. Es importante asegurarse de que, cuando tu app muestre un anuncio intersticial, también suspenda el uso de algunos recursos para que el anuncio los aproveche. Por ejemplo, cuando realices la llamada para mostrar un anuncio intersticial, asegúrate de pausar la salida de audio producida por tu app. Puedes reanudar la reproducción de sonidos en el método
OnAdDismissedFullScreenContent
de tuFullScreenContentListener
instalado, que se invocará cuando el usuario haya terminado de interactuar con el anuncio. Además, considera detener temporalmente cualquier tarea de cálculo intensa (como un bucle de juego) mientras se muestra el anuncio. Esto garantizará que el usuario no experimente gráficos lentos o que no respondan, ni videos entrecortados. - Proporciona un tiempo de carga adecuado.
- Así como es importante asegurarse de mostrar anuncios intersticiales en un momento adecuado, también lo es asegurarse de que el usuario no deba esperar a que se carguen. Cargar el anuncio con anticipación antes de mostrarlo puede garantizar que tu app tenga un anuncio intersticial completamente cargado y listo cuando llegue el momento de mostrarlo.
- No sobrecargues al usuario con anuncios.
- Si bien aumentar la frecuencia de los anuncios intersticiales de tu app podría parecer una gran manera de aumentar los ingresos, también puede afectar la experiencia del usuario y reducir las tasas de clics. Asegúrate de que la frecuencia de las interrupciones experimentadas por los usuarios no sea tan alta como para que estos ya no puedan disfrutar de tu app.
- No uses el futuro de carga completa para mostrar el anuncio intersticial.
- Esto puede generar una experiencia del usuario deficiente. En su lugar, carga previamente el anuncio antes de necesitar mostrarlo.
Recursos adicionales
Ejemplo en GitHub
- Consulta el código fuente de nuestra app de guía de inicio rápido de ejemplo en GitHub.
Instructivos de video de Mobile Ads Garage
Historias de éxito
Próximos pasos
- Si aún no lo has hecho, crea tu propia unidad de anuncios intersticiales en la IU de AdMob.
- Obtén información sobre la segmentación de anuncios y los lineamientos de anuncios intersticiales.