Android v3 (लेगसी) - खास जानकारी

इस डेवलपर गाइड में बताया गया है कि मोबाइल ऐप्लिकेशन में Google Tag Manager को कैसे लागू किया जाता है.

शुरुआती जानकारी

Google Tag Manager की मदद से डेवलपर, Google Tag Manager इंटरफ़ेस का इस्तेमाल करके अपने मोबाइल ऐप्लिकेशन में कॉन्फ़िगरेशन की वैल्यू बदल सकते हैं. इसके लिए, उन्हें ऐप्लिकेशन बाइनरी बनाने की ज़रूरत नहीं है.

यह आपके ऐप्लिकेशन में किसी भी कॉन्फ़िगरेशन वैल्यू या फ़्लैग को मैनेज करने के लिए फ़ायदेमंद है, जिसमें आपको आने वाले समय में बदलाव करने की ज़रूरत पड़ सकती है. इनमें ये शामिल हैं:

  • कई यूज़र इंटरफ़ेस (यूआई) सेटिंग और डिसप्ले स्ट्रिंग
  • आपके ऐप्लिकेशन में दिखाए जाने वाले विज्ञापनों के साइज़, जगह या टाइप
  • गेम की सेटिंग

रनटाइम पर कॉन्फ़िगरेशन वैल्यू का आकलन भी नियमों का इस्तेमाल करके किया जा सकता है. इससे डाइनैमिक कॉन्फ़िगरेशन चालू होते हैं, जैसे:

  • विज्ञापन बैनर का साइज़ तय करने के लिए, स्क्रीन साइज़ का इस्तेमाल करना
  • यूज़र इंटरफ़ेस (यूआई) एलिमेंट कॉन्फ़िगर करने के लिए, भाषा और जगह की जानकारी का इस्तेमाल करना

Google TagManager, ऐप्लिकेशन में ट्रैकिंग टैग और पिक्सल को डाइनैमिक तरीके से लागू करने की सुविधा भी देता है. डेवलपर, ज़रूरी इवेंट को डेटा लेयर में डाल सकते हैं. साथ ही, बाद में यह तय कर सकते हैं कि किस ट्रैकिंग टैग या पिक्सल को ट्रिगर करना है. फ़िलहाल, TagManager इन टैग के साथ काम करता है:

  • Google Mobile App Analytics
  • कस्टम फ़ंक्शन कॉल टैग

आरंभ करने से पहले

इस शुरुआती निर्देश का इस्तेमाल करने से पहले, आपको इनकी ज़रूरत होगी:

अगर आपने Google Tag Manager का इस्तेमाल पहले कभी नहीं किया है, तो हमारा सुझाव है कि इस गाइड को जारी रखने से पहले, आप कंटेनर, मैक्रो, और नियमों (सहायता केंद्र) के बारे में ज़्यादा जानें.

YouTube पर शुरुआत करना

यह सेक्शन, Tag Manager के सामान्य वर्कफ़्लो के बारे में डेवलपर को गाइड करेगा:

  1. अपने प्रोजेक्ट में Google Tag Manager SDK टूल जोड़ना
  2. कंटेनर की डिफ़ॉल्ट वैल्यू सेट करना
  3. कंटेनर खोलें
  4. कंटेनर से कॉन्फ़िगरेशन वैल्यू पाना
  5. Datalayer में इवेंट पुश करें
  6. कंटेनर की झलक देखना और उसे पब्लिश करना

1. अपने प्रोजेक्ट में Google Tag Manager SDK टूल जोड़ना

Google Tag Manager SDK टूल का इस्तेमाल करने से पहले, आपको SDK टूल पैकेज को अनज़िप करना होगा. साथ ही, लाइब्रेरी को अपने प्रोजेक्ट के बिल्ड पाथ में जोड़ना होगा. साथ ही, अपनी AndroidManifest.xml फ़ाइल में अनुमतियां जोड़नी होंगी.

सबसे पहले, Google Tag Manager की लाइब्रेरी को अपने प्रोजेक्ट के /libs फ़ोल्डर में जोड़ें.

इसके बाद, इन अनुमतियों का इस्तेमाल करने के लिए अपनी AndroidManifest.xml फ़ाइल अपडेट करें:

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />

