Pakiety IMA SDK ułatwiają integrację reklam multimedialnych z witrynami i aplikacjami. Pakiety IMA SDK mogą wysyłać żądania reklam do dowolnego serwera reklam zgodnego z VAST i zarządzać odtwarzaniem reklam w aplikacjach. Za pomocą pakietów IMA DAI SDK aplikacje wysyłają żądanie strumienia reklamy i treści wideo – VOD lub treści na żywo. Pakiet SDK zwraca wtedy połączony strumień wideo, dzięki czemu nie musisz zarządzać przełączaniem między reklamą a treściami wideo w aplikacji.
Wybierz interesujące Cię rozwiązanie DAI
Wyświetlanie bloków reklamowych w ramach dynamicznego wstawiania reklam
Z tego przewodnika dowiesz się, jak odtwarzać strumień wyświetlany w ramach dynamicznego wstawiania reklam w przypadku treści na żywo lub VOD za pomocą pakietu IMA DAI SDK na HTML5 w odtwarzaczu wideo, który do odtwarzania wykorzystuje hls.js. Aby wyświetlić lub śledzić ukończoną przykładową integrację z obsługą zarówno HLS.js, jak i odtwarzania w Safari, zobacz przykład bloków reklamowych HLS. Informacje o obsłudze DASH.js znajdziesz w przykładzie wyświetlania bloków reklamowych DASH. Te przykładowe aplikacje możesz pobrać ze strony z wersją HTML5 DAI w GitHubie.
Omówienie wyświetlania bloków reklamowych w ramach dynamicznego wstawiania reklam
Wdrażanie wyświetlania bloków reklamowych za pomocą pakietu IMA DAI SDK obejmuje 2 główne komponenty, które zostały opisane w tym przewodniku:
PodStreamRequest
/PodVodStreamRequest
: obiekt, który definiuje żądanie strumienia do serwerów reklamowych Google. Żądania określają kod sieci, aPodStreamRequest
wymaga też niestandardowego klucza zasobu i opcjonalnego klucza API. Obie zawierają inne parametry opcjonalne.StreamManager
: obiekt, który obsługuje komunikację między strumieniem wideo a pakietem IMA DAI SDK, np. wysyła pingi śledzące i przekazuje wydawcy zdarzenia strumienia.
Wymagania wstępne
Zanim zaczniesz, musisz mieć:
3 puste pliki:
- dai.html
- dai.css
- dai.js
Python zainstalowany na komputerze lub serwer WWW albo inne hostowane środowisko deweloperskie do testowania
Konfigurowanie środowiska programistycznego
SDK wczytuje zależności za pomocą tego samego protokołu co strona, z której jest wczytywany, więc do testowania aplikacji musisz użyć serwera WWW. Szybkim sposobem na uruchomienie lokalnego serwera deweloperskiego jest użycie wbudowanego serwera Pythona.
W wierszu poleceń w katalogu zawierającym plik
index.html
uruchom to polecenie:python -m http.server 8000
W przeglądarce otwórz stronę
http://localhost:8000/
Możesz też użyć dowolnego innego hostowanego środowiska deweloperskiego lub serwera internetowego, np. serwera HTTP Apache.
Tworzenie odtwarzacza wideo
Najpierw zmodyfikuj plik dai.html, aby utworzyć element wideo HTML5 i element div, który będzie używany w elementach interfejsu reklam. Dodaj też niezbędne tagi, aby wczytać pliki dai.css i dai.js, a także zaimportować hls.js
odtwarzacz wideo.
Następnie zmodyfikuj plik dai.css, aby określić rozmiar i pozycję elementów strony.
Na koniec w pliku dai.js zdefiniuj zmienne do przechowywania informacji o żądaniu strumienia i funkcję initPlayer()
, która będzie uruchamiana po wczytaniu strony.
Stałe żądania strumienia są następujące:
BACKUP_STREAM
: adres URL strumienia zapasowego, który ma być odtwarzany w przypadku, gdy proces reklam napotka błąd krytyczny.STREAM_URL
: używane tylko w przypadku transmisji na żywo. URL strumienia wideo podany przez manipulator plików manifestu lub partnera zewnętrznego korzystającego z wyświetlania bloków reklamowych. Przed wysłaniem żądania musisz wstawić identyfikator strumienia podany przez pakiet IMA DAI SDK. W tym przypadku adres URL strumienia zawiera obiekt zastępczy[[STREAMID]]
, który przed wysłaniem żądania jest zastępowany identyfikatorem strumienia.NETWORK_CODE
: kod sieci na koncie Ad Managera 360.CUSTOM_ASSET_KEY
: używane tylko w przypadku transmisji na żywo. Niestandardowy klucz zasobu, który identyfikuje zdarzenie wyświetlania podcastu w usłudze Ad Manager 360. Może go utworzyć manipulator pliku manifestu lub zewnętrzny partner w zakresie wyświetlania bloków reklamowych.API_KEY
: używane tylko w przypadku transmisji na żywo. Opcjonalny klucz API, który może być wymagany do pobrania identyfikatora strumienia z pakietu IMA DAI SDK.
dai.html
<html>
<head>
<script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script>
<script src="dai.js"></script>
<link rel="stylesheet" href="dai.css" type="text/css">
</head>
<body onLoad="initPlayer()">
<h2>IMA DAI SDK Demo (HLS.JS)</h2>
<video id="video"></video>
<div id="adUi"></div>
</body>
</html>
dai.css
#video,
#adUi {
width: 640px;
height: 360px;
position: absolute;
top: 35px;
left: 0;
}
#adUi {
cursor: pointer;
}
dai.js
var BACKUP_STREAM =
'https://storage.googleapis.com/interactive-media-ads/media/bbb.m3u8'
// Stream Config.
const STREAM_URL = "";
const NETWORK_CODE = "";
const CUSTOM_ASSET_KEY = "";
const API_KEY = "";
var hls = new Hls(); // hls.js video player
var videoElement;
var adUiElement;
function initPlayer() {
videoElement = document.getElementById('video');
adUiElement = document.getElementById('adUi');
}
Wczytywanie pakietu IMA DAI SDK
Następnie dodaj platformę DAI za pomocą tagu skryptu w pliku dai.html przed tagiem dla dai.js.
dai.html
<html>
<head>
<script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script>
<script type="text/javascript" src="//imasdk.googleapis.com/js/sdkloader/ima3_dai.js"></script>
<script src="dai.js"></script>
<link rel="stylesheet" href="dai.css" type="text/css">
</head>
...
Inicjowanie StreamManager i wysyłanie żądania transmisji na żywo lub VOD
Wyświetlanie podów transmisji na żywo
Aby poprosić o zestaw reklam, utwórz ima.dai.api.StreamManager
, który odpowiada za wysyłanie żądań strumieni DAI i zarządzanie nimi. Konstruktor przyjmuje element wideo, a wynikowa instancja przyjmuje element interfejsu reklamy do obsługi interakcji z reklamą.
Następnie zdefiniuj funkcję, która będzie wysyłać żądanie transmisji na żywo z usługi Pod Serving. Ta funkcja najpierw tworzy obiekt PodStreamRequest
, konfiguruje go za pomocą parametrów streamRequest podanych w kroku 2, a następnie wywołuje streamManager.requestStream()
z tym obiektem żądania.
dai.js
function initPlayer() {
videoElement = document.getElementById('video');
adUiElement = document.getElementById('adUi');
streamManager = new google.ima.dai.api.StreamManager(videoElement, adUiElement)
requestLivePodStream(NETWORK_CODE, CUSTOM_ASSET_KEY, API_KEY);
}
function requestLivePodStream(networkCode, customAssetKey, apiKey) {
// clear HLS.js instance, if in use
if (hls) {
hls.destroy();
}
// Generate a Pod Serving live Stream Request
const streamRequest = new google.ima.dai.api.PodStreamRequest();
streamRequest.networkCode = networkCode;
streamRequest.customAssetKey = customAssetKey;
streamRequest.apiKey = apiKey;
streamRequest.format = 'hls';
streamManager.requestStream(streamRequest);
}
Wyświetlanie bloków reklamowych w ramach VOD
Aby poprosić o zestaw reklam, utwórz ima.dai.api.StreamManager
, który odpowiada za wysyłanie żądań strumieni DAI i zarządzanie nimi. Konstruktor przyjmuje element wideo, a wynikowa instancja przyjmuje element interfejsu reklamy do obsługi interakcji z reklamą.
Następnie zdefiniuj funkcję, która będzie wysyłać żądanie strumienia VOD z blokiem reklamowym. Ta funkcja najpierw tworzy obiekt PodVodStreamRequest
, konfiguruje go za pomocą parametrów streamRequest podanych w kroku 2, a następnie wywołuje streamManager.requestStream()
z tym obiektem żądania.
dai.js
function initPlayer() {
videoElement = document.getElementById('video');
adUiElement = document.getElementById('adUi');
streamManager = new google.ima.dai.api.StreamManager(videoElement, adUiElement)
requestVodPodStream(NETWORK_CODE);
}
function requestVodPodStream(networkCode) {
// clear HLS.js instance, if in use
if (hls) {
hls.destroy();
}
// Generate a Pod Serving VOD Stream Request
const streamRequest = new google.ima.dai.api.PodVodStreamRequest();
streamRequest.networkCode = networkCode;
streamRequest.format = 'hls';
streamManager.requestStream(streamRequest);
}
Obsługa zdarzeń strumienia
Wyświetlanie podów transmisji na żywo
Następnie zaimplementuj odbiorniki zdarzeń dla najważniejszych zdarzeń związanych z filmem. W tym przykładzie obsługiwane są zdarzenia STREAM_INITIALIZED
, ERROR
, AD_BREAK_STARTED
i AD_BREAK_ENDED
przez wywołanie funkcji onStreamEvent()
. Ta funkcja obsługuje wczytywanie strumienia i błędy, a także wyłączanie elementów sterujących odtwarzacza podczas wyświetlania reklamy, co jest wymagane przez pakiet SDK. Po wczytaniu strumienia odtwarzacz wideo wczytuje i odtwarza podany adres URL za pomocą funkcji loadStream()
.
dai.js
var isAdBreak;
function initPlayer() {
videoElement = document.getElementById('video');
adUiElement = document.getElementById('adUi');
streamManager = new google.ima.dai.api.StreamManager(videoElement, adUiElement);
streamManager.addEventListener(
[google.ima.dai.api.StreamEvent.Type.STREAM_INITIALIZED,
google.ima.dai.api.StreamEvent.Type.ERROR,
google.ima.dai.api.StreamEvent.Type.AD_BREAK_STARTED,
google.ima.dai.api.StreamEvent.Type.AD_BREAK_ENDED],
onStreamEvent,
false);
...
function onStreamEvent(e) {
switch (e.type) {
case google.ima.dai.api.StreamEvent.Type.STREAM_INITIALIZED:
console.log('Stream initialized');
loadStream(e.getStreamData().streamId);
break;
case google.ima.dai.api.StreamEvent.Type.ERROR:
console.log('Error loading stream, playing backup stream.' + e);
loadStream('');
break;
case google.ima.dai.api.StreamEvent.Type.AD_BREAK_STARTED:
console.log('Ad Break Started');
isAdBreak = true;
videoElement.controls = false;
adUiElement.style.display = 'block';
break;
case google.ima.dai.api.StreamEvent.Type.AD_BREAK_ENDED:
console.log('Ad Break Ended');
isAdBreak = false;
videoElement.controls = true;
adUiElement.style.display = 'none';
break;
default:
break;
}
}
function loadStream(streamID) {
var url;
if(streamID) {
url = STREAM_URL.replace('[[STREAMID]]', streamID);
} else {
console.log('Stream Initialization Failed');
url = BACKUP_STREAM;
}
console.log('Loading:' + url);
hls.loadSource(url);
hls.attachMedia(videoElement);
}
Wyświetlanie bloków reklamowych w ramach VOD
Następnie zaimplementuj odbiorniki zdarzeń dla najważniejszych zdarzeń związanych z filmem. W tym przykładzie obsługiwane są zdarzenia STREAM_INITIALIZED
, LOADED
, ERROR
, AD_BREAK_STARTED
i AD_BREAK_ENDED
przez wywołanie funkcji onStreamEvent()
. Ta funkcja obsługuje wczytywanie strumienia i błędy, a także wyłączanie elementów sterujących odtwarzacza podczas wyświetlania reklamy, co jest wymagane przez pakiet SDK.
Dodatkowo strumienie VOD Pod Serving wymagają wywołania
StreamManager.loadStreamMetadata()
w odpowiedzi na zdarzenie
STREAM_INITIALIZED
. Musisz też poprosić partnera technologicznego ds. wideo o adres URL strumienia. Gdy wywołanie loadStreamMetadata()
zakończy się powodzeniem, wywoła zdarzenie LOADED
, w którym należy wywołać funkcję loadStream()
z adresem URL strumienia, aby załadować i odtwarzać strumień.
var isAdBreak;
function initPlayer() {
videoElement = document.getElementById('video');
adUiElement = document.getElementById('adUi');
streamManager = new google.ima.dai.api.StreamManager(videoElement, adUiElement);
streamManager.addEventListener(
[google.ima.dai.api.StreamEvent.Type.STREAM_INITIALIZED,
google.ima.dai.api.StreamEvent.Type.ERROR,
google.ima.dai.api.StreamEvent.Type.AD_BREAK_STARTED,
google.ima.dai.api.StreamEvent.Type.AD_BREAK_ENDED],
onStreamEvent,
false);
...
function onStreamEvent(e) {
switch (e.type) {
case google.ima.dai.api.StreamEvent.Type.STREAM_INITIALIZED:
const streamId = e.getStreamData().streamId;
// 'vtpInterface' is a place holder for your own video technology
// partner (VTP) API calls.
vtpInterface.requestStreamURL({
'streamId': streamId,
})
.then( (vtpStreamUrl) => {
streamUrl = vtpStreamUrl;
streamManager.loadStreamMetadata();
}, (error) => {
// Handle the error.
});
break;
case google.ima.dai.api.StreamEvent.Type.LOADED:
loadStream(streamUrl);
break;
case google.ima.dai.api.StreamEvent.Type.ERROR:
console.log('Error loading stream, playing backup stream.' + e);
loadStream();
break;
case google.ima.dai.api.StreamEvent.Type.AD_BREAK_STARTED:
console.log('Ad Break Started');
isAdBreak = true;
videoElement.controls = false;
adUiElement.style.display = 'block';
break;
case google.ima.dai.api.StreamEvent.Type.AD_BREAK_ENDED:
console.log('Ad Break Ended');
isAdBreak = false;
videoElement.controls = true;
adUiElement.style.display = 'none';
break;
default:
break;
}
}
function loadStream(url) {
if(url) {
console.log('Loading:' + url);
hls.loadSource(url);
} else {
console.log('Stream Initialization Failed');
hls.loadSource(BACKUP_STREAM);
}
hls.attachMedia(videoElement);
}
Obsługa metadanych strumienia
W tym kroku zaimplementujesz detektory zdarzeń metadanych, aby powiadamiać pakiet SDK o zdarzeniach związanych z reklamami. Odsłuchiwanie zdarzeń metadanych w strumieniu może się różnić w zależności od formatu strumienia (HLS lub DASH), typu strumienia (transmisja na żywo lub strumień VOD), typu odtwarzacza i typu używanego backendu DAI. Więcej informacji znajdziesz w naszym przewodniku Metadane czasowe.
Format strumienia HLS (strumienie na żywo i VOD, odtwarzacz HLS.js)
Jeśli używasz odtwarzacza HLS.js, nasłuchuj zdarzenia FRAG_PARSING_METADATA
HLS.js, aby uzyskać metadane ID3, i przekaż je do pakietu SDK za pomocą funkcji StreamManager.processMetadata()
.
Aby automatycznie odtworzyć film po załadowaniu i przygotowaniu wszystkich elementów, nasłuchuj zdarzenia MANIFEST_PARSED
HLS.js, aby wywołać odtwarzanie.
function loadStream(streamID) {
hls.loadSource(url);
hls.attachMedia(videoElement);
// Timed metadata is passed HLS stream events to the streamManager.
hls.on(Hls.Events.FRAG_PARSING_METADATA, parseID3Events);
hls.on(Hls.Events.MANIFEST_PARSED, startPlayback);
}
function parseID3Events(event, data) {
if (streamManager && data) {
// For each ID3 tag in the metadata, pass in the type - ID3, the
// tag data (a byte array), and the presentation timestamp (PTS).
data.samples.forEach((sample) => {
streamManager.processMetadata('ID3', sample.data, sample.pts);
});
}
}
function startPlayback() {
console.log('Video Play');
videoElement.play();
}
DASH.js (format strumieni DASH, typ strumienia na żywo i VOD)
Jeśli używasz odtwarzacza DASH.js, musisz użyć różnych ciągów znaków, aby nasłuchiwać metadanych ID3 w przypadku strumieni na żywo lub VOD:
- Transmisje na żywo:
'https://developer.apple.com/streaming/emsg-id3'
- Strumienie VOD:
'urn:google:dai:2018'
Przekaż metadane ID3 do pakietu SDK za pomocą funkcji StreamManager.processMetadata()
.
Aby automatycznie wyświetlać elementy sterujące odtwarzaniem po załadowaniu i przygotowaniu wszystkich elementów, nasłuchuj zdarzenia MANIFEST_LOADED
DASH.js.
const googleLiveSchema = 'https://developer.apple.com/streaming/emsg-id3';
const googleVodSchema = 'urn:google:dai:2018';
dashPlayer.on(googleLiveSchema, processMetadata);
dashPlayer.on(googleVodSchema, processMetadata);
dashPlayer.on(dashjs.MediaPlayer.events.MANIFEST_LOADED, loadlistener);
function processMetadata(metadataEvent) {
const messageData = metadataEvent.event.messageData;
const timestamp = metadataEvent.event.calculatedPresentationTime;
// Use StreamManager.processMetadata() if your video player provides raw
// ID3 tags, as with dash.js.
streamManager.processMetadata('ID3', messageData, timestamp);
}
function loadlistener() {
showControls();
// This listener must be removed, otherwise it triggers as addional
// manifests are loaded. The manifest is loaded once for the content,
// but additional manifests are loaded for upcoming ad breaks.
dashPlayer.off(dashjs.MediaPlayer.events.MANIFEST_LOADED, loadlistener);
}
Shaka Player z transmisjami na żywo (format strumieni DASH)
Jeśli do odtwarzania transmisji na żywo używasz odtwarzacza Shaka, użyj ciągu znaków 'emsg'
, aby nasłuchiwać zdarzeń metadanych.
Następnie użyj danych z wiadomości o zdarzeniu w wywołaniu funkcji StreamManager.onTimedMetadata()
.
shakaPlayer.addEventListener('emsg', (event) => onEmsgEvent(event));
function onEmsgEvent(metadataEvent) {
// Use StreamManager.onTimedMetadata() if your video player provides
// processed metadata, as with Shaka player livestreams.
streamManager.onTimedMetadata({'TXXX': metadataEvent.detail.messageData});
}
Shaka Player ze strumieniami VOD (format strumieni DASH)
Jeśli do odtwarzania strumienia VOD używasz odtwarzacza Shaka, użyj ciągu znaków 'timelineregionenter'
, aby nasłuchiwać zdarzeń metadanych. Następnie użyj danych z wiadomości o zdarzeniu w wywołaniu funkcji
StreamManager.processMetadata()
z ciągiem znaków 'urn:google:dai:2018'
.
shakaPlayer.addEventListener('timelineregionenter', (event) => onTimelineEvent(event));
function onTimelineEvent(metadataEvent) {
const detail = metadataEvent.detail;
if ( detail.eventElement.attributes &&
detail.eventElement.attributes['messageData'] &&
detail.eventElement.attributes['messageData'].value ) {
const mediaId = detail.eventElement.attributes['messageData'].value;
const pts = detail.startTime;
// Use StreamManager.processMetadata() if your video player provides raw
// ID3 tags, as with Shaka player VOD streams.
streamManager.processMetadata('urn:google:dai:2018', mediaId, pts);
}
}
Obsługa zdarzeń odtwarzacza
Dodaj detektory zdarzeń pause
i start
do elementu wideo, aby umożliwić użytkownikowi wznowienie odtwarzania, gdy pakiet SDK wstrzymuje odtwarzanie podczas przerw na reklamy.
function loadStream(streamUrl) {
...
videoElement.addEventListener('pause', onStreamPause);
videoElement.addEventListener('play', onStreamPlay);
}
function onStreamPause() {
console.log('paused');
if (isAdBreak) {
videoElement.controls = true;
adUiElement.style.display = 'none';
}
}
function onStreamPlay() {
console.log('played');
if (isAdBreak) {
videoElement.controls = false;
adUiElement.style.display = 'block';
}
}
Czyszczenie zasobów IMA DAI
Gdy skończysz wysyłać żądania reklam i wyświetlać je w strumieniu z wyświetlaniem bloków reklamowych za pomocą pakietu IMA DAI SDK, zalecamy usunięcie wszystkich zasobów po zakończeniu sesji wyświetlania bloków reklamowych. Wywołaj funkcję StreamManager.destroy()
, aby zatrzymać odtwarzanie strumienia, śledzenie reklam i zwolnić wszystkie wczytane komponenty strumienia.
Więcej informacji o zaawansowanych funkcjach pakietu SDK znajdziesz w innych przewodnikach lub przykładach na GitHubie.