Mô hình dữ liệu trên iOS

Home API dành cho iOS trình bày tất cả thiết bị trong hệ sinh thái Google Home theo một mô hình dữ liệu thống nhất. Mô hình dữ liệu này bao gồm tất cả các loại thiết bị (từ Google Nest hoặc nhà sản xuất bên thứ ba), bất kể công nghệ nhà thông minh cơ bản (chẳng hạn như Matter hoặc Cloud-to-cloud), và cung cấp một nền tảng API chung để xây dựng trải nghiệm người dùng cho cả smart home và nhà phát triển ứng dụng di động.

Loại thiết bị

Các loại thiết bị được trình bày trong Home API là sự hợp nhất của MatterCloud-to-cloud mô hình dữ liệu. Một số loại được lấy trực tiếp từ Matter, một số loại là phần mở rộng của Matter loại thiết bị và một số loại được lấy từ Cloud-to-cloud.

Các loại thiết bị chứa các đặc điểm được dùng để kiểm soát và quản lý thiết bị. Giống như các loại thiết bị, các đặc điểm được lấy từ các cụm Matter và các đặc điểm Cloud-to-cloud đồng thời được trình bày ở định dạng chung tương tự như các cụm Matter. Trong Home API, các đặc điểm bắt nguồn từ Matter được gọi là đặc điểm chứ không phải cụm.

Do đó, các loại thiết bị và đặc điểm trong Home API được thiết kế để ưu tiên Matter. Loại thiết bị hoặc đặc điểm Mattersẽ được ưu tiên hơn so với loại thiết bị hoặc đặc điểm tương tự Cloud-to-cloud.

Hãy xem bài viết Các loại thiết bị được hỗ trợ trên iOS để biết danh sách các loại thiết bị và đặc điểm của chúng.

Đặc điểm

Các phiên bản Swift của đặc điểm được tạo để sử dụng trong Home API và chứa các tính năng bổ sung dành riêng cho Home API (không có trong Matter hoặc Cloud-to-cloud). Ví dụ: mỗi đặc điểm có các phương thức để kiểm tra xem một đặc điểm có hỗ trợ một thuộc tính hoặc lệnh cụ thể hay không. Điều này rất hữu ích khi xác định xem có thể đọc trạng thái hoặc thực hiện một số hành động trên thiết bị của người dùng hay không, vì không phải tất cả thiết bị trong một loại thiết bị đều có tất cả các tính năng giống nhau.

Để nhập các đặc điểm và loại thiết bị, hãy nhập mô-đun GoogleHomeTypes vào ứng dụng:

import GoogleHomeTypes

Ngoài ra, bạn có thể sử dụng typealias cho tên đặc điểm và loại thiết bị để rút ngắn mã và tránh lặp lại không gian tên:

import GoogleHomeTypes

typealias OpenCloseTrait = Google.OpenCloseTrait
typealias OnOffTrait = Matter.OnOffTrait
typealias FanDevice = Matter.FanDeviceType

Hầu hết các đặc điểm đều được hỗ trợ để sử dụng với tính năng Tự động hoá và một số đặc điểm chỉ có sẵn cho tính năng Tự động hoá. Để biết thêm thông tin chi tiết, hãy xem bài viết Hỗ trợ đặc điểm API tự động hoá trên Android.

Cấu trúc loại thiết bị

Home API hỗ trợ hầu hết các cụm ứng dụng Matter dưới dạng đặc điểm trong mô hình dữ liệu. Các đặc điểm không tương ứng với trạng thái hoặc tính năng kiểm soát thiết bị và không mang lại tiện ích nào cho người dùng cuối (chẳng hạn như Liên kết và Nhóm) sẽ không được hiển thị thông qua Home API.

Các đặc điểm bắt nguồn từ Cloud-to-cloud đặc điểm nhà thông minh thường có cùng tên giữa Cloud-to-cloud và Home API, chẳng hạn như trong ví dụ về OpenCloseTrait. Các đặc điểm khác được biểu diễn dưới dạng phần mở rộng của Matter đặc điểm, được tạo bằng Matter phần mở rộng dành riêng cho nhà sản xuất. Các đặc điểm này giúp thu hẹp khoảng cách cho một smart home đặc điểm khi chức năng được chia tách giữa Matter SDK và hệ sinh thái Google Home. Một ví dụ cụ thể về điều này là các loại thiết bị Google* đến từ Cloud-to-cloud nhưng chưa có các loại thiết bị Matter tương tự.

Các loại thiết bị bao gồm các đặc điểm từ một hoặc cả hai nguồn, Matter hoặc Cloud-to-cloud.

Ví dụ: FanDeviceType bao gồm cả và có 3 đặc điểm:

  • Đặc điểm IdentifyTrait Matter cung cấp tất cả chức năng từ Matter IdentifyTrait.
  • Đặc điểm FanControlTrait Matter cung cấp tất cả chức năng từ Matter FanControlTrait.
  • Đặc điểm Google ExtendedFanControlTrait cung cấp tất cả chức năng từ smart home FanSpeedTrait của Google mà đặc điểm FanControlTrait Matter không bao gồm.

Loại cấu trúc đặc điểm này cung cấp một mô hình linh hoạt cho chức năng hoàn chỉnh của loại thiết bị, trừu tượng hoá các mô hình dữ liệu cơ bản smart home.