SDK IMA giúp bạn dễ dàng tích hợp quảng cáo đa phương tiện vào trang web và ứng dụng của mình. SDK IMA có thể yêu cầu quảng cáo từ bất kỳ máy chủ quảng cáo tuân thủ VAST nào và quản lý việc phát quảng cáo trong ứng dụng của bạn. Với SDK DAI của IMA, các ứng dụng sẽ đưa ra yêu cầu về luồng cho quảng cáo và video nội dung – có thể là nội dung VOD hoặc nội dung trực tiếp. Sau đó, SDK sẽ trả về một luồng video kết hợp, nhờ đó bạn không phải quản lý việc chuyển đổi giữa quảng cáo và video nội dung trong ứng dụng của mình.
Chọn giải pháp DAI mà bạn quan tâm
DAI trọn gói
Hướng dẫn này minh hoạ cách tích hợp SDK DAI của IMA vào một ứng dụng trình phát video đơn giản. Nếu muốn xem hoặc làm theo một mẫu tích hợp hoàn chỉnh, hãy tải BasicExample xuống từ GitHub.
Tổng quan về DAI của IMA
Việc triển khai IMA DAI bao gồm 4 thành phần SDK chính như minh hoạ trong hướng dẫn này:
StreamDisplayContainer
: Một đối tượng vùng chứa nằm phía trên phần tử phát video và chứa các phần tử giao diện người dùng của quảng cáo.AdsLoader
: Một đối tượng yêu cầu luồng và xử lý các sự kiện do đối tượng phản hồi yêu cầu luồng kích hoạt. Bạn chỉ nên khởi tạo một trình tải quảng cáo và có thể dùng lại trình tải này trong suốt thời gian hoạt động của ứng dụng.StreamRequest
: Một đối tượng xác định yêu cầu truyền phát. Yêu cầu phát trực tuyến có thể là yêu cầu phát video theo yêu cầu hoặc phát trực tiếp. Yêu cầu phát trực tiếp chỉ định một khoá thành phần, trong khi yêu cầu VOD chỉ định một mã CMS và mã video. Cả hai loại yêu cầu đều có thể bao gồm một khoá API (không bắt buộc) cần thiết để truy cập vào các luồng truyền phát được chỉ định và mã mạng Google Ad Manager để SDK IMA xử lý mã nhận dạng quảng cáo như được chỉ định trong phần cài đặt Google Ad Manager.StreamManager
: Một đối tượng xử lý các luồng chèn quảng cáo động và các lượt tương tác với phần phụ trợ DAI. Trình quản lý luồng phát cũng xử lý các ping theo dõi và chuyển tiếp các sự kiện luồng phát và quảng cáo đến nhà xuất bản.
Điều kiện tiên quyết
- Android Studio
- Ứng dụng trình phát video mẫu để tích hợp SDK
Tải xuống và chạy ứng dụng trình phát video mẫu
Ứng dụng mẫu cung cấp một trình phát video hoạt động và phát video HLS. Hãy sử dụng thông tin này làm điểm bắt đầu để tích hợp các chức năng DAI của SDK DAI IMA.
Tải ứng dụng trình phát video mẫu xuống và giải nén.
Khởi động Android Studio rồi chọn Mở một dự án Android Studio hiện có, hoặc nếu Android Studio đã chạy, hãy chọn Tệp > Mới > Nhập dự án. Sau đó, hãy chọn
SampleVideoPlayer/build.gradle
.Chạy một quy trình đồng bộ hoá Gradle bằng cách chọn Tools > Android > Sync Project with Gradle Files (Công cụ > Android > Đồng bộ hoá dự án với các tệp Gradle).
Đảm bảo rằng ứng dụng trình phát biên dịch và chạy trên một thiết bị Android thực hoặc một Thiết bị Android ảo bằng cách sử dụng Run > Run 'app' (Chạy > Chạy "ứng dụng"). Việc luồng video mất vài phút để tải trước khi phát là điều bình thường.
Khám phá trình phát video mẫu
Trình phát video mẫu chưa có mã tích hợp SDK DAI của IMA. Ứng dụng mẫu này gồm 2 phần chính:
samplevideoplayer/SampleVideoPlayer.java
: Trình phát HLS dựa trên ExoPlayer đóng vai trò là cơ sở cho việc tích hợp DAI của IMA.videoplayerapp/MyActivity.java
: Hoạt động này tạo trình phát video và truyền cho trình phát mộtContext
vàmedia3.ui.PlayerView
.
Thêm IMA DAI SDK vào ứng dụng trình phát
Bạn cũng phải thêm một thông tin tham chiếu đến IMA DAI SDK. Trong Android Studio, hãy thêm nội dung sau vào tệp build.gradle ở cấp ứng dụng, nằm tại app/build.gradle. SDK IMA yêu cầu bật tính năng khử đường dẫn thư viện. Bạn phải thực hiện việc này bằng cách đặt coreLibraryDesugaringEnabled true
và thêm coreLibraryDesugaring 'com.android.tools:desugar_jdk_libs:2.1.5'
làm phần phụ thuộc trong tệp build.gradle. Để biết thêm thông tin, hãy xem phần Các API Java 11 trở lên hiện có thông qua quy trình đơn giản hoá bằng thông số kỹ thuật nio.
Tích hợp IMA DAI SDK
Tạo một lớp mới có tên là
SampleAdsWrapper
trong góivideoplayerapp
(trongapp/java/com.google.ads.interactivemedia.v3.samples/videoplayerapp/
) để bao bọcSampleVideoPlayer
hiện có và thêm logic triển khai IMA DAI. Để làm việc này, trước tiên, bạn phải tạo mộtAdsLoader
dùng để yêu cầu luồng DAI.Đoạn mã này bao gồm các tham số mẫu cho HLS và DASH, luồng phát trực tiếp và luồng VOD. Để đặt luồng đang phát, hãy cập nhật biến
CONTENT_TYPE
.Tạo một phương thức trợ giúp
createSampleVideoPlayerCallback()
để xử lý việc tạo một thực thể giao diệnSampleVideoPlayerCallback
mở rộngVideoStreamPlayer.VideoStreamPlayerCallback
.Để hoạt động với DAI, trình phát phải truyền các sự kiện ID3 cho luồng phát trực tiếp đến SDK IMA DAI. Phương thức
callback.onUserTextReceived()
thực hiện việc này trong đoạn mã mẫu sau.Thêm phương thức
buildStreamRequest()
để tạoSteamRequest
. Phương thức này chuyển đổi giữa các luồng khác nhau dựa trên cách bạn đặt biếnCONTENT_TYPE
. Luồng mặc định được dùng trong hướng dẫn này là luồng HLS VOD mẫu của IMA.Bạn cũng cần có
VideoStreamPlayer
để phát luồng, vì vậy, hãy thêm phương thứccreateVideoStreamPlayer()
. Phương thức này sẽ tạo một lớp ẩn danh triển khaiVideoStreamPlayer
.Triển khai các trình nghe bắt buộc và thêm tính năng hỗ trợ xử lý lỗi.
Lưu ý việc triển khai
AdErrorListener
, vì phương thức này sẽ gọi một URL dự phòng nếu quảng cáo không phát được. Vì nội dung và quảng cáo nằm trong cùng một luồng, nên bạn phải sẵn sàng gọi một luồng dự phòng nếu luồng DAI gặp lỗi.Thêm mã để ghi nhật ký.
Sửa đổi
MyActivity
trongvideoplayerapp
để khởi tạo và gọiSampleAdsWrapper
. Ngoài ra, hãy gọiImaSdkFactory.initialize()
tại đây bằng phương thức trợ giúp để tạo một thực thểImaSdkSettings
.Thêm phương thức trợ giúp
getImaSdkSettings()
để tạo một thực thểImaSdkSettings
.Sửa đổi tệp bố cục
activity_my.xml
của Hoạt động để thêm các phần tử trên giao diện người dùng để ghi nhật ký.
Xin chúc mừng! Giờ đây, bạn đang yêu cầu và hiển thị quảng cáo dạng video trong ứng dụng Android của mình. Để tinh chỉnh việc triển khai, hãy xem Bookmarks (Dấu trang), Snapback (Quay lại nhanh) và tài liệu API.
Khắc phục sự cố
Nếu bạn gặp vấn đề khi phát một quảng cáo dạng video, hãy thử tải BasicExample đã hoàn tất xuống. Nếu hoạt động đúng cách trong BasicExample, thì có thể mã tích hợp IMA của ứng dụng của bạn có vấn đề.
Nếu bạn vẫn gặp vấn đề, hãy truy cập vào diễn đàn IMA SDK.