ओपन सोर्स नोटिस शामिल करें

Google Play services में, कभी-कभी ओपन सोर्स लाइब्रेरी शामिल होती हैं या उन पर निर्भर करता है. ओपन सोर्स लाइब्रेरी की लाइसेंस से जुड़ी ज़रूरी शर्तों का पालन करने के लिए, डेवलपर के तौर पर यह आपकी ज़िम्मेदारी है कि आप अपने ऐप्लिकेशन में इस्तेमाल की जाने वाली ओपन सोर्स लाइब्रेरी की सूचनाओं को सही तरीके से दिखाएं.

Google Play services में टूल का एक सेट शामिल है, जिसे इस तरह से डिज़ाइन किया गया है कि डेवलपर अपने ऐप्लिकेशन में इस्तेमाल की जाने वाली लाइब्रेरी के ओपन सोर्स सॉफ़्टवेयर की सूचनाएं आसानी से ज़ाहिर कर सकें. इनमें से एक टूल Gradle प्लग इन है, जो शामिल की गई लाइब्रेरी से लाइसेंस की शर्तें इकट्ठा करता है, जैसा कि उनकी पीओएम फ़ाइलों में बताया गया है. यह एक ऐसी गतिविधि बनाता है जिसका इस्तेमाल इन शब्दों को दिखाने के लिए किया जा सकता है. इस बारे में ज़्यादा जानें कि टूल, लाइसेंस की जानकारी और पैकेज की जानकारी कैसे ढूंढता है.

Gradle प्लग इन जोड़ना

अपनी रूट-लेवल की बिल्ड फ़ाइल में ये काम करें:

  1. इसमें Google Maven रिपॉज़िटरी शामिल है.
  2. अपनी डिपेंडेंसी में oss-licenses प्लगिन जोड़ें.

नीचे दिया गया कोड स्निपेट यह तरीका दिखाता है:

Kotlin डीएसएल

build.gradle.kts

buildscript {
  repositories {
    ...
    google()  // maven { url("https://maven.google.com") } for Gradle <= 3
  }
  dependencies {
    ...
    classpath("com.google.android.gms:oss-licenses-plugin:0.10.6")
  }
}

ग्रूवी डीएसएल

build.gradle

buildscript {
  repositories {
    ...
    google()  // maven { url "https://maven.google.com" } for Gradle <= 3
  }
  dependencies {
    ...
    classpath 'com.google.android.gms:oss-licenses-plugin:0.10.6'
  }
}

ऐप्लिकेशन लेवल की बिल्ड फ़ाइल में, प्लगिन को लागू करने के लिए फ़ाइल के सबसे ऊपर मौजूद com.android.application प्लगिन के मौजूदा एलान के नीचे यह लाइन जोड़ें:

Kotlin डीएसएल

ऐप्लिकेशन/build.gradle.kts

plugins {
    id("com.android.application")
    id("com.google.android.gms.oss-licenses-plugin")
}

ग्रूवी डीएसएल

ऐप्लिकेशन/build.gradle

plugins {
    id 'com.android.application'
    id 'com.google.android.gms.oss-licenses-plugin'
}

GitHub पर इस प्लग इन का कोड देखा जा सकता है.

अपने ऐप्लिकेशन में लाइब्रेरी जोड़ना

ऐप्लिकेशन-लेवल की बिल्ड फ़ाइल के dependencies सेक्शन में, oss-licenses लाइब्रेरी पर डिपेंडेंसी जोड़ें:

Kotlin डीएसएल

build.gradle.kts

implementation("com.google.android.gms:play-services-oss-licenses:17.1.0")

ग्रूवी डीएसएल

build.gradle

implementation 'com.google.android.gms:play-services-oss-licenses:17.1.0'

लाइसेंस की जानकारी दिखाएं

