Android 16 में, Android TV के लिए मीडिया क्वालिटी फ़्रेमवर्क लॉन्च किया जा रहा है. इसका मकसद, पिक्चर क्वालिटी (पीक्यू) और ऑडियो क्वालिटी (एक्यू) को अडजस्ट करने के लिए, स्टैंडर्ड एपीआई उपलब्ध कराना है. इसका मुख्य मकसद, Android TV वाले अलग-अलग डिवाइसों पर इन बदलावों को एक साथ लागू करना है. इस स्टैंडर्ड फ़्रेमवर्क का मकसद, ऐप्लिकेशन डेवलपर, ओरिजनल इक्विपमेंट मैन्युफ़ैक्चरर (ओईएम), और सिस्टम-ऑन-चिप (एसओसी) वेंडर के लिए डेवलपमेंट को आसान बनाना है. इसके लिए, यह Android एपीआई का एक जैसा सेट उपलब्ध कराता है. खास तौर पर, SoC वेंडर के लिए यह सुविधा उपलब्ध है. इसकी मदद से, Android फ़्रेमवर्क को पीक्यू और एक्यू कॉन्फ़िगरेशन को मैनेज करने की अनुमति मिलती है. इससे अलग-अलग ऐप्लिकेशन डेवलपर के साथ मिलकर काम करने का बोझ कम हो जाता है.
आखिरकार, Google और Android प्लैटफ़ॉर्म के लिए, यह फ़्रैगमेंटेशन को कम करने, क्वालिटी और स्केलेबिलिटी को बेहतर बनाने, नई सुविधाएं देने, और यूनीफ़ाइड एएक्यू/पीक्यू यूज़र इंटरफ़ेस (यूआई) और बेहतर उपयोगकर्ता अनुभव के लिए आधार तैयार करने में मदद करता है.
मीडिया क्वालिटी फ़्रेमवर्क, टीवी देखने के अनुभव को बेहतर बनाने के लिए अलग-अलग तरह के इस्तेमाल के उदाहरणों के साथ काम करता है. ध्यान दें कि हर पैकेज के नाम (ऐप्लिकेशन) और हर इनपुट आईडी के हिसाब से, प्रोफ़ाइलों और सेटिंग को मैनेज किया जा सकता है. इसके अलावा, सिस्टम ऐप्लिकेशन या अनुमति वाली सूची में शामिल अन्य ऐप्लिकेशन भी प्रोफ़ाइलें बना सकते हैं. प्रोफ़ाइलें सिर्फ़ उनके मालिक अपडेट या हटा सकते हैं. खास तौर पर, फ़्रेमवर्क Picture और Sound Profiles को मैनेज करता है. पिक्चर पैरामीटर के उदाहरणों में चमक, कंट्रास्ट, और शार्पनेस शामिल हैं. साउंड पैरामीटर के उदाहरणों में बास और ट्रेबल शामिल हैं. इन प्रोफ़ाइलों को अलग-अलग संदर्भों में लागू किया जा सकता है. जैसे, ग्लोबल डिफ़ॉल्ट प्रोफ़ाइलें सेट करना, MediaCodec के ज़रिए स्ट्रीमिंग प्रोफ़ाइलें सेट करना, कुछ मीडिया ऐप्लिकेशन के लिए ऐप्लिकेशन की डिफ़ॉल्ट प्रोफ़ाइलें सेट करना, और एचडीएमआई जैसे कुछ इनपुट के लिए टीवी इनपुट की पिक्चर प्रोफ़ाइलें सेट करना. यह फ़्रेमवर्क, स्टेटस में होने वाले बदलावों के साथ भी काम करता है. इससे एचडीआर जैसे स्टेटस के लिए अलग-अलग पैरामीटर सेट किए जा सकते हैं. साथ ही, चालू प्रोसेसिंग के लिए ऐक्टिव पिक्चर प्रोफ़ाइल मैनेज की जा सकती हैं और ऐंबियंट बैकलाइट की सुविधाओं को कंट्रोल किया जा सकता है.
Android टीम, मीडिया क्वालिटी फ़्रेमवर्क को सपोर्ट करने के लिए, हमारे नेटवर्क के पार्टनर के साथ मिलकर काम कर रही है.
Components
मीडिया क्वालिटी फ़्रेमवर्क में कई मुख्य कॉम्पोनेंट होते हैं. ये ऐप्लिकेशन, फ़्रेमवर्क, और हार्डवेयर लेयर पर एक साथ काम करते हैं.

