מאפיינים של צירוף מצלמות לאחר ההפעלה

אלה התכונות שאפשר להשתמש בהן אחרי הפעלת המכשיר:

מאפיין OtaSoftwareUpdateRequestor

המאפיין הזה מספק ממשק למעקב אחרי עדכון תוכנה OTA במצלמה. אחרי ההפעלה, המצלמה מתחילה את העדכון ומדווחת על המצב שלה לאפליקציה. כשהאפליקציה מקבלת את הסטטוס שהעדכון הסתיים, המצלמה יכולה להתחיל בשידור חי.

בדוגמת הקוד הבאה ובתיאור שלה אפשר לראות איך להשתמש בתכונה.

withTimeout(OTA_TIMEOUT_MS) {
  device.type(OtaRequestorDevice)
    .mapNotNull { it?.trait(OtaSoftwareUpdateRequestor) }
    .distinctUntilChanged()
    .transformWhile { trait ->
      emit(trait)
      !isTerminalState(trait.updateState)
    }
    .collect { trait ->
      updateState = trait.updateState
      updateStateProgress = trait.updateStateProgress
    }
}
  • זמן קצוב לתפוגה: withTimeout מגדיר משך זמן מקסימלי (OTA_TIMEOUT_MS) לתהליך הניטור. אם העדכון לא יושלם בפרק הזמן הזה, הוא יפסיק לפעול.

  • מעקב אחרי שינויים במאפיינים: האופרטור .distinctUntilChanged() מוודא שהקוד הבא בשרשרת יגיב רק כשמצב המאפיין משתנה בפועל, ולכן הוא יעיל יותר מסקר קבוע.

  • עיבוד עד לסיום: האופרטור .transformWhile ממשיך לעבד עדכונים כל עוד ה-OTA updateState לא נמצא במצב סופי (כמו הצלחה או כישלון).

  • סטטוס האיסוף: בכל שינוי במצב, הבלוק .collect מופעל כדי לעדכן את המשתנים updateState ו-updateStateProgress עם הערכים האחרונים מהמאפיין.

מידע נוסף זמין במאמר בנושא OtaSoftwareUpdateRequestor.

מאפיין ConfigurationDone

התכונה הזו לא נדרשת להפעלת המצלמה, אבל היא מאפשרת לאפליקציה לעקוב אחרי השלמת ההגדרה של המכשיר והפיכתו לשימושי, על ידי הגדרת מאפיין AppConfigurationComplete לערך true. צריך להשתמש בתכונה הזו אחרי התכונה OtaSoftwareUpdateRequestor.

device.trait(ConfigurationDone).first().update { setAppConfigurationComplete(true) }