2. अपने प्रोजेक्ट में डिफ़ॉल्ट कंटेनर फ़ाइल जोड़ना

आपका ऐप्लिकेशन पहली बार चलाए जाने पर, Google Tag Manager एक डिफ़ॉल्ट कंटेनर का इस्तेमाल करता है. डिफ़ॉल्ट कंटेनर का इस्तेमाल तब तक किया जाएगा, जब तक ऐप्लिकेशन, नेटवर्क पर नया कंटेनर हासिल नहीं कर लेता.

डिफ़ॉल्ट कंटेनर बाइनरी डाउनलोड करके अपने ऐप्लिकेशन में जोड़ने के लिए, यह तरीका अपनाएं:

  1. Google Tag Manager के वेब इंटरफ़ेस में साइन इन करें.
  2. उस कंटेनर का वर्शन चुनें जिसे आपको डाउनलोड करना है.
  3. कंटेनर बाइनरी को फिर से पाने के लिए, डाउनलोड करें बटन पर क्लिक करें.
  4. बाइनरी फ़ाइल को इस पाथ में जोड़ें: <project-root>/assets/tagmanager/

डिफ़ॉल्ट फ़ाइल नाम कंटेनर आईडी (उदाहरण के लिए GTM-1234) होना चाहिए. बाइनरी फ़ाइल डाउनलोड करने के बाद, फ़ाइल नाम से वर्शन सफ़िक्स को हटाना न भूलें. इससे यह पक्का किया जा सकेगा कि आपने नाम रखने के सही तरीके का पालन किया है.

हमारा सुझाव है कि आप बाइनरी फ़ाइल का इस्तेमाल करें. हालांकि, अगर आपके कंटेनर में कोई नियम या टैग मौजूद नहीं हैं, तो आपके पास एक सामान्य JSON फ़ाइल इस्तेमाल करने का विकल्प है. फ़ाइल, आपके Android प्रोजेक्ट के नए /assets/tagmanager फ़ोल्डर में होनी चाहिए. साथ ही, फ़ाइल को नाम रखने के इस तरीके का पालन करना चाहिए: <Container_ID>.json. उदाहरण के लिए, अगर आपका कंटेनर आईडी GTM-1234 है, तो आपको अपनी डिफ़ॉल्ट कंटेनर वैल्यू को /assets/tagmanager/GTM-1234.json में जोड़ना चाहिए.

3. कंटेनर खोलना

किसी कंटेनर से वैल्यू वापस पाने से पहले, आपके ऐप्लिकेशन को कंटेनर खोलना होगा. कंटेनर खोलने पर, वह डिस्क से लोड हो जाएगा (अगर उपलब्ध हो) या नेटवर्क से अनुरोध करेगा (अगर ज़रूरी हो).

Android पर कंटेनर खोलने का सबसे आसान तरीका, ContainerOpener.openContainer(..., Notifier notifier) का इस्तेमाल करना है, जैसा कि यहां दिए गए उदाहरण में दिखाया गया है:

import com.google.tagmanager.Container;
import com.google.tagmanager.ContainerOpener;
import com.google.tagmanager.ContainerOpener.OpenType;
import com.google.tagmanager.TagManager;

import android.app.Activity;
import android.os.Bundle;

public class RacingGame {

  // Add your public container ID.
  private static final String CONTAINER_ID = "GTM-YYYY";

  volatile private Container mContainer;

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    TagManager mTagManager = TagManager.getInstance(this);

    // The container is returned to containerFuture when available.
    ContainerOpener.openContainer(
        mTagManager,                            // TagManager instance.
        CONTAINER_ID,                           // Tag Manager Container ID.
        OpenType.PREFER_NON_DEFAULT,            // Prefer not to get the default container, but stale is OK.
        null,                                   // Time to wait for saved container to load (ms). Default is 2000ms.
        new ContainerOpener.Notifier() {        // Called when container loads.
          @Override
          public void containerAvailable(Container container) {
            // Handle assignment in callback to avoid blocking main thread.
            mContainer = container;
          }
        }
    );
    // Rest of your onCreate code.
  }
}