पहली इमेज. मीडिया क्वालिटी फ़्रेमवर्क के कॉम्पोनेंट के बीच इंटरैक्शन
- मीडिया क्वालिटी मैनेजर (SDK API): यह ऐप्लिकेशन के लिए उपलब्ध SDK API है. इसकी मदद से ऐप्लिकेशन, पिक्चर और साउंड प्रोफ़ाइलों को मैनेज कर सकते हैं.
- मीडिया क्वालिटी सर्विस: यह एक सिस्टम सर्विस है. इसमें मुख्य कारोबारी नियम, प्रोफ़ाइलें मैनेज करना, अनुमतियां, और HAL के साथ कम्यूनिकेशन शामिल है.
- मीडिया क्वालिटी डेटाबेस: यह एक SQLite डेटाबेस है. इसमें सभी फ़ोटो और साउंड प्रोफ़ाइलें सेव होती हैं.
- मीडिया क्वालिटी कॉन्ट्रैक्ट: यह स्टैंडर्ड पैरामीटर और डेटा स्ट्रक्चर तय करता है. इनका इस्तेमाल, ऐप्लिकेशन और फ़्रेमवर्क के बीच कम्यूनिकेशन के लिए किया जाता है.
- मीडिया क्वालिटी एचएएल: यह एक हार्डवेयर ऐब्स्ट्रैक्शन लेयर है. इसे एसओसी वेंडर लागू करते हैं, ताकि वे हार्डवेयर को इमेज और साउंड प्रोफ़ाइल में हुए बदलावों के बारे में बता सकें.
सुविधाएं
मीडिया क्वालिटी फ़्रेमवर्क में कई तरह की सुविधाएं उपलब्ध हैं. इनसे मीडिया क्वालिटी को मैनेज करने के लिए, एक फ़्लेक्सिबल और बेहतर सिस्टम मिलता है.
प्रोफ़ाइल मैनेज करना
- ऐप्लिकेशन के ज़रिए मैनेज की जाने वाली प्रोफ़ाइलें: ऐप्लिकेशन, अपनी प्रोफ़ाइलें बना सकते हैं, उन्हें अपडेट कर सकते हैं, और मिटा सकते हैं, ताकि आपको मनमुताबिक अनुभव दिया जा सके.
- डिफ़ॉल्ट प्रोफ़ाइलें: सिस्टम ऐप्लिकेशन, कुछ ऐप्लिकेशन या टीवी इनपुट के लिए डिफ़ॉल्ट प्रोफ़ाइलें सेट कर सकते हैं. जैसे, एचडीएमआई 1).
- ग्लोबल डिफ़ॉल्ट प्रोफ़ाइल: यह सिस्टम-वाइड फ़ॉलबैक प्रोफ़ाइल होती है. इसे तब लागू किया जाता है, जब कोई खास प्रोफ़ाइल सेट नहीं की जाती.
पूरा वर्कफ़्लो
यहां दिए गए डायग्राम में, मीडिया क्वालिटी से जुड़ी सामान्य कार्रवाइयों के लिए कॉल सीक्वेंस दिखाए गए हैं.
पिक्चर प्रोफ़ाइल बनाना और लागू करना

दूसरी इमेज. पिक्चर प्रोफ़ाइल बनाने के लिए सीक्वेंस डायग्राम
- सिस्टम ऐप्लिकेशन,
setPictureProfileAllowList()को कॉल करता है, ताकि मीडिया ऐप्लिकेशन को प्रोफ़ाइलें बनाने की अनुमति दी जा सके. - मीडिया ऐप्लिकेशन, प्रोफ़ाइल में किए गए बदलावों के बारे में सूचनाएं पाने के लिए
PictureProfileCallbackरजिस्टर करता है. - मीडिया ऐप्लिकेशन,
PictureProfileऑब्जेक्ट के साथcreatePictureProfile()को कॉल करता है. MediaQualityServiceअनुरोध को प्रोसेस करता है, प्रोफ़ाइल को डेटाबेस में सेव करता है, और रजिस्टर किए गए कॉलबैक (onPictureProfileAdded()याonError()) के ज़रिए ऐप्लिकेशन को सफलता या गड़बड़ी की सूचना देता है.
हर स्ट्रीम के लिए पिक्चर प्रोफ़ाइल सेट करना
इस वर्कफ़्लो में बताया गया है कि कोई ऐप्लिकेशन, वीडियो चलाने के दौरान अपने वीडियो कॉन्टेंट पर कोई खास प्रोफ़ाइल कैसे लागू कर सकता है.

