返回略過的廣告時段
透過集合功能整理內容
你可以依據偏好儲存及分類內容。
影片發布商可能會希望觀眾
尋找略過片中廣告使用者跳轉而略過廣告插播時
可以直接回到廣告插播的開始時間
廣告播放完畢後,就會前往尋找地點這個
功能稱為「回溯」
請參考下圖範例。觀眾正在觀看影片
並決定從 5 分鐘的標記跳轉至 15 分鐘的位置。
但在 10 分鐘標記處加入廣告插播時間點
然後才觀看內容:

如要顯示這個廣告插播時間點,請按照下列步驟操作:
- 檢查使用者是否跳轉到未觀看的廣告時段。
如果有,請將觀眾帶回廣告插播時間點
- 廣告插播時間點後,請回到原本的時間點。
圖表形式如下所示:

以下說明如何使用 IMA DAI SDK 導入備用廣告,如
進階範例。
避免跳轉,讓觀眾在不知情的情況下離開廣告插播時間
檢查使用者的跳轉廣告是否超過未觀看的廣告插播時間點。
如果有,請將觀眾帶回廣告插播時間點
在 HTML5 SDK 中,設定內容播放器 seeked
事件的事件監聽器
觸發 onSeekEnd()
。該方法 (如下所示) 會檢查提示點
。如果沒有播放,請跳到這個部分的開頭
取代原本的跳轉點,並儲存所需的搜尋點
snapForwardTime
中的跳轉點。
function onSeekEnd() {
if (isLiveStream) { return; }
if (isSnapback) {
isSnapback = false;
return;
}
var currentTime = videoElement.currentTime;
var previousCuePoint =
streamManager.previousCuePointForStreamTime(currentTime);
if (previousCuePoint && !previousCuePoint.played) {
isSnapback = true;
snapForwardTime = currentTime;
videoElement.currentTime = previousCuePoint.start;
}
讓使用者回到原本的搜尋頁面
現在當您收到 AD_BREAK_ENDED
事件時,請檢查 snapForwardTime
資源。如果是的話,請將使用者帶往串流的時間點,因為廣告
剛才觀看的打斷影片是挽回的結果:
function onAdBreakEnded(e) {
videoElement.controls = true;
clickElement.style.display = 'none';
adUiDiv.style.display = 'none';
if (snapForwardTime && snapForwardTime > videoElement.currentTime) {
videoElement.currentTime = snapForwardTime;
snapForwardTime = null;
}
}
除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。
上次更新時間:2025-08-21 (世界標準時間)。
[null,null,["上次更新時間:2025-08-21 (世界標準時間)。"],[[["\u003cp\u003eSnapback prevents viewers from skipping mid-roll ads by returning them to the start of the ad break if they seek past it.\u003c/p\u003e\n"],["\u003cp\u003eWhen a viewer seeks past an unwatched ad, snapback takes them back to the ad and then returns them to their intended location after the ad completes.\u003c/p\u003e\n"],["\u003cp\u003eImplementing snapback involves checking for seeks past unwatched ad breaks and redirecting the viewer accordingly using the IMA DAI SDK.\u003c/p\u003e\n"],["\u003cp\u003eDevelopers can use the \u003ccode\u003eseeked\u003c/code\u003e event and \u003ccode\u003epreviousCuePointForStreamTime\u003c/code\u003e function to detect and manage snapback scenarios within their video players.\u003c/p\u003e\n"],["\u003cp\u003eAfter an ad break initiated by snapback, the \u003ccode\u003eAD_BREAK_ENDED\u003c/code\u003e event and \u003ccode\u003esnapForwardTime\u003c/code\u003e variable are used to return the viewer to their original seek position.\u003c/p\u003e\n"]]],[],null,["# Return to a skipped ad break\n\nAs a video publisher, you may want to prevent your viewers from\nseeking past your mid-roll ads. When a user seeks past an ad break,\nyou can take them back to the start of that ad break, and then return\nthem to their seek location after that ad break has completed. This\nfeature is called \"snapback.\"\n\nAs an example, see the diagram below. Your viewer is watching a video,\nand decides to seek from the 5-minute mark to the 15-minute mark.\nThere is, however, an ad break at the 10-minute mark that you want\nthem to watch before they can watch the content after it:\n\nIn order to show this ad break, take the following steps:\n\n1. Check if the user ran a seek that jumped past an unwatched ad break, and if so, take them back to the ad break.\n2. After the ad break completes, return them to their original seek.\n\nIn diagram form, that looks like this:\n\nHere's how to implement snapback using the IMA DAI SDK, as demonstrated in\n[Advanced Example](https://github.com/googleads/googleads-ima-html5-dai/tree/master/hls_js/advanced).\n\nPrevent a seek from leaving an ad break unwatched\n-------------------------------------------------\n\nCheck if the user has run a seek that went past an unwatched ad break,\nand if so, take them back to the ad break.\nIn the HTML5 SDK, set an event listener on the content player's `seeked` event\nto trigger `onSeekEnd()`. That method (presented below) checks the cue point\nprior to the user's seek time. If it is unplayed, seek to the beginning of that\nad break instead of their initial desired seek point, and save that desired\nseek point in `snapForwardTime`. \n\n function onSeekEnd() {\n if (isLiveStream) { return; }\n if (isSnapback) {\n isSnapback = false;\n return;\n }\n var currentTime = videoElement.currentTime;\n var previousCuePoint =\n streamManager.previousCuePointForStreamTime(currentTime);\n if (previousCuePoint && !previousCuePoint.played) {\n isSnapback = true;\n snapForwardTime = currentTime;\n videoElement.currentTime = previousCuePoint.start;\n }\n\nPut the user back to their original seek\n----------------------------------------\n\nNow when you get an `AD_BREAK_ENDED` event, check to see if `snapForwardTime`\nis set. If so, take the user to that point in the stream, because the ad\nbreak they just watched was the result of snapback: \n\n function onAdBreakEnded(e) {\n videoElement.controls = true;\n clickElement.style.display = 'none';\n adUiDiv.style.display = 'none';\n if (snapForwardTime && snapForwardTime \u003e videoElement.currentTime) {\n videoElement.currentTime = snapForwardTime;\n snapForwardTime = null;\n }\n }"]]