启用开放式衡量

请选择平台HTML5 Android iOS

适用于 Android 的 IMA SDK 包含 Open Measurement (OM) SDK, 这是由 美国互动广告局 (IAB) 开发的业界标准,用于实现第三方 可见度和验证衡量。使用适用于 Android 的 IMA SDK 时,其中包含的 OM SDK 会自动解析 <AdVerifications> 标记,并使用 OMID API 将可见度数据发送给 指定的衡量供应商。IMA SDK 支持 OM SDK v1.4、VAST 2+ 上的 GAM AdVerifications 扩展程序,以及 VAST 4+ 上的 AdVerifications 节点。如需利用 Open Measurement,请注意以下几点:

  • 如需使用 Open Measurement,您必须拥有适用于 Android 的 IMA SDK 3.11.0 或更高版本。 不过,本指南中的示例是为最新版本的 SDK 设计的,其中包含 3.16.5 版中引入的 API。

  • 如果使用 VAST 4.1+,则必须按照 VAST 4.1 规范 将广告配置为在 VAST 中投放 <AdVerifications>;否则,应使用 <Extension type="AdVerifications">

  • 请勿使用任何叠加层(透明或不透明)覆盖 AdDisplayContainer,因为这些叠加层会被 OM SDK 标记为障碍物,并降低可见度。

前提条件

测试

如需使用 IMA SDK 测试 Open Measurement,请使用支持 OM SDK 的 IMA 版本以及 测试广告代码

您应该会在 VAST 响应中看到返回的 <AdVerifications>

注册视频控件叠加层障碍物

暂停按钮或进度条等视频控件可为用户提供重要的播放信息和操作。在移动设备上,由于点击不精确和用户期望,在媒体元素上呈现大型、易于触摸的控件已成为常见做法。这些控件通常会在用户点击时淡入和淡出,并且在绝大多数播放时间内都不可见。

如需查看叠加视频控件的示例,请参阅 YouTube 应用呈现控件的下图:

打开测量叠加层示例图片

使用 IMA SDK 时,大多数发布商都会通过在广告展示容器上方添加一个几乎完全透明的视图来实现这些控件。通常,这些控件是此视图的子元素,它们会完全遮挡底层的视频播放器。此透明叠加层用于捕获点击事件,然后在用户点击时向用户呈现控件。

在使用 Open Measurement SDK 计算广告可见度时,叠加在媒体元素上的所有视图都被视为障碍物,并会降低可见率。如果透明点击叠加层位于整个广告展示容器上方,则广告资源可能会被声明为完全不可见。

Open Measurement SDK 规定,视频控件应被视为对用户体验至关重要的“友好”障碍物。注册为友好后,这些控件将从广告可见度衡量中排除。

在 IAB 和 MRC 的支持下,IMA SDK 引入了一个 API,用于向 Open Measurement 衡量 SDK 注册这些叠加层。这些控件必须是完全透明的叠加层或小按钮。不得注册与视频控件无关的任何其他视图。

请注册 请勿注册
  • 用于捕获用户点击的透明叠加层
  • 临时按钮
    • 暂停
    • 播放
    • 全屏
    • 投放/AirPlay
    • 收起
    • 进度/快进
    • 其他与播放相关的操作
  • 水印
  • 弹出式广告
  • 对话框
  • 非临时按钮
  • 其他遮挡视图

以下示例代码演示了如何在广告展示容器上注册视频控件叠加层:

private void registerFriendlyObstructions(
    AdDisplayContainer adDisplayContainer, View transparentTapOverlay, View pauseButton) {
  ImaSdkFactory imaSdkFactory = ImaSdkFactory.getInstance();
  // Make sure to register all friendly obstructions before ad playback starts.
  FriendlyObstruction overlayObstruction =
      imaSdkFactory.createFriendlyObstruction(
          transparentTapOverlay,
          FriendlyObstructionPurpose.NOT_VISIBLE,
          "This overlay is transparent");
  FriendlyObstruction pauseButtonObstruction =
      imaSdkFactory.createFriendlyObstruction(
          pauseButton,
          FriendlyObstructionPurpose.VIDEO_CONTROLS,
          "This is the video player pause button");

  adDisplayContainer.registerFriendlyObstruction(overlayObstruction);
  adDisplayContainer.registerFriendlyObstruction(pauseButtonObstruction);
}

使用完毕后,可以通过调用以下方法移除这些障碍物:

private void unregisterFriendlyObstructions(AdDisplayContainer adDisplayContainer) {
  adDisplayContainer.unregisterAllFriendlyObstructions();
}