जब आपका ऐप्लिकेशन बन जाता है, तो Gradle प्लग इन लाइसेंस को प्रोसेस करता है और उन्हें आपके ऐप्लिकेशन के संसाधनों में जोड़ देता है. लाइसेंस को आसानी से दिखाने के लिए, अपने ऐप्लिकेशन में सही जगह पर play-services-oss-licenses लाइब्रेरी से उपलब्ध कराई गई गतिविधि लॉन्च की जा सकती है, जैसा कि इस कोड स्निपेट में दिखाया गया है:

Kotlin

import com.google.android.gms.oss.licenses.OssLicensesMenuActivity
...

// When the user selects an option to see the licenses:
startActivity(Intent(this, OssLicensesMenuActivity::class.java))

Java

import com.google.android.gms.oss.licenses.OssLicensesMenuActivity;
...

// When the user selects an option to see the licenses:
startActivity(new Intent(this, OssLicensesMenuActivity.class));

लॉन्च किए जाने के बाद, इस गतिविधि में उन ओपन सोर्स लाइब्रेरी की सूची दिखती है जिन्हें आपके ऐप्लिकेशन में इकट्ठा किया जाता है. इसमें वे लाइब्रेरी भी शामिल हैं जो Google Play की सेवाओं का हिस्सा हैं, जैसा कि पहली इमेज में दिखाया गया है. किसी लाइब्रेरी के लाइसेंस की अतिरिक्त जानकारी देखने के लिए, उपयोगकर्ता उस लाइब्रेरी के नाम पर टैप कर सकते हैं.

हर एक एलिमेंट के साथ सूची वाला व्यू, जिसमें ओपन सोर्स लाइब्रेरी का नाम होता है

पहला डायग्राम. लाइसेंस मेन्यू की गतिविधि से, उन ओपन सोर्स लाइब्रेरी की चुनी जा सकने वाली सूची दिखाई जाती है जिनका इस्तेमाल ऐप्लिकेशन करता है.

गतिविधि का टाइटल सेट करें

डिफ़ॉल्ट रूप से, दिखाई गई गतिविधि का टाइटल "ओपन सोर्स लाइसेंस" होता है. setActivityTitle() पर कॉल करके, गतिविधि के टाइटल को अपनी पसंद के मुताबिक बनाया जा सकता है, जैसा कि इस कोड स्निपेट में दिखाया गया है:

Kotlin

OssLicensesMenuActivity.setActivityTitle(getString(R.string.custom_license_title))

Java

OssLicensesMenuActivity.setActivityTitle(getString(R.string.custom_license_title));

गतिविधि में कोई थीम लागू करें

गतिविधि में कोई थीम लागू की जा सकती है, ताकि उसका मिलान आपके ऐप्लिकेशन की अन्य गतिविधियों में इस्तेमाल होने वाली थीम से किया जा सके. ऐसा करने के लिए, अपने ऐप्लिकेशन की मेनिफ़ेस्ट फ़ाइल में <activity> एलिमेंट में, ओपन सोर्स लाइसेंस की गतिविधि शामिल करें, जैसा कि इस कोड स्निपेट में दिखाया गया है:

<application android:theme="@style/AppTheme" ...>
    <activity
        android:name="com.google.android.gms.oss.licenses.OssLicensesMenuActivity"
        android:theme="@style/AppTheme" />
    <activity
        android:name="com.google.android.gms.oss.licenses.OssLicensesActivity"
        android:theme="@style/AppTheme" />
</application>

लाइसेंस की सूची कैसे तय की जाती है

कंपाइल करते समय, Gradle प्लग इन आपके ऐप्लिकेशन के प्रोजेक्ट की पीओएम डिपेंडेंसी स्कैन करता है. जब Maven पीओएम, ऐप्लिकेशन की डायरेक्ट डिपेंडेंसी के लिए मौजूद होता है, तो प्लग इन हर <licenses> एलिमेंट को प्रोसेस करता है. साथ ही, हर लाइसेंस के लिंक और टाइटल को आपके ऐप्लिकेशन में मौजूद Android ऐसेट में जोड़ता है.