IMA SDK можно использовать для монетизации прямых трансляций, а также видео по запросу. Для прямых трансляций необходимо создавать новый запрос рекламы для каждой рекламной паузы. Распределите эти запросы по времени, чтобы все ваши зрители не запрашивали рекламу одновременно и не перегружали рекламные серверы.
Для решения этой проблемы в IMA SDK есть свойство AdsRequest.liveStreamPrefetchSeconds
. Это свойство определяет максимальное количество секунд, которое SDK должен ждать перед обращением к рекламному серверу после вызова AdsLoader.requestAds()
. Фактическое время запроса будет рандомизировано. Например, если задать для AdsRequest.liveStreamPrefetchSeconds
значение 30, SDK будет ждать от 0 до 30 секунд после вызова AdsLoader.requestAds()
, чтобы фактически отправить запрос к серверу.
Предварительная выборка в прямом эфире на практике
Мы рекомендуем предварительно загружать следующую рекламную паузу сразу после завершения предыдущей. Это обеспечивает максимальную продолжительность окна предварительной загрузки. Предположим, между рекламными паузами у вас 5 минут. После завершения рекламной паузы вы можете запросить следующую рекламную паузу с окном предварительной загрузки 290 секунд (5 минут минус 10 секунд, чтобы убедиться, что запросы, отправленные в конце окна предварительной загрузки, успеют обработаться):
В этих фрагментах кода показано, как добавить предварительную выборку прямой трансляции в расширенный пример , но этот подход можно применить и к другим реализациям 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); }