IMA SDK облегчают интеграцию мультимедийной рекламы в ваши веб-сайты и приложения. IMA SDK могут запрашивать рекламу с любого совместимого с VAST сервера объявлений и управлять воспроизведением рекламы в ваших приложениях. С IMA DAI SDK приложения делают потоковый запрос на рекламу и контентное видео — либо VOD, либо прямой контент. Затем SDK возвращает объединенный видеопоток, так что вам не придется управлять переключением между рекламой и контентным видео в вашем приложении.
Выберите интересующее вас решение DAI
Подающий DAI
В этом руководстве показано, как воспроизводить поток DAI Pod Serving в прямом эфире или VOD с помощью IMA DAI SDK для tvOS с видеоплеером. Чтобы просмотреть или отследить завершенный пример интеграции, загрузите пример приложения Pod Serving ( Obj C или Swift ).
Обзор обслуживания IMA DAI Pod
Реализация Pod Serving с использованием IMA DAI SDK для tvOS включает два основных компонента:
StreamRequest
: объект, определяющий запрос потока к рекламным серверам Google. Должен быть создан с использованиемIMAPodStreamRequest
илиIMAPodVODStreamRequest
для включения Pod Serving. Оба метода требуют Network Code , аIMAPodStreamRequest
также требует Custom Asset Key . API Key необязателен.IMAStreamManager
: объект, который управляет взаимодействием между видеопотоком и IMA DAI SDK, например, запускает отслеживающие пинги и пересылает события потока издателю.
Предпосылки
Прежде чем начать, вам понадобится следующее:
- Xcode 13 или более поздняя версия.
- CocoaPods (предпочтительно), Swift Package Manager или загруженная копия IMA DAI SDK для tvOS .
- Приложение tvOS, уже настроенное с IMA DAI SDK для воспроизведения видеопотоков с рекламой DAI. Если у вас еще нет такого приложения, мы рекомендуем использовать tvOS DAI BasicExample в качестве отправной точки. BasicExample имеет кодовую базу, на которую ссылаются в этом руководстве. Для получения дополнительной информации о том, как реализовать IMA DAI SDK, см. Краткое руководство по началу работы .
Настройте переменные обслуживания Pod
Все изменения, необходимые для Pod Serving, выполняются в ViewController.swift
в Swift или ViewController.m
в Objective-C. Фрагменты в этом руководстве по умолчанию используют язык Swift. Первый шаг — обновить константные переменные.
Вот константы запроса потока рекламного модуля, которые необходимо добавить:
-
STREAM_URL
( используется только для прямых трансляций ): URL-адрес видеопотока, предоставленный вашим манипулятором манифеста или сторонним партнером, использующим Pod Serving. Он должен потребовать от вас вставить идентификатор потока, предоставленный IMA DAI SDK, перед тем, как вы сделаете запрос. В этом случае URL-адрес потока включает заполнитель,"[[STREAMID]]"
, который заменяется на идентификатор потока, перед тем, как сделать запрос. -
NETWORK_CODE
: сетевой код для вашего аккаунта Ad Manager 360. -
CUSTOM_ASSET_KEY
( используется только для прямых трансляций ): пользовательский ключ актива, который идентифицирует ваше событие Pod Serving в Ad Manager 360. Его может создать ваш манипулятор манифеста или сторонний партнер Pod Serving. -
API_KEY
( используется только для прямых трансляций ): необязательный ключ API, который может потребоваться для получения идентификатора потока из IMA DAI SDK.
Измените раздел переменных примера так, чтобы он соответствовал следующему:
...
class ViewController:
UIViewController,
IMAAdsLoaderDelegate,
IMAStreamManagerDelegate,
AVPlayerViewControllerDelegate
{
static let streamUrl = ""
static let networkCode = ""
static let customAssetKey = ""
static let APIKey = ""
static let backupStreamURLString = ""
var adsLoader: IMAAdsLoader?
...
Создайте запрос на прямую трансляцию или VOD-трансляцию
Обслуживание Pod в режиме реального времени
Измените метод requestStream
, чтобы создать запрос потока pod в реальном времени, создав экземпляр IMAPodStreamRequest
.
...
func requestStream() {
guard let playerViewController = self.playerViewController else return
guard let adContainerView = self.adContainerView else return
guard let adsLoader = self.adsLoader else return
self.videoDisplay = IMAAVPlayerVideoDisplay(avPlayer: playerViewController.player)
adDisplayContainer = IMAAdDisplayContainer(
adContainer: adContainerView, viewController: self)
// Create a podserving stream request.
request = IMAPodStreamRequest(
networkCode: self.networkCode,
customAssetKey: self.customAssetKey,
adDisplayContainer: adDisplayContainer,
videoDisplay: self.videoDisplay,
userContext: nil)
adsLoader.requestStream(with: request)
}
...
VOD поток Pod Обслуживание
Измените метод requestStream
, чтобы создать запрос потока VOD-пода, создав экземпляр IMAPodVODStreamRequest
.
...
func requestStream() {
guard let playerViewController = self.playerViewController else return
guard let adContainerView = self.adContainerView else return
guard let adsLoader = self.adsLoader else return
self.videoDisplay = IMAAVPlayerVideoDisplay(avPlayer: playerViewController.player)
adDisplayContainer = IMAAdDisplayContainer(
adContainer: adContainerView, viewController: self)
// Create a podserving stream request.
request = IMAPodVODStreamRequest(
networkCode: self.networkCode,
adDisplayContainer: adDisplayContainer,
videoDisplay: self.videoDisplay,
userContext: nil)
adsLoader.requestStream(with: request)
}
...
Отредактируйте и установите URL-адрес потока
Обслуживание Pod в режиме реального времени
Измените методы IMAAdsLoaderDelegate
, используя streamManager.streamId
для получения идентификатора потока. Затем вставьте идентификатор потока в STREAM_URL
, заменив "[[STREAMID]]"
. После внесения этого изменения новый URL потока можно задать с помощью videoDisplay.loadStream()
.
...
// MARK: - IMAAdsLoaderDelegate
func adsLoader(_ loader: IMAAdsLoader!, adsLoadedWith adsLoadedData: IMAAdsLoadedData!) {
let streamManager = adsLoadedData.streamManager
let streamId = streamManager.streamId
let urlString = streamUrl.replacingOccurrences(of: "[[STREAMID]]", with: streamId)
let loadedStreamUrl = URL(string:urlString)
self.videoDisplay.loadStream(loadedStreamUrl, subtitles:@[])
self.videoDisplay.play()
streamManager.delegate = self
streamManager.initialize(with: nil)
self.streamManager = streamManager
}
...
VOD поток Pod Обслуживание
Измените методы IMAAdsLoaderDelegate
, используя streamManager.streamId
для получения идентификатора потока. Затем запросите URL потока у вашего партнера по видеотехнологиям (VTP) и вызовите IMAStreamManager.loadThirdPartyStream()
, чтобы IMA загрузил URL потока и любые субтитры, возвращенные вашим TVP.
...
// MARK: - IMAAdsLoaderDelegate
func adsLoader(_ loader: IMAAdsLoader!, adsLoadedWith adsLoadedData: IMAAdsLoadedData!) {
let streamManager = adsLoadedData.streamManager
let streamId = streamManager.streamId
// 'vtpInterface' is a place holder for your own video technology partner
// (VTP) API calls.
let streamUrl = vtpInterface.requestStreamURL(streamID)
self.streamManager.loadThirdPartyStream(streamUrl, streamSubtitles:@[])
streamManager.delegate = self
streamManager.initialize(with: nil)
self.streamManager = streamManager
}
Очистите активы IMA DAI
После успешного завершения запроса и отображения рекламы в потоке Pod Serving с помощью IMA DAI SDK мы рекомендуем вам очистить все ресурсы после завершения сеанса Pod Serving. Вызовите IMAStreamManager.destroy()
, чтобы остановить воспроизведение потока, остановить все отслеживание рекламы и освободить все загруженные потоковые активы.
Чтобы увидеть другие примеры использования tvOS SDK, ознакомьтесь с примерами на GitHub .