तीसरी इमेज. हर स्ट्रीम के लिए, पिक्चर प्रोफ़ाइल सेट करने का सीक्वेंस डायग्राम
- मीडिया ऐप्लिकेशन, उपलब्ध पिक्चर प्रोफ़ाइलों की सूची पाने के लिए
MediaQualityManagerसे क्वेरी करता है. - इसके बाद, ऐप्लिकेशन
MediaCodec.setParametersका इस्तेमाल करके, स्ट्रीम के लिए अपनी पसंद की प्रोफ़ाइल चुनता है और उसे सेट करता है. - यह फ़्रेमवर्क, इस विकल्प के बारे में मीडिया क्वालिटी (एमक्यू) एचएएल को बताता है. साथ ही, प्रोफ़ाइल आईडी और उसके पैरामीटर भी पास करता है.
- आखिर में, MQ HAL इन पैरामीटर को कंपोज़र HAL को भेजता है. यह कंपोज़र HAL, वीडियो स्ट्रीम को तय की गई पिक्चर प्रोफ़ाइल के साथ रेंडर करता है.
ग्लोबल डिफ़ॉल्ट प्रोफ़ाइल सेट करना
सिर्फ़ सिस्टम ऐप्लिकेशन, ग्लोबल डिफ़ॉल्ट प्रोफ़ाइल सेट कर सकते हैं. यह प्रोफ़ाइल, ऐसे कॉन्टेंट के लिए फ़ॉलबैक के तौर पर काम करती है जिसे कोई खास प्रोफ़ाइल असाइन नहीं की गई है.
- सिस्टम ऐप्लिकेशन, फ़्रेमवर्क से उपलब्ध फ़ोटो प्रोफ़ाइलों की सूची वापस पाता है.
- इसके बाद, ऐप्लिकेशन
setDefaultPictureProfile(id)को कॉल करके, इनमें से किसी एक प्रोफ़ाइल को नया ग्लोबल डिफ़ॉल्ट चुनता है. - फ़्रेमवर्क, उस प्रोफ़ाइल के पैरामीटर को Media Quality HAL पर भेजता है. इसके बाद, HAL उन बदलावों को लागू करता है.
Media Quality SDK API
Media Quality SDK API, ऐप्लिकेशन को फ़्रेमवर्क के साथ इंटरैक्ट करने के लिए ज़रूरी टूल उपलब्ध कराता है. मुख्य एंट्री पॉइंट android.media.quality पैकेज है.
android.media.quality
इस पैकेज में, मीडिया क्वालिटी को मैनेज करने के लिए प्राइमरी क्लास शामिल हैं.
| कक्षा | ब्यौरा |
|---|---|
MediaQualityManager |
यह MQF के साथ इंटरैक्ट करने के लिए सेंट्रल क्लास है. |
PictureProfile |
यह एक डेटा क्लास है. यह किसी खास मोड के लिए, फ़ोटो के पैरामीटर का पूरा सेट दिखाती है. |
SoundProfile |
यह साउंड पैरामीटर के लिए डेटा क्लास है. |
MediaQualityContract |
यह क्लास, पहले से तय की गई सभी पैरामीटर कुंजियों के लिए कॉन्स्टेंट शामिल करती है. |
MediaQualityManager
इसके लिए, ये मुख्य तरीके अपनाए जाते हैं:
| Method | ब्यौरा |
|---|---|
createPictureProfile(PictureProfile profile) |
नई पिक्चर प्रोफ़ाइल बनाता है. इसके लिए, खास अनुमतियों की ज़रूरत होती है या ऐप्लिकेशन को अनुमति वाली सूची में शामिल करना होता है. |
updatePictureProfile(PictureProfile profile) |
इस कुकी का इस्तेमाल, मौजूदा प्रोफ़ाइल फ़ोटो को अपडेट करने के लिए किया जाता है. इसे सिर्फ़ प्रोफ़ाइल का क्रिएटर कॉल कर सकता है. |
removePictureProfile(String profileId) |
यह कुकी, किसी प्रोफ़ाइल को मिटाती है. इसे सिर्फ़ प्रोफ़ाइल का क्रिएटर कॉल कर सकता है. |
getAvailablePictureProfiles() |
यह उपलब्ध सभी पिक्चर प्रोफ़ाइलों की सूची दिखाता है. |
setDefaultPictureProfile(String profileId) |
यह कुकी, ग्लोबल डिफ़ॉल्ट पिक्चर प्रोफ़ाइल सेट करती है. इसके लिए, MANAGE_GLOBAL_PICTURE_QUALITY_SERVICE की अनुमति ज़रूरी है. |
registerPictureProfileCallback(PictureProfileCallback cb) |
यह कुकी, प्रोफ़ाइल में किए गए बदलावों को सुनने के लिए कॉलबैक रजिस्टर करती है. |
PictureProfile ऑब्जेक्ट
PictureProfile ऑब्जेक्ट में, किसी दिए गए पिक्चर मोड के बारे में पूरी जानकारी शामिल होती है.
public final class PictureProfile {
private String id;
private int type; // System or Application
private String name; // e.g., "Movie", "Game"
private String inputId; // e.g., "HDMI1"
private String packageName; // e.g., "com.google.android.youtube"
private PersistableBundle parameters; // Bundle containing all PQ parameters
}
मीडिया क्वालिटी एचएएल
मीडिया क्वालिटी एचएएल, एआईडीएल पर आधारित एक इंटरफ़ेस है. इसे hardware/interfaces/tv/mediaquality/aidl/ में तय किया गया है. एसओसी वेंडर को इस इंटरफ़ेस को लागू करना होगा, ताकि वे अपने डिवाइसों पर मीडिया क्वालिटी फ़्रेमवर्क को चालू कर सकें. HAL, Android फ़्रेमवर्क में मौजूद MediaQualityService और हार्डवेयर के बीच कम्यूनिकेशन ब्रिज के तौर पर काम करता है. इसकी ज़िम्मेदारी, इमेज और आवाज़ में बदलाव करने की होती है.
एचएएल, एआईडीएल पार्सल का इस्तेमाल करके, इमेज और साउंड प्रोफ़ाइल मैनेज करता है. इसमें फ़्रेमवर्क से प्रोफ़ाइल में हुए बदलावों की जानकारी पाना और हार्डवेयर लेवल पर किए गए किसी भी अडजस्टमेंट के बारे में फ़्रेमवर्क को सूचना देना शामिल है.
मॉड्यूल
एचएएल इंटरफ़ेस में कई अहम एआईडीएल फ़ाइलें शामिल होती हैं:
| एचएएल फ़ाइल | ब्यौरा |
|---|---|
IMediaQuality.aidl |
यह मीडिया क्वालिटी सेवा का मुख्य इंटरफ़ेस है. इसका इस्तेमाल, सुनने वालों की संख्या सेट करने और हार्डवेयर की क्षमताओं के बारे में जानने के लिए किया जाता है. |
IPictureProfileChangedListener.aidl |
यह एक लिसनर इंटरफ़ेस है. इसका इस्तेमाल फ़्रेमवर्क, एचएएल को सूचना देने के लिए करता है. खास तौर पर, कंपोज़र एचएएल जैसे कॉम्पोनेंट को, पिक्चर प्रोफ़ाइल में हुए बदलावों के बारे में सूचना देने के लिए. |
IPictureProfileAdjustmentListener.aidl |
यह एक लिसनर इंटरफ़ेस है. इसका इस्तेमाल एचएएल, हार्डवेयर लेवल पर किए गए बदलावों के बारे में फ़्रेमवर्क को सूचना देने के लिए करता है. उदाहरण के लिए, जब कोई उपयोगकर्ता हार्डवेयर रिमोट से सीधे तौर पर कोई सेटिंग बदलता है. |
PictureParameter.aidl |
यह एक AIDL यूनियन है. इसमें कंट्रास्ट और शार्पनेस जैसे सभी स्टैंडर्ड पिक्चर पैरामीटर तय किए जाते हैं. इन पैरामीटर को अडजस्ट किया जा सकता है. |
PictureProfile.aidl |
यह AIDL पार्सल करने लायक ऑब्जेक्ट है. यह HAL लेयर पर मौजूद PictureProfile ऑब्जेक्ट को दिखाता है. इसमें प्रोफ़ाइल आईडी और उससे जुड़े पैरामीटर शामिल होते हैं. |
ISoundProfileChangedListener.aidl |
यह एक लिसनर इंटरफ़ेस है. इसका इस्तेमाल फ़्रेमवर्क, HAL को साउंड प्रोफ़ाइल में हुए बदलावों की सूचना देने के लिए करता है. |
ISoundProfileAdjustmentListener.aidl |
यह एक लिसनर इंटरफ़ेस है. इसका इस्तेमाल एचएएल, हार्डवेयर लेवल पर किए गए साउंड अडजस्टमेंट के बारे में फ़्रेमवर्क को सूचना देने के लिए करता है. |