Android पर मल्टीपार्ट डिवाइस

कुछ Matter डिवाइस, एक ही तरह के डिवाइस के कई एंडपॉइंट से मिलकर बने होते हैं. अन्य Matter डिवाइस, क्रम के हिसाब से बने होते हैं. इनमें एंडपॉइंट, दूसरे एंडपॉइंट में नेस्ट किए जाते हैं. Home APIs में, दोनों तरह के डिवाइसों को मल्टीपार्ट डिवाइस कहा जाता है.

फ़्लैट व्यू

Home APIs के 1.8 वर्शन से पहले, मल्टीपार्ट डिवाइसों को Home APIs में अलग-अलग और असंबद्ध डिवाइसों के तौर पर दिखाया जाता है. इसे फ़्लैट व्यू कहा जाता है.

उदाहरण के लिए, चार स्विच वाला एक वॉल पैनल डिवाइस, Home APIs में चार अलग-अलग और असंबद्ध डिवाइसों के तौर पर दिखता है. वहीं, क्रम के हिसाब से बने Matter डिवाइस, जैसे कि रेफ़्रिजरेटर को Home APIs में डिवाइसों के सेट के तौर पर दिखाया जा सकता है. इनमें से हर डिवाइस, एक एंडपॉइंट से जुड़ा होता है.

  • कई स्विच वाला वॉल पैनल, जिसमें नेटिव Matter का उदाहरण दिखाया गया है. साथ ही, Home API की फ़्लैट रेंडरिंग दिखाई गई है

    चार स्विच वाले वॉल पैनल का फ़्लैट व्यू.

  • रेफ़्रिजरेटर का उदाहरण, जिसमें Matter के नेटिव वर्शन और Home API के फ़्लैट रेंडरिंग को दिखाया गया है

    रेफ़्रिजरेटर का फ़्लैट व्यू

पहली इमेज: फ़्लैट रेंडरिंग के उदाहरण

मल्टीपार्ट व्यू

Home APIs के 1.8 वर्शन से, किसी मल्टीपार्ट डिवाइस को एपीआई में एक डिवाइस के तौर पर दिखाया जा सकता है. इस सुविधा को चालू करने के लिए, Structure, Room या HomeManager पर devices() तरीका कॉल करें और enableMultipartDevices पैरामीटर को true पर सेट करें:

let devices = try await self.home.devices(enableMultipartDevices: true).list()
    let device = try XCTUnwrap(devices.first { $0.id == powerstripID })
    let outlets = try await device.types.getAll(of: OnOffPluginUnitDeviceType.self)

यहां दिए गए डायग्राम में दिखाया गया है कि enableMultipartDevices विकल्प, Home APIs में किसी मल्टीपार्ट डिवाइस को दिखाने के तरीके पर कैसे असर डालता है:

  • कई स्विच वाला वॉल पैनल, जिसमें Matter के नेटिव वर्शन और Home API की मल्टीपार्ट रेंडरिंग को दिखाया गया है

    वॉल पैनल का मल्टीपार्ट व्यू.

  • रेफ़्रिजरेटर का उदाहरण, जिसमें Matter के नेटिव वर्शन और Home API की मल्टीपार्ट रेंडरिंग को दिखाया गया है

    रेफ़्रिजरेटर का मल्टीपार्ट व्यू.

दूसरी इमेज: मल्टीपार्ट रेंडरिंग के उदाहरण

enableMultipartDevices पैरामीटर को छोड़कर या इसे false पर सेट करके, फ़्लैट व्यू पाने का विकल्प हमेशा आपके पास होता है.

मल्टीपार्ट डिवाइस में, किसी डिवाइस टाइप के हर कॉम्पोनेंट इंस्टेंस को पार्ट कहा जाता है.

डिवाइस टाइप या Matter सिमैंटिक टैग का इस्तेमाल करके, पैरंट डिवाइस या क्रम के हिसाब से बने किसी पार्ट को सीधे तौर पर ऐक्सेस किया जा सकता है. Home APIs में, सिमैंटिक टैग को DescriptorTrait.SemanticTagStruct के साथ लागू किया जाता है.

DeviceType ऐब्स्ट्रैक्ट क्लास HasParts इंटरफ़ेस को लागू करती है. इससे डेवलपर, parts प्रॉपर्टी और part() तरीके से डिवाइस ट्री पर नेविगेट कर सकते हैं. हर पार्ट इंस्टेंस भी HasParts इंटरफ़ेस को लागू करता है. इसलिए, किसी पार्ट पर parts() को कॉल करने पर, ज़ीरो या उससे ज़्यादा सब-पार्ट की सूची मिलती है.

यहां दिए गए उदाहरण में, मल्टी-स्विच डिवाइस के पार्ट को ऐक्सेस करने का तरीका बताया गया है:

val device =
      homeManager
        .devices(enableMultipartDevices = true)
        .itemFlow(Id(MULTI_SWITCH_DEVICE))
        .first()

// Here at top-level, we are using the homeDevice.parts() API to access flow of
// all the switches. Then we get the part ids.
val partIds =
      device
        .parts()
        .map { parts ->
          parts.filter { it.has(Switch) }.mapNotNull { it.metadata.partId }
        }
        .first()
        .toSet()

अगले उदाहरण में, रेफ़्रिजरेटर डिवाइस के पार्ट को ऐक्सेस करने का तरीका बताया गया है:

val rootDevice = homeManager.devices(true).itemFlow(Id("device@uuid1"))

// On the top level, HomeDevice provides both plural (parts)
// and singular (part) APIs.
// The parts() API returns all the parts accessible from the top level,
// including Endpoint 0 and its children.
val childParts = rootDevice.parts().first()
// childParts contain (EP0 as RootNode, EP1 as Refrigerator)

// The singular part() API accepts DeviceType and tags (optional).
val refrigerator = rootDevice.part(Refrigerator).first()

// Get the refrigerator device which in this case is just device@uuid1
val refrigeratorDevice = homeManager.devices(false).itemFlow(refrigerator.metadata.partId.deviceId)

// DeviceType uses a synchronous API for providing access to parts
val cabinets = refrigerator.parts  // [EP2, EP3]

// Get the HomeDevice for these cabinets (device@uuid2 and device@uuid3)
val cabinetDeviceIds = cabinets.map { it.metadata.partId }

// Now use the devices API with enableMultipartDevices = false.
val cabinetDevices = homeManager.devices(false)
    .map { devices ->
devices.filter { it.id in cabinetDeviceIds }
}.first()