实时主内容
创建对象:
- 用户
- 管理员
- 开发人员
方案
在此方案中,有一个实时资源,在加入实时流后 40 秒内不播放任何广告。
触发器 | 心跳方法 | 网络调用 | 注释 |
---|---|---|---|
用户点击 播放 | trackSessionStart | Analytics 内容开始,心跳内容开始 | 这可以是用户点击 播放 或自动播放事件。 |
播放媒体的第一帧。 | trackPlay | 心率内容播放 | 此方法将触发计时器。只要继续播放,就会每 10 秒发送一次心跳。 |
将播放内容。 | 内容心率 | ||
会话结束。 | trackSessionEnd | SessionEnd 是指观看会话结束。即使用户没有观看至媒体结束,也必须调用此 API。 |
参数
您在 Adobe Analytics 内容开始调用中看到的很多值,同样也会在心率内容开始调用中看到。您还会看到许多其他参数,Adobe 使用这些参数填充 Adobe Analytics 中的各种媒体报表。我们不会在这里涵盖所有这些变量,而是只列出一些非常重要的变量。
心率内容开始
参数 | 值 | 注释 |
---|---|---|
s:sc:rsid | <您的 Adobe 报表包 ID> | |
s:sc:tracking_serve | <您的 Analytics 跟踪服务器 URL> | |
s:user:mid | s:user:mid | 应当匹配 Adobe Analytics 内容开始调用中的中间值 |
s:event:type | "start" | |
s:asset:type | "main" | |
s:asset:mediao_id | <您的媒体名称> | |
s:stream:type | live | |
s:meta:* | 可选 | 对媒体设置的自定义元数据 |
内容心率
在媒体播放期间,有一个计时器将会每 10 秒发送一次主内容的一个或多个心率(或 ping),每 1 秒发送一次广告的一个或多个心率(或 ping)。这些心率将包含有关播放、广告、缓冲和许多其他内容的信息。每个心跳的确切内容不在本文档涵盖的范围之内,验证的关键内容是在持续播放期间始终触发心跳。
在内容心跳中,查找一些特定的内容:
参数 | 值 | 注释 |
---|---|---|
s:event:type | "play" | |
l:event:playhead | <播放头位置> 例如,50、60、70 | 这应该反映播放头的当前位置。 |
心率内容结束
由于实时流从不结束,因此这种情况下不会有结束调用。
播放头值设置
对于 LIVE 流,您需要将播放头值设置为自当天 UTC 午夜开始的秒数,以便在报告中,分析人员可以确定用户在 24 小时视图内何时加入和离开 LIVE 流。
开始时
对于 LIVE 媒体,当用户开始播放流时,您需要将 l:event:playhead
设置为自当天 UTC 午夜以来的秒数。这与 VOD 相反,在 VOD 中,您需要将播放头设置为“0”。请注意:使用进度标记时,需要内容持续时间,并且播放头需要更新为从媒体项目开始的秒数,从 0 开始。
例如,假设实时流事件从午夜开始,并且持续 24 小时(a.media.length=86400
;l:asset:length=86400
)。然后,再假设某位用户在中午 12:00 开始播放该实时流。在这种场景下,您应该将 l:event:playhead
设置为 43200(自当天 UTC 午夜起 12 小时,以秒为单位)。
暂停时
当用户暂停播放时,必须应用在播放开始时所应用的相同“实时播放头”逻辑。当用户返回播放 LIVE 流时,您必须根据自午夜 UTC 以来的新秒数设置 l:event:playhead
值,不是 到用户暂停 LIVE 流的点。
示例代码
Android
以下是预期的 API 调用顺序:
// Set up mediaObject
MediaObject mediaInfo = MediaHeartbeat.createMediaObject(
Configuration.MEDIA_NAME,
Configuration.MEDIA_ID,
Configuration.MEDIA_LENGTH,
MediaHeartbeat.StreamType.LIVE
);
HashMap<String, String> mediaMetadata = new HashMap<String, String>();
mediaMetadata.put(CUSTOM_VAL_1, CUSTOM_KEY_1);
mediaMetadata.put(CUSTOM_VAL_2, CUSTOM_KEY_2);
// 1. Call trackSessionStart() when the user clicks Play or if autoplay is used,
// i.e., there is an intent to start playback.
_mediaHeartbeat.trackSessionStart(mediaInfo, mediaMetadata);
......
......
// 2. Call trackPlay() when the playback actually starts, i.e., when the first
// frame of main content is rendered on the screen.
_mediaHeartbeat.trackPlay();
.......
.......
// 3. Call trackSessionEnd() when user ends the playback session.
// Since the user does not watch live media to completion, there
// is no need to call trackComplete().
_mediaHeartbeat.trackSessionEnd();
.......
.......
iOS
以下是预期的 API 调用顺序:
// Set up mediaObject
ADBMediaObject *mediaObject =
[ADBMediaHeartbeat createMediaObjectWithName:MEDIA_NAME
length:MEDIA_LENGTH
streamType:ADBMediaHeartbeatStreamTypeLIVE];
NSMutableDictionary *mediaContextData = [[NSMutableDictionary alloc] init];
[mediaContextData setObject:CUSTOM_VAL_1 forKey:CUSTOM_KEY_1];
[mediaContextData setObject:CUSTOM_VAL_2 forKey:CUSTOM_KEY_2];
// 1. Call trackSessionStart when the user clicks Play or if autoplay is used,
// i.e., there is an intent to start playback.
[_mediaHeartbeat trackSessionStart:mediaObject data:mediaContextData];
......
......
// 2. Call trackPlay when the playback actually starts, i.e., when the first
// frame of the main content is rendered on the screen.
[_mediaHeartbeat trackPlay];
.......
.......
// 3. Call trackSessionEnd when user ends the playback session. Since the user
// does not watch live media to completion, there is no need to call
// trackComplete.
[_mediaHeartbeat trackSessionEnd];
........
........
JavaScript
以下是预期的 API 调用顺序:
// Set up mediaObject
var mediaInfo =
MediaHeartbeat.createMediaObject(Configuration.MEDIA_NAME,
Configuration.MEDIA_ID,
Configuration.MEDIA_LENGTH,
MediaHeartbeat.StreamType.VOD);
var mediaMetadata = {
CUSTOM_KEY_1 : CUSTOM_VAL_1,
CUSTOM_KEY_2 : CUSTOM_VAL_2,
CUSTOM_KEY_3 : CUSTOM_VAL_3
};
// 1. Call trackSessionStart() when Play is clicked or if autoplay
// is used, i.e., there's an intent to start playback.
this._mediaHeartbeat.trackSessionStart(mediaInfo, mediaMetadata);
......
......
// 2. Call trackPlay() when the playback actually starts, i.e., when the
// first frame of media is rendered on the screen.
this._mediaHeartbeat.trackPlay();
.......
.......
// 3. Call trackSessionEnd() when user ends the playback session.
// Since user does not watch live media to completion, there is
// no need to call trackComplete().
this._mediaHeartbeat.trackSessionEnd();
........
........