Pakiet IMA SDK pozwala zarabiać zarówno na transmisjach na żywo, jak i filmach na żądanie. W przypadku transmisji na żywo dla każdej przerwy na reklamę musisz wysłać nowe żądanie reklamy. Rozłóż te prośby w czasie, aby mieć pewność, że żaden z Twoich widzów nie wysyła próśb i mocno nadmiernie spowalnia serwery reklam.
Aby Ci w tym pomóc, pakiet IMA SDK zawiera AdsRequest.liveStreamPrefetchSeconds
usłudze. Ta właściwość określa maksymalną liczbę sekund, przez jaką pakiet SDK
powinien poczekać przed nawiązaniem połączenia z serwerem reklam
AdsLoader.requestAds()
Rzeczywisty czas żądania będzie randomizowany. Dla:
Jeśli np. ustawisz AdsRequest.liveStreamPrefetchSeconds
na 30, pakiet SDK
czeka od 0 do 30 sekund po wywołaniu usługi AdsLoader.requestAds()
,
wysyła żądanie do serwera.
Pobieranie z wyprzedzeniem transmisji na żywo w praktyce
Zalecamy pobranie z wyprzedzeniem kolejnej przerwy na reklamę zaraz po jej zakończeniu. Dzięki temu możesz mieć pewność, że jest dostępny maksymalny czas pobierania z wyprzedzeniem. Załóżmy, że masz 5-minutowe przerwy na reklamę. Po zakończeniu przerwy na reklamę możesz poprosić o następną przerwę na reklamę, gdy okno pobierania z wyprzedzeniem będzie wynosić 290 sekund (5 minut minus 10 sekund, aby mieć pewność, że żądania wysłane pod koniec okres pobierania z wyprzedzeniem musi zostać rozwiązany).
Te fragmenty kodu pokazują, jak dodać pobieranie transmisji z wyprzedzeniem do tagu Przykład zaawansowany , ale możesz też zastosować tę metodę w innych implementacjach 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);
}