Configurar o SDK do IMA para DAI

Os SDKs do IMA facilitam a integração de anúncios multimídia aos seus sites e apps. Os SDKs do IMA podem solicitar anúncios de qualquer servidor de anúncios compatível com VAST e gerenciar a reprodução de anúncios nos seus apps. Com os SDKs de DAI do IMA, os apps fazem uma solicitação de stream para anúncios e vídeos de conteúdo, seja VOD ou conteúdo ao vivo. Em seguida, o SDK retorna um stream de vídeo combinado para que você não precise gerenciar a troca entre o anúncio e o vídeo de conteúdo no app.

Selecione a solução de DAI que você quer usar

DAI de veiculação de conjunto

Os SDKs do IMA facilitam a integração de anúncios multimídia aos seus sites e apps. Os SDKs do IMA podem solicitar anúncios de qualquer servidor de anúncios compatível com VAST e gerenciar a reprodução de anúncios nos seus apps. Com os SDKs de DAI do IMA, os apps fazem uma solicitação de stream para anúncios e vídeos de conteúdo, seja VOD ou conteúdo ao vivo. Em seguida, o SDK retorna um stream de vídeo combinado para que você não precise gerenciar a troca entre o anúncio e o vídeo de conteúdo no app.

Este guia demonstra como reproduzir um stream de veiculação de conjunto da DAI usando o SDK DAI da IMA com um player de vídeo para reprodução de streams ao vivo e VOD. Para conferir ou seguir um exemplo de integração concluído, faça o download do exemplo de serviço de pod.

Visão geral da Veiculação de conjunto DAI do IMA

  • StreamRequest: um objeto que define uma solicitação de stream para servidores de publicidade do Google. Precisa ser criado usando ImaSdkFactory.createPodStreamRequest() ou ImaSdkFactory.createPodVodStreamRequest() para ativar a veiculação de pods. Esses métodos exigem um código de rede, e createPodStreamRequest também requer uma chave de recurso personalizada e uma chave de API opcional. Ambos incluem outros parâmetros opcionais.

  • StreamManager: um objeto que processa a comunicação entre o stream de vídeo e o SDK do IMA DAI, como o disparo de pings de rastreamento e o encaminhamento de eventos de stream para o editor.

Pré-requisitos

Configurar as variáveis de veiculação de conjunto

Todas as mudanças necessárias para a veiculação de pods são feitas em SampleAdsWrapper.java. A primeira etapa é atualizar as variáveis constantes.

Confira as constantes de solicitação de stream de bloco de anúncios que precisam ser adicionadas:

  • STREAM_URL: usado apenas em transmissões ao vivo: o URL do stream de vídeo fornecido pelo manipulador de manifesto ou parceiro terceirizado usando a veiculação de conjunto. Ele deve exigir que você insira o ID de stream fornecido pelo SDK do IMA DAI antes de fazer uma solicitação. Nesse caso, o URL do stream inclui um marcador de posição, "[[STREAMID]]", que é substituído pelo ID do stream antes de fazer uma solicitação.

  • NETWORK_CODE: o código de rede da sua conta do Ad Manager 360.

  • CUSTOM_ASSET_KEY: usada apenas em transmissões ao vivo. É a chave de recurso personalizada que identifica seu evento de veiculação de pods no Ad Manager 360. Ele pode ser criado pelo gerenciador de manifesto ou por um parceiro terceirizado de veiculação de pods.

  • API_KEY: usada apenas em transmissões ao vivo. Uma chave de API opcional que pode ser necessária para recuperar um ID de stream do SDK do IMA DAI.

O BasicExample do DAI Android foi projetado para reproduzir vários tipos de stream diferentes, mas, para a veiculação de pods, ele é configurado para reproduzir apenas um stream. Mude a seção de variáveis do exemplo para corresponder ao seguinte:

