मध्यवर्ती विज्ञापन

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

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

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

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

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

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

/6499/example/interstitial

Mobile Ads SDK शुरू करें

विज्ञापन लोड करने से पहले, MobileAds.Initialize() को कॉल करके अपने ऐप्लिकेशन को Mobile Ads SDK शुरू करने के लिए कहें. ऐसा सिर्फ़ एक बार करना होगा. आम तौर पर, ऐप्लिकेशन लॉन्च करते समय ऐसा करना बेहतर होता है.

using GoogleMobileAds;
using GoogleMobileAds.Api;

public class GoogleMobileAdsDemoScript : MonoBehaviour
{
    public void Start()
    {
        // Initialize the Google Mobile Ads SDK.
        MobileAds.Initialize((InitializationStatus initStatus) =>
        {
            // This callback is called once the MobileAds SDK is initialized.
        });
    }
}

अगर मीडिएशन का इस्तेमाल किया जा रहा है, तो विज्ञापन लोड करने से पहले कॉलबैक होने तक इंतज़ार करें. इससे यह पक्का हो जाएगा कि सभी मीडिएशन अडैप्टर शुरू हो गए हैं.

कार्यान्वयन

पेज पर अचानक दिखने वाले विज्ञापनों को इंटिग्रेट करने का मुख्य तरीका ये है:

  1. मध्यवर्ती विज्ञापन लोड करें
  2. मध्यवर्ती विज्ञापन दिखाएं
  3. पेज पर अचानक दिखने वाले विज्ञापन के इवेंट सुनें
  4. अचानक दिखने वाले (इंटरस्टीशियल) विज्ञापन से स्टोरेज खाली करें
  5. पेज पर अचानक दिखने वाला अगला विज्ञापन पहले से लोड करें

मध्यवर्ती विज्ञापन लोड करें

इंटरस्टीशियल विज्ञापन को लोड करने के लिए, InterstitialAd क्लास में स्टैटिक Load() तरीके का इस्तेमाल किया जाता है. लोड करने के तरीके के लिए, विज्ञापन यूनिट आईडी, AdManagerAdRequest ऑब्जेक्ट, और पूरा करने वाले हैंडलर की ज़रूरत होती है. विज्ञापन लोड होने या न होने पर इसे कॉल किया जाता है. लोड किया गया AdManagerInterstitialAd ऑब्जेक्ट, पूरा होने वाले हैंडलर में पैरामीटर के तौर पर दिया जाता है. नीचे दिए गए उदाहरण में, AdManagerInterstitialAd को लोड करने का तरीका बताया गया है.


  // This ad unit is configured to always serve test ads.
  private string _adUnitId = "/6499/example/interstitial";

  private InterstitialAd _interstitialAd;

  /// <summary>
  /// Loads the interstitial ad.
  /// </summary>
  public void LoadInterstitialAd()
  {
      // Clean up the old ad before loading a new one.
      if (_interstitialAd != null)
      {
            _interstitialAd.Destroy();
            _interstitialAd = null;
      }

      Debug.Log("Loading the interstitial ad.");

      // create our request used to load the ad.
      var adRequest = new AdManagerAdRequest();

      // send the request to load the ad.
      AdManagerInterstitialAd.Load(_adUnitId, adRequest,
          (InterstitialAd ad, LoadAdError error) =>
          {
              // if error is not null, the load request failed.
              if (error != null || ad == null)
              {
                  Debug.LogError("interstitial ad failed to load an ad " +
                                 "with error : " + error);
                  return;
              }

              Debug.Log("Interstitial ad loaded with response : "
                        + ad.GetResponseInfo());

              _interstitialAd = ad;
          });
  }

मध्यवर्ती विज्ञापन दिखाएं

अचानक दिखने वाला (इंटरस्टीशियल) विज्ञापन दिखाने के लिए, AdManagerInterstitialAd इंस्टेंस पर Show() तरीके को कॉल करें. हर लोड के लिए एक बार विज्ञापन दिखाए जा सकते हैं. CanShowAd() तरीके का इस्तेमाल करके पुष्टि करें कि विज्ञापन दिखाए जाने के लिए तैयार है.

/// <summary>
/// Shows the interstitial ad.
/// </summary>
public void ShowInterstitialAd()
{
    if (_interstitialAd != null && _interstitialAd.CanShowAd())
    {
        Debug.Log("Showing interstitial ad.");
        _interstitialAd.Show();
    }
    else
    {
        Debug.LogError("Interstitial ad is not ready yet.");
    }
}

पेज पर अचानक दिखने वाले विज्ञापन के इवेंट सुनें

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

private void RegisterEventHandlers(InterstitialAd interstitialAd)
{
    // Raised when the ad is estimated to have earned money.
    interstitialAd.OnAdPaid += (AdValue adValue) =>
    {
        Debug.Log(String.Format("Interstitial ad paid {0} {1}.",
            adValue.Value,
            adValue.CurrencyCode));
    };
    // Raised when an impression is recorded for an ad.
    interstitialAd.OnAdImpressionRecorded += () =>
    {
        Debug.Log("Interstitial ad recorded an impression.");
    };
    // Raised when a click is recorded for an ad.
    interstitialAd.OnAdClicked += () =>
    {
        Debug.Log("Interstitial ad was clicked.");
    };
    // Raised when an ad opened full screen content.
    interstitialAd.OnAdFullScreenContentOpened += () =>
    {
        Debug.Log("Interstitial ad full screen content opened.");
    };
    // Raised when the ad closed full screen content.
    interstitialAd.OnAdFullScreenContentClosed += () =>
    {
        Debug.Log("Interstitial ad full screen content closed.");
    };
    // Raised when the ad failed to open full screen content.
    interstitialAd.OnAdFullScreenContentFailed += (AdError error) =>
    {
        Debug.LogError("Interstitial ad failed to open full screen content " +
                       "with error : " + error);
    };
}

