Android TV की होम स्क्रीन या होम स्क्रीन पर, ऐसा यूज़र इंटरफ़ेस (यूआई) दिखता है जो सुझाए गए कॉन्टेंट को चैनल और प्रोग्राम की टेबल के तौर पर दिखाता है. हर पंक्ति एक चैनल है. किसी चैनल पर उपलब्ध हर कार्यक्रम के कार्ड शामिल होते हैं:
इस दस्तावेज़ में होम स्क्रीन पर चैनल और प्रोग्राम जोड़ने, कॉन्टेंट अपडेट करने, उपयोगकर्ता की कार्रवाइयों को मैनेज करने, और उपयोगकर्ताओं को बेहतर अनुभव देने के तरीके के बारे में बताया गया है. (अगर आपको एपीआई के बारे में ज़्यादा जानकारी चाहिए, तो होम स्क्रीन कोडलैब और I/O 2017 Android TV सेशन देखें.)
ध्यान दें: सुझाव चैनल सिर्फ़ यहां उपलब्ध हैं Android 8.0 (एपीआई लेवल 26) और इसके बाद के वर्शन. इन संसाधनों का इस्तेमाल इन कामों के लिए किया जा सकता है: Android 8.0 (एपीआई लेवल 26) और उसके बाद के वर्शन पर काम करने वाले ऐप्लिकेशन के लिए सुझाव. यहां की यात्रा पर हूं Android के पुराने वर्शन पर चल रहे ऐप्लिकेशन के लिए सुझाव दें, को सुझावों की लाइन आज़माएं.
होम स्क्रीन का यूज़र इंटरफ़ेस (यूआई)
ऐप्लिकेशन किसी चैनल में नए चैनल बना सकते हैं, प्रोग्राम जोड़ सकते हैं, हटा सकते हैं, और अपडेट कर सकते हैं. साथ ही, किसी चैनल में प्रोग्राम का क्रम तय कर सकते हैं. उदाहरण के लिए, कोई ऐप्लिकेशन "नया क्या है" नाम से चैनल बना सकता है और नए प्रोग्राम के कार्ड दिखाने के लिए कहें.
ऐप्लिकेशन, होम स्क्रीन पर चैनलों के दिखने का क्रम तय नहीं कर सकते. जब आपका ऐप्लिकेशन कोई नया चैनल बनाता है, तो होम स्क्रीन उसे चैनल सूची में सबसे नीचे जोड़ देती है. उपयोगकर्ता, चैनलों को फिर से क्रम में लगा सकता है, छिपा सकता है, और उन्हें दिखा सकता है.
'अगला वीडियो' चैनल
'अगला देखें' चैनल दूसरी पंक्ति है, जो होम स्क्रीन पर इसके बाद दिखती है ऐप्लिकेशन लाइन. यह सिस्टम, चैनल बनाता है और उसका रखरखाव करता है. आपका ऐप्लिकेशन जोड़ सकता है तो 'अगला देखें' चैनल के लिए प्रोग्राम. ज़्यादा जानकारी के लिए, इसमें प्रोग्राम जोड़ें 'अगला देखें' चैनल.
ऐप्लिकेशन चैनल
आपका ऐप्लिकेशन जो चैनल बनाता है वे सभी इस लाइफ़ साइकल के हिसाब से होते हैं:
- उपयोगकर्ता आपके ऐप्लिकेशन में किसी चैनल को खोजता है और उसे होम स्क्रीन पर जोड़ने का अनुरोध करता है.
- ऐप्लिकेशन, चैनल बनाता है और उसे
TvProvider
में जोड़ देता है (इस समय चैनल नहीं दिख रहा है). - ऐप्लिकेशन, सिस्टम से चैनल दिखाने के लिए कहता है.
- सिस्टम, उपयोगकर्ता से नए चैनल की मंज़ूरी मांगता है.
- नया चैनल, होम स्क्रीन की आखिरी पंक्ति में दिखता है.
डिफ़ॉल्ट चैनल
आपका ऐप्लिकेशन, लोगों को होम स्क्रीन पर जोड़ने के लिए जितने चाहें उतने चैनल ऑफ़र कर सकता है. उपयोगकर्ता को आम तौर पर होम स्क्रीन पर दिखने से पहले, हर चैनल को चुनें और उसे अनुमति दें. हर ऐप्लिकेशन में एक डिफ़ॉल्ट चैनल बनाने का विकल्प होता है. डिफ़ॉल्ट चैनल खास होता है, क्योंकि यह अपने-आप होम स्क्रीन पर दिखता है; उपयोगकर्ता के लिए ज़रूरी नहीं है कि साफ़ तौर पर इसका अनुरोध करें.
ज़रूरी शर्तें
Android TV की होम स्क्रीन पर, आपके ऐप्लिकेशन के बनाए हुए चैनलों और प्रोग्राम को मैनेज करने के लिए, Android के TvProvider
एपीआई इस्तेमाल किए जाते हैं.
सेवा देने वाली कंपनी का डेटा ऐक्सेस करने के लिए, अपने ऐप्लिकेशन के मेनिफ़ेस्ट में यहां दी गई अनुमति जोड़ें:
<uses-permission android:name="com.android.providers.tv.permission.WRITE_EPG_DATA" />
TvProvider
की सहायता लाइब्रेरी से, प्रोवाइडर का इस्तेमाल करना आसान हो जाता है. इसे अपनी build.gradle
फ़ाइल की डिपेंडेंसी में जोड़ें:
implementation 'androidx.tvprovider:tvprovider:1.0.0'
implementation("androidx.tvprovider:tvprovider:1.0.0")
चैनलों और प्रोग्राम के साथ काम करने के लिए, अपने प्रोग्राम में सपोर्ट लाइब्रेरी से इंपोर्ट किए गए इन डेटा को शामिल करना न भूलें:
import android.support.media.tv.Channel import android.support.media.tv.TvContractCompat import android.support.media.tv.ChannelLogoUtils import android.support.media.tv.PreviewProgram import android.support.media.tv.WatchNextProgram
import android.support.media.tv.Channel; import android.support.media.tv.TvContractCompat; import android.support.media.tv.ChannelLogoUtils; import android.support.media.tv.PreviewProgram; import android.support.media.tv.WatchNextProgram;
चैनल
आपका ऐप्लिकेशन जो पहला चैनल बनाता है, वह उसका डिफ़ॉल्ट चैनल बन जाता है. डिफ़ॉल्ट चैनल, होम स्क्रीन पर अपने-आप दिखने लगता है. आपके बनाए गए अन्य सभी चैनल, होम स्क्रीन पर दिखने से पहले, उपयोगकर्ता को चुनने होंगे और उन्हें स्वीकार करना होगा.
चैनल बनाना
आपके ऐप्लिकेशन को सिस्टम से, जोड़े गए नए चैनलों को सिर्फ़ तब दिखाने के लिए कहना चाहिए, जब वे फ़ोरग्राउंड में चल रहे हों. इससे आपका ऐप्लिकेशन, चैनल जोड़ने की अनुमति का अनुरोध करने वाला डायलॉग बॉक्स नहीं दिखाता. ऐसा तब होता है, जब उपयोगकर्ता कोई दूसरा ऐप्लिकेशन इस्तेमाल कर रहा हो. अगर बैकग्राउंड में चलते हुए किसी चैनल को जोड़ने की कोशिश की जाती है, तो गतिविधि का onActivityResult()
तरीका, स्टेटस कोड RESULT_CANCELED
दिखाता है.
चैनल बनाने के लिए, यह तरीका अपनाएं:
चैनल बिल्डर बनाएं और इसकी विशेषताएं सेट करें. ध्यान दें कि चैनल का टाइप
TYPE_PREVIEW
होना चाहिए. ज़्यादा जानकारी जोड़ें एट्रिब्यूट सबमिट करें.val builder = Channel.Builder() // Every channel you create must have the type
TYPE_PREVIEW
builder.setType(TvContractCompat.Channels.TYPE_PREVIEW) .setDisplayName("Channel Name") .setAppLinkIntentUri(uri)Channel.Builder builder = new Channel.Builder(); // Every channel you create must have the type
TYPE_PREVIEW
builder.setType(TvContractCompat.Channels.TYPE_PREVIEW) .setDisplayName("Channel Name") .setAppLinkIntentUri(uri);प्रोवाइडर में चैनल डालें:
-
चैनल में प्रोग्राम जोड़ने के लिए, आपको चैनल आईडी सेव करना होगा बाद में. दिए गए यूआरआई से चैनल आईडी निकालें:
आपको अपने चैनल के लिए एक लोगो जोड़ना होगा.
Uri
याBitmap
का इस्तेमाल करें. लोगो आइकॉन 80dp x 80dp का होना चाहिए और यह ओपेक होना चाहिए. इसे इसके नीचे दिखाया जाता है: सर्कुलर मास्क:// Choose one or the other storeChannelLogo(context: Context, channelId: Long, logoUri: Uri) // also works if logoUri is a URL storeChannelLogo(context: Context, channelId: Long, logo: Bitmap)
// Choose one or the other storeChannelLogo(Context context, long channelId, Uri logoUri); // also works if logoUri is a URL storeChannelLogo(Context context, long channelId, Bitmap logo);
डिफ़ॉल्ट चैनल बनाना (ज़रूरी नहीं): जब आपका ऐप्लिकेशन अपना पहला चैनल बनाता है चैनल बनाना चाहते हैं, तो आप इसे डिफ़ॉल्ट चैनल, ताकि यह होम में दिखे उपयोगकर्ता की कार्रवाई के बिना तुरंत स्क्रीन शेयर करें. ऐसे अन्य चैनल जिन्हें आपने बनाया है तब तक नहीं दिखती, जब तक उपयोगकर्ता साफ़ तौर पर न दिखे उन्हें चुनता है.
- अपना ऐप्लिकेशन खोलने से पहले, अपना डिफ़ॉल्ट चैनल दिखाएं. आप
यह काम करने के लिए, एक
BroadcastReceiver
जोड़ेंandroid.media.tv.action.INITIALIZE_PROGRAMS
कार्रवाई, जो होम स्क्रीन पर दिखेगी ऐप्लिकेशन इंस्टॉल होने के बाद भेजता है: डेवलपमेंट के दौरान अपने ऐप्लिकेशन को अलग से लोड करते समय, इसकी जांच की जा सकती है adb के ज़रिए इंटेंट को ट्रिगर करना, जहां your.package.name/.YourReceiverName आपके ऐप्लिकेशन का है<receiver android:name=".RunOnInstallReceiver" android:exported="true"> <intent-filter> <action android:name="android.media.tv.action.INITIALIZE_PROGRAMS" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </receiver>
BroadcastReceiver
:adb shell am broadcast -a android.media.tv.action.INITIALIZE_PROGRAMS -n \
your.package.name /.YourReceiverName बहुत कम मामलों में, आपके ऐप्लिकेशन को उपयोगकर्ता के डिवाइस पर ब्रॉडकास्ट मिल सकता है आपका ऐप्लिकेशन शुरू करता है. पक्का करें कि आपका कोड, डिफ़ॉल्ट चैनल जोड़ने की कोशिश न करता हो एक से ज़्यादा बार.
चैनल अपडेट करना
चैनलों को अपडेट करना, उन्हें बनाने जैसा ही है.
जिन एट्रिब्यूट को बदलना है उन्हें सेट करने के लिए, दूसरे Channel.Builder
का इस्तेमाल करें.
चैनल को अपडेट करने के लिए, ContentResolver
का इस्तेमाल करें. उस चैनल आईडी का इस्तेमाल करें जिसे आपने पहली बार चैनल जोड़ते समय सेव किया था:
context.contentResolver.update( TvContractCompat.buildChannelUri(channelId), builder.build().toContentValues(), null, null )
context.getContentResolver().update(TvContractCompat.buildChannelUri(channelId), builder.build().toContentValues(), null, null);
चैनल का लोगो अपडेट करने के लिए, storeChannelLogo()
का इस्तेमाल करें.
किसी चैनल को मिटाना
context.contentResolver.delete(TvContractCompat.buildChannelUri(channelId), null, null)
context.getContentResolver().delete(TvContractCompat.buildChannelUri(channelId), null, null);
कार्यक्रम
किसी ऐप्लिकेशन चैनल में प्रोग्राम जोड़ना
PreviewProgram.Builder
बनाएं और उसके एट्रिब्यूट सेट करें:
val builder = PreviewProgram.Builder() builder.setChannelId(channelId) .setType(TvContractCompat.PreviewPrograms.TYPE_CLIP) .setTitle("Title") .setDescription("Program description") .setPosterArtUri(uri) .setIntentUri(uri) .setInternalProviderId(appProgramId)
PreviewProgram.Builder builder = new PreviewProgram.Builder(); builder.setChannelId(channelId) .setType(TvContractCompat.PreviewPrograms.TYPE_CLIP) .setTitle("Title") .setDescription("Program description") .setPosterArtUri(uri) .setIntentUri(uri) .setInternalProviderId(appProgramId);
प्रोग्राम के टाइप के हिसाब से ज़्यादा एट्रिब्यूट जोड़ें. (एट्रिब्यूट देखने के लिए हर तरह के प्रोग्राम के लिए उपलब्ध है, तो नीचे दी गई टेबल देखें.)
प्रोवाइडर में प्रोग्राम डालें:
var programUri = context.contentResolver.insert(TvContractCompat.PreviewPrograms.CONTENT_URI, builder.build().toContentValues())
Uri programUri = context.getContentResolver().insert(TvContractCompat.PreviewPrograms.CONTENT_URI, builder.build().toContentValues());
बाद में इस्तेमाल करने के लिए प्रोग्राम आईडी फिर से पाएं:
val programId = ContentUris.parseId(programUri)
long programId = ContentUris.parseId(programUri);
'अगला देखें' चैनल में कार्यक्रम जोड़ना
'अगला देखें' चैनल में प्रोग्राम जोड़ने के लिए, 'वॉच में प्रोग्राम जोड़ें' लेख देखें अगला चैनल.
प्रोग्राम अपडेट करना
आपके पास किसी प्रोग्राम की जानकारी में बदलाव करने का विकल्प होता है. उदाहरण के लिए, ऐसा हो सकता है कि आप किसी फ़िल्म के किराये की कीमत अपडेट करना चाहें. इसके अलावा, प्रोग्रेस बार में यह जानकारी भी दी जा सकती है कि उपयोगकर्ता ने कोई प्रोग्राम कितना देखा है.
जिन एट्रिब्यूट को आपको बदलना है उन्हें सेट करने के लिए, PreviewProgram.Builder
का इस्तेमाल करें,
इसके बाद, प्रोग्राम को अपडेट करने के लिए, getContentResolver().update
को कॉल करें. वह प्रोग्राम आईडी बताएं जिसे आपने मूल रूप से प्रोग्राम जोड़ते समय सेव किया था:
context.contentResolver.update( TvContractCompat.buildPreviewProgramUri(programId), builder.build().toContentValues(), null, null )
context.getContentResolver().update(TvContractCompat.buildPreviewProgramUri(programId), builder.build().toContentValues(), null, null);
प्रोग्राम मिटाना
context.contentResolver .delete(TvContractCompat.buildPreviewProgramUri(programId), null, null)
context.getContentResolver().delete(TvContractCompat.buildPreviewProgramUri(programId), null, null);
उपयोगकर्ता की कार्रवाइयों को मैनेज करना
आपका ऐप्लिकेशन, चैनल दिखाने और जोड़ने के लिए यूज़र इंटरफ़ेस (यूआई) उपलब्ध करा सकता है. इससे लोगों को कॉन्टेंट खोजने में मदद मिल सकती है. होम स्क्रीन पर चैनल दिखने के बाद, ऐप्लिकेशन में उन चैनलों के साथ होने वाले इंटरैक्शन भी मैनेज किए जाने चाहिए.
चैनल खोजना और जोड़ना
आपका ऐप्लिकेशन, यूज़र इंटरफ़ेस (यूआई) एलिमेंट दे सकता है. इससे उपयोगकर्ता अपने चैनल चुन सकता है और जोड़ सकता है. उदाहरण के लिए, ऐसा बटन जिस पर चैनल जोड़ने के लिए कहा जा सकता है.
उपयोगकर्ता की ओर से किसी चैनल का अनुरोध करने के बाद, उसे होम स्क्रीन के यूज़र इंटरफ़ेस (यूआई) में जोड़ने के लिए, उपयोगकर्ता की अनुमति पाने के लिए इस कोड को एक्ज़ीक्यूट करें:
val intent = Intent(TvContractCompat.ACTION_REQUEST_CHANNEL_BROWSABLE) intent.putExtra(TvContractCompat.EXTRA_CHANNEL_ID, channelId) try { activity.startActivityForResult(intent, 0) } catch (e: ActivityNotFoundException) { // handle error }
Intent intent = new Intent(TvContractCompat.ACTION_REQUEST_CHANNEL_BROWSABLE); intent.putExtra(TvContractCompat.EXTRA_CHANNEL_ID, channelId); try { activity.startActivityForResult(intent, 0); } catch (ActivityNotFoundException e) { // handle error }
सिस्टम एक डायलॉग बॉक्स दिखाता है, जिसमें उपयोगकर्ता से चैनल को अनुमति देने के लिए कहा जाता है.
अनुरोध के नतीजे को मैनेज करने के लिए, अपनी गतिविधि के onActivityResult
तरीके (Activity.RESULT_CANCELED
या Activity.RESULT_OK
) का इस्तेमाल करें.
Android TV की होम स्क्रीन पर इवेंट
जब उपयोगकर्ता, ऐप्लिकेशन पर पब्लिश किए गए प्रोग्राम/चैनलों से इंटरैक्ट करता है, तब होम स्क्रीन ऐप्लिकेशन को इंटेंट भेजती है:
- जब उपयोगकर्ता चैनल का लोगो चुनता है, तो होम स्क्रीन किसी चैनल के APP_LINK_INTENT_uri एट्रिब्यूट में सेव किए गए
Uri
, ऐप्लिकेशन को भेज देती है. ऐप्लिकेशन को सिर्फ़ अपना मुख्य यूज़र इंटरफ़ेस (यूआई) या चुने गए चैनल से जुड़ा कोई व्यू लॉन्च करना चाहिए. - जब उपयोगकर्ता कोई प्रोग्राम चुनता है, तो होम स्क्रीन किसी प्रोग्राम के INTENT_uri एट्रिब्यूट में सेव
Uri
, ऐप्लिकेशन को भेज देती है. ऐप्लिकेशन को चुना गया कॉन्टेंट चलाना चाहिए. - उपयोगकर्ता यह बता सकता है कि अब उसकी किसी प्रोग्राम में दिलचस्पी नहीं है और वह उसे होम स्क्रीन के यूज़र इंटरफ़ेस (यूआई) से हटाना चाहता है. सिस्टम, प्रोग्राम को यूज़र इंटरफ़ेस (यूआई) से हटा देता है और उस ऐप्लिकेशन को भेजता है जिसके पास प्रोग्राम का इंटेंट (android.media.tv.ACTION_Preview_PROGRAM_BROWSABLE_वनD या android.media.tv.ACTION_watch_Next_PROGRAM_BROWSABLE_CLICKSD) प्रोग्राम है. ऐप्लिकेशन को, सेवा देने वाले ऐप्लिकेशन से प्रोग्राम हटा देना चाहिए और उसे फिर से नहीं डालना चाहिए.
उन सभी Uris
के लिए इंटेंट फ़िल्टर ज़रूर बनाएं जिन्हें होम स्क्रीन, उपयोगकर्ता के इंटरैक्शन के लिए भेजती है; उदाहरण के लिए:
<receiver
android:name=".WatchNextProgramRemoved"
android:enabled="true"
android:exported="true">
<intent-filter>
<action android:name="android.media.tv.ACTION_WATCH_NEXT_PROGRAM_BROWSABLE_DISABLED" />
</intent-filter>
</receiver>
सबसे सही तरीके
- कई टीवी ऐप्लिकेशन के लिए, लोगों को लॉगिन करना पड़ता है. इस मामले में,
BroadcastReceiver
जोandroid.media.tv.action.INITIALIZE_PROGRAMS
सुनता है, उसके लिए सुझाव चाहिए चैनल के कॉन्टेंट की पुष्टि नहीं की है.उदाहरण के लिए, आपका ऐप्लिकेशन शुरुआत में बेहतरीन कॉन्टेंट या मौजूदा समय में लोकप्रिय कॉन्टेंट दिखाने के लिए. उपयोगकर्ता के लॉग इन करने के बाद, आपके हिसाब से बनाया गया कॉन्टेंट दिखा सकती है. यह ऐप्लिकेशन की अप-सेल करने की संभावना बढ़ाने का बेहतरीन मौका है इससे पहले वे लॉगिन कर सकें. - जब आपका ऐप्लिकेशन फ़ोरग्राउंड में न हो और आपको किसी चैनल या
तो काम को शेड्यूल करने के लिए,
JobScheduler
का इस्तेमाल करें (देखें: नौकरी शेड्यूल करने वाला व्यक्ति और JobService) है. - अगर आपका ऐप्लिकेशन ठीक से काम नहीं करता है, तो सिस्टम आपके ऐप्लिकेशन के लिए दी गई अनुमतियां रद्द कर सकता है उदाहरण के लिए: सेवा देने वाली कंपनी को डेटा का इस्तेमाल करके लगातार स्पैम करना. पक्का करें कि उस कोड को रैप करें जो प्रोवाइडर को हैंडल करने के लिए, ट्राई-कैच क्लॉज़ के साथ ऐक्सेस करता है सुरक्षा के अपवाद हैं.
प्रोग्राम और चैनल अपडेट करने से पहले, डेटा उपलब्ध करवाने वाली कंपनी से क्वेरी करें को डेटा को अपडेट और उसका समाधान करने की ज़रूरत होती है. उदाहरण के लिए, Google Analytics 4 प्रॉपर्टी को अपडेट करने की ज़रूरत नहीं है ऐसा प्रोग्राम जिसे उपयोगकर्ता यूज़र इंटरफ़ेस से हटाना चाहता है. बैकग्राउंड जॉब का इस्तेमाल करें, मौजूदा यूआरएल के लिए क्वेरी करने के बाद प्रोवाइडर में आपका डेटा डालता/अपडेट करता है आपके चैनल के लिए मंज़ूरी का अनुरोध करता है. इस काम को तब किया जा सकता है, जब ऐप्लिकेशन चालू हो जाता है और जब भी उसे अपने डेटा को अपडेट करने की ज़रूरत होती है.
context.contentResolver .query( TvContractCompat.buildChannelUri(channelId), null, null, null, null).use({ cursor-> if (cursor != null and cursor.moveToNext()) { val channel = Channel.fromCursor(cursor) if (channel.isBrowsable()) { //update channel's programs } } })
try (Cursor cursor = context.getContentResolver() .query( TvContractCompat.buildChannelUri(channelId), null, null, null, null)) { if (cursor != null && cursor.moveToNext()) { Channel channel = Channel.fromCursor(cursor); if (channel.isBrowsable()) { //update channel's programs } } }
सभी इमेज (लोगो, आइकॉन, कॉन्टेंट की इमेज) के लिए यूनीक Uris का इस्तेमाल करें. इमेज अपडेट करते समय एक अलग यूआरआई का इस्तेमाल करना न भूलें. सभी इमेज कैश मेमोरी में सेव की जाती हैं. अगर इमेज बदलते समय यूआरआई को नहीं बदला जाता है, तो पुरानी इमेज दिखती रहेगी.
याद रखें कि WHERE क्लॉज़ की अनुमति नहीं है और WHERE क्लॉज़ वाले सेवा देने वालों को कॉल करने पर सुरक्षा में अपवाद होगा.
विशेषताएं
इस सेक्शन में, चैनल और प्रोग्राम से जुड़े एट्रिब्यूट के बारे में अलग-अलग जानकारी दी गई है.
चैनल की विशेषताएं
आपको हर चैनल के लिए इन एट्रिब्यूट की जानकारी देनी होगी:
एट्रिब्यूट | नोट |
---|---|
वाई-फ़ाई के टाइप के बारे में जानकारी | TYPE_PREVIEW पर सेट किया गया. |
DISPLAY_NAME | चैनल के नाम पर सेट करें. |
APP_LINK_INTENT_यूआरआई | जब लोग चैनल का लोगो चुनते हैं, तब सिस्टम चैनल से जुड़ी गतिविधि शुरू करने के लिए इंटेंट भेजता है. इस इंटेंट में चैनल से जुड़ा कॉन्टेंट दिखाया जाता है. इस एट्रिब्यूट को उस गतिविधि के इंटेंट फ़िल्टर में इस्तेमाल किए गए Uri पर सेट करें. |
इसके अलावा, चैनल में छह फ़ील्ड भी होते हैं, जो संगठन में काम करने वालों के लिए ऐप्लिकेशन के इस्तेमाल के लिए रिज़र्व हैं. इन फ़ील्ड का इस्तेमाल कुंजियां या ऐसी दूसरी वैल्यू सेव करने के लिए किया जा सकता है जिनसे ऐप्लिकेशन को, चैनल को उसके इंटरनल डेटा स्ट्रक्चर से मैप करने में मदद मिल सकती है:
- इंटरनल_PROVIDER_ID
- इंटरनल_PROVIDER_DATA
- इंटरनल_PROVIDER_FLAG1
- इंटरनल_PROVIDER_FLAG2
- इंटरनल_PROVIDER_FLAG3
- इंटरनल_PROVIDER_FLAG4
प्रोग्राम की विशेषताएं
हर तरह के प्रोग्राम की विशेषताओं के लिए, अलग-अलग पेज देखें:
- वीडियो प्रोग्राम के एट्रिब्यूट
- ऑडियो प्रोग्राम के एट्रिब्यूट
- गेम प्रोग्राम के एट्रिब्यूट
- 'अगला वीडियो देखें' कार्यक्रम के एट्रिब्यूट
नमूना कोड
होम स्क्रीन से इंटरैक्ट करने वाले और Android TV की होम स्क्रीन पर चैनल और प्रोग्राम जोड़ने वाले ऐप्लिकेशन बनाने के बारे में ज़्यादा जानने के लिए, हमारी होम स्क्रीन पर मौजूद कोडलैब (कोड बनाना सीखना) लेख पढ़ें.