वेब व्यू के लिए बने एपीआई, आपके
WKWebView में मौजूद टैग के लिए ऐप्लिकेशन के सिग्नल उपलब्ध कराते हैं. इससे, कॉन्टेंट उपलब्ध कराने वाले
पब्लिशरों को ज़्यादा कमाई करने में मदद मिलती है और विज्ञापन देने वाले लोगों या कंपनियों को स्पैम से बचाया जा सकता है.
यह कैसे काम करता है
Google Mobile Ads SDK से बातचीत सिर्फ़ तब होती है, जब इनमें से किसी वजह से विज्ञापन इवेंट ट्रिगर होते हैं:
एसडीके, रजिस्टर किए गए WKWebView में मैसेज हैंडलर जोड़ता है, ताकि इन विज्ञापन इवेंट को सुना जा सके. यह कैसे काम करता है, इस बारे में ज़्यादा जानने के लिए,
टेस्ट पेज का सोर्स कोड देखें.
ज़रूरी शर्तें
- Google Mobile Ads SDK का 9.6.0 या इससे नया वर्शन.
Info.plistफ़ाइल को, यहां दी गई कुंजी और स्ट्रिंग वैल्यू के साथ अपडेट करें. इससे , Google Mobile Ads SDK की ओर से की जाने वाली उस जांच को बायपास किया जा सकता है जो Google Mobile Ads SDK वैल्यू के लिए की जाती है. यह वैल्यू, उन डेवलपर पर लागू होती है जो वेब व्यू के बाहर विज्ञापन लागू करते हैं.GADApplicationIdentifierअगर आपने यह चरण छोड़ दिया औरGADApplicationIdentifierउपलब्ध नहीं कराया, तो ऐप्लिकेशन शुरू होने पर, Google Mobile Ads SDKGADInvalidInitializationExceptionदिखाता है.<!-- Indicate Google Mobile Ads SDK usage is only for web view APIs for ads --> <key>GADIntegrationManager</key> <string>webview</string>
वेब व्यू रजिस्टर करना
हर WKWebView इंस्टेंस में,
AdSense कोड या Google Publisher Tag में मौजूद JavaScript हैंडलर के साथ कनेक्शन बनाने के लिए, मुख्य थ्रेड पर Call
register(_:)
को कॉल करें. यह काम जल्द से जल्द किया जाना चाहिए. जैसे, अपने व्यू कंट्रोलर के
viewDidLoad तरीके में.
Swift
import WebKit
class ViewController: UIViewController {
var webView: WKWebView!
override func viewDidLoad() {
super.viewDidLoad()
// Initialize a WKWebViewConfiguration object.
let webViewConfiguration = WKWebViewConfiguration()
// Let HTML videos with a "playsinline" attribute play inline.
webViewConfiguration.allowsInlineMediaPlayback = true
// Let HTML videos with an "autoplay" attribute play automatically.
webViewConfiguration.mediaTypesRequiringUserActionForPlayback = []
// Initialize the WKWebView with your WKWebViewConfiguration object.
webView = WKWebView(frame: view.frame, configuration: webViewConfiguration)
view.addSubview(webView)
// Register the web view.
MobileAds.shared.register(webView)
}
}
Objective-C
@import WebKit;
#import "ViewController.h"
@interface ViewController ()
@property(nonatomic, strong) WKWebView *webView;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Initialize a WKWebViewConfiguration object.
WKWebViewConfiguration *webViewConfiguration = [[WKWebViewConfiguration alloc] init];
// Let HTML videos with a "playsinline" attribute play inline.
webViewConfiguration.allowsInlineMediaPlayback = YES;
// Let HTML videos with an "autoplay" attribute play automatically.
webViewConfiguration.mediaTypesRequiringUserActionForPlayback = WKAudiovisualMediaTypeNone;
// Initialize the WKWebView with your WKWebViewConfiguration object.
self.webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:webViewConfiguration];
[self.view addSubview:self.webView];
// Register the web view.
[GADMobileAds.sharedInstance registerWebView:self.webView];
}
अपने इंटिग्रेशन की जांच करें
अपना यूआरएल इस्तेमाल करने से पहले, हमारा सुझाव है कि इंटिग्रेशन की जांच करने के लिए, यह यूआरएल लोड करें:
https://google.github.io/webview-ads/test/#api-for-ads-tests
अगर ये शर्तें पूरी होती हैं, तो टेस्ट यूआरएल पर, इंटिग्रेशन के सफल होने पर हरे रंग के स्टेटस बार दिखते हैं:
WKWebViewसे कनेक्ट हो Google Mobile Ads SDK
अगले चरण
WKWebViewमें सहमति लेना. वेब व्यू के लिए बने एपीआई, IAB TCF v2.0 या IAB CCPA कंप्लायंस फ़्रेमवर्क का इस्तेमाल करके, मोबाइल ऐप्लिकेशन के कॉन्टेक्स्ट में इकट्ठा की गई सहमति को, आपके वेब व्यू में मौजूद टैग तक नहीं पहुंचाते. अगर आपकोWKWebViewऔर उससे जुड़े वेब कॉन्टेंट, दोनों के मालिक के तौर पर, सहमति लेने का एक ही फ़्लो लागू करना है, तोWKWebViewके कॉन्टेक्स्ट में सहमति इकट्ठा करने के लिए, अपने सहमति मैनेजमेंट प्लैटफ़ॉर्म के साथ मिलकर काम करें.