Quảng cáo xen kẽ là quảng cáo toàn màn hình, che phủ giao diện của ứng dụng lưu trữ. Quảng cáo này thường xuất hiện tại các điểm chuyển tiếp tự nhiên trong luồng thực thi 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 sẽ có lựa chọn để nhấn vào quảng cáo tiếp tục đến đích đến của nó hoặc đóng quảng cáo và quay lại ứng dụng.
Hướng dẫn này giải thích cách tích hợp quảng cáo xen kẽ vào một Android .
Điều kiện tiên quyết
- SDK Quảng cáo của Google trên thiết bị di động phiên bản 19.7.0 trở lên.
- Xem hết Hướng dẫn bắt đầu sử dụng.
Luôn thử nghiệm bằng quảng cáo thử nghiệm
Khi 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 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ẽ trên Android:
/21775744923/example/interstitial
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 sử dụng miễn phí mã này trong ứng dụng của riêng bạn khi lập trình, thử nghiệm và gỡ lỗi. Chỉ cần tạo bạn nhớ thay thế mã này bằng mã đơn vị quảng cáo của riêng 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.
Tải một quảng cáo
Để tải quảng cáo xen kẽ, hãy gọi AdManagerInterstitialAd
tĩnh
load()
và chuyển vào một
AdManagerInterstitialAdLoadCallback
để nhận tệp đã tải
quảng cáo hoặc bất kỳ lỗi nào có thể xảy ra. Lưu ý rằng giống như các lệnh gọi lại tải định dạng khác,
AdManagerInterstitialAdLoadCallback
tận dụng
LoadAdError
để cung cấp thông tin chi tiết về lỗi có độ trung thực cao hơn.
Java
import com.google.android.gms.ads.admanager.AdManagerInterstitialAd;
import com.google.android.gms.ads.admanager.AdManagerInterstitialAdLoadCallback;
public class MainActivity extends Activity {
private AdManagerInterstitialAd mAdManagerInterstitialAd;
private static final String TAG = "MainActivity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
AdManagerAdRequest adRequest = new AdManagerAdRequest.Builder().build();
AdManagerInterstitialAd.load(this,"/21775744923/example/interstitial", adRequest,
new AdManagerInterstitialAdLoadCallback() {
@Override
public void onAdLoaded(@NonNull AdManagerInterstitialAd interstitialAd) {
// The mAdManagerInterstitialAd reference will be null until
// an ad is loaded.
mAdManagerInterstitialAd = interstitialAd;
Log.i(TAG, "onAdLoaded");
}
@Override
public void onAdFailedToLoad(@NonNull LoadAdError loadAdError) {
// Handle the error
Log.d(TAG, loadAdError.toString());
mAdManagerInterstitialAd = null;
}
});
}
}
Kotlin
import com.google.android.gms.ads.admanager.AdManagerInterstitialAd;
import com.google.android.gms.ads.admanager.AdManagerInterstitialAdLoadCallback;
class MainActivity : AppCompatActivity() {
private var mAdManagerInterstitialAd: AdManagerInterstitialAd? = null
private final val TAG = "MainActivity"
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val adRequest = AdManagerAdRequest.Builder().build()
AdManagerInterstitialAd.load(this,"/21775744923/example/interstitial", adRequest, object : AdManagerInterstitialAdLoadCallback() {
override fun onAdFailedToLoad(adError: LoadAdError) {
Log.d(TAG, adError?.toString())
mAdManagerInterstitialAd = null
}
override fun onAdLoaded(interstitialAd: AdManagerInterstitialAd) {
Log.d(TAG, 'Ad was loaded.')
mAdManagerInterstitialAd = interstitialAd
}
})
}
}
Đặt FullScreenContentCallback
FullScreenContentCallback
xử lý các sự kiện liên quan đến việc hiển thị
InterstitialAd
Trước khi hiển thị InterstitialAd
, hãy nhớ đặt
gọi lại:
Java
mAdManagerInterstitialAd.setFullScreenContentCallback(new FullScreenContentCallback(){
@Override
public void onAdClicked() {
// Called when a click is recorded for an ad.
Log.d(TAG, "Ad was clicked.");
}
@Override
public void onAdDismissedFullScreenContent() {
// Called when ad is dismissed.
// Set the ad reference to null so you don't show the ad a second time.
Log.d(TAG, "Ad dismissed fullscreen content.");
mAdManagerInterstitialAd = null;
}
@Override
public void onAdFailedToShowFullScreenContent(AdError adError) {
// Called when ad fails to show.
Log.e(TAG, "Ad failed to show fullscreen content.");
mAdManagerInterstitialAd = null;
}
@Override
public void onAdImpression() {
// Called when an impression is recorded for an ad.
Log.d(TAG, "Ad recorded an impression.");
}
@Override
public void onAdShowedFullScreenContent() {
// Called when ad is shown.
Log.d(TAG, "Ad showed fullscreen content.");
}
});
Kotlin
mAdManagerInterstitialAd?.fullScreenContentCallback = object: FullScreenContentCallback() {
override fun onAdClicked() {
// Called when a click is recorded for an ad.
Log.d(TAG, "Ad was clicked.")
}
override fun onAdDismissedFullScreenContent() {
// Called when ad is dismissed.
Log.d(TAG, "Ad dismissed fullscreen content.")
mAdManagerInterstitialAd = null
}
override fun onAdFailedToShowFullScreenContent(adError: AdError?) {
// Called when ad fails to show.
Log.e(TAG, "Ad failed to show fullscreen content.")
mAdManagerInterstitialAd = null
}
override fun onAdImpression() {
// Called when an impression is recorded for an ad.
Log.d(TAG, "Ad recorded an impression.")
}
override fun onAdShowedFullScreenContent() {
// Called when ad is shown.
Log.d(TAG, "Ad showed fullscreen content.")
}
}
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 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ụ.
Để hiển thị quảng cáo xen kẽ, hãy sử dụng
Phương thức show()
.
Java
if (mAdManagerInterstitialAd != null) {
mAdManagerInterstitialAd.show(MyActivity.this);
} else {
Log.d("TAG", "The interstitial ad wasn't ready yet.");
}
Kotlin
if (mAdManagerInterstitialAd != null) {
mAdManagerInterstitialAd?.show(this)
} else {
Log.d("TAG", "The interstitial ad wasn't ready yet.")
}
Một số phương pháp hay nhất
- 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. Kết thúc một thao tác trong ứng dụng, chẳng hạn như chia sẻ hình ảnh hoặc hoàn tất trò chơi của bạn, tạo ra một điểm như vậy. Hãy đảm bảo bạn cân nhắc tại thời điểm nào trong của ứng dụng, bạn sẽ hiển thị quảng cáo xen kẽ và khả năng người dùng phản hồi.
- Hãy nhớ tạm dừng hành độ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à nhiều nội dung khác. Điều quan trọng là phải đảm bảo rằng khi ứng dụng của bạn hiển thị quảng cáo xen kẽ cũng sẽ tạm ngừng việc sử dụng một số tài nguyên để cho phép quảng cáo hãy tận dụng chúng. 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 mọi đầu ra âm thanh mà ứng dụng của bạn đang phát.
- Cho phép có đủ thời gian tải.
- Điều quan trọng là bạn phải đảm bảo hiển thị quảng cáo xen kẽ ở
thời gian thích hợp, nhưng bạn cũng phải đảm bảo rằng
người dùng không phải
hãy đợi chúng tải. Tải quảng cáo trước bằng cách gọi
load()
trước khi bạn định gọishow()
có thể đảm bảo rằng ứng dụng của bạn có quảng cáo xen kẽ đã tải đầy đủ tại sẵn sàng hiển thị quảng cáo của bạn khi đến lúc. - Đừng hiển thị quá nhiều quảng cáo cho người dùng.
- Mặc dù có vẻ như bạn sẽ tăng tần suất hiển thị quảng cáo xen kẽ trong ứng dụng của mình giống như cách tuyệt vời để tăng doanh thu, nhưng nó cũng có thể làm giảm trải nghiệm người dùng và tỷ lệ nhấp thấp hơn. Hãy đảm bảo rằng người dùng không thường xuyên bị gián đoạn khiến họ không còn hứng thú khi sử dụng ứng dụng của bạn.
Ví dụ trên GitHub
Các bước tiếp theo
- Tìm hiểu thêm về nhắm mục tiêu quảng cáo.
- Tìm hiểu thêm về quyền riêng tư của người dùng.
- Khám phá hoạt động khởi chạy SDK được tối ưu hoá và tải quảng cáo (thử nghiệm).