इनाम वाले इंटरस्टीशियल विज्ञापन (बीटा)

इनाम वाले इंटरस्टीशियल विज्ञापन, एक तरह के विज्ञापन फ़ॉर्मैट हैं. इनकी मदद से, ऐप्लिकेशन में स्वाभाविक तौर पर हुए ट्रांज़िशन के दौरान दिखने वाले विज्ञापनों के लिए, इनाम दिए जा सकते हैं. उपयोगकर्ताओं को इनाम वाले इंटरस्टीशियल विज्ञापन देखने के लिए, ऑप्ट-इन करना ज़रूरी नहीं होता. इनाम वाले विज्ञापनों के लिए ऐसा करना ज़रूरी है. इस गाइड में, AdMob से इनाम वाले इंटरस्टीशियल विज्ञापनों को Flutter ऐप्लिकेशन में इंटिग्रेट करने का तरीका बताया गया है.

ज़रूरी शर्तें

  • Flutter प्लग इन 1.1.0 या इसके बाद का वर्शन.
  • शुरू करें को पूरा करें. आपके Flutter ऐप्लिकेशन में, Google Mobile Ads Flutter प्लग इन पहले से इंपोर्ट किया गया होना चाहिए.

हमेशा टेस्ट विज्ञापनों की मदद से जांच करें

अपने ऐप्लिकेशन बनाते और टेस्ट करते समय, लाइव और प्रोडक्शन विज्ञापनों के बजाय, टेस्ट विज्ञापनों का इस्तेमाल करें. ऐसा न करने पर, आपके खाते को निलंबित किया जा सकता है.

टेस्ट विज्ञापनों को लोड करने का सबसे आसान तरीका, इनाम वाले इंटरस्टीशियल विज्ञापनों के लिए, हमारे खास टेस्ट विज्ञापन यूनिट आईडी का इस्तेमाल करना है:

Android

ca-app-pub-3940256099942544/5354046379

iOS

ca-app-pub-3940256099942544/6978759866

टेस्ट विज्ञापन यूनिट को हर अनुरोध के लिए टेस्ट विज्ञापन दिखाने के लिए कॉन्फ़िगर किया जाता है. साथ ही, कोडिंग, टेस्टिंग, और डीबग करने के दौरान, इनका इस्तेमाल अपने ऐप्लिकेशन में किया जा सकता है. बस पक्का करें कि ऐप्लिकेशन पब्लिश करने से पहले, उन्हें अपनी विज्ञापन यूनिट के आईडी से बदल दिया जाए.

विज्ञापन लोड करना

इस उदाहरण में, इनाम वाला इंटरस्टीशियल विज्ञापन लोड किया गया है:

class RewardedInterstitialExampleState extends State<RewardedInterstitialExample> {
  RewardedInterstitialAd? _rewardeInterstitialdAd;

  // TODO: replace this test ad unit with your own ad unit.
  final adUnitId = Platform.isAndroid
    ? 'ca-app-pub-3940256099942544/5354046379'
    : 'ca-app-pub-3940256099942544/6978759866';

  /// Loads a rewarded ad.
  void loadAd() {
    RewardedInterstitialAd.load(
        adUnitId: adUnitId,
        adRequest: const AdRequest(),
        adLoadCallback: RewardedInterstitialAdLoadCallback(
          // Called when an ad is successfully received.
          onAdLoaded: (ad) {
            debugPrint('$ad loaded.');
            // Keep a reference to the ad so you can show it later.
            _rewardedInterstitialAd = ad;
          },
          // Called when an ad request failed.
          onAdFailedToLoad: (LoadAdError error) {
            debugPrint('RewardedInterstitialAd failed to load: $error');
          },
        ));
  }
}

इनाम वाले इंटरस्टीशियल विज्ञापन इवेंट

