Carga anuncios previos al video para transmisiones en vivo

Selecciona la plataforma: HTML5 Android iOS tvOS

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 nueva solicitud de anuncio para cada pausa publicitaria. Escalona estas solicitudes para garantizar que todos tus usuarios no soliciten anuncios al mismo tiempo y ralenticen los servidores de anuncios.

Para ayudarte con esto, el SDK de IMA tiene la propiedad AdsRequest.liveStreamPrefetchSeconds. Esta propiedad especifica la cantidad máxima de segundos que el SDK debe esperar antes de comunicarse con el servidor de anuncios después de que llames a AdsLoader.requestAds(). La hora real de la solicitud se aleatorizará. 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.

Prefetch de transmisiones en vivo en la práctica

Te recomendamos que realices una recuperación previa de tu próxima pausa publicitaria en cuanto finalice una. Esto garantiza que la ventana de recuperación previa tenga la duración máxima posible. Supongamos que tienes 5 minutos entre pausas publicitarias. Cuando finaliza una pausa publicitaria, puedes solicitar la siguiente con una ventana de carga previa de 290 segundos (5 minutos menos 10 segundos, para asegurarte de que las solicitudes enviadas al final de la ventana de carga previa tengan tiempo suficiente para resolverse):

En estos fragmentos de código, se muestra cómo agregar la recuperación previa de transmisiones en vivo al ejemplo avanzado, pero el enfoque se puede aplicar a otras implementaciones del 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 through 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);
}