IMA SDK를 사용하면 멀티미디어 광고를 웹사이트와 앱에 쉽게 통합할 수 있습니다. IMA SDK는 모든 VAST 호환 광고 서버에서 광고를 요청하고 앱에서 광고 재생을 관리할 수 있습니다. IMA DAI SDK를 사용하면 앱에서 광고 및 콘텐츠 동영상(VOD 또는 라이브 콘텐츠)의 스트림을 요청합니다. 그러면 SDK가 결합된 동영상 스트림을 반환하므로 앱 내에서 광고와 콘텐츠 동영상 간의 전환을 관리할 필요가 없습니다.
관심 있는 DAI 솔루션 선택
풀서비스 DAI
이 가이드에서는 IMA DAI SDK를 간단한 동영상 플레이어 앱에 통합하는 방법을 보여줍니다. 완료된 샘플 통합을 보거나 함께 확인하려면 GitHub에서 BasicExample을 다운로드하세요.
IMA DAI 개요
IMA DAI를 구현하려면 이 가이드에서 설명하는 것처럼 네 가지 주요 SDK 구성요소가 필요합니다.
StreamDisplayContainer
: 동영상 재생 요소 상단에 위치하며 광고 UI 요소를 포함하는 컨테이너 객체입니다.AdsLoader
: 스트림을 요청하고 스트림 요청 응답 객체에 의해 트리거된 이벤트를 처리하는 객체입니다. 광고 로더는 하나만 인스턴스화해야 하며 이 로더는 애플리케이션의 수명 주기 동안 재사용할 수 있습니다.StreamRequest
: 스트림 요청을 정의하는 객체입니다. 스트림 요청은 VOD 또는 라이브 스트림에 대한일 수 있습니다. 라이브 스트림 요청은 저작물 키를 지정하는 반면 VOD 요청은 CMS ID 및 동영상 ID를 지정합니다. 두 요청 유형 모두 지정된 스트림에 액세스하는 데 필요한 API 키와 IMA SDK가 Google Ad Manager 설정에 지정된 대로 광고 식별자를 처리하기 위한 Google Ad Manager 네트워크 코드를 선택적으로 포함할 수 있습니다.StreamManager
: 동적 광고 삽입 스트림 및 DAI 백엔드와의 상호작용을 처리하는 객체입니다. 또한 스트림 관리자는 핑 추적을 처리하고 스트림 및 광고 이벤트를 게시자에게 전달합니다.
기본 요건
- Android 스튜디오
- SDK 통합을 위한 샘플 동영상 플레이어 앱
샘플 동영상 플레이어 앱 다운로드 및 실행
샘플 앱은 HLS 동영상을 재생하는 작동하는 동영상 플레이어를 제공합니다. 이를 IMA DAI SDK의 DAI 기능을 통합하기 위한 시작점으로 사용하세요.
샘플 동영상 플레이어 앱을 다운로드하여 추출합니다.
Android 스튜디오를 시작하고 Open an existing Android Studio project를 선택하거나, Android 스튜디오가 이미 실행 중인 경우 File > New > Import Project를 선택합니다. 그런 다음
SampleVideoPlayer/build.gradle
를 선택합니다.Tools > Android > Sync Project with Gradle Files를 선택하여 Gradle 동기화를 실행합니다.
Run > Run 'app'을 사용하여 플레이어 앱이 실제 Android 기기나 Android Virtual Device에서 컴파일되고 실행되는지 확인합니다. 동영상 스트림을 재생하기 전에 로드하는 데 몇 분 정도 걸리는 것이 일반적입니다.
샘플 동영상 플레이어 검사
샘플 동영상 플레이어에는 아직 IMA DAI SDK 통합 코드가 포함되어 있지 않습니다. 샘플 앱은 두 가지 주요 부분으로 구성됩니다.
samplevideoplayer/SampleVideoPlayer.java
: IMA DAI 통합의 기반 역할을 하는 ExoPlayer 기반 HLS 플레이어입니다.videoplayerapp/MyActivity.java
: 이 활동은 동영상 플레이어를 만들어Context
및media3.ui.PlayerView
에 전달합니다.
플레이어 앱에 IMA DAI SDK 추가
IMA DAI SDK에 대한 참조도 포함해야 합니다. Android 스튜디오에서 app/build.gradle
에 있는 애플리케이션 수준 build.gradle
파일에 다음을 추가합니다.
IMA DAI SDK 통합
videoplayerapp
패키지(app/java/com.google.ads.interactivemedia.v3.samples/videoplayerapp/
에)에SampleAdsWrapper
라는 새 클래스를 만들어 기존SampleVideoPlayer
를 래핑하고 IMA DAI를 구현하는 로직을 추가합니다. 이렇게 하려면 먼저 DAI 스트림을 요청하는 데 사용되는AdsLoader
를 만들어야 합니다.이 스니펫에는 HLS 및 DASH, 실시간 및 VOD 스트림을 위한 샘플 매개변수가 포함되어 있습니다. 재생 중인 스트림을 설정하려면
CONTENT_TYPE
변수를 업데이트하세요.VideoStreamPlayer.VideoStreamPlayerCallback
를 확장하는SampleVideoPlayerCallback
인터페이스 인스턴스 생성을 처리하는createSampleVideoPlayerCallback()
도우미 메서드를 만듭니다.DAI를 사용하려면 플레이어가 라이브 스트림의 ID3 이벤트를 IMA DAI SDK에 전달해야 합니다. 다음 샘플 코드에서
callback.onUserTextReceived()
메서드가 이 작업을 실행합니다.buildStreamRequest()
메서드를 추가하여SteamRequest
를 만듭니다. 이 메서드는CONTENT_TYPE
변수를 설정한 방법에 따라 여러 스트림 간에 전환합니다. 이 가이드에서 사용하는 기본 스트림은 IMA의 샘플 VOD HLS 스트림입니다.스트림을 재생하려면
VideoStreamPlayer
도 필요하므로VideoStreamPlayer
를 구현하는 익명 클래스를 만드는createVideoStreamPlayer()
메서드를 추가합니다.필수 리스너를 구현하고 오류 처리 지원을 추가합니다.
광고가 재생되지 않으면 대체 URL을 호출하므로
AdErrorListener
구현에 유의하세요. 콘텐츠와 광고가 하나의 스트림에 있으므로 DAI 스트림에 오류가 발생하는 경우 대체 스트림을 호출할 준비가 되어 있어야 합니다.로깅을 위해 코드를 추가합니다.
SampleAdsWrapper
를 인스턴스화하고 호출하도록videoplayerapp
의MyActivity
를 수정합니다. 또한 도우미 메서드를 사용하여 여기에서ImaSdkFactory.initialize()
를 호출하여ImaSdkSettings
인스턴스를 만듭니다.getImaSdkSettings()
도우미 메서드를 추가하여ImaSdkSettings
인스턴스를 만듭니다.활동의 레이아웃 파일
activity_my.xml
을 수정하여 로깅을 위한 UI 요소를 추가합니다.
축하합니다. 이제 Android 앱에서 동영상 광고를 요청하고 표시합니다. 구현을 세밀하게 조정하려면 북마크, Snapback, API 문서를 참고하세요.
문제 해결
동영상 광고를 재생하는 데 문제가 있다면 완성된 BasicExample을 다운로드해 보세요. BasicExample에서 제대로 작동한다면 앱의 IMA 통합 코드에 문제가 있을 수 있습니다.
그래도 문제가 계속되면 IMA SDK 포럼을 방문하시기 바랍니다.