Aby ułatwić korzystanie z interfejsu Automation API na Androidzie, udostępniamy uproszczone wersje niektórych cech.
Uproszczona cecha zastępuje standardową cechę interfejsu Home API, podobnie jak działa wzorzec fasady. Uproszczone cechy zapewniają polecenia, które ułatwiają wykonywanie typowych zadań na niektórych typach urządzeń. Uproszczone cechy to cechy interfejsu Home API, które podobnie jak inne cechy tego interfejsu działają na urządzeniach Matter i Cloud-to-cloud.
Uproszczona cecha oferuje alternatywny podzbiór atrybutów i poleceń, które są bardziej specyficzne dla urządzenia niż te z odpowiedniej standardowej cechy.
Na przykład standardowy
LevelControl
atrybut to atrybut ogólny, który można stosować w przypadku dowolnego urządzenia z ustawieniem, które zmienia się w sposób ciągły w zakresie wartości liczbowych.
Brightness to uproszczona cecha, która zastępuje LevelControl i zawiera tylko polecenia i atrybuty wymagane przez urządzenie DimmableLight. Brightness ma polecenie
moveToBrightness, które przyjmuje jeden argumentbrightnessPercent, natomiast LevelControl ma kilka poleceń move, z których większość ma co najmniej 4 parametry, aby uwzględnić szerszy zakres zastosowań.
W tabeli poniżej znajdziesz uproszczone cechy i odpowiadające im standardowe cechy. Każda nazwa cechy jest powiązana z odpowiednią dokumentacją interfejsu API:
| Uproszczona cecha | Cechy standardowe |
|---|---|
SimplifiedThermostat
|
Thermostat
|
Brightness
|
LevelControl
|
SimplifiedOnOff
|
OnOff
|
Volume
|
LevelControlOnOff
|
Uproszczone cechy i interfejs Discovery API
Interfejs Discovery API raportuje uproszczone cechy, a także ich podstawowe cechy standardowe, o ile obie cechy zostały zarejestrowane w FactoryRegistry. Jeśli na przykład w strukturze występuje urządzenie DimmableLight, a deweloper zarejestrował w FactoryRegistry cechy LevelControl i Brightness, interfejs Discovery API wskaże obecność obu tych cech. Deweloper może użyć w automatyzacji dowolnej z tych cech.
Więcej informacji znajdziesz w artykule Interfejs Discovery API na Androidzie.
Pobieranie urządzenia, które obsługuje uproszczony trait
Jeśli używasz interfejsu Device API do uzyskiwania urządzeń w strukturze, która obsługuje uproszczony atrybut, np. SimplifiedThermostat, nie możesz używać metody has(trait). Zamiast tego użyj metody has(deviceType):
val thermostat = home.devices().list().first { device -> device.has(ThermostatDevice) }