इस उदाहरण में, ContainerOpener.openContainer(..., Notifier notifier) का इस्तेमाल लोकल स्टोरेज से, सेव किए गए कंटेनर का अनुरोध करने के लिए किया गया है. containerAvailable कॉलबैक में mContainer के असाइनमेंट को मैनेज करके, हम यह पक्का करते हैं कि मुख्य थ्रेड ब्लॉक न की गई हो. अगर सेव किया गया कंटेनर 12 घंटे से ज़्यादा पुराना है, तो कॉल, नेटवर्क पर नए कंटेनर को एसिंक्रोनस तरीके से फिर से पाने के लिए अनुरोध भी शेड्यूल करेगा.

लागू करने का यह नमूना, ContainerOpener सुविधा क्लास का इस्तेमाल करके किसी कंटेनर से वैल्यू को खोलने और वापस पाने का सबसे आसान तरीका दिखाता है. लागू करने के बेहतर विकल्पों के लिए, बेहतर कॉन्फ़िगरेशन देखें.

4. कंटेनर से कॉन्फ़िगरेशन वैल्यू फ़ेच करना

कंटेनर खुलने के बाद, get<type>Value() तरीकों का इस्तेमाल करके, कॉन्फ़िगरेशन वैल्यू वापस पाई जा सकती हैं:

// Retrieving a configuration value from a Tag Manager Container.

// Get the configuration value by key.
String title = mContainer.getStringValue("title_string");

किसी गैर-मौजूद कुंजी से किए गए अनुरोधों के लिए, अनुरोध किए गए टाइप के हिसाब से डिफ़ॉल्ट वैल्यू दिखेगी:

// Empty keys will return a default value depending on the type requested.

// Key does not exist. An empty string is returned.
string subtitle = container.getStringValue("Non-existent-key");
subtitle.equals(""); // Evaluates to true.

5. Datalayer में वैल्यू पुश करना

DataLine एक ऐसा मैप है जो आपके ऐप्लिकेशन के रनटाइम की जानकारी को चालू करता है. जैसे, टच इवेंट या स्क्रीन व्यू. इससे कंटेनर में मौजूद टैग मैनेजर मैक्रो और टैग के लिए, रनटाइम की जानकारी उपलब्ध कराई जा सकती है.

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

push() और DataLayer.mapOf() हेल्पर तरीके का इस्तेमाल करके, इवेंट को Datalayer में पुश किया जाता है:

//
// MainActivity.java
// Pushing an openScreen event with a screen name into the data layer.
//

import com.google.tagmanager.TagManager;
import com.google.tagmanager.DataLayer;

import android.app.Activity;
import android.os.Bundle;

public MainActivity extends Activity {

  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

  }

  // This screen becomes visible when Activity.onStart() is called.
  public void onStart() {
    super.onStart();

    // The container should have already been opened, otherwise events pushed to
    // the DataLayer will not fire tags in that container.
    DataLayer dataLayer = TagManager.getInstance(this).getDataLayer();
    dataLayer.push(DataLayer.mapOf("event",
                                   "openScreen",      // The event type. This value should be used consistently for similar event types.
                                   "screenName",      // Writes a key "screenName" to the dataLayer map.
                                   "Home Screen")     // Writes a value "Home Screen" for the "screenName" key.
    );
  }
  // Rest of the Activity implementation
}

वेब इंटरफ़ेस में, अब आप इस नियम को बनाकर हर स्क्रीन व्यू के लिए सक्रिय करने के लिए टैग (जैसे कि Google Analytics टैग) बना सकते हैं: इसके बराबर है "openScreen". स्क्रीन के नाम को इनमें से किसी एक टैग को पास करने के लिए, डेटा लेयर मैक्रो बनाएं. यह मैक्रो डेटा लेयर में "screenName" कुंजी का इस्तेमाल करता है. सिर्फ़ खास स्क्रीन व्यू को चालू करने के लिए, एक टैग (जैसे कि Google Ads कन्वर्ज़न पिक्सल) भी बनाया जा सकता है. ऐसा करने के लिए एक ऐसा नियम बनाया जा सकता है जिसमें equals "openScreen" && equals "ConfirmationScreen" बराबर हो.

6. कंटेनर की झलक देखना और उसे पब्लिश करना

मैक्रो वैल्यू हमेशा, पब्लिश किए गए मौजूदा वर्शन के हिसाब से होंगी. कंटेनर का सबसे नया वर्शन पब्लिश करने से पहले, अपने ड्राफ़्ट कंटेनर की झलक देखी जा सकती है.

कंटेनर की झलक देखने के लिए, कंटेनर के उस वर्शन को चुनकर Preview को चुनें जिसकी झलक आपको देखनी है. ऐसा करके, Google Tag Manager के वेब इंटरफ़ेस में झलक दिखाने वाला यूआरएल जनरेट करें. इस झलक यूआरएल पर बने रहें, क्योंकि आपको बाद के चरणों में इसकी ज़रूरत पड़ेगी.

झलक यूआरएल, Tag Manager वेब इंटरफ़ेस की झलक विंडो में उपलब्ध हैं
पहली इमेज: Tag Manager के वेब इंटरफ़ेस से, झलक दिखाने वाला यूआरएल पाना.

इसके बाद, नीचे दी गई गतिविधि को अपने ऐप्लिकेशन की AndroidManifest.xml फ़ाइल में जोड़ें:

<!-- Google Tag Manager Preview Activity -->
<activity
  android:name="com.google.tagmanager.PreviewActivity"
  android:label="@string/app_name"
  android:noHistory="true" >  <!-- Optional, removes the PreviewActivity from activity stack. -->
  <intent-filter>
    <data android:scheme="tagmanager.c.application_package_name" />
    <action android:name="android.intent.action.VIEW" />
    <category android:name="android.intent.category.DEFAULT" />
    <category android:name="android.intent.category.BROWSABLE"/>
  </intent-filter>
</activity>
  

अपने ऐप्लिकेशन में ड्राफ़्ट कंटेनर की झलक देखने के लिए, एम्युलेटर या फ़िज़िकल डिवाइस पर इस लिंक को खोलें.

जब आप अपने ऐप्लिकेशन पर ड्राफ़्ट कॉन्फ़िगरेशन की वैल्यू उपलब्ध कराने के लिए तैयार हों, तब कंटेनर पब्लिश करें.

बेहतर कॉन्फ़िगरेशन

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

कंटेनर खोलने के लिए बेहतर विकल्प

Google Tag Manager SDK टूल, कंटेनर खोलने के लिए कई तरीके उपलब्ध कराता है. इनकी मदद से, लोड होने की प्रोसेस पर ज़्यादा कंट्रोल पाया जा सकता है:

TagManager.openContainer()

कंटेनर खोलने के लिए, TagManager.openContainer() सबसे निचले लेवल का और सबसे सुविधाजनक एपीआई है. अगर सेव किया गया कंटेनर मौजूद नहीं है या सेव किया गया कंटेनर नया नहीं है (12 घंटे से ज़्यादा पुराना है), तो यह डिफ़ॉल्ट कंटेनर के साथ तुरंत, डिस्क या नेटवर्क से कंटेनर को एसिंक्रोनस तरीके से लोड करता है.

mContainer = tagManager.openContainer(CONTAINER_ID, new Container.Callback() {

  // Called when a refresh is about to begin for the given refresh type.
  @Override
  public void containerRefreshBegin(Container container, RefreshType refreshType) {
    // Notify UI that the Container refresh is beginning.
   }

  // Called when a successful refresh occurred for the given refresh type.
  @Override
  public void containerRefreshSuccess(Container container, RefreshType refreshType]) {
    // Notify UI that Container is ready.
  }

  // Called when a refresh failed for the given refresh type.
  @Override
  public void containerRefreshFailure(Container container,
                                      RefreshType refreshType,
                                      RefreshFailure refreshFailure) {
    // Notify UI that the Container refresh has failed.
  }

लोड होने की पूरी प्रोसेस के दौरान, TagManager.openContainer() कई लाइफ़साइकल कॉलबैक को समस्या करता है, ताकि आपका कोड पता लगा सके कि लोड करने का अनुरोध कब शुरू होता है, वह पूरा होता है या नहीं, वह क्यों काम नहीं करता, और कंटेनर डिस्क या नेटवर्क से लोड हुआ है या नहीं.

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

TagManager.openContainer(), इन enum वैल्यू को इन कॉलबैक में आर्ग्युमेंट के तौर पर पास करता है:

RefreshType

वैल्यूब्यौरा
Container.Callback.SAVED रीफ़्रेश करने का अनुरोध, स्थानीय तौर पर सेव किया गया कंटेनर लोड कर रहा है.
Container.Callback.NETWORK रीफ़्रेश करने का अनुरोध, नेटवर्क पर कंटेनर लोड किया जा रहा है.

RefreshFailure

वैल्यूब्यौरा
Container.Callback.NO_SAVED_CONTAINER सेव किया गया कोई कंटेनर उपलब्ध नहीं है.
Container.Callback.IO_ERROR I/O गड़बड़ी की वजह से कंटेनर को रीफ़्रेश नहीं किया जा सका.
Container.Callback.NO_NETWORK इंटरनेट नहीं है.
Container.Callback.NETWORK_ERROR नेटवर्क में कोई गड़बड़ी हुई.
Container.Callback.SERVER_ERROR सर्वर में कोई गड़बड़ी हुई.
Container.Callback.UNKNOWN_ERROR एक ऐसी गड़बड़ी हुई है जिसे कैटगरी में नहीं बांटा जा सकता.

ऐसे कंटेनर खोलने के तरीके जो डिफ़ॉल्ट नहीं हैं और नए हैं

ContainerOpener, TagManager.openContainer() को रैप करता है और कंटेनर खोलने के लिए दो आसान तरीके देता है: ContainerOpener.openContainer(..., Notifier notifier) और ContainerOpener.openContainer(..., Long timeoutInMillis).

इनमें से हर एक तरीके की मदद से गिनती के आधार पर या तो नॉन-डिफ़ॉल्ट या फ़्रेश कंटेनर का अनुरोध किया जाता है.

ज़्यादातर ऐप्लिकेशन के लिए OpenType.PREFER_NON_DEFAULT का सुझाव दिया जाता है. यह सलाह दी जाती है कि Drive या नेटवर्क से किसी समयसीमा के अंदर, पहले मौजूद नॉन-डिफ़ॉल्ट कंटेनर को वापस लाने की कोशिश की जाए. भले ही, वह कंटेनर 12 घंटे से ज़्यादा पुराना हो. अगर यह सेव किया गया पुराना कंटेनर दिखाता है, तो यह नए के लिए एसिंक्रोनस नेटवर्क अनुरोध भी करेगा. OpenType.PREFER_NON_DEFAULT का इस्तेमाल करते समय, अगर कोई दूसरा कंटेनर उपलब्ध नहीं है या टाइम आउट की अवधि तय सीमा से ज़्यादा हो गई है, तो डिफ़ॉल्ट कंटेनर दिखाया जाएगा.

OpenType.PREFER_FRESH तय टाइम आउट अवधि के अंदर, डिस्क या नेटवर्क से नया कंटेनर दिखाने की कोशिश करता है. नेटवर्क कनेक्शन उपलब्ध न होने और/या टाइम आउट की अवधि खत्म होने पर, यह सेव किया गया कंटेनर दिखाता है.

ऐसी जगहों पर OpenType.PREFER_FRESH का इस्तेमाल करने का सुझाव नहीं दिया जाता जहां अनुरोध करने में ज़्यादा समय लगता है, जिससे उपयोगकर्ता अनुभव पर काफ़ी असर पड़ सकता है, जैसे कि यूज़र इंटरफ़ेस (यूआई) फ़्लैग या डिसप्ले स्ट्रिंग. नेटवर्क कंटेनर का अनुरोध करने के लिए जब चाहें, Container.refresh() का इस्तेमाल करें.

सुविधा के ये दोनों तरीके ब्लॉक नहीं किए जा सकते. ContainerOpener.openContainer(..., Long timeoutInMillis) एक ContainerOpener.ContainerFuture ऑब्जेक्ट दिखाता है, जिसका get तरीका लोड होते ही Container दिखाता है (लेकिन तब तक यह ब्लॉक हो जाएगा). ContainerOpener.openContainer(..., Notifier notifier) तरीके में एक कॉलबैक होता है, जिसे कंटेनर उपलब्ध होने पर कहा जाता है. इसका इस्तेमाल मुख्य थ्रेड को ब्लॉक होने से रोकने के लिए किया जा सकता है. दोनों तरीकों की डिफ़ॉल्ट टाइम आउट अवधि 2000 मिलीसेकंड है.

नियमों का इस्तेमाल करके रनटाइम में मैक्रो का आकलन करना

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

रनटाइम के दौरान, डिवाइस की भाषा के आधार पर डिसप्ले स्ट्रिंग
            चुनने के लिए एक नियम का इस्तेमाल किया जाता है: भाषा es के बराबर है. इस नियम में पहले से तय भाषा मैक्रो और दो वर्ण वाले ISO 639-1 भाषा कोड का इस्तेमाल किया जाता है.
पहली इमेज: स्पैनिश भाषा का इस्तेमाल करने के लिए कॉन्फ़िगर किए गए डिवाइसों के लिए, वैल्यू कलेक्शन मैक्रो चालू करने का नियम जोड़ा जा रहा है.

इसके बाद, हर भाषा के लिए वैल्यू कलेक्शन मैक्रो बनाए जा सकते हैं और इस नियम को हर मैक्रो में जोड़ा जा सकता है. साथ ही, सही भाषा कोड डाला जा सकता है. इस कंटेनर के पब्लिश होने पर, आपका ऐप्लिकेशन स्थानीय जगह के हिसाब से डिसप्ले स्ट्रिंग दिखा पाएगा. हालांकि, रनटाइम के समय, यह उपयोगकर्ता के डिवाइस की भाषा पर निर्भर करता है.

ध्यान दें कि अगर आपके डिफ़ॉल्ट कंटेनर को नियमों की ज़रूरत है, तो आपको डिफ़ॉल्ट कंटेनर के तौर पर बाइनरी कंटेनर फ़ाइल का इस्तेमाल करना होगा.

नियम कॉन्फ़िगर करने के बारे में ज़्यादा जानें (सहायता केंद्र).

बाइनरी डिफ़ॉल्ट कंटेनर फ़ाइलें

जिन डिफ़ॉल्ट कंटेनर को नियमों की ज़रूरत होती है उन्हें डिफ़ॉल्ट कंटेनर के तौर पर, JSON फ़ाइल के बजाय, बाइनरी कंटेनर फ़ाइल का इस्तेमाल करना चाहिए. बाइनरी कंटेनर, Google Tag Manager के नियमों की मदद से, रनटाइम के दौरान मैक्रो वैल्यू तय करने में मदद करते हैं, जबकि JSON फ़ाइलें ऐसा नहीं करती हैं.

बाइनरी कंटेनर फ़ाइलें, Google Tag Manager के वेब इंटरफ़ेस से डाउनलोड की जा सकती हैं. इन्हें आपके प्रोजेक्ट के /assets/tagmanager/ फ़ोल्डर में जोड़ा जाना चाहिए. साथ ही, इन्हें इस पैटर्न के हिसाब से होना चाहिए: /assets/tagmanager/GTM-XXXX, जहां फ़ाइल का नाम आपके कंटेनर आईडी को दिखाता है.

ऐसे मामलों में जहां JSON फ़ाइल और बाइनरी कंटेनर फ़ाइल मौजूद होती है, SDK टूल, डिफ़ॉल्ट कंटेनर के तौर पर बाइनरी कंटेनर फ़ाइल का इस्तेमाल करेगा.

फ़ंक्शन कॉल मैक्रो का इस्तेमाल करना

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

फ़ंक्शन कॉल मैक्रो कॉन्फ़िगर करने के लिए:

  1. Google Tag Manager वेब इंटरफ़ेस में फ़ंक्शन कॉल मैक्रो तय करें. तर्क, विकल्प के तौर पर की-वैल्यू पेयर के तौर पर कॉन्फ़िगर किए जा सकते हैं.
  2. Container.registerFunctionCallMacroHandler() और Google Tag Manager के वेब इंटरफ़ेस में कॉन्फ़िगर किए गए फ़ंक्शन के नाम का इस्तेमाल करके, अपने ऐप्लिकेशन में FunctionCallMacroHandler को रजिस्टर करें. साथ ही, इसके getValue() तरीके को बदलें:
    /**
     * Registers a function call macro handler.
     *
     * @param functionName The function name field, as defined in the Google Tag
     *     Manager web interface.
     */
    mContainer.registerFunctionCallMacroHandler(functionName, new FunctionCallMacroHandler() {
    
      /**
       * This code will execute when any custom macro's rule(s) evaluate to true.
       * The code should check the functionName and process accordingly.
       *
       * @param functionName Corresponds to the function name field defined
       *     in the Google Tag Manager web interface.
       * @param parameters An optional map of parameters
       *     as defined in the Google Tag Manager web interface.
       */
      @Override
      public Object getValue(String functionName, Map<String, Object> parameters)) {
    
        if (functionName.equals("myConfiguredFunctionName")) {
          // Process and return the calculated value of this macro accordingly.
          return macro_value
        }
        return null;
      }
    });
    

