מודל נתונים ב-Android

ממשקי ה-API של Home ל-Android מציגים את כל המכשירים במערכת האקולוגית של Google Home במודל נתונים מאוחד. מודל הנתונים הזה כולל את כל סוגי המכשירים (מ-Google Nest או מיצרנים של צד שלישי), ללא קשר לטכנולוגיה הבסיסית של הבית החכם (כמו Matter או Cloud-to-cloud), ומספק ממשק API משותף לבניית חוויות משתמש למפתחי smart home ולאפליקציות לנייד.

סוגי מכשירים

סוגי המכשירים שמוצגים בממשקי ה-API של Home הם איחוד של מודלי הנתונים Matter ו-Cloud-to-cloud. חלקם נגזרים ישירות מ-Matter, חלקם הם הרחבה של סוגי המכשירים ב-Matter וחלקם נגזרים מ-Cloud-to-cloud.

סוגי מכשירים מכילים מאפיינים שמשמשים לשליטה במכשירים ולניהול שלהם. בדומה לסוגי המכשירים, המאפיינים נגזרים מאשכולות Matter וממאפיינים של Cloud-to-cloud, ומוצגים בפורמט משותף שדומה לפורמט של אשכולות Matter. ב-Home APIs, תכונות שמקורן ב-Matter נקראות traits ולא clusters.

לכן, סוגי מכשירים ותכונות בממשקי ה-API של Home מיועדים להיות Matter-first. סוג מכשיר או תכונה של Matter קודמים לאנלוגים של Cloud-to-cloud.

כאן מופיעה רשימה של סוגי מכשירים והמאפיינים שלהם ב-Android.

תכונות

גרסאות Kotlin של מאפיינים נוצרות לשימוש בממשקי Home API, והן מכילות תכונות נוספות שספציפיות לממשקי Home API (לא נמצאות ב-Matter או ב-Cloud-to-cloud). לדוגמה, לכל מאפיין יש שיטות לבדיקה אם מאפיין תומך במאפיין או בפקודה ספציפיים. זה שימושי כשקובעים אם אפשר לקרוא את המצב או לבצע פעולות מסוימות במכשיר של משתמש, כי לא בכל המכשירים מסוג מסוים צפויות להיות אותן תכונות.

כל מאפיין כלול במרחב שמות משלו, וצריך לייבא אותו בנפרד כדי להשתמש בו.

לדוגמה, כדי להשתמש בתכונת Matter On/Off ובסוג המכשיר On/Off Plug-in Unit, צריך לייבא את החבילות הבאות לאפליקציה:

import com.google.home.matter.standard.OnOff
import com.google.home.matter.standard.OnOffPluginUnitDevice

עבור סוג מכשיר למוסך(מבית חכם של Google), צריך לכלול שילוב של Matter ותכונות של Google:

import com.google.home.google.LockUnlock
import com.google.home.matter.standard.DoorLock
import com.google.home.matter.standard.GoogleGarageDevice

Android Studio כולל פונקציונליות של השלמה אוטומטית, ולרוב הוא יטפל בשמות החבילות המלאים בשבילכם כשמוסיפים שורות import לקובצי מקור בפרויקט. עם זאת, שמות החבילות לא עקביים בכל סוגי המכשירים והמאפיינים. כדי לוודא מה שם החבילה הנכון לכל DeviceType או Trait, אפשר לעיין בהפניה.

רוב המאפיינים נתמכים לשימוש באוטומציות, וחלק מהמאפיינים זמינים רק לאוטומציות. פרטים נוספים זמינים במאמר תמיכה במאפייני Automation API ב-Android.

הרכב סוגי המכשירים

ממשקי ה-API של Home תומכים ברוב אשכולות האפליקציות של Matter כמאפיינים במודל הנתונים. מאפיינים שלא תואמים לשליטה במכשיר או למצבים, ולא מציעים שום תועלת למשתמשי הקצה, כמו Binding ו-Groups, לא נחשפים דרך ממשקי ה-API של Home.

מאפיינים שנגזרים מCloud-to-cloud מאפייני בית חכם בדרך כלל מקבלים את אותו השם בין Cloud-to-cloud לבין Home APIs, כמו בדוגמה של OpenClose. אחרים מיוצגים כהרחבות של מאפייני Matter, שנוצרו באמצעות הרחבות ספציפיות ליצרן Matter. התכונות האלה מגשרות על הפער בין מאפיין smart home שבו הפונקציונליות מחולקת בין Matter SDK לבין המערכת האקולוגית של Google Home. דוגמה ספציפית לכך היא סוגי המכשירים Google* שמגיעים מ-Cloud-to-cloud אבל עדיין אין להם אנלוגים של Matter.

סוגי המכשירים מורכבים מ-Traits ממקור אחד או משני המקורות, Matter או Cloud-to-cloud.

לדוגמה, סוג המכשיר Fan מורכב מ- וכולל שלושה מאפיינים:

  • מאפיין Identify Matter מספק את כל הפונקציונליות של מאפיין Matter Identify.
  • מאפיין FanControl Matter מספק את כל הפונקציונליות של מאפיין Matter FanControl
  • מאפיין Google‏ ExtendedFanControl מספק את כל הפונקציונליות של מאפיין Google‏ smart home FanSpeed שלא נכללת במאפיין FanControl Matter

ההרכב הזה של מאפיינים מספק מודל גמיש לפונקציונליות מלאה של סוג המכשיר, ומבצע הפשטה של מודלים בסיסיים של נתונים ב-smart home.