IMA SDK 可用于通过直播视频和视频点播创收。 对于直播,您需要为每个广告插播时间点发出新的广告请求。 错开这些请求,以确保所有观看者不会同时请求广告,从而避免广告服务器不堪重负。
为了帮助解决此问题,IMA SDK 提供了 AdsRequest.liveStreamPrefetchSeconds
属性。此属性用于指定在您调用 AdsLoader.requestAds()
后,SDK 在连接到广告服务器之前应等待的最长时间(以秒为单位)。实际请求时间将随机化。例如,如果您将 AdsRequest.liveStreamPrefetchSeconds
设置为 30,则在您调用 AdsLoader.requestAds()
后,SDK 会等待 0 到 30 秒,然后才实际向服务器发出请求。
直播预提取实践
我们建议您在广告插播时段结束后立即预提取下一个广告插播时段。 这样可确保预取窗口具有最长的时间长度。假设您在广告插播时间点之间有 5 分钟的间隔。广告插播时间点结束后,您可以请求下一个广告插播时间点,预提取时间窗口为 290 秒(5 分钟减去 10 秒,以确保在预提取时间窗口结束时发送的请求有足够的时间来解析):
// 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 IMA HTML5 client-side "Set up the IMA SDK" guide:
// https://developers.google.com/interactive-media-ads/docs/sdks/html5/client-side/get-started
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>);
adsManager.start();
}