El SDK de IMA se puede usar para monetizar transmisiones en vivo y videos on demand. En el caso de las transmisiones en vivo, debes realizar una solicitud de anuncio nueva para cada pausa. Escalona las solicitudes para asegurarte de que los usuarios no las soliciten. anuncios al mismo tiempo y sobrecargar los servidores de anuncios.
Para facilitar esta tarea, el SDK de IMA tiene la AdsRequest.liveStreamPrefetchSeconds
propiedad. Esta propiedad especifica la cantidad máxima de segundos que el SDK
debería esperar antes de comunicarse con el servidor de anuncios después de llamar
AdsLoader.requestAds()
El tiempo real de la solicitud será aleatorio. Para
Por ejemplo, si configuras AdsRequest.liveStreamPrefetchSeconds
en 30, el SDK
espera entre 0 y 30 segundos después de que llamas a AdsLoader.requestAds()
para
realizar la solicitud al servidor.
Carga previa de la transmisión en vivo en práctica
Te recomendamos que precargues tu próxima pausa publicitaria en cuanto finalice la pausa. Esto garantiza que el tiempo máximo esté disponible para tu período de carga previa. Supongamos que tienes 5 minutos entre las pausas publicitarias. Cuando finaliza una pausa publicitaria, Puedes solicitar tu próxima pausa publicitaria con una ventana de carga previa de 290 segundos. (5 minutos menos 10 segundos, para asegurarnos de que las solicitudes enviadas al final del la ventana de carga previa tienen tiempo suficiente para resolverse):
Estos fragmentos de código muestran cómo agregar la precarga de transmisión en vivo al Ejemplo avanzado , aunque puede aplicarse a otras implementaciones de IMA.
VideoPlayerController.java
/** Ads logic for handling the IMA SDK integration code and events. */ public class VideoPlayerController { // 5 minutes == 300 seconds. Include a 10 second buffer private float AD_INTERVAL = 290; private double AD_TIMEOUT = 300; ... adsManager.addAdEventListener( new AdEvent.AdEventListener() { /** Responds to AdEvents. */ @Override public void onAdEvent(AdEvent adEvent) { ... case ALL_ADS_COMPLETED: if (adsManager != null) { adsManager.destroy(); adsManager = null; } // When pre-fetching for live streams, be sure to destroy the current AdsManager, // in case the tag you requested previously contains post-rolls // (you don't want to play those now). // Pre-fetch the next ad break. // Play those ads in ~5 minutes. In a real-world implementation, // this will likely be done as the result of a message from your // streaming server, not a via the playAdsAfterThisTime parameter // of requestAndPlayAds(). requestAndPlayAds(AD_TIMEOUT); break; default: break; } } ... public void requestAndPlayAds(double playAdsAfterThisTime) { if (currentAdTagUrl == null || currentAdTagUrl == "") { log("No VAST ad tag URL specified"); resumeContent(); return; } // Since you're switching to a new video, tell the SDK the previous video is finished. if (adsManager != null) { adsManager.destroy(); } playButton.setVisibility(View.GONE); // Create the ads request. AdsRequest request = sdkFactory.createAdsRequest(); request.setAdTagUrl(currentAdTagUrl); request.setContentProgressProvider(videoPlayerWithAdPlayback.getContentProgressProvider()); request.setLiveStreamPrefetchSeconds(AD_INTERVAL); playAdsAfterTime = playAdsAfterThisTime; // Request the ad. After the ad is loaded, onAdsManagerLoaded() will be called. adsLoader.requestAds(request); }