Cechy, których można używać po skonfigurowaniu urządzenia:
Cecha OtaSoftwareUpdateRequestor
Ta cecha zapewnia interfejs do monitorowania aktualizacji oprogramowania OTA na urządzeniu z kamerą. Po skonfigurowaniu kamera rozpoczyna aktualizację i zgłasza jej stan aplikacji. Gdy aplikacja otrzyma informację, że aktualizacja oprogramowania została zakończona, kamera może rozpocząć transmisję na żywo.
Poniższy przykładowy kod i wyjaśnienie pokazują, jak można używać tej cechy.
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
}
}
Limit czasu:
withTimeoutwymusza maksymalny czas trwania (OTA_TIMEOUT_MS) procesu monitorowania. Jeśli aktualizacja nie zostanie ukończona w tym czasie, nastąpi przekroczenie limitu czasu.Obserwowanie zmian cech: operator
.distinctUntilChanged()zapewnia, że kolejny kod w łańcuchu będzie reagować tylko wtedy, gdy stan cechy faktycznie się zmieni, co jest bardziej wydajne niż ciągłe odpytywanie.Przetwarzanie do momentu zakończenia: operator
.transformWhilekontynuuje przetwarzanie aktualizacji, dopókiupdateStateOTA nie osiągnie stanu końcowego (np. powodzenie lub niepowodzenie).Zbieranie stanu: przy każdej zmianie stanu wykonywany jest blok
.collect, aby zaktualizować zmienneupdateStateiupdateStateProgresso najnowsze wartości z cechy.
Więcej informacji znajdziesz w dokumentacji cechy
OtaSoftwareUpdateRequestor.
Cecha ConfigurationDone
Ta cecha nie jest wymagana do aktywacji kamery, ale umożliwia aplikacji śledzenie, kiedy urządzenie jest w pełni skonfigurowane i gotowe do użycia, przez ustawienie atrybutu AppConfigurationComplete na true.
Tej cechy należy używać po cesze OtaSoftwareUpdateRequestor.
device.trait(ConfigurationDone).first().update { setAppConfigurationComplete(true) }