डिवाइस एपीआई को Home API के ज़रिए ऐक्सेस किया जा सकता है. इन पैकेज को अपने ऐप्लिकेशन में इंपोर्ट करें:
import com.google.home.Home
import com.google.home.HomeDevice
import com.google.home.Id
Device API के साथ किसी खास तरह के डिवाइस या खासताओं का इस्तेमाल करने के लिए, उन्हें अलग-अलग इंपोर्ट करना होगा.
उदाहरण के लिए, Matter चालू/बंद करने की सुविधा और चालू/बंद करने की सुविधा वाले प्लग-इन यूनिट डिवाइस टाइप का इस्तेमाल करने के लिए, अपने ऐप्लिकेशन में ये पैकेज इंपोर्ट करें:
import com.google.home.matter.standard.OnOff
import com.google.home.matter.standard.OnOffPluginUnitDevice
ज़्यादा जानकारी के लिए, डेटा मॉडल देखें.
गड़बड़ी ठीक करना
Home के एपीआई में मौजूद कोई भी तरीका,
HomeException
को ट्रिगर कर सकता है. इसलिए, हमारा सुझाव है कि आप सभी कॉल पर HomeException
को पकड़ने के लिए, try-catch
ब्लॉक का इस्तेमाल करें.
HomeException
को मैनेज करते समय, इसकी code
और message
फ़ील्ड की जांच करें, ताकि यह पता चल सके कि क्या गड़बड़ी हुई है.
बिना मैनेज किए गए किसी भी अपवाद की वजह से, आपका ऐप्लिकेशन क्रैश हो जाएगा.
ज़्यादा जानकारी के लिए, गड़बड़ी को मैनेज करना लेख पढ़ें.
उदाहरण के लिए, किसी डिवाइस को निर्देश भेजना देखें.
कॉल के सैंपल
डिवाइसों की सूची देखना
स्ट्रक्चर उपलब्ध होने पर, devices()
कॉल से उस स्ट्रक्चर से ऐक्सेस किए जा सकने वाले डिवाइसों का फ़्लो दिखता है:
// Get a flow of all devices accessible to the user val allDevicesFlow: HomeObjectsFlow<HomeDevice> = home.devices() // Calling list() on a HomeObjectsFlow returns the first Set of elements. val allDevices: Set<HomeDevice> = allDevicesFlow.list()
यहां से, हर डिवाइस की स्थिति को ऐक्सेस किया जा सकता है. साथ ही, डिवाइस पर काम करने वाले निर्देश भेजे जा सकते हैं.
डिवाइस की स्थिति पढ़ना
आइए, डिवाइस के चालू/बंद होने के ट्रैट से OnOff
एट्रिब्यूट की जांच करने के उदाहरण पर नज़र डालते हैं. Home APIs के ट्रैट डेटा मॉडल का इस्तेमाल करके, इस ट्रैट को OnOff
के तौर पर पहचाना जा सकता है. साथ ही, डिवाइस टाइप की standardTraits
क्लास की मदद से, ट्रैट का डेटा वापस पाया जा सकता है:
// Assuming we have a device. val deviceFlow = home.devices().itemFlow(myDeviceId) val device = deviceFlow.first() // Get a flow of a standard trait on the type. distinctUntilChanged() is needed to only trigger // on the specific trait changes and not the whole type. val onOffTraitFlow: Flow<OnOff?> = device.type(DimmableLightDevice).map { it.standardTraits.onOff }.distinctUntilChanged() val onOffTrait: OnOff = onOffTraitFlow.first()!!
Kotlin फ़्लो फ़ंक्शन के बारे में ज़्यादा जानने के लिए, distinctUntilChanged
देखें.
किसी ट्रैट की सदस्यता की स्थिति को अमान्य करना
TraitStateInvalidation
इंटरफ़ेस, टारगेट डिवाइस पर सदस्यताओं के ज़रिए हासिल की गई स्थिति को अमान्य करने की सुविधा देता है. ऐसा तब किया जाता है, जब स्थिति की सही तरीके से रिपोर्टिंग नहीं की जा रही हो.
स्थिति की सही तरीके से रिपोर्ट न किए जाने के उदाहरणों में, Matter के "C" क्वालिटी वाले ट्रैट में एट्रिब्यूट का इस्तेमाल करना या डिवाइस को लागू करने की वजह से अचानक समस्या का होना शामिल है.
यह एपीआई, ट्रैट की मौजूदा स्थिति को फ़ोर्स रीड करता है और मौजूदा ट्रैट फ़्लो के ज़रिए नतीजा दिखाता है.
ट्रैट पाएं, फिर उस पर forceRead
चलाएं:
val generalDiagnosticsTrait = device.trait(GeneralDiagnostics).first()
generalDiagnosticsTrait.forceRead()
डिवाइस टाइप के ट्रैट की सूची पाना
डिवाइस टाइप का इस्तेमाल, ट्रैट पढ़ने के लिए एंट्री पॉइंट के तौर पर किया जाना चाहिए. ऐसा इसलिए, क्योंकि ये किसी डिवाइस को उसके फ़ंक्शन के हिसाब से अलग-अलग हिस्सों में बांट देते हैं. जैसे, Matter में एंडपॉइंट.
अगर किसी डिवाइस में दो तरह के डिवाइस होते हैं और दोनों में एक ही ट्रैट होता है, तो ट्रैट के टकराव की स्थिति में भी ये ट्रैट काम आते हैं. उदाहरण के लिए, अगर कोई डिवाइस, स्पीकर और मंद रोशनी देने वाली लाइट, दोनों है, तो उसमें दो चालू/बंद और दो लाइट के लेवल कंट्रोल वाले ट्रैट होंगे.
'रोशनी कम करने की सुविधा वाला लाइट' डिवाइस टाइप के लिए उपलब्ध ट्रैट की सूची पाने के लिए:
// Get all types available on this device. Requires the types to be part of the registry during // SDK initialization. val typesFlow: Flow<Set<DeviceType>> = device.types() // Get a snapshot of all types. val types: Set<DeviceType> = typesFlow.first() // Get the DimmableLightDevice instance from the set of types. val dimmableLightDevice = types.filterIsInstance<DimmableLightDevice>().firstOrNull() // Get all traits in the type + traits registered val allTraits: Set<Trait> = dimmableLightDevice!!.traits()
जब किसी डिवाइस में एक ही नाम के दो ट्रैट मौजूद होते हैं, तो एक और तरह का ट्रैट कॉलिज़न हो सकता है. उदाहरण के लिए, onOff
, स्टैंडर्ड OnOff
एट्रिब्यूट के किसी इंस्टेंस का रेफ़रंस दे सकता है. इसके अलावा, यह मैन्युफ़ैक्चरर के तय किए गए OnOff
एट्रिब्यूट के किसी इंस्टेंस का रेफ़रंस भी दे सकता है. किसी भी संभावित गलतफ़हमी को दूर करने के लिए कि किस ट्रीट की ज़रूरत है, डिवाइस के ज़रिए रेफ़र किए गए Trait
इंस्टेंस के पहले, क्वालीफ़ाइंग नेमस्पेस होना चाहिए. स्टैंडर्ड ट्रैट के लिए, standardTraits
का इस्तेमाल करें. ये ट्रैट, Matter स्टैंडर्ड क्लस्टर से मिलते-जुलते होते हैं. Google के ट्रैट के लिए, इनका इस्तेमाल करें:googleTraits
// Accessing standard traits on the type. val onOffTrait: OnOff? = dimmableLightDevice.standardTraits.onOff val levelControlTrait: LevelControl? = dimmableLightDevice.standardTraits.levelControl
मैन्युफ़ैक्चरर के हिसाब से किसी खास एट्रिब्यूट को ऐक्सेस करने के लिए, उसका सीधे तौर पर रेफ़रंस दें:
// Accessing a custom trait on the type. val customTrait = dimmableLightDevice.trait(MyCustomTrait)
किसी खास विशेषता वाले डिवाइसों की सूची पाना
Kotlin में filter
फ़ंक्शन का इस्तेमाल करके, एपीआई कॉल को और बेहतर बनाया जा सकता है. उदाहरण के लिए, होम में उन सभी डिवाइसों की सूची पाने के लिए जिनमें चालू/बंद करने की सुविधा है:
// Get all devices that support OnOff val onOffDevices: Flow<List<HomeDevice>> = home.devices().map { devices -> devices.filter { it.has(OnOff) } }
Home के एपीआई में उपलब्ध ट्रैट की पूरी सूची देखने के लिए, Trait
इंटरफ़ेस देखें.
एक जैसे डिवाइस टाइप वाले डिवाइसों की सूची पाना
किसी होम में मौजूद सभी लाइटों को कंट्रोल करने वाले डिवाइसों की सूची देखने के लिए:
// Get a list of devices with similar device types (lights) val lightDevices = home.devices().map { devices -> devices.filter { it.has(DimmableLightDevice) || it.has(OnOffLightDevice) || it.has(ColorTemperatureLightDevice) || it.has(ExtendedColorLightDevice) } }
Home API में, डिवाइस के कई टाइप होते हैं. इनमें से किसी एक टाइप को मुख्य डिवाइस टाइप के तौर पर दिखाया जा सकता है. उदाहरण के लिए, "लाइट" डिवाइस टाइप नहीं है. इसके बजाय, चार अलग-अलग तरह के डिवाइस हैं जो लाइट को दिखा सकते हैं, जैसा कि पिछले उदाहरण में दिखाया गया है. इसलिए, होम में मौजूद बेहतर डिवाइसों के बारे में पूरी जानकारी पाने के लिए, फ़िल्टर किए गए फ़्लो में कई तरह के डिवाइस शामिल करने होंगे.
Home API में उपलब्ध डिवाइस टाइप की पूरी सूची देखने के लिए, DeviceType
इंटरफ़ेस देखें.
किसी डिवाइस के लिए वेंडर आईडी या प्रॉडक्ट आईडी पाना
BasicInformation
ट्रैट में, किसी डिवाइस के लिए वेंडर आईडी, प्रॉडक्ट आईडी, प्रॉडक्ट का नाम, और सीरियल नंबर जैसी जानकारी शामिल होती है:
// Get device basic information. All general information traits are on the RootNodeDevice type. val basicInformation = device.type(RootNodeDevice).first().standardTraits.basicInformation!! println("vendorName ${basicInformation.vendorName}") println("vendorId ${basicInformation.vendorId}") println("productId ${basicInformation.productId}")
क्लाउड-टू-क्लाउड डिवाइसों की पहचान करना
अगर आप डिवाइस बनाने वाली कंपनी हैं और Cloud-to-cloud डिवाइस बनाते हैं, तो BasicInformation
ट्रेट की मदद से अपने Cloud-to-cloud डिवाइसों की पहचान करने के लिए, उनके SYNC
रिस्पॉन्स में ये स्ट्रिंग फ़ील्ड शामिल किए जा सकते हैं:
Connectivity Standards Alliance (सीएसए) से मिला वेंडर आईडी:
"matterOriginalVendorId": "0xfff1",
प्रॉडक्ट आइडेंटिफ़ायर, जो किसी वेंडर के प्रॉडक्ट की खास पहचान करता है:
"matterOriginalProductId": "0x1234",
डिवाइस का यूनीक आइडेंटिफ़ायर, जिसे मैन्युफ़ैक्चरर के हिसाब से बनाया जाता है:
"matterUniqueId": "matter-device-id",
इन स्ट्रिंग फ़ील्ड में जानकारी डालते समय, अगर आपके पास Matter
वेंडर और प्रॉडक्ट आईडी हैं, तो उनका इस्तेमाल करें. अगर आप सीएसए के सदस्य नहीं हैं और आपको ये आईडी असाइन नहीं किए गए हैं, तो matterOriginalVendorId
और matterOriginalProductId
फ़ील्ड को खाली छोड़ा जा सकता है. साथ ही, आइडेंटिफ़ायर के तौर पर matterUniqueId
दिया जा सकता है.
सिंक रिस्पॉन्स के उदाहरण में, इन फ़ील्ड का इस्तेमाल दिखाया गया है:
{
"requestId": "ff36a3cc-ec34-11e6-b1a0-64510650abcf",
"payload": {
"agentUserId": "1836.15267389",
"devices": [
{
"id": "456",
"type": "action.devices.types.LIGHT",
"traits": [
"action.devices.traits.OnOff",
"action.devices.traits.Brightness",
"action.devices.traits.ColorSetting",
],
"willReportState": true,
"deviceInfo": { ... },
"matterOriginalVendorId": "0xfff1",
"matterOriginalProductId": "0x1234",
"matterUniqueId": "matter-device-id",
"otherDeviceIds": [
{
"deviceId": "local-device-id",
}
]
}
]
}
}
ज़्यादा जानकारी के लिए, Cloud-to-cloud SYNC
दस्तावेज़ देखें.
डिवाइस और ट्रैट का मेटाडेटा
Home API में मौजूद डिवाइसों और खासताओं के साथ मेटाडेटा जुड़ा होता है. इससे, किसी ऐप्लिकेशन में उपयोगकर्ता अनुभव को मैनेज करने में मदद मिलती है.
Home API में मौजूद हर ट्रैट में एक sourceConnectivity
प्रॉपर्टी होती है. इसमें ट्रैट के ऑनलाइन स्टेटस और जगह (लोकल या रिमोट रूटिंग) की जानकारी होती है.
किसी डिवाइस का प्राइमरी टाइप पाना
हो सकता है कि कुछ डिवाइस, Home API की मदद से कई तरह के डिवाइसों के तौर पर दिखें. यह पक्का करने के लिए कि उपयोगकर्ताओं को उनके डिवाइसों के लिए, ऐप्लिकेशन में सही विकल्प (जैसे, डिवाइस कंट्रोल और सुझाए गए ऑटोमेशन) दिखाए जाएं, यह देखना ज़रूरी है कि किसी डिवाइस का मुख्य टाइप क्या है.
सबसे पहले, type()
का इस्तेमाल करके, डिवाइस का टाइप पता करें. इसके बाद, यह तय करें कि मुख्य टाइप कौनसा है:
val types = device.types().first() val primaryType = types.first { it.metadata.isPrimaryType }
देखना कि कोई ट्रैट ऑनलाइन है या नहीं
किसी ट्रैट की कनेक्टिविटी की जांच करने के लिए, connectivityState()
तरीके का इस्तेमाल करें:
val onOffConnectivity = onOffTrait?.metadata?.sourceConnectivity?.connectivityState
अगर डिवाइस में इंटरनेट कनेक्शन नहीं है, तो हो सकता है कि कुछ खास तौर पर Google smart home के ट्रैट, ऑफ़लाइन दिखें. ऐसा इसलिए है, क्योंकि ये ट्रैट क्लाउड-आधारित होते हैं और इनमें लोकल रूटिंग नहीं होती.
किसी डिवाइस की कनेक्टिविटी की जांच करना
किसी डिवाइस की कनेक्टिविटी की जांच, डिवाइस टाइप के लेवल पर की जाती है, क्योंकि कुछ डिवाइसों पर कई तरह के डिवाइस काम करते हैं. डिवाइस की स्थिति, उस डिवाइस पर मौजूद सभी ट्रैट की कनेक्टिविटी की स्थितियों का एक कॉम्बिनेशन होती है.
val lightConnectivity = dimmableLightDevice.metadata.sourceConnectivity.connectivityState
अलग-अलग तरह के डिवाइसों के साथ इंटरनेट कनेक्शन न होने पर, PARTIALLY_ONLINE
की स्थिति दिख सकती है. स्थानीय रूटिंग की वजह से, हो सकता है कि Matter के स्टैंडर्ड ट्रैट अब भी ऑनलाइन हों. हालांकि, क्लाउड-आधारित ट्रैट ऑफ़लाइन हो जाएंगे.
किसी विशेषता के नेटवर्क राउटिंग की जांच करना
किसी विशेषता के लिए जगह की जानकारी, Home API में भी उपलब्ध है. dataSourceLocality
से पता चलता है कि ट्रैट को रिमोट तौर पर (क्लाउड के ज़रिए), लोकल तौर पर (लोकल हब के ज़रिए) या पीयर-टू-पीयर (सीधे डिवाइस से डिवाइस पर, बिना हब के) भेजा गया है.
जगह की जानकारी की अज्ञात वैल्यू UNSPECIFIED
तब दिख सकती है, जब कोई ऐप्लिकेशन शुरू हो रहा हो और वह अब तक डिवाइस कनेक्टिविटी के लिए किसी हब या सर्वर तक न पहुंचा हो. इन डिवाइसों से इंटरैक्ट नहीं किया जा सकता. साथ ही, इन पर निर्देशों या इवेंट से इंटरैक्ट करने के अनुरोध काम नहीं करेंगे. ऐसे डिवाइसों को मैनेज करने का तरीका तय करना, क्लाइंट की ज़िम्मेदारी है.
val onOffLocality = onOffTrait?.metadata?.sourceConnectivity?.dataSourceLocality
किसी डिवाइस के लिए नेटवर्क रूटिंग की जांच करना
कनेक्टिविटी की तरह ही, जगह की जानकारी की जांच भी डिवाइस के टाइप के हिसाब से की जाती है. इससे पता चलता है कि डिवाइस पर मौजूद सभी ट्रैट की जगह की जानकारी क्या है.
val lightLocality = dimmableLightDevice.metadata.sourceConnectivity.dataSourceLocality
MIXED
की स्थिति, PARTIALLY_ONLINE
कनेक्टिविटी की स्थिति जैसी ही हो सकती है: कुछ ट्रैट क्लाउड-आधारित होते हैं, जबकि कुछ स्थानीय होते हैं.
एपीआई की सूची
Home
का एक इंस्टेंस बनाने के बाद, इन डिवाइस एपीआई को ऐक्सेस किया जा सकता है:
एपीआई | ब्यौरा |
---|---|
devices() |
Google खाते पर सभी डिवाइसों को सभी स्ट्रक्चर में पाएं. एक HomeObjectsFlow दिखाता है, जो डेटा को वापस पाने और फ़िल्टर करने के अन्य विकल्प देता है. |
HomeDevice
मिलने के बाद,
इन एपीआई को ऐक्सेस किया जा सकता है:
एपीआई | ब्यौरा |
---|---|
allCandidates() |
यह डिवाइस और उसके चाइल्ड डिवाइसों के लिए, ऑटोमेशन के लिए चुने गए सभी डिवाइस दिखाता है. |
candidates() |
डिवाइस के लिए, ऑटोमेशन के सभी उम्मीदवार दिखाता है. |
connectivityStateChanged |
डिवाइस की स्थिति में बदलाव होने का सबसे हाल का समय. |
events(event) |
किसी खास इवेंट का फ़्लो पाता है. |
events(trait) |
इस ट्रैट के हिसाब से सभी इवेंट का फ़्लो मिलता है. |
events(traits) |
इन ट्रेट के हिसाब से सभी इवेंट का फ़्लो मिलता है. |
getSourceConnectivity(trait) |
किसी खास ट्रैट के लिए मेटाडेटा पाना. SourceConnectivity दिखाता है. |
has(trait) |
देखें कि डिवाइस पर, अनुरोध किया गया मौजूदा ट्रैट काम करता है या नहीं. |
has(type) |
अगर डिवाइस पर दिए गए टाइप का इस्तेमाल किया जा सकता है. |
id |
डिवाइस का यूनीक सिस्टम आईडी. |
isInRoom |
अगर डिवाइस किसी कमरे में है. |
isInStructure |
अगर डिवाइस किसी स्ट्रक्चर में है. |
isMatterDevice |
अगर डिवाइस पर Matter का बैकअप लिया गया है. |
name |
डिवाइस का वह नाम जो उपयोगकर्ता ने दिया है. |
room() |
वह रूम जिसे डिवाइस असाइन किया गया है. Room दिखाता है. |
roomId |
उस रूम का आईडी जिसे डिवाइस असाइन किया गया है. Id दिखाता है. |
sourceConnectivity |
डिवाइस की सोर्स कनेक्टिविटी, जो डिवाइस के ट्रैट की इकट्ठा की गई कनेक्टिविटी की स्थितियों और नेटवर्क की जगह की जानकारी दिखाती है. |
structure() |
वह स्ट्रक्चर जिसे डिवाइस असाइन किया गया है. Structure दिखाता है. |
structureId |
उस स्ट्रक्चर का आईडी जिसे डिवाइस असाइन किया गया है. Id दिखाता है. |
type(type) |
सीधे ऐक्सेस के लिए, टाइप की परिभाषा को उन ट्रैट के साथ पाएं जो उपलब्ध हैं. हमेशा ट्रैट के अप-टू-डेट स्नैपशॉट दिखाता है. |
types() |
डिवाइस पर उपलब्ध सभी टाइप की सूची पाएं. |