Solicitud previa de transmisión en vivo

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):

// 5 minutes == 300 seconds. Include a 10 second buffer
var AD_INTERVAL = 290;

function onAdEvent(adEvent) {
  var ad = adEvent.getAd();
  switch(adEvent.type) {
    case google.ima.AdEvent.Type.ALL_ADS_COMPLETED:
      // Pre-fetch our next ad break.
      requestAds();
      // Play those ads in 5 minutes. In a real-world implementation,
      // this is likely done as the result of a message from your
      // streaming server, not a timeout.
      setTimeout(playAds, AD_INTERVAL * 1000);// Convert to ms.
  }
}

function requestAds() {
  // Destroy the current AdsManager, in case the tag you requested previously
  // contains post-rolls (don't play those now).
  if (adsManager) {
    adsManager.destroy();
  }
  // Your AdsLoader will be set up on page-load. You should re-use the same
  // AdsLoader for every request. For more info on setting up the AdsLoader,
  // see the "Get Started" guide in the prerequisites above.
  if (adsLoader) {
    // Reset the IMA SDK.
    adsLoader.contentComplete();
  }
  var adsRequest = new google.ima.AdsRequest();
  adsRequest.adTagUrl = '...';
  adsRequest.linearAdSlotWidth = <linear_width>;
  adsRequest.linearAdSlotHeight = <linear_height>;
  adsRequest.nonLinearAdSlotWidth = <nonlinear_width>;
  adsRequest.nonLinearAdSlotHeight = <nonlinear_height>;
  adsRequest.liveStreamPrefechSeconds = AD_INTERVAL;
  adsLoader.requestAds(adsRequest);
}

function playAds() {
  adsManager.init(
      <linear_width>,  <linear_height>, google.ima.ViewMode.NORMAL);
  adsManager.start();
}