यह गाइड उन पब्लिशर के लिए है जो Firebase का इस्तेमाल किए बिना, AdMob की मदद से C++ ऐप्लिकेशन से कमाई करना चाहते हैं. अगर आपको अपने ऐप्लिकेशन में Firebase शामिल करना है या इस बारे में सोच रहे हैं, तो इस गाइड का Firebase के साथ AdMob वर्शन देखें.
Google Mobile Ads C++ SDK टूल को ऐप्लिकेशन में इंटिग्रेट करना, आपके लिए सबसे पहले विज्ञापन दिखाकर और कमाई करने में मदद करता है. SDK टूल को इंटिग्रेट करने के बाद, इंटरस्टीशियल या इनाम वाले विज्ञापन जैसे विज्ञापन फ़ॉर्मैट को चुना जा सकता है. साथ ही, उसे लागू करने के लिए दिए गए निर्देशों का पालन किया जा सकता है.
Google Mobile Ads C++ SDK में Google Mobile Ads iOS और Android SDK टूल शामिल किए गए हैं.
यह सुविधा सिर्फ़ उन प्लैटफ़ॉर्म पर उपलब्ध है. Google Mobile Ads C++ SDK टूल,
एसिंक्रोनस ऑपरेशन को सपोर्ट करने के लिए Firebase C++ कंस्ट्रक्ट का इस्तेमाल करता है. इसलिए, यह
firebase::gma
नेमस्पेस में.
अगर आपने पहली बार इस गाइड को पढ़ा है, तो हमारा सुझाव है कि आप Google Mobile Ads C++ टेस्ट ऐप्लिकेशन को डाउनलोड करें और इस गाइड में दिए गए निर्देशों का पालन करें.
ज़रूरी शर्तें
Android
- Android Studio 3.2 या इसके बाद के वर्शन का इस्तेमाल करना
- पक्का करें कि आपके ऐप्लिकेशन की बिल्ड फ़ाइल में इन वैल्यू का इस्तेमाल किया गया हो:
- 16 या उससे ज़्यादा का
minSdkVersion
compileSdkVersion
28 या उससे ज़्यादा होना चाहिए
- 16 या उससे ज़्यादा का
iOS
- Xcode 13 या उसके बाद के वर्शन का इस्तेमाल करना
- iOS 10.0 या इसके बाद के वर्शन को टारगेट करना
अपने AdMob खाते में ऐप्लिकेशन सेट अप करना
अपने ऐप्लिकेशन को AdMob ऐप्लिकेशन के तौर पर रजिस्टर करने के लिए, यह तरीका अपनाएं:
साइन इन करें या साइन अप करें AdMob खाते के लिए.
अपने ऐप्लिकेशन को AdMob के साथ रजिस्टर करें. यह चरण एक AdMob बनाता है यूनीक AdMob ऐप्लिकेशन आईडी वाला ऐप्लिकेशन जिसकी ज़रूरत इस गाइड में बाद में है.
Google Mobile Ads C++ SDK इंस्टॉल करना
Google Mobile Ads C++ SDK टूल, firebase::gma
नेमस्पेस में मौजूद है,
Firebase C++ SDK टूल डाउनलोड करना होगा,
और फिर उसे अपनी पसंद की किसी डायरेक्ट्री में अनज़िप करें.
Firebase C++ SDK टूल, प्लैटफ़ॉर्म के हिसाब से नहीं है. हालांकि, इसके लिए यह ज़रूरी है प्लैटफ़ॉर्म के हिसाब से लाइब्रेरी कॉन्फ़िगरेशन.
Android
हम CMake का इस्तेमाल करने का सुझाव देते हैं, लेकिन आपको ndk-build के लिए निर्देश यहां मिल सकते हैं
सामान्य Firebase C++ SDK टूल इस्तेमाल करना शुरू करें
देखने के लिए गाइड करें
libfirebase_app.a
और libfirebase_gma.a
को अपने ऐप्लिकेशन से लिंक करें.
अपने प्रोजेक्ट की
gradle.properties
फ़ाइल में, अनज़िप किए गए SDK टूल की जगह की जानकारी दें:systemProp.firebase_cpp_sdk.dir=FULL_PATH_TO_SDK
अपने प्रोजेक्ट की
settings.gradle
फ़ाइल में, यह कॉन्टेंट जोड़ें:def firebase_cpp_sdk_dir = System.getProperty('firebase_cpp_sdk.dir') gradle.ext.firebase_cpp_sdk_dir = "$firebase_cpp_sdk_dir" includeBuild "$firebase_cpp_sdk_dir"
अपने मॉड्यूल (ऐप्लिकेशन-लेवल) की Gradle फ़ाइल में, आम तौर पर
app/build.gradle
में यह कॉन्टेंट जोड़ें. इसमें Google Mobile Ads C++ SDK के लिए लाइब्रेरी डिपेंडेंसी शामिल है.android.defaultConfig.externalNativeBuild.cmake { arguments "-DFIREBASE_CPP_SDK_DIR=$gradle.firebase_cpp_sdk_dir" } # Add the dependency for the Google Mobile Ads C++ SDK apply from: "$gradle.firebase_cpp_sdk_dir/Android/firebase_dependencies.gradle" firebaseCpp.dependencies { gma }
अपने प्रोजेक्ट की
CMakeLists.txt
फ़ाइल में, यह कॉन्टेंट जोड़ें.# Add Firebase libraries to the target using the function from the SDK. add_subdirectory(${FIREBASE_CPP_SDK_DIR} bin/ EXCLUDE_FROM_ALL) # Add the Google Mobile Ads C++ SDK. # The Firebase C++ library `firebase_app` is required, # and it must always be listed last. set(firebase_libs firebase_gma firebase_app ) target_link_libraries(${target_name} "${firebase_libs}")
अपने ऐप्लिकेशन को सिंक करें, ताकि यह पक्का किया जा सके कि सभी डिपेंडेंसी के ज़रूरी वर्शन मौजूद हों.
iOS
इस सेक्शन में दिए गए चरण, Google मोबाइल विज्ञापनों को जोड़ने के तरीके का उदाहरण हैं C++ SDK टूल का इस्तेमाल अपने iOS प्रोजेक्ट में करने के लिए किया जा सकता है.
CocoaPods का वर्शन 1 या उसके बाद का वर्शन पाने के लिए, यह तरीका अपनाएं:
sudo gem install cocoapods --pre
अनज़िप किए गए SDK टूल से Google Mobile Ads पॉड जोड़ें.
अगर आपके पास पहले से कोई Podfile नहीं है, तो एक बनाएं:
cd APP_DIRECTORY
pod init
अपनी Podfile में, Google Mobile Ads C++ SDK, Google User Messaging Platform SDK, और ज़रूरी Firebase कोर SDK टूल के लिए पॉड जोड़ें. GMA C++ SDK के लिए ये ज़रूरी हैं:
pod 'Firebase/CoreOnly' pod 'Google-Mobile-Ads-SDK' pod 'GoogleUserMessagingPlatform'
पॉड इंस्टॉल करें. इसके बाद, Xcode में
.xcworkspace
फ़ाइल खोलें.pod install
open APP.xcworkspace
Firebase C++ SDK टूल से प्रोजेक्ट में ये फ़्रेमवर्क जोड़ें:
xcframeworks/firebase.xcframework
xcframeworks/firebase_gma.xcframework
आप बिल्कुल तैयार हैं! आपका C++ ऐप्लिकेशन, Firebase की किसी भी अन्य सेवा के बिना Google Mobile Ads C++ SDK टूल का इस्तेमाल करने के लिए कॉन्फ़िगर किया गया है.
अपने ऐप्लिकेशन का AdMob ऐप्लिकेशन आईडी कॉन्फ़िगर करना
Android
मोबाइल विज्ञापन SDK टूल में बताए गए तरीके से, अपना ऐप्लिकेशन कॉन्फ़िगर करें के तीसरे चरण को अपनाएं Android गाइड इस पेज पर वापस आएँ.
iOS
Mobile Ads SDK के लिए iOS गाइड में बताए गए तरीके से, अपना Info.plist अपडेट करें. इसके बाद, इस पेज पर वापस आएं.
Google Mobile Ads SDK को शुरू करना
विज्ञापन लोड करने से पहले, अपने ऐप्लिकेशन को Google Mobile Ads C++ SDK टूल को शुरू करने के लिए कहें. इसके लिए, firebase::gma::Initialize()
को कॉल करें. यह SDK टूल शुरू करता है और शुरू होने के बाद (या 30 सेकंड के टाइम आउट के बाद) firebase::Future
को पूरा करता है. इसे सिर्फ़ एक बार करना होगा. आम तौर पर, ऐप्लिकेशन लॉन्च करते समय ऐसा करना चाहिए.
Initialize()
को कॉल करने पर, Google Mobile Ads C++ SDK या मीडिएशन पार्टनर SDKs के ज़रिए विज्ञापन पहले से लोड किए जा सकते हैं. अगर आपको यूरोपियन इकनॉमिक एरिया (ईईए) में रहने वाले उपयोगकर्ताओं की सहमति लेनी है, तो अनुरोध से जुड़े किसी भी फ़्लैग (जैसे, tag_for_child_directed_treatment
या tag_for_under_age_of_consent
) को सेट करें. इसके अलावा, विज्ञापन लोड करने से पहले कोई कार्रवाई भी की जा सकती है. हालांकि, ऐसा करने के लिए, Google Mobile Ads C++ SDK को शुरू करने से पहले, firebase::gma::SetRequestConfiguration()
को चालू करना न भूलें. ज़्यादा जानकारी के लिए, यह देखें:
टारगेटिंग गाइड.
यहां Initialize()
को कॉल करने का तरीका बताया गया है:
Android
// Initialize the Google Mobile Ads library
firebase::InitResult result;
Future<AdapterInitializationStatus> future =
firebase::gma::Initialize(jni_env, j_activity, &result);
if (result != kInitResultSuccess) {
// Initialization immediately failed, most likely due to a missing
// dependency. Check the device logs for more information.
return;
}
// Monitor the status of the future.
// See "Use a Future to monitor the completion status of a method call" below.
if (future.status() == firebase::kFutureStatusComplete &&
future.error() == firebase::gma::kAdErrorCodeNone) {
// Initialization completed.
} else {
// Initialization on-going, or an error has occurred.
}
iOS
// Initialize the Google Mobile Ads library.
firebase::InitResult result;
Future<AdapterInitializationStatus> future =
firebase::gma::Initialize(&result);
if (result != kInitResultSuccess) {
// Initialization immediately failed, most likely due to a missing
// dependency. Check the device logs for more information.
return;
}
// Monitor the status of the future.
// See "Use a Future to monitor the completion status of a method call" below.
if (future.status() == firebase::kFutureStatusComplete &&
future.error() == firebase::gma::kAdErrorCodeNone) {
// Initialization completed.
} else {
// Initialization on-going, or an error has occurred.
}
किसी तरीके से आए कॉल के पूरा होने की स्थिति पर नज़र रखने के लिए, Future
का इस्तेमाल करें
Future
की मदद से, अपनी परफ़ॉर्मेंस की स्थिति का पता लगाया जा सकता है
एसिंक्रोनस तरीके कॉल.
उदाहरण के लिए, जब आपका ऐप्लिकेशन firebase::gma::Initialize()
को कॉल करता है, तो एक नया firebase::Future
बनाया जाता है और उसे दिखाया जाता है. इसके बाद, आपका ऐप्लिकेशन Future
के status()
को पोल करके यह पता लगा सकता है कि शुरू करने की प्रोसेस कब पूरी हुई.
प्रोसेस पूरी होने के बाद, आपका ऐप्लिकेशन result()
शुरू कर सकता है, ताकि नतीजे मिल सकें
AdapterInitializationStatus
.
Future
रिटर्न करने वाले तरीकों में संबंधित "पिछला नतीजा" होता है वह तरीका
ऐप्लिकेशन, किसी कार्रवाई के लिए सबसे हाल के Future
को वापस पाने के लिए इसका इस्तेमाल कर सकते हैं. उदाहरण के लिए, firebase::gma::Initialize()
के लिए एक तरीका है, जिसे firebase::gma::InitializeLastResult()
कहा जाता है. यह एक Future
दिखाता है, जिसका इस्तेमाल आपका ऐप्लिकेशन firebase::gma::Initialize()
को किए गए आखिरी कॉल की स्थिति देखने के लिए कर सकता है.
अगर Future
की स्थिति पूरी हो गई है और इसका गड़बड़ी कोड यह है
firebase::gma::kAdErrorCodeNone
, फिर कार्रवाई पूरी हो गई है
का इस्तेमाल किया जा सकता है.
Future
पूरा होने पर कॉलबैक ट्रिगर करने के लिए भी उन्हें रजिस्टर किया जा सकता है. तय सीमा में
कुछ मामलों में, कॉलबैक अलग थ्रेड में चलेगा, इसलिए
आपका कोड थ्रेड से सुरक्षित है. यह कोड स्निपेट, कॉलबैक के लिए फ़ंक्शन पॉइंटर का इस्तेमाल करता है:
// Registers the OnCompletion callback. user_data is a pointer that is passed verbatim
// to the callback as a void*. This allows you to pass any custom data to the callback
// handler. In this case, the app has no data, so you must pass nullptr.
firebase::gma::InitializeLastResult().OnCompletion(OnCompletionCallback,
/*user_data=*/nullptr);
// The OnCompletion callback function.
static void OnCompletionCallback(
const firebase::Future<AdapterInitializationStatus>& future, void* user_data) {
// Called when the Future is completed for the last call to firebase::gma::Initialize().
// If the error code is firebase::gma::kAdErrorCodeNone,
// then the SDK has been successfully initialized.
if (future.error() == firebase::gma::kAdErrorCodeNone) {
// success!
} else {
// failure.
}
}
विज्ञापन फ़ॉर्मैट चुनना
Google Mobile Ads C++ SDK टूल अब इंपोर्ट हो गया है. अब आप विज्ञापन AdMob कई तरह के विज्ञापन फ़ॉर्मैट की सुविधा देता है, इसलिए आपके पास सही फ़ॉर्मैट चुनने का विकल्प होता है जो आपके ऐप्लिकेशन के उपयोगकर्ता अनुभव के हिसाब से सबसे सही हो.
बैनर
आयताकार विज्ञापन, जो डिवाइस की स्क्रीन के ऊपर या नीचे दिखते हैं. जब उपयोगकर्ता ऐप्लिकेशन के साथ इंटरैक्ट करते हैं, तब बैनर विज्ञापन स्क्रीन पर दिखते रहते हैं. इसके अलावा, एक तय समय के बाद अपने-आप रीफ़्रेश हो जाएगा. अगर आपने मोबाइल पर विज्ञापन दिखाने की सुविधा का इस्तेमाल पहले कभी नहीं किया है, तो इनसे शुरुआत करें.
मध्यवर्ती
फ़ुल-स्क्रीन विज्ञापन, जो किसी ऐप्लिकेशन के इंटरफ़ेस को तब तक कवर करते हैं, जब तक उपयोगकर्ता उन्हें बंद नहीं कर देता. इनका इस्तेमाल, ऐप्लिकेशन के फ़्लो में मौजूद नैचुरल ब्रेक के दौरान किया जाता है. जैसे, किसी गेम के लेवल के बीच में या टास्क पूरा होने के बाद.
अचानक दिखने वाले (इंटरस्टीशियल) विज्ञापन लागू करना
इनाम दिया गया
इन विज्ञापनों में इनाम पाने के लिए उपयोगकर्ताओं को छोटे-छोटे वीडियो देखने होते हैं. इसके अलावा, उन्हें 'गेम खेलने देने वाले विज्ञापन' से इंटरैक्ट करना होता है या फिर सर्वे भरना होता है. इसका इस्तेमाल, मुफ़्त में खेले जाने वाले ऐप्लिकेशन से कमाई करने के लिए किया जाता है.