इनाम वाले इंटरस्टीशियल विज्ञापन, नए तरह से तैयार किए गए विज्ञापन फ़ॉर्मैट हैं. इनकी मदद से, ऐप्लिकेशन में स्वाभाविक तौर पर हुए ट्रांज़िशन के दौरान दिखने वाले विज्ञापनों के लिए इनाम दिए जा सकते हैं. उपयोगकर्ताओं को इनाम वाले इंटरस्टीशियल विज्ञापन देखने के लिए, ऑप्ट-इन करना ज़रूरी नहीं होता. इनाम वाले विज्ञापनों के लिए ऐसा करना ज़रूरी है.
ज़रूरी शर्तें
- Google Mobile Ads SDK 19.2.0 या इसके बाद का वर्शन.
- शुरुआती निर्देश पढ़ें.
लागू करना
इनाम वाले इंटरस्टीशियल विज्ञापन इंटिग्रेट करने के लिए, यह तरीका अपनाएं:
- विज्ञापन लोड करना
- फ़ुल स्क्रीन इवेंट के कॉलबैक के लिए रजिस्टर करें
- इनाम के कॉलबैक को मैनेज करना
- विज्ञापन दिखाना
- [ज़रूरी नहीं] एसएसवी कॉलबैक की पुष्टि करना
विज्ञापन लोड करना
विज्ञापन को लोड करने के लिए, RewardedInterstitialAd
क्लास में स्टैटिक load()
तरीके का इस्तेमाल किया जाता है. लोड करने के तरीके के लिए, कॉन्टेक्स्ट, आपकी विज्ञापन यूनिट का आईडी, AdRequest
ऑब्जेक्ट, और RewardedInterstitialAdLoadCallback
की ज़रूरत होती है. इससे विज्ञापन लोड होने या लोड न होने पर सूचना मिलती है. लोड किया गया RewardedInterstitialAd
ऑब्जेक्ट, onRewardedInterstitialAdLoaded()
कॉलबैक में पैरामीटर के तौर पर दिया जाता है.
यहां दिए गए उदाहरण में, MainActivity
में RewardedInterstitialAd
को लोड करने का तरीका बताया गया है.
Java
Kotlin
AD_UNIT_ID की जगह अपना विज्ञापन यूनिट आईडी डालें.
कॉलबैक के लिए रजिस्टर करना
प्रज़ेंटेशन इवेंट की सूचनाएं पाने के लिए, आपको अपने विज्ञापन पर सेटर को FullScreenContentCallback
ऑब्जेक्ट पास करना होगा. FullScreenContentCallback
ऑब्जेक्ट, विज्ञापन के दिखने या न दिखने और उसे खारिज किए जाने के लिए कॉलबैक को मैनेज करता है. यहां दिए गए कोड से, आपको अपने FullScreenContentCallback
में अनाम FullScreenContentCallback
ऑब्जेक्ट सेट करने का तरीका पता चलेगा:RewardedInterstitialAdLoadCallback
Java
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
ऑब्जेक्ट का इस्तेमाल किया जाता है.
Java
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
क्वेरी पैरामीटर वैल्यू मौजूद नहीं होगी.
नीचे दिए गए कोड सैंपल में, विज्ञापन का अनुरोध करने से पहले इनाम वाले इंटरस्टीशियल विज्ञापन ऑब्जेक्ट पर कस्टम डेटा सेट करने का तरीका बताया गया है.
Java
Kotlin
SAMPLE_CUSTOM_DATA_STRING की जगह अपना कस्टम डेटा डालें.
अगर आपको कस्टम इनाम स्ट्रिंग सेट करनी है, तो आपको विज्ञापन दिखाने से पहले ऐसा करना होगा.
GitHub पर मौजूद उदाहरण
अगले चरण
इन विषयों के बारे में जानें: