Multipart-Geräte auf Android-Geräten

Einige Matter-Geräte bestehen aus mehreren Endpunkten mit demselben Gerätetyp. Andere Matter-Geräte sind hierarchisch aufgebaut, wobei Endpunkte in anderen Endpunkten verschachtelt sind. In den Home APIs werden beide Arten von Geräten als Multipart-Geräte bezeichnet.

Einfache Darstellung

Vor Version 1.8 der Home APIs wurden Multipart-Geräte in den Home APIs als eine Reihe separater, unabhängiger Geräte dargestellt. Dies wird als flache Darstellung bezeichnet.

Ein einzelnes Wandpaneel mit vier Schaltern wird in den Home-APIs beispielsweise als vier separate und unabhängige Geräte angezeigt. Ein hierarchisches Matter-Gerät wie ein Kühlschrank kann in den Home-APIs als eine Reihe von Geräten dargestellt werden, die jeweils einem der Endpunkte entsprechen.

  • Beispiel für ein Wandpaneel mit mehreren Schaltern, das die native Matter-Darstellung und die flache Darstellung der Home API zeigt

    Flache Darstellung einer Wandplatte mit vier Schaltern.

  • Beispiel für einen Kühlschrank mit der nativen Matter-Darstellung und der flachen Darstellung der Home API

    Flache Darstellung eines Kühlschranks

Abbildung 1: Beispiele für die flache Darstellung

Mehrteilige Darstellung

Ab Version 1.8 der Home APIs kann ein mehrteiliges Gerät in der API als einzelnes Gerät dargestellt werden. Rufen Sie zum Aktivieren dieses Verhaltens die Methode devices() für Structure, Room oder HomeManager auf und legen Sie den Parameter enableMultipartDevices auf true fest:

var multipartDevice = structure.devices(enableMultipartDevices = multipartEnabled)
var multipartDevice = multipartDevices.list().filter{ device ->  device.has(PowerStrip)}

Die folgenden Diagramme veranschaulichen, wie sich die Option enableMultipartDevices auf die Darstellung eines mehrteiligen Geräts in den Home APIs auswirkt:

  • Beispiel für ein Wandpaneel mit mehreren Schaltern, das die native Matter-Darstellung und das Multipart-Rendering der Home API zeigt

    Mehrteilige Darstellung einer Wandplatte.

  • Beispiel für einen Kühlschrank mit der nativen Matter-Darstellung und der mehrteiligen Darstellung der Home API

    Multipart-Darstellung eines Kühlschranks.

Abbildung 2: Beispiele für das Rendern von Multipart-Inhalten

Sie haben immer die Möglichkeit, die flache Darstellung zu erhalten, indem Sie entweder den Parameter enableMultipartDevices weglassen oder auf false setzen.

Bei einem mehrteiligen Gerät wird jede Komponenteninstanz eines Gerätetyps als Teil bezeichnet.

Auf Teile kann entweder direkt auf dem übergeordneten Gerät oder hierarchisch über Gerätetypen oder semantische Matter-Tags zugegriffen werden. Semantische Tags werden in den Home-APIs mit DescriptorTrait.SemanticTagStruct implementiert.

Die abstrakte Klasse DeviceType implementiert die Schnittstelle HasParts. Dadurch können Entwickler über die Property parts und die Methode part() im Gerätebaum navigieren. Jede Teilinstanz implementiert auch die Schnittstelle HasParts. Wenn Sie also parts() für ein Teil aufrufen, wird eine Liste mit null oder mehr untergeordneten Teilen zurückgegeben.

Das folgende Beispiel zeigt, wie auf die Teile des Geräts mit mehreren Schaltern zugegriffen wird:

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()

Im nächsten Beispiel wird gezeigt, wie auf die Teile eines Kühlschranks zugegriffen wird:

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()