अचानक दिखने वाले (इंटरस्टीशियल) विज्ञापन से स्टोरेज खाली करें

जब आप AdManagerInterstitialAd का इस्तेमाल कर लें, तो अपना रेफ़रंस देने से पहले Destroy() तरीके को कॉल करना न भूलें:

_interstitialAd.Destroy();

इससे प्लगिन को सूचना मिलती है कि ऑब्जेक्ट का अब इस्तेमाल नहीं किया जा रहा है और उसमें मौजूद मेमोरी को फिर से वापस पाने के लिए किया जा सकता है. इस तरीके को कॉल न करने पर, मेमोरी लीक हो सकती है.

पेज पर अचानक दिखने वाला अगला विज्ञापन पहले से लोड करें

पेज पर अचानक दिखने वाले विज्ञापन, एक बार इस्तेमाल किए जाने वाले ऑब्जेक्ट हैं. इसका मतलब है कि पेज पर अचानक दिखने वाला विज्ञापन दिखाने के बाद, उस ऑब्जेक्ट को दोबारा इस्तेमाल नहीं किया जा सकता. इंटरस्टीशियल विज्ञापन का अनुरोध करने के लिए, एक नया AdManagerInterstitialAd ऑब्जेक्ट बनाएं.

अगले इंप्रेशन के अवसर के लिए इंटरस्टीशियल विज्ञापन को तैयार करने के लिए, OnAdFullScreenContentClosed या OnAdFullScreenContentFailed विज्ञापन इवेंट बढ़ाने के बाद पेज पर अचानक दिखने वाले विज्ञापन को पहले से लोड करें.

private void RegisterReloadHandler(InterstitialAd interstitialAd)
{
    // Raised when the ad closed full screen content.
    interstitialAd.OnAdFullScreenContentClosed += ()
    {
        Debug.Log("Interstitial Ad full screen content closed.");

        // Reload the ad so that we can show another as soon as possible.
        LoadInterstitialAd();
    };
    // Raised when the ad failed to open full screen content.
    interstitialAd.OnAdFullScreenContentFailed += (AdError error) =>
    {
        Debug.LogError("Interstitial ad failed to open full screen content " +
                       "with error : " + error);

        // Reload the ad so that we can show another as soon as possible.
        LoadInterstitialAd();
    };
}

ऐप्लिकेशन इवेंट

ऐप्लिकेशन इवेंट की मदद से, ऐसे विज्ञापन बनाए जा सकते हैं जिनसे उनके ऐप्लिकेशन कोड पर मैसेज भेजा जा सकता है. इसके बाद, ऐप्लिकेशन इन मैसेज के आधार पर कार्रवाइयां कर सकता है.

AppEvent का इस्तेमाल करके, Ad Manager के खास ऐप्लिकेशन इवेंट का पता लगाया जा सकता है. ये इवेंट, विज्ञापन के लाइफ़साइकल के दौरान किसी भी समय हो सकते हैं. यहां तक कि लोड शुरू होने से पहले भी ऐसा हो सकता है.

namespace GoogleMobileAds.Api.AdManager;

/// The App event message sent from the ad.
public class AppEvent
{
    // Name of the app event.
    string Name;
    // Argument passed from the app event.
    string Value;
}

किसी विज्ञापन में ऐप्लिकेशन इवेंट होने पर, OnAppEventReceived बढ़ जाता है. यहां एक उदाहरण में बताया गया है कि अपने कोड में इस इवेंट को कैसे मैनेज किया जा सकता है:

_interstitialAd.OnAppEventReceived += (AppEvent args) =>
{
    Debug.Log($"Received app event from the ad: {args.Name}, {args.Value}.");
};

रंग के नाम वाले ऐप्लिकेशन इवेंट के आधार पर, अपने ऐप्लिकेशन के बैकग्राउंड का रंग बदलने का तरीका दिखाने वाला एक उदाहरण यहां दिया गया है:

_interstitialAd.OnAppEventReceived += (AppEvent args) =>
{
  if (args.Name == "color")
  {
    Color color;
    if (ColorUtility.TryParseColor(arg.Value, out color))
    {
      gameObject.GetComponent<Renderer>().material.color = color;
    }
  }
};

और यहां संबंधित क्रिएटिव दिया गया है, जो कलर ऐप्लिकेशन इवेंट भेजता है:

<html>
<head>
  <script src="//www.gstatic.com/afma/api/v1/google_mobile_app_ads.js"></script>
  <script>
    document.addEventListener("DOMContentLoaded", function() {
      // Send a color=green event when ad loads.
      admob.events.dispatchAppEvent("color", "green");

      document.getElementById("ad").addEventListener("click", function() {
        // Send a color=blue event when ad is clicked.
        admob.events.dispatchAppEvent("color", "blue");
      });
    });
  </script>
  <style>
    #ad {
      width: 320px;
      height: 50px;
      top: 0px;
      left: 0px;
      font-size: 24pt;
      font-weight: bold;
      position: absolute;
      background: black;
      color: white;
      text-align: center;
    }
  </style>
</head>
<body>
  <div id="ad">Carpe diem!</div>
</body>
</html>

सबसे सही तरीके

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

अन्य संसाधन