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

请选择平台HTML5 Android iOS tvOS Roku

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

例如,请参见下图。观看者正在观看视频,并决定从 5 分钟标记处快进到 15 分钟标记处。 不过,您希望观看者在观看 10 分钟后的内容之前先观看 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;
  }
}