Quảng cáo xen kẽ là quảng cáo toàn màn hình, che phủ giao diện của một ứng dụng cho đến khi người dùng đóng quảng cáo. Quảng cáo này thường xuất hiện ở các điểm chuyển tiếp tự nhiên trong quy trình hoạt động của ứng dụng, chẳng hạn như giữa các hoạt động hoặc trong thời gian tạm dừng giữa các cấp độ trong trò chơi. Khi một ứng dụng hiển thị quảng cáo xen kẽ, người dùng có thể chọn nhấn vào quảng cáo và tiếp tục chuyển đến trang đích của quảng cáo đó hoặc đóng quảng cáo và quay lại ứng dụng. Nghiên cứu điển hình.
Tài liệu hướng dẫn này trình bày cách tích hợp quảng cáo xen kẽ vào các ứng dụng Android và iOS bằng SDK Quảng cáo trên thiết bị di động của Google bằng C++.
Điều kiện tiên quyết
- Hoàn thành các bước Bắt đầu.
- (Chỉ dành cho Android) Có kinh nghiệm làm việc với các tham chiếu
jobjectcủa JNI (xem bài viết Mẹo về JNI Android).
Luôn thử nghiệm bằng quảng cáo thử nghiệm
Khi bạn tạo và thử nghiệm ứng dụng, hãy nhớ sử dụng quảng cáo thử nghiệm thay vì quảng cáo đang chạy trong thực tế. Chúng tôi có thể tạm ngưng tài khoản của bạn nếu bạn không làm như vậy.
Cách dễ nhất để tải quảng cáo thử nghiệm là sử dụng mã đơn vị quảng cáo thử nghiệm dành riêng cho quảng cáo xen kẽ. Mã này sẽ khác nhau tuỳ theo nền tảng thiết bị:
- Android:
ca-app-pub-3940256099942544/1033173712 - iOS:
ca-app-pub-3940256099942544/4411468910
Mã này được định cấu hình đặc biệt để trả về quảng cáo thử nghiệm cho mọi yêu cầu và bạn có thể sử dụng mã này trong ứng dụng của mình khi viết mã, chạy thử nghiệm và gỡ lỗi. Bạn chỉ cần thay thế mã này bằng mã đơn vị quảng cáo của mình trước khi xuất bản ứng dụng.
Để biết thêm thông tin về cách hoạt động của quảng cáo thử nghiệm của SDK quảng cáo trên thiết bị di động, hãy xem Quảng cáo thử nghiệm.
Triển khai
Các bước chính để tích hợp quảng cáo xen kẽ là:
- Tải một quảng cáo.
- Đăng ký các lệnh gọi lại.
- Hiển thị quảng cáo và xử lý các sự kiện trong vòng đời của quảng cáo.
Định cấu hình InterstitialAd
Quảng cáo xen kẽ hiển thị trong các đối tượng InterstitialAd, do đó, bước đầu tiên để tích hợp quảng cáo xen kẽ vào ứng dụng là tạo và khởi động đối tượng InterstitialAd.
Thêm tiêu đề sau vào mã C++ của ứng dụng:
#include "firebase/gma/interstial_ad.h"
Khai báo và khởi tạo đối tượng
InterstitialAd:firebase::gma::InterstitialAd* interstitial_ad; interstitial_ad = new firebase::gma::InterstitialAd();
Khởi động thực thể
InterstitialAdbằng cách sử dụng chế độ xem của cha mẹ được chuyển đổi đến một loạiAdParent. Khung hiển thị mẹ là một tham chiếujobjectJNI đến mộtActivityAndroid hoặc một con trỏ đến mộtUIViewiOS.// my_ad_parent is a jobject reference to an Android Activity or // a pointer to an iOS UIView. firebase::gma::AdParent ad_parent = static_cast<firebase::gma::AdParent>(my_ad_parent); firebase::Future<void> result = interstitial_ad->Initialize(ad_parent);Ngoài việc giữ lại tương lai dưới dạng một biến, bạn có thể định kỳ kiểm tra trạng thái của thao tác khởi động bằng cách gọi
InitializeLastResult()trên đối tượngInterstitialAd. Điều này có thể hữu ích để theo dõi quá trình khởi động trong vòng lặp trò chơi toàn cầu.// Monitor the status of the future in your game loop: firebase::Future<void> result = interstitial_ad->InitializeLastResult(); if (result.status() == firebase::kFutureStatusComplete) { // Initialization completed. if(future.error() == firebase::gma::kAdErrorCodeNone) { // Initialization successful. } else { // An error has occurred. } } else { // Initialization on-going. }
Để biết thêm thông tin về cách làm việc với firebase::Future, hãy xem
bài viết Sử dụng Futures để theo dõi trạng thái hoàn thành của các lệnh gọi phương
thức.
Tải một quảng cáo
Bạn có thể tải quảng cáo bằng phương thức LoadAd() trên đối tượng InterstitialAd. Phương thức tải này yêu cầu bạn đã khởi động đối tượng InterstitialAd và có mã đơn vị quảng cáo cũng như đối tượng AdRequest. firebase::Future sẽ được trả về. Bạn có thể sử dụng đối tượng này để theo dõi trạng thái và kết quả của thao tác tải.
Đoạn mã sau đây cho biết cách tải một quảng cáo sau khi InterstitialAd được khởi động thành công:
firebase::gma::AdRequest ad_request;
firebase::Future<firebase::gma::AdResult> load_ad_result;
load_ad_result = interstitial_ad->LoadAd(interstitial_ad_unit_id, ad_request);
Đăng ký các lệnh gọi lại
Bạn phải mở rộng lớp FullScreenContentListener để nhận thông báo về các sự kiện trong vòng đời và sự kiện trình bày quảng cáo xen kẽ. Lớp con
FullScreenContentListener tuỳ chỉnh của bạn có thể được đăng ký thông qua phương thức
InterstitialAd::SetFullScreenContentListener(). Lớp con này sẽ nhận được
các lệnh gọi lại khi quảng cáo hiển thị thành công hoặc không thành công, cũng như khi
quảng cáo bị đóng.
Đoạn mã sau đây cho biết cách mở rộng lớp và chỉ định lớp đó cho quảng cáo:
class ExampleFullScreenContentListener : public firebase::gma::FullScreenContentListener { public: ExampleFullScreenContentListener() {} void OnAdClicked() override { // This method is invoked when the user clicks the ad. } void OnAdDismissedFullScreenContent() override { // This method is invoked when the ad dismisses full screen content. } void OnAdFailedToShowFullScreenContent(const AdError& error) override { // This method is invoked when the ad failed to show full screen content. // Details about the error are contained within the AdError parameter. } void OnAdImpression() override { // This method is invoked when an impression is recorded for an ad. } void OnAdShowedFullScreenContent() override { // This method is invoked when the ad showed its full screen content. } }; ExampleFullScreenContentListener* full_screen_content_listener = new ExampleFullScreenContentListener(); interstitial_ad->SetFullScreenContentListener(full_screen_content_listener);
InterstitialAd là đối tượng dùng một lần. Điều này có nghĩa là sau khi hiển thị, quảng cáo xen kẽ không thể hiển thị lại. Phương pháp hay nhất là tải một quảng cáo xen kẽ khác trong phương thức OnAdDismissedFullScreenContent() của FullScreenContentListener để quảng cáo xen kẽ tiếp theo bắt đầu tải ngay khi quảng cáo trước đó bị đóng.
Hiển thị quảng cáo
Quảng cáo xen kẽ nên xuất hiện tại các điểm tạm dừng tự nhiên trong quy trình hoạt động của ứng dụng. Bạn nên thiết lập để quảng cáo xuất hiện xen kẽ giữa các cấp độ của trò chơi hoặc sau khi người dùng hoàn thành một nhiệm vụ.
Mặc dù bạn có thể sử dụng FullScreenContentListener để xác định thời điểm quảng cáo hiển thị nội dung toàn màn hình, nhưng tương lai do Show() trả về cũng sẽ báo hiệu thời điểm quảng cáo hiển thị thành công.
firebase::Future<void> result = interstitial_ad->Show();
Các phương pháp hay nhất
- Hãy cân nhắc xem quảng cáo xen kẽ có phải là loại quảng cáo phù hợp cho ứng dụng của bạn hay không.
- Quảng cáo xen kẽ hoạt động hiệu quả nhất trong những ứng dụng có các điểm chuyển tiếp tự nhiên. Việc hoàn thành một tác vụ trong ứng dụng, chẳng hạn như chia sẻ hình ảnh hoặc hoàn thành một cấp độ trò chơi, sẽ tạo ra một điểm như vậy. Vì người dùng sẽ có một khoảng nghỉ tạm thời, nên bạn có thể hiển thị một quảng cáo xen kẽ mà không làm gián đoạn trải nghiệm của họ. Hãy nhớ cân nhắc thời điểm mà bạn muốn hiển thị quảng cáo xen kẽ trong quy trình hoạt động của ứng dụng và khả năng phản hồi của người dùng.
- Nhớ tạm dừng hành động trong trò chơi/ứng dụng khi hiển thị quảng cáo xen kẽ.
- Có nhiều loại quảng cáo xen kẽ: văn bản, hình ảnh, video và các loại khác. Điều quan trọng là bạn phải đảm bảo rằng khi ứng dụng của bạn hiển thị quảng cáo xen kẽ, ứng dụng đó cũng sẽ tạm ngừng sử dụng một số tài nguyên để cho phép quảng cáo tận dụng các tài nguyên đó. Ví dụ: khi bạn thực hiện lệnh gọi để hiển thị quảng cáo xen kẽ, hãy nhớ tạm dừng phát mọi đầu ra âm thanh trên ứng dụng của mình. Bạn có thể tiếp tục phát âm thanh trong phương thức
OnAdDismissedFullScreenContentcủaFullScreenContentListenerđã cài đặt. Phương thức này sẽ được gọi khi người dùng hoàn thành lượt tương tác với quảng cáo. Ngoài ra, hãy cân nhắc việc tạm dừng mọi công việc tính toán cường độ cao (chẳng hạn như vòng lặp trò chơi) trong khi hiển thị quảng cáo. Việc này sẽ giúp người dùng không thấy hình ảnh chậm hiển thị hoặc không phản hồi hay video bị giật. - Cho phép đủ thời gian tải.
- Điều quan trọng là đảm bảo bạn hiển thị quảng cáo xen kẽ tại thời điểm phù hợp, nhưng điều cũng quan trọng không kém là đảm bảo người dùng không phải đợi quảng cáo tải. Việc tải quảng cáo trước thời điểm bạn dự định hiển thị quảng cáo có thể đảm bảo rằng ứng dụng của bạn có quảng cáo xen kẽ đã tải đầy đủ và sẵn sàng hiển thị tại thời điểm thích hợp.
- Đừng hiển thị quá nhiều quảng cáo cho người dùng.
- Mặc dù việc tăng tần suất hiển thị quảng cáo xen kẽ trong ứng dụng có thể là một cách hay để tăng doanh thu, nhưng việc đó cũng có thể kéo trải nghiệm người dùng đi xuống và làm giảm tỷ lệ nhấp. Hãy đảm bảo rằng người dùng không bị gián đoạn thường xuyên đến mức họ không còn hứng thú khi sử dụng ứng dụng của bạn nữa.
- Không sử dụng tương lai hoàn thành tải để hiển thị quảng cáo xen kẽ.
- Việc này có thể dẫn đến trải nghiệm người dùng kém. Thay vào đó, hãy tải trước quảng cáo rồi mới hiển thị quảng cáo đó.
Tài nguyên khác
Ví dụ trong GitHub
Video hướng dẫn về Trung tâm quảng cáo trên thiết bị di động
Câu chuyện thành công
Các bước tiếp theo
- Tạo đơn vị quảng cáo xen kẽ của riêng bạn trong Giao diện người dùng AdMob nếu bạn chưa thực hiện việc này.
- Tìm hiểu về tính năng nhắm mục tiêu quảng cáo và hướng dẫn triển khai quảng cáo xen kẽ.