Расширенная интеграция (InStream API)
InStream API — расширенный API для настройки, управления загрузкой и воспроизведением InStream-рекламы. Позволяет поддержать проигрывание всех типов рекламных вставок, а также использовать свою реализацию плеера. InStream-реклама состоит из рекламных вставок, которые проигрываются автоматически и вручную.
Для автоматического проигрывания вставок с типом Pre-roll, Mid-roll, Post-roll используется InstreamAdBinder API. Для ручного запуска рекламных вставок с типом In-roll и Pause-roll используются In-roll API и Pause-roll API соответственно.
Примечание
Доступно одновременное использование InstreamAdBinder API, In-roll API и Pause-roll API при соблюдении определенных условий:
- Используйте разные инстансы рекламного плеера.
- Не запускайте Pause-roll и In-roll API для воспроизведения, если через InStreamAdBinder API было приостановлено основное видео.
Принципы работы
Загруженный объект InStream-рекламы содержит в себе расписание показа рекламных вставок. Каждая рекламная вставка описывается объектом InstreamAdBreak. Рекламная вставка может иметь один из следующих типов: Pre / Mid / Post / In / Pause-roll. Показать Pre / Mid / Post-Roll вставки можно через InstreamAdBinder API. Показать In / Pause-Roll вставки можно через In-roll API и Pause-roll API соответственно.
Для взаимодействия с основным видеоконтентом используется интерфейс VideoPlayer, а для воспроизведения рекламного видео внутри рекламной вставки — интерфейс InstreamAdPlayer.
InstreamAdBinder отслеживает ход воспроизведения основного видео и показывает рекламные вставки на основе настроек видеоресурса в интерфейсе Рекламной сети Яндекса.
InstreamAdBinder не управляет непосредственно отрисовкой рекламного видео в PlayerView. Воспроизводить рекламное видео необходимо со стороны приложения основываясь на сигналах от интерфейсов плееров, переданных в InstreamAdBinder. InstreamAdBinder сообщает о начале проигрывания рекламной вставки через вызов VideoPlayer.pauseVideo() и об окончании проигрывания рекламной вставки через вызов VideoPlayer.resumeVideo().
В момент вызова VideoPlayer.pauseVideo() со стороны приложения необходимо скрыть контролы управления основным видео, приостановить основное видео и начать воспроизведение рекламного видео. Со стороны рекламного SDK после вызова метода будут показаны рекламные контролы внутри контейнера InstreamAdView и будет вызван метод InstreamAdPlayer.playAd() для старта воспроизведения рекламного видео.
В момент вызова VideoPlayer.resumeVideo() со стороны приложения необходимо вернуть контролы управления основным видео и продолжить воспроизведение основного видео. Со стороны рекламного SDK до вызова метода будут убраны рекламные контролы внутри контейнера InstreamAdView.
In / Pause-Roll API не управляет непосредственно отрисовкой рекламного видео в PlayerView. Воспроизводить рекламное видео необходимо со стороны приложения основываясь на сигналах от интерфейсов плееров, переданных в In / Pause-Roll. In / Pause-Roll сообщает о начале проигрывания рекламной вставки через вызов InstreamAdBreakEventListener.onInstreamAdBreakStarted() и об окончании проигрывания рекламной вставки через вызов InstreamAdBreakEventListener.onInstreamAdBreakCompleted() или InstreamAdBreakEventListener.onInstreamAdBreakError().
В момент вызова InstreamAdBreakEventListener.onInstreamAdBreakStarted() со стороны приложения необходимо скрыть контролы управления основным видео, приостановить основное видео. Со стороны рекламного SDK после вызова метода будут показаны рекламные контролы внутри контейнера InstreamAdView и будет вызван метод InstreamAdPlayer.playAd() для старта воспроизведения рекламного видео.
В момент вызова InstreamAdBreakEventListener.onInstreamAdBreakCompleted() или InstreamAdBreakEventListener.onInstreamAdBreakError() со стороны приложения необходимо вернуть контролы управления основным видео и продолжить воспроизведение основного видео. Со стороны рекламного SDK до вызова методов будут убраны рекламные контролы из контейнера InstreamAdView.
Загрузка рекламных объявлений
-
Создайте экземпляр класса
InstreamAdLoaderдля получения InStream-рекламы. -
Настройте получение уведомлений (успешная загрузка рекламы или ошибка при загрузке рекламы): создайте экземпляр
InstreamAdLoadListenerи установите его в качестве слушателя событий загрузчика рекламных объявлений. -
Создайте конфигурацию запроса
instreamAdRequestConfigurationс помощью классаInstreamAdRequestConfiguration.Builder. В качестве параметров запроса передайте идентификатор страницы (PAGE_ID) из интерфейса Рекламной сети Яндекса. -
Загрузите рекламу с помощью метода
InstreamAdLoader.loadInstreamAd, передайте в негоContextиinstreamAdRequestConfiguration.
Пример кода:
Для тестирования корректности интеграции используйте демонстрационный PAGE_ID: demo-instream-vmap-yandex.
val instreamAdLoader = InstreamAdLoader(this)
instreamAdLoader.setInstreamAdLoadListener(object : InstreamAdLoadListener {
override fun onInstreamAdLoaded(instreamAd: InstreamAd) {
// ...
}
override fun onInstreamAdFailedToLoad(reason: String) {
// ...
}
})
val instreamAdRequestConfiguration = InstreamAdRequestConfiguration.Builder(PAGE_ID).build()
instreamAdLoader.loadInstreamAd(this, instreamAdRequestConfiguration)
final InstreamAdLoader instreamAdLoader = new InstreamAdLoader(context);
instreamAdLoader.setInstreamAdLoadListener(new InstreamAdLoadListener() {
@override
public void onInstreamAdLoaded(@NonNull final InstreamAd instreamAd) {
// ...
}
@override
public void onInstreamAdFailedToLoad(@NonNull final String reason) {
// ...
}
});
final InstreamAdRequestConfiguration instreamAdRequestConfiguration =
new InstreamAdRequestConfiguration.Builder(PAGE_ID).build();
instreamAdLoader.loadInstreamAd(this, instreamAdRequestConfiguration);
Показ рекламных объявлений
-
Реализуйте интерфейсы
InstreamAdPlayerиVideoPlayer.В разделах справочника
Package com.yandex.mobile.ads.instream.player.adиPackage com.yandex.mobile.ads.instream.player.contentприведена подробная информация по работе методов и их реализации. Дополнительно рекомендуется ориентироваться на тестовый пример реализации.Совет
Для упрощения реализации, рекомендуется использовать разные инстансы плееров для воспроизведения рекламы и контентного видео.
-
Добавьте в layout приложения InstreamAdView. InstreamAdView должна содержать в себе PlayerView, в которой будут проигрываться рекламные ролики.
Пример кода:
Ограничение
Размер контейнера должен быть не меньше 300dp x 160dp.
<com.yandex.mobile.ads.instream.player.ad.InstreamAdView android:id="@+id/instream_ad_view" android:layout_width="match_parent" android:layout_height="wrap_content"> <PlayerView android:id="@+id/player_view" android:layout_width="match_parent" android:layout_height="wrap_content"/> </com.yandex.mobile.ads.instream.player.ad.InstreamAdView> -
Создайте объект
InstreamAdBinder: передайте в конструктор Context, объект загруженной рекламыInstreamAdи реализации плееровInstreamAdPlayer,VideoPlayer.Настройте получение уведомлений о ходе воспроизведения рекламы (готовность к проигрыванию видеорекламы, завершение воспроизведения или ошибка в процессе воспроизведения): создайте экземпляр
InstreamAdListenerи установите его в качестве слушателя событий объектаInstreamAdBinder.KotlinJavainstreamAdBinder = InstreamAdBinder( this, instreamAd, checkNotNull(instreamAdPlayer), checkNotNull(contentVideoPlayer) ) instreamAdBinder.setInstreamAdListener(...)mInstreamAdBinder = new InstreamAdBinder(context, mInstreamAd, mYandexAdPlayer, mContentVideoPlayer); mInstreamAdBinder.setInstreamAdListener(...); -
Для ускорения старта рекламной вставки с типом Pre-roll, заранее предзагрузите ее через вызов метода
InstreamAdBinder.prepareAd().KotlinJavaprivate fun preparePrerollAd(instreamAdBinder: InstreamAdBinder) { instreamAdBinder.setInstreamAdListener(object : InstreamAdListener { // ... override fun onInstreamAdPrepared() { addInstreamAdBinderToPreloadedAdQueue(instreamAdBinder) } // ... }) instreamAdBinder.prepareAd() }private void preparePrerollAd(@NonNull final InstreamAdBinder instreamAdBinder) { instreamAdBinder.setInstreamAdListener(new InstreamAdListener() { // ... public void onInstreamAdPrepared() { addInstreamAdBinderToPreloadedAdQueue(instreamAdBinder); } // ... }); instreamAdBinder.prepareAd(); } -
Вызовите метод
InstreamAdBinder.bind(instreamAdView)у созданного объектаInstreamAdBinder. В качестве параметра передайтеInstreamAdView. После этого InStream SDK начнет автоматически отслеживать прогресс воспроизведения основного видео и возьмет на себя управление проигрыванием рекламных роликов.KotlinJavainstreamAdBinder.bind(instreamAdView)mInstreamAdBinder.bind(mInstreamAdView); -
При реализации проигрывания InStream-рекламы в списке, необходимо использовать метод
InStreamBinder.unbind()при инвалидации ячейки с рекламой в списке. При реализации переиспользуемого пула плееров для скролла, необходимо вызыватьInstreamAdbinder.invalidateAdPlayer()при переиспользовании плеера рекламы привязанного кInstreamAdBinder, а при переиспользовании плеера основного контентаInstreamAdBinder.invalidateVideoPlayer(). -
При остановке использования
InStreamAdBinderнеобходимо очищать состояние.KotlinJavaoverride fun onDestroy() { instreamAdBinder.apply { unbind() instreamAdBinder.invalidateVideoPlayer() instreamAdBinder.invalidateAdPlayer() instreamAdBinder.setInstreamAdListener(null) instreamAdBinder.setVideoAdPlaybackListener(null) } super.onDestroy() }public void onDestroy() { instreamAdBinder.unbind(); instreamAdBinder.invalidateVideoPlayer(); instreamAdBinder.invalidateAdPlayer(); instreamAdBinder.setInstreamAdListener(null); instreamAdBinder.setVideoAdPlaybackListener(null); super.onDestroy(); }
Примечание
Показ рекламной вставки Pause-roll настраивается по аналогии с In-roll. Для этого замените In-roll классы / методы на Pause-roll.
-
Реализуйте интерфейс InstreamAdPlayer.
В разделе справочника
Package com.yandex.mobile.ads.instream.player.adприведена подробная информация по работе методов и их реализации. Дополнительно рекомендуется ориентироваться на тестовый пример реализации.Совет
Для упрощения реализации, рекомендуется использовать разные инстансы плееров для воспроизведения рекламы и контентного видео.
-
Добавьте в layout приложения InstreamAdView. InstreamAdView должна содержать в себе PlayerView, в которой будут проигрываться рекламные ролики.
Пример кода:
Ограничение
Размер контейнера должен быть не меньше 300dp x 160dp.
<com.yandex.mobile.ads.instream.player.ad.InstreamAdView android:id="@+id/instream_ad_view" android:layout_width="match_parent" android:layout_height="wrap_content"> <PlayerView android:id="@+id/player_view" android:layout_width="match_parent" android:layout_height="wrap_content"/> </com.yandex.mobile.ads.instream.player.ad.InstreamAdView> -
Загрузите через
InstreamAdLoaderобъектInstreamAdс помощью идентификатора страницы (PAGE_ID) из интерфейса Рекламной сети Яндекса. -
InstreamAd содержит в себе набор рекламных вставок разных типов. Чтобы получить рекламные вставки In-roll, используйте
InrollQueueProvider. ОчередьInrollQueueProviderпозволяет получать объекты In-roll в необходимом для показа порядке.KotlinJavafun onInstreamAdLoaded(instreamAd: InstreamAd) { val inrollQueueProvider = InrollQueueProvider(context, instreamAd) instreamAdBreakQueue = inrollQueueProvider.queue }public void onInstreamAdLoaded(@NonNull final InstreamAd instreamAd) { final InrollQueueProvider inrollQueueProvider = new InrollQueueProvider(context, instreamAd); mInstreamAdBreakQueue = inrollQueueProvider.getQueue(); } -
Для запуска полученного In-roll, необходимо его подготовить. Без подготовки In-roll не запустится.
Чтобы подготовить In-roll, вызовите
Inroll.prepare(instreamAdPlayer)интерфейса и передайте в него инстанс созданной реализацииInstreamAdPlayer. Для отслеживания состояния рекламной вставки установите слушательInstreamAdBreakEventListener.KotlinJavafun prepare(instreamAdPlayer: SampleInstreamAdPlayer) { currentInroll = instreamAdBreakQueue.poll()?.apply { setListener(InrollListener()) instreamAdPlayer.let(::prepare) } }public void prepare(instreamAdPlayer) { currentInroll = mInstreamAdBreakQueue.poll(); currentInroll.setListener(new InrollListener()); currentInroll.prepare(instreamAdPlayer); } -
По окончанию подготовки In-roll будет вызван
InstreamAdBreakEventListener.onInstreamAdBreakPrepared(). Подготовленный In-roll готов к показу.Совет
Показывайте объявления в порядке их получения из InstreamAdBreakQueue. Показ полученных In-roll в другом порядке может снизить монетизацию вашего приложения.
-
Чтобы показать подготовленный In-roll, вызовите
Inroll.play()и передайте в качестве параметраInstreamAdView.KotlinJavafun onInstreamAdBreakPrepared() { currentInroll?.play(instreamAdView) }public void onInstreamAdBreakPrepared() { if (currentInroll != null) { currentInroll.play(instreamAdView); } } -
После начала проигрывания рекламной вставки, будет вызван метод
InstreamAdBreakEventListener.onInstreamAdBreakStarted(). По вызову этого метода необходимо поставить на паузу проигрывание основного видео и скрыть контролы управления основного видео.KotlinJavafun onInstreamAdBreakStarted() { contentVideoPlayer?.pauseVideo() }public void onInstreamAdBreakStarted() { if (contentVideoPlayer != null) { contentVideoPlayer.pauseVideo(); } } -
После проигрывания рекламной вставки необходимо продолжить воспроизведение основного видео. Проигрывание рекламной вставки может завершиться успешно или с ошибкой, эти две ситуации необходимо обрабатывать.
KotlinJavaoverride fun onInstreamAdBreakCompleted() { handleAdBreakCompleted() } override fun onInstreamAdBreakError(reason: String) { handleAdBreakCompleted() } private fun handleAdBreakCompleted() { currentInroll = null contentVideoPlayer?.resumeVideo() }@Override public void onInstreamAdBreakCompleted() { handleAdBreakCompleted(); } @Override public void onInstreamAdBreakError(@NonNull final String reason) { handleAdBreakCompleted(); } private void handleAdBreakCompleted() { currentInroll = null; if (contentVideoPlayer != null) { contentVideoPlayer.resumeVideo(); } } -
После завершения проигрывания текущего InRoll проверьте очередь воспроизведения на наличие следующего In-roll в
InstreamAdBreakQueue.KotlinJavafun prepareNextAd() { currentInroll = mInstreamAdBreakQueue.poll() currentInroll?.prepareInroll(currentInroll) }public void prepareNextAd() { currentInroll = mInstreamAdBreakQueue.poll(); if (currentInroll != null) { prepareInroll(currentInroll); } } -
При остановке использования In-roll необходимо очищать его состояние.
KotlinJavaoverride fun onDestroy() { currentInroll?.apply { invalidate() setListener(null) } super.onDestroy() }public void onDestroy() { if (currentInroll != null) { currentInroll.invalidate(); currentInroll.setListener(null); } super.onDestroy(); }