"الإعلان البيني مقابل مكافأة" هو نوع من أشكال الإعلانات المحفَّزة التي تتيح لك تقديم مكافآت مقابل الإعلانات التي تظهر تلقائيًا أثناء عمليات النقل العادية للتطبيقات. وعلى عكس الإعلانات مقابل مكافأة، لا يُطلب من المستخدمين الموافقة لعرض الإعلانات البينية مقابل مكافأة.
المتطلبات الأساسية
- Google Mobile Ads SDK 19.2.0 أو الإصدارات الأحدث
قبل المتابعة، عليك إعداد Google Mobile Ads SDK.
التنفيذ
في ما يلي الخطوات الأساسية لدمج "الإعلانات البينية مقابل مكافأة":
- تحميل إعلان
- التسجيل في معاودة الاتصال بأحداث ملء الشاشة
- التعامل مع معاودة الاتصال بالمكافأة
- عرض الإعلان
- [اختياري] التحقّق من صحة عمليات معاودة الاتصال بميزة "التحقّق من جهة الخادم"
تحميل إعلان
يتم تحميل الإعلان باستخدام طريقة load() الثابتة في فئة RewardedInterstitialAd. تتطلّب طريقة التحميل `Context` ورقم تعريف وحدتك الإعلانية وكائن AdRequest وRewardedInterstitialAdLoadCallback لتلقّي إشعار عند نجاح تحميل الإعلان أو فشله. يتم توفير الكائن RewardedInterstitialAd الذي تم تحميله كمعلَمة في
معاودة الاتصال onRewardedInterstitialAdLoaded().
يوضِّح المثال التالي كيفية تحميل RewardedInterstitialAd في MainActivity.
جافا
Kotlin
استبدِل AD_UNIT_ID برقم تعريف وحدتك الإعلانية.
التسجيل في عمليات معاودة الاتصال
لتلقّي الإشعارات بأحداث العرض، عليك تمرير كائن FullScreenContentCallback إلى أداة تحديد القيمة في إعلانك. يتعامل كائن FullScreenContentCallback مع عمليات معاودة الاتصال عندما يتم عرض الإعلان بنجاح أو بدون نجاح، وعندما يتم إغلاقه. يوضِّح الرمز التالي كيفية ضبط كائن FullScreenContentCallback مجهول ضمن RewardedInterstitialAdLoadCallback:
جافا
rewardedInterstitialAd.setFullScreenContentCallback(
new FullScreenContentCallback() {
@Override
public void onAdDismissedFullScreenContent() {
// Called when fullscreen content is dismissed.
Log.d(TAG, "The ad was dismissed.");
// Make sure to set your reference to null so you don't
// show it a second time.
rewardedInterstitialAd = null;
if (googleMobileAdsConsentManager.canRequestAds()) {
loadRewardedInterstitialAd();
}
}
@Override
public void onAdFailedToShowFullScreenContent(AdError adError) {
// Called when fullscreen content failed to show.
Log.d(TAG, "The ad failed to show.");
// Make sure to set your reference to null so you don't
// show it a second time.
rewardedInterstitialAd = null;
}
@Override
public void onAdShowedFullScreenContent() {
// Called when fullscreen content is shown.
Log.d(TAG, "The ad was shown.");
}
@Override
public void onAdImpression() {
// Called when an impression is recorded for an ad.
Log.d(TAG, "The ad recorded an impression.");
}
@Override
public void onAdClicked() {
// Called when ad is clicked.
Log.d(TAG, "The ad was clicked.");
}
});
Kotlin
rewardedInterstitialAd?.fullScreenContentCallback =
object : FullScreenContentCallback() {
override fun onAdDismissedFullScreenContent() {
// Called when fullscreen content is dismissed.
Log.d(TAG, "Ad was dismissed.")
// Don't forget to set the ad reference to null so you
// don't show the ad a second time.
rewardedInterstitialAd = null
}
override fun onAdFailedToShowFullScreenContent(adError: AdError) {
// Called when fullscreen content failed to show.
Log.d(TAG, "Ad failed to show.")
// Don't forget to set the ad reference to null so you
// don't show the ad a second time.
rewardedInterstitialAd = null
}
override fun onAdShowedFullScreenContent() {
// Called when fullscreen content is shown.
Log.d(TAG, "Ad showed fullscreen content.")
}
override fun onAdImpression() {
// Called when an impression is recorded for an ad.
Log.d(TAG, "Ad recorded an impression.")
}
override fun onAdClicked() {
// Called when an ad is clicked.
Log.d(TAG, "Ad was clicked.")
}
}
عرض الإعلان
عند عرض "إعلان بيني مقابل مكافأة"، يمكنك استخدام كائن OnUserEarnedRewardListener للتعامل مع أحداث المكافأة.
جافا
rewardedInterstitialAd.show(
MainActivity.this,
new OnUserEarnedRewardListener() {
@Override
public void onUserEarnedReward(@NonNull RewardItem rewardItem) {
Log.d(TAG, "The user earned the reward.");
// Handle the reward.
int rewardAmount = rewardItem.getAmount();
String rewardType = rewardItem.getType();
}
});
Kotlin
rewardedInterstitialAd?.show(this) { rewardItem ->
Log.d(TAG, "User earned the reward.")
// Handle the reward.
val rewardAmount = rewardItem.amount
val rewardType = rewardItem.type
}
[اختياري] التحقّق من صحة عمليات معاودة الاتصال بميزة "التحقّق من جهة الخادم"
يجب أن تستخدم التطبيقات التي تتطلّب بيانات إضافية في عمليات معاودة الاتصال بميزة "التحقّق من جهة الخادم" ميزة البيانات المخصّصة للإعلانات مقابل مكافأة. يتم تمرير أي قيمة سلسلة يتم ضبطها على كائن إعلان مقابل مكافأة إلى مَعلمة طلب البحث custom_data لعملية معاودة الاتصال بميزة "التحقّق من جهة الخادم". إذا لم يتم ضبط أي قيمة للبيانات المخصّصة، لن تظهر قيمة مَعلمة طلب البحث custom_data في عملية معاودة الاتصال بميزة "التحقّق من جهة الخادم".
توضِّح عينة تعليمات برمجية التالية كيفية ضبط بيانات مخصّصة على كائن "إعلان بيني مقابل مكافأة" قبل طلب إعلان.
جافا
Kotlin
استبدِل SAMPLE_CUSTOM_DATA_STRING ببياناتك المخصّصة.
إذا أردت ضبط سلسلة المكافأة المخصّصة، عليك إجراء ذلك قبل عرض الإعلان.
أمثلة على GitHub
الخطوات التالية
استكشاف المواضيع التالية: