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 IMA DAI SDK 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 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 phát trực tuyến. 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. Các yêu cầu phát trực tiếp chỉ định một khoá thành phần, trong khi các 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 IMA DAI.
- 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ột- Contextvà- 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à - SampleAdsWrappertrong gói- videoplayerapp(trong- app/java/com.google.ads.interactivemedia.v3.samples/videoplayerapp/) để bao bọc- SampleVideoPlayerhiệ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ột- AdsLoaderdù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ện- SampleVideoPlayerCallbackmở rộng- VideoStreamPlayer.VideoStreamPlayerCallback.- Để hoạt động với DAI, trình phát phải truyền các sự kiện ID3 đế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ạo- SteamRequest. 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ến- CONTENT_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 một - VideoStreamPlayerđể phát luồng, vì vậy, hãy thêm phương thức- createVideoStreamPlayer(). Phương thức này sẽ tạo một lớp ẩn danh triển khai- VideoStreamPlayer.
- 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 - MyActivitytrong- videoplayerappđể khởi tạo và gọi- SampleAdsWrapper. Ngoài ra, hãy gọi- ImaSdkFactory.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.xmlcủ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.