完整事件重播(FER)是一種可作為即時/DVR資產的VOD資產,因此您的應用程式必須採取措施以確保廣告正確放置。
對於即時內容,TVSDK會使用資訊清單中的中繼資料/提示來決定放置廣告的位置。 不過,有時即時/線性內容可能會類似VOD內容。 例如,當即時內容完成時, EXT-X-ENDLIST
標籤會附加至即時資訊清單。 若為HLS,則為 EXT-X-ENDLIST
標籤表示資料流是VOD資料流。 若要正確插入廣告,TVSDK無法自動區分此串流與典型VOD串流。
您的應用程式必須透過指定 AdSignalingMode
.
對於FER資料流,Adobe Primetime ad decisioning伺服器不應提供在開始播放之前需要在時間軸上插入的廣告插播清單。 這是VOD內容的典型程式。 相反地,透過指定不同的訊號模式,TVSDK會從FER資訊清單讀取所有提示點,並前往廣告伺服器讓每個提示點請求廣告插播。 此程式類似於即時/DVR內容。
除了與提示點相關聯的每個請求之外,TVSDK還會針對前段廣告提出額外的廣告請求。
從外部來源(例如vCMS)取得應使用的訊號模式。
建立廣告相關中繼資料。
如果預設行為必須覆寫,請指定 AdSignalingMode
藉由使用 AdvertisingMetadata.setSignalingMode
.
有效值為 DEFAULT
, SERVER_MAP
、和 MANIFEST_CUES
.
呼叫之前,您必須設定廣告訊號模式 prepareToPlay
. 在TVSDK開始解析廣告並將其放置在時間軸上後,廣告訊號模式的變更會被忽略。 建立時設定模式 AuditudeSettings
物件。
繼續播放。
MediaPlayer mediaPlayer =
new MediaPlayer(getActivity.().getApplicationContext());
AuditudeSettings auditudeSettings = new AuditudeSettings();
auditudeSettings.setSignalingMode(AdSignalingMode.MANIFEST_CUES);
auditudeSettings.setDomain("your-auditude-domain");
auditudeSettings.setZoneId("your-auditude-zone-id");
auditudeSettings.setMediaId("your-media-id");
// set additional targeting parameters or custom parameters
MediaPlayerItemConfig itemConfig =
new MediaPlayerItemConfig(getActivity().getApplicationContext());
MediaResource mediaResource =
new MediaResource("https://example.com/media/test_media.m3u8",
MediaResource.Type.HLS, Metadata);
mediaPlayer.addEventListener(MediaPlayerEvent.STATUS_CHANGED,
new StatusChangeEventListener() {
@Override
public void onStatusChanged(MediaPlayerStatusChangeEvent event) {
if (status == MediaPlayerStatus.INITIALIZED) {
mediaPlayer.prepareToPlay();
}
else if( event.getStatus() == MediaPlayerStatus.PREPARED ) {
// TVSDK is in the PREPARED state, so start the playback
mediaPlayer.play();
}
else if( event.getStatus() == MediaPlayerStatus.COMPLETE ) {
// playback has reached the end of stream ( ads included )
// if we want to rewind we can call
mediaPlayer.seek(mediaPlayer.getSeekableRange().getBegin());
}
}
});
mediaPlayer.replaceCurrentResource(mediaResource, itemConfig);