Canlı Yayını Önceden Getirme

IMA SDK, canlı yayınların yanı sıra seç-izle videolardan para kazanmak için kullanılabilir. Canlı yayınlarda her reklam arası için yeni bir reklam isteği göndermeniz gerekir. Bu istekleri, tüm izleyicilerinizin aynı anda reklam istemediğinden ve reklam sunucularında sorun yaşamadığından emin olmak için düzenleyin.

IMA SDK, bu konuda yardımcı olması için AdsRequest.liveStreamPrefetchSeconds özelliğine sahiptir. Bu özellik, AdsLoader.requestAds() çağrısından sonra SDK'nın reklam sunucusuna ulaşmadan önce beklemesi gereken maksimum saniye sayısını belirtir. Gerçek istek süresi rastgele belirlenecektir. Örneğin, AdsRequest.liveStreamPrefetchSeconds öğesini 30 değerine ayarlarsanız SDK, isteği sunucuya gerçekten yapmak için AdsLoader.requestAds() çağrısından sonra 0 ila 30 saniye bekler.

Uygulamada canlı yayın önceden getirme işlemi

Reklam arası tamamlanır tamamlanmaz bir sonraki reklam aranızı önceden getirmenizi öneririz. Bu, önceden getirme aralığınız için maksimum sürenin kullanılabilmesini sağlar. Reklam araları arasında 5 dakika olduğunu varsayalım. Reklam arası tamamlandığında, 290 saniyelik bir önceden getirme aralığıyla (önceden getirme aralığının sonunda gönderilen isteklerin çözümlenmek için yeterli zamana sahip olduğundan emin olmak amacıyla 5 dakika eksi 10 saniye) bir sonraki reklam aranızı isteyebilirsiniz:

Objective-C


- (void)adsManager:(IMAAdsManager *)adsManager didReceiveAdEvent:(IMAAdEvent *)event {

  ...

  switch (event.type) {

    ...

    case kIMAAdEvent_ALL_ADS_COMPLETED:

      IMAAdsRequest *request = [[IMAAdsRequest alloc]
             initWithAdTagUrl: self.adTagUrl
           adDisplayContainer: self.adDisplayContainer
         avPlayerVideoDisplay: self.avPlayerVideoDisplay
        pictureInPictureProxy: self.pictureInPictureProxy
                  userContext: nil];

      // set a delay between the end of the last ad
      // in the last request, and the first ad from
      // the new request
      Float64 adGap = 30;
      // make sure the request occurs at least five
      // seconds before starting the new set of ads
      request.liveStreamPrefetchSeconds = adGap - 5;
      [self.adsLoader requestAdsWithRequest:request];
      // start new ads after adGap seconds have elapsed
      dispatch_after(dispatch_time(DISPATCH_TIME_NOW, adGap * NSEC_PER_SEC), dispatch_get_main_queue(), ^{
        [adsManager start];
      });

      break;

    ...

  }

  ...

}

Swift

func adsManager(_ adsManager: IMAAdsManager!, didReceive event: IMAAdEvent!) {
  switch event.type {

    ...

    case IMAAdEventType.ALL_ADS_COMPLETED:

      let request = IMAAdsRequest(
        adTagUrl: AdTagUrl,
        adDisplayContainer: adDisplayContainer,
        contentPlayhead: contentPlayhead,
        userContext: nil)

      // set a delay between the end of the last ad
      // in the last request, and the first ad from
      // the new request
      let adGap = 30
      // make sure the request occurs at least five
      // seconds before starting the new set of ads
      request.liveStreamPrefetchSeconds = adGap - 5
      adsLoader.requestAds(with: request)
      // start new ads after adGap seconds have elapsed
      DispatchQueue.main.asyncAfter(deadline: .now() + adGap) {
        adsManager.start()
      }

      break

    ...
  }
}