/** This class implements IMA to add pod ad-serving support to SampleVideoPlayer */
@SuppressLint("UnsafeOptInUsageError")
/* @SuppressLint is needed for new media3 APIs. */
public class SampleAdsWrapper
    implements AdEvent.AdEventListener, AdErrorEvent.AdErrorListener, AdsLoader.AdsLoadedListener {

  // Set up the pod serving variables.
  private static final String NETWORK_CODE = "";
  private static final String CUSTOM_ASSET_KEY = "";
  private static final String API_KEY = "";
  private static final String STREAM_URL = "";
  private static final StreamFormat STREAM_FORMAT = StreamFormat.HLS;

Crie uma solicitação de stream de podcast ao vivo ou VOD para ativar a veiculação de conjunto

Veiculação de pods de transmissões ao vivo

Remove o método buildStreamRequest(), que era usado para alternar entre a criação de vários tipos de fluxos. Em seguida, modifique requestAndPlayAds() para chamar ImaSdkFactory.createPodStreamRequest() e criar uma solicitação de veiculação de anúncio de Live Pod.

// Live pod stream request.
request = sdkFactory.createPodStreamRequest(NETWORK_CODE, CUSTOM_ASSET_KEY, API_KEY);

Veiculação de conjunto de stream de VOD

Remove o método buildStreamRequest(), que era usado para alternar entre a criação de vários tipos de fluxos. Em seguida, modifique requestAndPlayAds() para chamar ImaSdkFactory.createPodVodStreamRequest() e criar uma solicitação de anúncio de veiculação de pod de VOD.

// VOD pod stream request.
request = sdkFactory.createPodVodStreamRequest(NETWORK_CODE);

Depois de criar a instância de solicitação de stream, peça o stream usando AdsLoader.requestStream():

request.setFormat(STREAM_FORMAT);
adsLoader.requestStream(request);

Editar e definir o URL da transmissão

Veiculação de pods de transmissões ao vivo

Chame o método StreamManager.getStreamId() para receber o ID do fluxo. Isso precisa ser inserido no STEAM_URL, substituindo "[[STREAMID]]". Depois que essa mudança for feita, defina o novo URL de stream usando o método videoPlayer.setStreamUrl() e chame o método videoPlayer.play() para iniciar a reprodução do stream.

// Play the live pod stream.
streamID = streamManager.getStreamId();
String liveStreamUrl = STREAM_URL.replace("[[STREAMID]]", streamID);
// Call videoPlayer.play() here, because IMA doesn't call the VideoStreamPlayer.loadUrl()
// function for livestreams.
videoPlayer.setStreamUrl(liveStreamUrl);
videoPlayer.play();

Veiculação de conjunto de stream de VOD

  1. Chame o método StreamManager.getStreamId() para receber o ID do fluxo.
  2. Peça um URL de stream ao seu parceiro de tecnologia de vídeo (VTP).
  3. Depois de receber o URL do VTP, chame o método StreamManager.loadThirdPartyStream() com o URL para carregar o stream, além de todas as legendas retornadas pelo VTP.
// Play the VOD pod stream.
streamID = streamManager.getStreamId();
String vodStreamUrl = "";
// Refer to your Video Tech Partner (VTP) or video stitching guide to fetch the stream URL
// and the subtitles for a the ad stitched VOD stream.

// In the following commented out code, 'vtpInterface' is a place holder
// for your own video technology partner (VTP) API calls.
// vodStreamUrl = vtpInterface.requestStreamURL(streamID);
List<Map<String, String>> subtitles = new ArrayList<>();
streamManager.loadThirdPartyStream(vodStreamUrl, subtitles);

Para solicitações de veiculação de pod de VOD, a IMA chama o callback VideoStreamPlayer.loadUrl() quando o stream é carregado. Para iniciar a reprodução da transmissão, adicione as chamadas videoPlayer.setStreamUrl() e videoPlayer.play() ao callback VideoStreamPlayer.loadUrl():

private VideoStreamPlayer createVideoStreamPlayer() {
  return new VideoStreamPlayer() {
    @Override
    public void loadUrl(String url, List<HashMap<String, String>> subtitles) {
      // IMA doesn't make calls to VideoStreamPlayer.loadUrl() for pod serving live streams.
      // The following code is for VOD streams.
      videoPlayer.setStreamUrl(url);
      videoPlayer.play();
    }

Limpar recursos da DAI da IMA

Quando você terminar de solicitar e exibir anúncios em um fluxo de veiculação de pod com o SDK de DAI do IMA, recomendamos limpar todos os recursos após a conclusão da sessão de veiculação de pod. Chame StreamManager.destroy() para interromper a reprodução de stream, parar todo o rastreamento de anúncios e liberar todos os recursos de stream carregados.

Para ver outros exemplos do uso do SDK do Android, consulte exemplos no GitHub.