Interactive Media Ads (IMA) Dynamic Ad Insertion SDK (DAI) 依赖于嵌入在媒体片段(带内元数据)或流式传输清单文件(清单内元数据)中的元数据信息来跟踪观看者的位置和客户端广告事件。元数据以不同格式从 DAI 流中提供,具体取决于正在播放的流的类型。IMA DAI SDK 通过单个 API 处理所有元数据格式。
您的应用负责捕获元数据并将其转发给 IMA DAI SDK。该 SDK 提供了 StreamManager.onMessage()
方法来传递此信息。此方法会转发由 roVideo 端口提供的 msg
对象形式的元数据。然后,IMA DAI SDK 会处理这些对象,以确定广告事件的时间。它接受一个实参:
msg
:由 roVideo 端口提供的消息类型对象。
元数据示例代码
以下示例展示了如何处理来自 roVideo 端口的元数据,并通过 StreamManager.onMessage()
将其传递给 IMA DAI SDK。
Sub runLoop()
' Forward all timed metadata events to IMA.
m.top.video.timedMetaDataSelectionKeys = ["*"]
' Cycle through all the fields and set listeners.
' IMPORTANT: Failure to listen to the position and timedmetadata fields could
' result in ad impressions not being reported.
m.port = CreateObject("roMessagePort")
fields = m.top.video.getFields()
for each field in fields
m.top.video.observeField(field, m.port)
end for
while True
msg = wait(1000, m.port)
if m.top.video = invalid
print "exiting"
exit while
end if
m.streamManager.onMessage(msg)
currentTime = m.top.video.position
If currentTime > 3 And not m.top.adPlaying
m.top.video.enableTrickPlay = true
End If
end while
End Sub
如需详细了解如何将循环处理流元数据纳入您的应用,请参阅 IMA Roku 入门指南。该指南的事件监听器和流启动部分包含元数据处理循环。
HLS CMAF 流
使用通用媒体应用框架 (CMAF) 的线性 DAI HLS 流会按照 ID3 通过 CMAF 标准,通过带内 eMSGv1 箱传递定时元数据。这些 eMSG 框嵌入在每个媒体段的开头,每个 ID3 eMSG 都包含一个相对于信息流中最后一个不连续点的 PTS。
对于 IMA Roku,所有 HLS CMAF 流都使用 eMSGv0 格式发送带内 ID3 数据。IMA 将 eMSGv0 格式提供的信息与视频对象中的信息相结合。
为了能够正确解析 HLS CMAF 流 ID3 事件,您必须使用 StreamRequest.videoObject
在流请求中发送视频对象。