नेटिव विज्ञापन, ऐसे विज्ञापन ऐसेट होते हैं जिन्हें यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट के ज़रिए दिखाया जाता है. प्लैटफ़ॉर्म के मूल रूप से मौजूद हैं. वे उन्हीं क्लास का इस्तेमाल करके दिखाए जा रहे हैं जिनका आप पहले से इस्तेमाल कर रहे हैं आपके स्टोरीबोर्ड का इस्तेमाल कर सकते हैं. साथ ही, इसे आपके ऐप्लिकेशन के विज़ुअल डिज़ाइन के हिसाब से फ़ॉर्मैट किया जा सकता है.
जब कोई नेटिव विज्ञापन लोड होता है, तो आपके ऐप्लिकेशन को एक विज्ञापन ऑब्जेक्ट मिलता है. इसमें उसकी एसेट होती हैं. इसके बाद, उन्हें दिखाने की ज़िम्मेदारी Google Mobile Ads SDK टूल के बजाय, ऐप्लिकेशन की होती है.
नेटिव विज्ञापनों को सही तरीके से लागू करने के लिए, दो काम करने होते हैं: SDK टूल का इस्तेमाल करके विज्ञापन लोड करना और फिर अपने ऐप्लिकेशन में विज्ञापन कॉन्टेंट दिखाना.
इस पेज पर, नेटिव विज्ञापन लोड करने के लिए SDK टूल का इस्तेमाल करने का तरीका बताया गया है.
ज़रूरी शर्तें
- शुरुआती निर्देश के बारे में पूरी जानकारी दें.
हमेशा टेस्ट विज्ञापनों की मदद से जांच करें
अपने ऐप्लिकेशन बनाते और टेस्ट करते समय, लाइव और प्रोडक्शन विज्ञापनों के बजाय, टेस्ट विज्ञापनों का इस्तेमाल करें.
टेस्ट विज्ञापनों को लोड करने का सबसे आसान तरीका, iOS पर नेटिव विज्ञापनों के लिए, हमारे खास टेस्ट विज्ञापन यूनिट आईडी का इस्तेमाल करना है:
ca-app-pub-3940256099942544/3986624511
इसे खास तौर पर कॉन्फ़िगर किया गया है, ताकि हर अनुरोध के हिसाब से टेस्ट विज्ञापन दिखाए जा सकें. साथ ही, आपको कोडिंग, टेस्ट, और डीबग करने के दौरान, अपने ऐप्लिकेशन में इसका इस्तेमाल करें. बस, ऐप्लिकेशन पब्लिश करने से पहले, इसे अपने विज्ञापन यूनिट आईडी से बदल लें.
Google Mobile Ads SDK के टेस्ट विज्ञापन कैसे काम करते हैं, इस बारे में ज़्यादा जानने के लिए यहां देखें विज्ञापनों की जांच करें.
विज्ञापन लोड करना
नेटिव विज्ञापनों में
GADAdLoader
क्लास होती है, जो उनके डेलिगेट को
GADAdLoaderDelegate
प्रोटोकॉल का इस्तेमाल करना चाहिए.
विज्ञापन लोड करने वाले टूल को शुरू करना
विज्ञापन लोड करने से पहले, आपको विज्ञापन लोडर को शुरू करना होगा.
नीचे दिए गए कोड में, GADAdLoader
को शुरू करने का तरीका बताया गया है:
Swift
adLoader = GADAdLoader(adUnitID: "ca-app-pub-3940256099942544/3986624511",
// The UIViewController parameter is optional.
rootViewController: rootViewController,
adTypes: [ .native ],
options: [ ... ad loader options objects ... ])
adLoader.delegate = self
Objective-C
self.adLoader = [[GADAdLoader alloc]
initWithAdUnitID:@"ca-app-pub-3940256099942544/3986624511"
// The UIViewController parameter is nullable.
rootViewController:rootViewController
adTypes:@[ GADAdLoaderAdTypeNative ]
options:@[ ... ad loader options objects ... ]];
self.adLoader.delegate = self;
आपको एक विज्ञापन यूनिट आईडी की ज़रूरत होगी (टेस्ट आईडी का इस्तेमाल किया जा सकता है). इसमें पास होने के लिए कॉन्सटेंट की वैल्यू होनी चाहिए
adTypes
कलेक्शन, ताकि यह बताया जा सके कि आपको किन नेटिव फ़ॉर्मैट का अनुरोध करना है और कोई भी
विकल्प जिन्हें आपको options
पैरामीटर में सेट करना है. options
पैरामीटर के लिए संभावित वैल्यू की सूची, नेटिव विज्ञापन के विकल्पों की सेटिंग वाले पेज में देखी जा सकती है.
adTypes
कलेक्शन में यह कॉन्स्टेंट शामिल होना चाहिए :
विज्ञापन लोडर डेलिगेट लागू करना
विज्ञापन लोड करने वाले प्रतिनिधि को, आपके विज्ञापन के टाइप के लिए खास प्रोटोकॉल लागू करने होंगे.
नेटिव विज्ञापनों के लिए, GADNativeAdLoaderDelegate
प्रोटोकॉल में एक मैसेज शामिल होता है. यह मैसेज, नेटिव विज्ञापन लोड होने पर, डेलिगेट को भेजा जाता है.
Swift
public func adLoader(_ adLoader: GADAdLoader,
didReceive nativeAd: GADNativeAd)
Objective-C
- (void)adLoader:(GADAdLoader *)adLoader
didReceiveNativeAd:(GADNativeAd *)nativeAd;
विज्ञापन जोड़ने का अनुरोध करें
GADAdLoader
को शुरू करने के बाद, विज्ञापन का अनुरोध करने के लिए, उसके loadRequest:
तरीके को कॉल करें:
Swift
adLoader.load(GADRequest())
Objective-C
[self.adLoader loadRequest:[GADRequest request]];
कॉन्टेंट बनाने
loadRequest:
में तरीका
GADAdLoader
इसे स्वीकार करता है
GADRequest
चीज़ों को बैनर और पेज पर अचानक दिखने वाले एलिमेंट के तौर पर पेश कर सकती हैं. अनुरोध वाले ऑब्जेक्ट में जोड़ने के लिए,
टारगेटिंग (विज्ञापन के लिए सही दर्शक चुनना) जानकारी.
अन्य विज्ञापन टाइप के साथ काम करता है.
कई विज्ञापन लोड करें (ज़रूरी नहीं)
एक ही अनुरोध में कई विज्ञापन लोड करने के लिए,
GADMultipleAdsAdLoaderOptions
GADAdLoader
को शुरू करते समय ऑब्जेक्ट होगा.
Swift
let multipleAdOptions = GADMultipleAdsAdLoaderOptions()
multipleAdOptions.numberOfAds = 5;
adLoader = GADAdLoader(adUnitID: "ca-app-pub-3940256099942544/3986624511",
// The UIViewController parameter is optional.
rootViewController: self,
adTypes: [ .native ],
options: [ multipleAdOptions ])
Objective-C
GADMultipleAdsAdLoaderOptions *multipleAdsOptions =
[[GADMultipleAdsAdLoaderOptions alloc] init];
multipleAdsOptions.numberOfAds = 5;
self.adLoader = [[GADAdLoader alloc]
initWithAdUnitID:@"ca-app-pub-3940256099942544/3986624511"
// The UIViewController parameter is nullable.
rootViewController:rootViewController
adTypes:@[ GADAdLoaderAdTypeNative ]
options:@[ multipleAdsOptions ]];
प्रति अनुरोध विज्ञापनों की संख्या पांच है और इसकी गारंटी नहीं है कि SDK टूल, अनुरोध किए गए विज्ञापनों की सटीक संख्या दिखाएगा.
Google से दिखाए गए विज्ञापन, एक-दूसरे से अलग होंगे. हालांकि, यह ज़रूरी नहीं है कि रिज़र्व की गई इन्वेंट्री या तीसरे पक्ष के खरीदारों के विज्ञापन यूनीक हों.
अगर मीडिएशन का इस्तेमाल किया जा रहा है, तो GADMultipleAdsAdLoaderOptions
क्लास का इस्तेमाल न करें,
कई नेटिव विज्ञापनों के अनुरोध फ़िलहाल उन विज्ञापन यूनिट आईडी के लिए काम नहीं करते
मीडिएशन के लिए कॉन्फ़िगर किया गया है.
यह पता लगाना कि लोडिंग कब खत्म हुई
जब कोई ऐप्लिकेशन loadRequest:
को कॉल करता है, तो वह इन कॉल का इस्तेमाल करके अनुरोध के नतीजे पा सकता है:
GADAdLoaderDelegate
मेंadLoader:didFailToReceiveAdWithError:
adLoader:didReceiveNativeAd:
GADNativeAdLoaderDelegate
में
किसी एक विज्ञापन के लिए अनुरोध करने पर, उनमें से किसी एक तरीके को एक कॉल किया जाएगा.
एक से ज़्यादा विज्ञापनों के लिए अनुरोध करने पर, ऊपर बताए गए तरीकों में से कम से कम एक कॉलबैक मिलेगा. हालांकि, यह अनुरोध किए गए विज्ञापनों की तय सीमा से ज़्यादा नहीं होगा.
इसके अलावा, GADAdLoaderDelegate
adLoaderDidFinishLoading
कॉलबैक भी उपलब्ध कराता है. यह डिलीगेट करने का तरीका बताता है कि विज्ञापन लोडर ने विज्ञापन लोड करना बंद कर दिया है. साथ ही, अनुरोध के लिए कोई और विज्ञापन या गड़बड़ी की रिपोर्ट नहीं की जाएगी. यह रही
एक बार में कई नेटिव विज्ञापन लोड करते समय, इसका इस्तेमाल कैसे किया जाए, इसके कुछ उदाहरण देखें:
Swift
class ViewController: UIViewController, GADNativeAdLoaderDelegate {
var adLoader: GADAdLoader!
override func viewDidLoad() {
super.viewDidLoad()
let multipleAdOptions = GADMultipleAdsAdLoaderOptions()
multipleAdOptions.numberOfAds = 5;
adLoader = GADAdLoader(adUnitID: "ca-app-pub-3940256099942544/3986624511",
// The UIViewController parameter is optional.
rootViewController: rootViewController,
adTypes: [ .native ],
options: [ multipleAdOptions ])
adLoader.delegate = self
adLoader.load(GADRequest())
}
func adLoader(_ adLoader: GADAdLoader,
didReceive nativeAd: GADNativeAd) {
// A native ad has loaded, and can be displayed.
}
func adLoaderDidFinishLoading(_ adLoader: GADAdLoader) {
// The adLoader has finished loading ads, and a new request can be sent.
}
}
Objective-C
@interface ViewController () <GADNativeAdLoaderDelegate, GADVideoControllerDelegate>
@property(nonatomic, strong) GADAdLoader *adLoader;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
GADMultipleAdsAdLoaderOptions *multipleAdsOptions =
[[GADMultipleAdsAdLoaderOptions alloc] init];
multipleAdsOptions.numberOfAds = 5;
self.adLoader = [[GADAdLoader alloc]
initWithAdUnitID:@"ca-app-pub-3940256099942544/3986624511"
// The UIViewController parameter is nullable.
rootViewController:rootViewController
adTypes:@[ GADAdLoaderAdTypeNative ]
options:@[ multipleAdsOptions ]];
self.adLoader.delegate = self;
[self.adLoader loadRequest:[GADRequest request]];
}
- (void)adLoader:(GADAdLoader *)adLoader
didReceiveNativeAd:(GADNativeAd *)nativeAd {
// A native ad has loaded, and can be displayed.
}
- (void)adLoaderDidFinishLoading:(GADAdLoader *) adLoader {
// The adLoader has finished loading ads, and a new request can be sent.
}
@end
पूरा न हो पाने वाले अनुरोधों को मैनेज करना
ऊपर दिए गए प्रोटोकॉल, GADAdLoaderDelegate
प्रोटोकॉल को बढ़ाते हैं. इससे, विज्ञापन लोड न होने पर भेजे गए मैसेज के बारे में पता चलता है.
Swift
public func adLoader(_ adLoader: GADAdLoader,
didFailToReceiveAdWithError error: NSError)
Objective-C
- (void)adLoader:(GADAdLoader *)adLoader
didFailToReceiveAdWithError:(NSError *)error;
नेटिव विज्ञापन इवेंट की सूचनाएं पाना
नेटिव विज्ञापन इंटरैक्शन से जुड़े इवेंट की सूचना पाने के लिए, नेटिव विज्ञापन की delegate प्रॉपर्टी सेट करें:
Swift
nativeAd.delegate = self
Objective-C
nativeAd.delegate = self;
इसके बाद, लागू करें
GADNativeAdDelegate
पाने के लिए इन प्रतिनिधि कॉल का इस्तेमाल करें:
Swift
func nativeAdDidRecordImpression(_ nativeAd: GADNativeAd) {
// The native ad was shown.
}
func nativeAdDidRecordClick(_ nativeAd: GADNativeAd) {
// The native ad was clicked on.
}
func nativeAdWillPresentScreen(_ nativeAd: GADNativeAd) {
// The native ad will present a full screen view.
}
func nativeAdWillDismissScreen(_ nativeAd: GADNativeAd) {
// The native ad will dismiss a full screen view.
}
func nativeAdDidDismissScreen(_ nativeAd: GADNativeAd) {
// The native ad did dismiss a full screen view.
}
func nativeAdWillLeaveApplication(_ nativeAd: GADNativeAd) {
// The native ad will cause the app to become inactive and
// open a new app.
}
Objective-C
- (void)nativeAdDidRecordImpression:(GADNativeAd *)nativeAd {
// The native ad was shown.
}
- (void)nativeAdDidRecordClick:(GADNativeAd *)nativeAd {
// The native ad was clicked on.
}
- (void)nativeAdWillPresentScreen:(GADNativeAd *)nativeAd {
// The native ad will present a full screen view.
}
- (void)nativeAdWillDismissScreen:(GADNativeAd *)nativeAd {
// The native ad will dismiss a full screen view.
}
- (void)nativeAdDidDismissScreen:(GADNativeAd *)nativeAd {
// The native ad did dismiss a full screen view.
}
- (void)nativeAdWillLeaveApplication:(GADNativeAd *)nativeAd {
// The native ad will cause the app to become inactive and
// open a new app.
}
सबसे सही तरीके
विज्ञापनों को लोड करते समय इन नियमों का पालन करें.
सूची में नेटिव विज्ञापनों का इस्तेमाल करने वाले ऐप्लिकेशन को, विज्ञापनों की सूची को पहले से कैश मेमोरी में सेव कर लेना चाहिए.
विज्ञापनों को पहले से कैश मेमोरी में सेव करें. इसके बाद, कैश मेमोरी में सेव डेटा मिटाएं और इसे एक घंटे बाद फिर से लोड करें.
जब तक पिछला अनुरोध लोड नहीं हो जाता, तब तक
GADAdLoader
परloadRequest:
को फिर से कॉल न करें. इसकी जानकारीadLoaderDidFinishLoading:
से मिलती है.नेटिव विज्ञापन को सिर्फ़ ज़रूरत के हिसाब से कैश मेमोरी में सेव करें. उदाहरण के लिए, प्रीकैशिंग करते समय, सिर्फ़ स्क्रीन पर दिखने वाले विज्ञापनों को कैश मेमोरी में सेव करें. नेटिव विज्ञापन इनकी मेमोरी फ़ुटप्रिंट बहुत ज़्यादा होता है. साथ ही, नेटिव विज्ञापनों को मिटाए बिना उन्हें कैश मेमोरी में सेव किया जाता है इससे मेमोरी का बहुत ज़्यादा इस्तेमाल होता है.
नेटिव विज्ञापनों का इस्तेमाल न होने पर उन्हें नष्ट करें.
आपका विज्ञापन दिखाना
विज्ञापन लोड करने के बाद, उसे अपने उपयोगकर्ताओं को दिखाना ही बाकी रह जाता है. हमारे नेटिव एडवांस्ड विज्ञापन पर जाएं गाइड पढ़ें.