Android के लिए Home APIs की खास जानकारी

Android के लिए Google Home API, एक यूनिफ़ाइड एपीआई प्लैटफ़ॉर्म उपलब्ध कराते हैं. इससे डेवलपर, उपयोगकर्ता के होम में मौजूद इकाइयों की स्थिति के साथ इंटरैक्ट कर सकते हैं. इन इकाइयों से, उपयोगकर्ता के स्ट्रक्चर और कमरों से जुड़े डिवाइसों और डिवाइस से जुड़ी जानकारी के बारे में पता चल सकता है.

Home API, उन इकाइयों के बारे में बताते हैं जिनके साथ उपयोगकर्ता इंटरैक्ट कर सकता है:

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

इस आर्किटेक्चर को पहली इमेज में दिखाया गया है:

Home APIs के आर्किटेक्चर को दिखाने वाला डायग्राम
पहली इमेज: Home के एपीआई का आर्किटेक्चर

Home API डिवाइस टाइप, स्मार्ट होम के लिए Matter, एक ओपन स्टैंडर्ड या Google Home नेटवर्क में Cloud-to-cloud डिवाइस के ज़रिए काम कर सकते हैं. कुछ डिवाइसों में, दोनों तरह की सुविधाएं शामिल हो सकती हैं. ज़्यादा जानकारी के लिए, Android पर काम करने वाले डिवाइस टाइप देखें.

Matter में, डिवाइस की मुख्य सुविधाओं को क्लस्टर के हिसाब से ग्रुप किया जाता है. इन्हें Home के एपीआई में Matter के स्टैंडर्ड ट्रैट के तौर पर दिखाया जाता है. Home के एपीआई, Matter क्लस्टर के स्टैंडर्ड सेट के साथ काम करते हैं. इस बारे में, Matter के मौजूदा स्पेसिफ़िकेशन में बताया गया है.

Google Home के नेटवर्क में, डिवाइस की सुविधाओं को स्मार्ट होम के लैंडस्केप के हिसाब से ग्रुप किया जाता है. इन लैंडस्केप को Home API में, Google स्मार्ट होम लैंडस्केप के तौर पर दिखाया जाता है. Home API, स्मार्ट होम के उन ट्रैट के सेट के साथ काम करते हैं जिनके बारे में Cloud-to-cloud प्रोग्राम में बताया गया है.

इसके अलावा, मैन्युफ़ैक्चरर के हिसाब से क्लस्टर और प्लैटफ़ॉर्म के हिसाब से ट्रैट जैसे अन्य ट्रैट भी उपलब्ध हैं. ज़्यादा जानने के लिए, Android पर डेटा मॉडल देखें.

भाषा

Android के लिए Home API, Kotlin में लिखे गए हैं. साथ ही, ये एक ऐसा Kotlin इंटरफ़ेस उपलब्ध कराते हैं जो स्थिति और सदस्यता को मैनेज करने के लिए, Flow का इस्तेमाल करता है. इससे, स्टैंडर्ड सदस्यता एपीआई के मुकाबले कई फ़ायदे मिलते हैं.

हमारा सुझाव है कि अगर आपने अब तक कोरूटीन, फ़्लो, और Jetpack Compose के बारे में Kotlin दस्तावेज़ नहीं पढ़े हैं, तो उन्हें पढ़ें:

इकाई के आइडेंटिफ़ायर

Home API में मौजूद हर इकाई का एक आईडी होता है, जो उसका मुख्य आइडेंटिफ़ायर होता है. यह आईडी एक यूनीक और स्टेबल आइडेंटिफ़ायर होता है. यह इकाई के पूरे जीवनकाल के लिए कभी नहीं बदलेगा. इस आईडी का इस्तेमाल, ऑब्जेक्ट को कैश मेमोरी में सेव करने या एक जैसे होने की जांच करने के लिए किया जा सकता है. ऐसा इसलिए, क्योंकि किसी इकाई का मेटाडेटा बदल सकता है.

यह जानने के लिए कि किन इकाइयों का आईडी है, HasId इंटरफ़ेस देखें.

शब्दावली मैपिंग

Home API में मौजूद इकाइयां, Matter और Cloud-to-cloud कॉन्सेप्ट से इस तरह मैप होती हैं:

Home APIs Matter Cloud-to-cloud
विशेषता क्लस्टर विशेषता
एट्रिब्यूट एट्रिब्यूट एट्रिब्यूट, स्टेटस
कमांड कमांड कमांड
इवेंट इवेंट फ़ॉलो अप रिस्पॉन्स, सूचना