返回到跳过的广告插播时间点

选择平台HTML5 Android iOS tvOS Roku

作为视频发布商,您可能不希望观看者跳过中贴片广告。当用户跳过广告插播时间点时,您可以将他们带回该广告插播时间点的起始处,并在该广告插播时间点结束后将他们返回至其跳转时的位置。此功能称为“跳回”。

例如,请参阅下图。您的观看者正在观看视频,并决定从 5 分钟标记处跳转到 15 分钟标记处。 不过,在 10 分钟标记处有一个广告插播时间点,您希望他们先观看该广告插播时间点,然后才能观看其后的内容:

如需展示此广告插播时间点,请按以下步骤操作:

  1. 检查用户是否执行了跳转,跳过了未观看的广告插播时间点,如果是,则将他们带回广告插播时间点。
  2. 广告插播时间点结束后,将他们返回至其原始跳转位置。

以图表形式表示如下:

下面介绍了如何使用 IMA DAI SDK 实现跳回功能,如 AdvancedExample中所示。

防止跳转导致广告插播时间点未被观看

检查用户是否执行了跳转,跳过了未观看的广告插播时间点,如果是,则将他们带回广告插播时间点。tvOS 高级示例利用了 AVPlayerViewController,该类具有一个委托方法,可告知您用户已执行跳转。 如果跳转开始时间早于上一个广告插播时间点(这意味着用户已跳过该广告插播时间点),并且该广告插播时间点尚未播放,则将用户跳转回广告插播时间点的起始处。此外,请记录 最初请求的跳转的开始时间,以便稍后在ad-break-did-end处理程序中进行检查:

- (void)playerViewController:(AVPlayerViewController *)playerViewController
  willResumePlaybackAfterUserNavigatedFromTime:(CMTime)oldTime
                      toTime:(CMTime)targetTime {
  if (self.streamManager) {
    IMACuepoint *prevCuepoint = [self.streamManager
        previousCuepointForStreamTime:CMTimeGetSeconds(targetTime)];
    if (prevCuepoint && !prevCuepoint.isPlayed && oldTime < prevCuepoint.startTime) {
      self.userSeekTime = CMTimeGetSeconds(targetTime);
      [self.playerViewController.player seekToTime:CMTimeMakeWithSeconds(
                 prevCuepoint.startTime, NSEC_PER_SEC)
                 toleranceBefore:kCMTimeZero
                  toleranceAfter:kCMTimeZero];
    }
  }
}

将用户返回至其原始跳转位置

在您的事件委托中,修改 AD_BREAK_ENDED 案例,以检查上一个广告插播时间点是否因跳回而播放。


- (void)streamManager:(IMAStreamManager *)streamManager didReceiveAdEvent:(IMAAdEvent *)event {
  NSLog(@"StreamManager event (%@).", event.typeString);
  switch (event.type) {
    // Your other events go here as normal.
    case kIMAAdEvent_AD_BREAK_ENDED: {
      if (self.userSeekTime > 0) {
        self.playerViewController.player
            seekToTime:CMTimeMakeWithSeconds(self.userSeekTime, NSEC_PER_SEC)
        toleranceBefore:kCMTimeZero
        toleranceAfter:kCMTimeZero];
        self.userSeekTime = 0;

      // existing handling for AD_BREAK_ENDED goes here.
      break;
    }
    // And so on for other events.
    default:
      break;
  }
}