Alguns dispositivos Matter são compostos por vários endpoints com o mesmo tipo de dispositivo. Outros dispositivos Matter são hierárquicos, com endpoints aninhados em outros endpoints. Nas APIs Home, os dois tipos de dispositivos são chamados de dispositivos multipartes.
Representação plana
Antes da versão 1.8 das APIs Home, os dispositivos multipartes eram representados pelas APIs Home como um conjunto de dispositivos separados e não relacionados. Isso é conhecido como representação simples.
Por exemplo, um único dispositivo de painel de parede com quatro interruptores aparece nas APIs Home como quatro dispositivos distintos e não relacionados. Um dispositivo Matter hierárquico, como uma geladeira, pode ser representado nas APIs Home como um conjunto de dispositivos, cada um correspondendo a um dos endpoints.
Representação plana de um painel de parede com quatro interruptores.
Representação plana de uma geladeira
Representação de várias partes
A partir da versão 1.8 das APIs Home, um dispositivo multipart pode ser
representado na API como um único dispositivo. Para ativar esse comportamento, chame o
método devices() em
Structure, Room ou HomeManager
e defina o parâmetro enableMultipartDevices como 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)
Os diagramas a seguir ilustram como a opção enableMultipartDevices
afeta a representação de um dispositivo multipart na API Home:
Representação de várias partes de um painel de parede.
Representação multipart de uma geladeira.
Você sempre tem a opção de receber a representação plana omitindo o parâmetro enableMultipartDevices ou definindo-o como false.
Navegar em um dispositivo multipart
Em um dispositivo multipart, cada instância de componente de um tipo de dispositivo é chamada de peça.
As peças podem ser acessadas diretamente no dispositivo principal ou de maneira
hierárquica, usando tipos de dispositivo ou tags semânticas
Matter. As tags semânticas são implementadas nas APIs Home com
DescriptorTrait.SemanticTagStruct.
A classe abstrata DeviceType implementa a interface HasParts, permitindo que os desenvolvedores naveguem pela árvore de dispositivos usando a propriedade parts e o método part(). Cada instância de parte também implementa a interface HasParts, para que
chamar parts() em uma parte produza uma lista de zero ou mais subpartes.
O exemplo a seguir mostra como acessar as partes do dispositivo de vários interruptores:
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()
O exemplo a seguir mostra como acessar as partes de um dispositivo de geladeira:
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()