FullScreenContentCallback का इस्तेमाल करके, लाइफ़साइकल के इवेंट को सुना जा सकता है. जैसे, विज्ञापन दिखाए जाने या खारिज किए जाने पर. इन इवेंट की सूचनाएं पाने के लिए, विज्ञापन दिखाने से पहले RewardedInterstitialAd.fullScreenContentCallback सेट करें. इस उदाहरण में, हर तरीके को लागू किया गया है और Console में एक मैसेज को लॉग किया गया है:

class RewardedInterstitialExampleState extends State<RewardedInterstitialExample> {
  RewardedInterstitialAd? _rewardedInterstitialAd;

  // TODO: replace this test ad unit with your own ad unit.
  final adUnitId = Platform.isAndroid
    ? 'ca-app-pub-3940256099942544/5354046379'
    : 'ca-app-pub-3940256099942544/6978759866';

  /// Loads a rewarded ad.
  void loadAd() {
    RewardedInterstitialAd.load(
        adUnitId: adUnitId,
        adRequest: const AdRequest(),
        adLoadCallback: RewardedInterstitialAdLoadCallback(
          // Called when an ad is successfully received.
          onAdLoaded: (ad) {
            ad.fullScreenContentCallback = FullScreenContentCallback(
              // Called when the ad showed the full screen content.
              onAdShowedFullScreenContent: (ad) {},
              // Called when an impression occurs on the ad.
              onAdImpression: (ad) {},
              // Called when the ad failed to show full screen content.
              onAdFailedToShowFullScreenContent: (ad, err) {
                // Dispose the ad here to free resources.
                ad.dispose();
              },
              // Called when the ad dismissed full screen content.
              onAdDismissedFullScreenContent: (ad) {
                // Dispose the ad here to free resources.
                ad.dispose();
              },
              // Called when a click is recorded for an ad.
              onAdClicked: (ad) {});

            debugPrint('$ad loaded.');
            // Keep a reference to the ad so you can show it later.
            _rewardedInterstitialAd = ad;
          },
          // Called when an ad request failed.
          onAdFailedToLoad: (LoadAdError error) {
            debugprint('RewardedInterstitialAd failed to load: $error');
          },
        ));
  }
}

Display Network में दिखने वाला विज्ञापन

RewardedInterstitialAd को ऐप्लिकेशन के सभी कॉन्टेंट के ऊपर ओवरले के तौर पर दिखाया जाता है और इसे स्टैटिक तौर पर रखा जाता है. इसलिए, इसे Flutter विजेट ट्री में नहीं जोड़ा जा सकता. show() को कॉल करके, यह चुना जा सकता है कि विज्ञापन कब दिखाया जाए. RewardedInterstitialAd.show() में OnUserEarnedRewardCallback पैरामीटर होता है. इसे तब ट्रिगर किया जाता है, जब उपयोगकर्ता को इनाम मिलता है. इसे लागू करना न भूलें और विज्ञापन देखने पर उपयोगकर्ता को इनाम दें.

_rewardedInterstitialAd.show(onUserEarnedReward: (AdWithoutView ad, RewardItem rewardItem) {
  // Reward the user for watching an ad.
});

show() को कॉल करने के बाद, इस तरह से दिखाए गए Ad को प्रोग्राम के ज़रिए नहीं हटाया जा सकता. इसके लिए, उपयोगकर्ता के इनपुट की ज़रूरत होती है. RewardedInterstitialAd को सिर्फ़ एक बार दिखाया जा सकता है. बाद में दिखाए जाने वाले कॉल, onAdFailedToShowFullScreenContent को ट्रिगर करेंगे.

जब किसी विज्ञापन का ऐक्सेस ज़रूरी न हो, तो उसे हटा देना चाहिए. dispose() को कॉल करने के लिए सबसे सही तरीका, FullScreenContentCallback.onAdDismissedFullScreenContent और FullScreenContentCallback.onAdFailedToShowFullScreenContent कॉलबैक में है.

हो गया! आपका ऐप्लिकेशन, इनाम वाले इंटरस्टीशियल विज्ञापन दिखाने के लिए अब तैयार है.

GitHub पर पूरा उदाहरण

इनाम वाला इंटरस्टीशियल विज्ञापन