फ़ंक्शन कॉल टैग इस्तेमाल करना

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

फ़ंक्शन कॉल टैग को कॉन्फ़िगर करने के लिए:

  1. Google Tag Manager वेब इंटरफ़ेस में फ़ंक्शन कॉल टैग तय करें. तर्क, विकल्प के तौर पर की-वैल्यू पेयर के तौर पर कॉन्फ़िगर किए जा सकते हैं.
  2. Container.registerFunctionCallTagHandler() का इस्तेमाल करके, अपने ऐप्लिकेशन में फ़ंक्शन कॉल टैग हैंडलर रजिस्टर करें:
    /**
     * Register a function call tag handler.
     *
     * @param functionName The function name, which corresponds to the function name field
     *     Google Tag Manager web interface.
     */
    mContainer.registerFunctionCallTagHandler(functionName, new FunctionCallTagHandler() {
    
      /**
       * This method will be called when any custom tag's rule(s) evaluates to true.
       * The code should check the functionName and process accordingly.
       *
       * @param functionName The functionName passed to the functionCallTagHandler.
       * @param parameters An optional map of parameters as defined in the Google
       *     Tag Manager web interface.
       */
      @Override
      public void execute(String functionName, Map<String, Object> parameters) {
        if (functionName.equals("myConfiguredFunctionName")) {
          // Process accordingly.
        }
      }
    });
    

