Các đặc điểm được đơn giản hoá trên Android

Để dễ sử dụng, các phiên bản đơn giản của một số đặc điểm có thể dùng với Automation API trên Android.

Đặc điểm đơn giản thay thế cho đặc điểm Home API tiêu chuẩn, tương tự như cách hoạt động của mẫu facade. Đặc điểm đơn giản cung cấp các lệnh giúp thực hiện các tác vụ phổ biến dễ dàng hơn đối với một số loại thiết bị. Đặc điểm đơn giản là đặc điểm Home API và giống như các đặc điểm Home API khác, chúng hoạt động cho cả MatterCloud-to-cloud thiết bị.

Đặc điểm đơn giản cung cấp một tập hợp con thay thế gồm các thuộc tính và lệnh dành riêng cho thiết bị hơn so với các thuộc tính và lệnh của đặc điểm tiêu chuẩn tương ứng. Ví dụ: đặc điểm LevelControl là một đặc điểm chung có thể dùng cho mọi thiết bị có chế độ cài đặt thay đổi liên tục trong một phạm vi giá trị số. Brightness là một đặc điểm đơn giản thay thế cho LevelControl và chỉ cung cấp các lệnh và thuộc tính mà thiết bị DimmableLight yêu cầu. Brightness có lệnh moveToBrightness nhận một đối số brightnessPercent, trong khi LevelControl có nhiều lệnh move, hầu hết đều có ít nhất 4 tham số để phù hợp với nhiều trường hợp sử dụng hơn.

Bảng sau đây cho thấy từng đặc điểm đơn giản và(các) đặc điểm tiêu chuẩn cơ bản. Mỗi tên đặc điểm liên kết đến tài liệu API tương ứng:

Bảng: Đặc điểm đơn giản
Đặc điểm đơn giản Đặc điểm tiêu chuẩn
SimplifiedThermostat Thermostat
Brightness LevelControl
SimplifiedOnOff OnOff
Volume LevelControl
OnOff

Đặc điểm đơn giản và Discovery API

Discovery API báo cáo các đặc điểm đơn giản cũng như các đặc điểm tiêu chuẩn cơ bản, miễn là cả hai đặc điểm đều được đăng ký trong FactoryRegistry. Ví dụ: nếu thiết bị DimmableLight có trong cấu trúc và nhà phát triển đã đăng ký cả LevelControlBrightness đặc điểm trong FactoryRegistry, thì Discovery API sẽ cho biết sự hiện diện của cả hai đặc điểm. Nhà phát triển có thể chọn sử dụng đặc điểm nào trong quá trình tự động hoá.

Xem bài viết Discovery API trên Android để biết thêm thông tin.

Truy xuất thiết bị hỗ trợ đặc điểm đơn giản

Khi sử dụng Device API để lấy các thiết bị trong một cấu trúc hỗ trợ đặc điểm đơn giản như SimplifiedThermostat, bạn không thể sử dụng phương thức has(trait). Thay vào đó, hãy sử dụng phương thức has(deviceType):

val thermostat = home.devices().list().first { device -> device.has(ThermostatDevice) }