自动制作广告播放列表

请选择平台HTML5 Android iOS tvOS

IMA Android SDK 支持完全自动化的广告播放列表。此功能可在投放广告时,按照 Google Ad Manager 中的指定将广告插播时间点插入到内容中。它还大大简化了支持广告插播(包括前贴片广告、中贴片广告和后贴片广告)所需的视频播放器代码。

  • 在 Ad Manager 中投放广告时,可以指定各种广告规则,例如“始终在内容开头插播广告”或“每 30 分钟的内容插播 1 分钟的广告”。
  • 请求广告时,广告服务器可以返回广告播放列表。SDK 会处理播放列表,并自动安排已指定的广告插播时间。
  • 由于 Android 对广告和内容播放使用相同的视频播放器,因此如果您计划实现广告规则,则必须在广告开始时保存内容的播放头位置,然后在广告结束时搜索到该位置。 请务必在视频播放器中实现 VideoAdPlayer 接口。这样可确保系统在 Ad Manager 中指定的时间自动插入广告插播时间点。
    private boolean playingContent = true;
    private int contentPosition = -1;
    private List callbacks =
        new ArrayList();
    
    @Override
    public void addCallback(VideoAdPlayerCallback callback) {
      callbacks.add(callback);
    }
    
    @Override
    public void removeCallback(VideoAdPlayerCallback callback) {
      callbacks.remove(callback);
    }
    
    public void loadContent() {
      playingContent = true;
      load(CONTENT_URL);
    }
    
    @Override
    public void loadAd(String mediaUrl) {
      playingContent = false;
      load(mediaUrl);
    }
    
    public void pauseContent() {
      savePosition();
      pause();
    }
    
    @Override
    public void pauseAd() {
      pause();
    }
    
    private void pause() {
      myVideoView.pause();
      for (VideoAdPlayerCallback callback : callbacks) {
        callback.onPause();
      }
    }
    
    public void resumeContent() {
      loadContent();
      if (contentPosition > 0) {
        restorePosition();
      }
      resume();
    }
    
    @Override
    public void resumeAd() {
      resume();
    }
    
    private void resume() {
      myVideoView.start();
      for (VideoAdPlayerCallback callback : callbacks) {
        callback.onResume();
      }
    }
    
    public void savePosition() {
      contentPosition = myVideoView.getCurrentPosition();
    }
    
    public void restorePosition() {
      myVideoView.seekTo(contentPosition);
    }
  • CONTENT_PAUSE_REQUESTEDCONTENT_RESUME_REQUESTED 事件用于在播放广告插播时暂停和恢复内容。如需详细了解这些事件,请参阅相关的 API 文档

注意:当内容播放完毕或用户停止播放时,请务必调用 AdsLoader.contentComplete,以便向 SDK 发出内容已播放完毕的信号。然后,SDK 会播放预定的后贴片广告插播时间。当所有广告时段都已播放完毕时,系统会触发 ALL_ADS_COMPLETED 事件。此外,请注意,当调用 init() 时,内容跟踪即会开始,并且您应始终在播放内容之前调用 init()