रीफ़्रेश करने के लिए कस्टम पीरियड सेट करना

अगर मौजूदा कंटेनर की उम्र 12 घंटे से ज़्यादा है, तो Google Tag Manager SDK टूल, नया कंटेनर पाने की कोशिश करेगा. कस्टम कंटेनर रीफ़्रेश अवधि सेट करने के लिए, Timer का इस्तेमाल करें, जैसा कि नीचे दिए गए उदाहरण में बताया गया है:

timer.scheduleTask(new TimerTask() {
  @Override
  public void run() {
    mContainer.refresh();
  }
}, delay, <new_period_in milliseconds>);

लॉगर की मदद से डीबग करना

Google Tag Manager SDK टूल, डिफ़ॉल्ट रूप से लॉग पर गड़बड़ियों और चेतावनियों को प्रिंट करता है. ज़्यादा शब्दों में जानकारी डालने की सुविधा चालू करने से, डीबग करने में मदद मिल सकती है. साथ ही, TagManager.setLogger के साथ अपना Logger लागू किया जा सकता है, जैसा कि इस उदाहरण में दिखाया गया है:

TagManager tagManager = TagManager.getInstance(this);
tagManager.setLogger(new Logger() {

  final String TAG = "myGtmLogger";

  // Log output with verbosity level of DEBUG.
  @Override
  public void d(String arg0) {
    Log.d(TAG, arg0);
  }

  // Log exceptions when provided.
  @Override
  public void d(String arg0, Throwable arg1) {
    Log.d(TAG, arg0);
    arg1.printStackTrace();
  }

  // Rest of the unimplemented Logger methods.

});

इसके अलावा, TagManager.getLogger().setLogLevel(LogLevel) का इस्तेमाल करके, मौजूदा लॉगर का लॉगलेवल सेट किया जा सकता है, जैसा कि इस उदाहरण में दिखाया गया है:

// Change the LogLevel to INFO to enable logging at INFO and higher levels.
TagManager tagManager = TagManager.getInstance(this);
tagManager.getLogger().setLogLevel(LogLevel.INFO);