|
|
@@ -16,7 +16,6 @@
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
*/
|
|
|
#include "unitemp.h"
|
|
|
-#include "interfaces/SingleWireSensor.h"
|
|
|
#include "Sensors.h"
|
|
|
#include "./views/UnitempViews.h"
|
|
|
|
|
|
@@ -220,16 +219,12 @@ bool unitemp_loadSettings(void) {
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
-static void unitemp_sensors_update_callback(void* context) {
|
|
|
- Unitemp* app = context;
|
|
|
- if(!app->processing) {
|
|
|
- view_dispatcher_stop(app->view_dispatcher);
|
|
|
- return;
|
|
|
- }
|
|
|
- if(app->sensors_ready) {
|
|
|
+static void view_dispatcher_tick_event_callback(void* context) {
|
|
|
+ UNUSED(context);
|
|
|
+
|
|
|
+ if((app->sensors_ready) && (app->sensors_update)) {
|
|
|
unitemp_sensors_updateValues();
|
|
|
}
|
|
|
- view_port_update(app->view_port);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -241,8 +236,8 @@ static void unitemp_sensors_update_callback(void* context) {
|
|
|
static bool unitemp_alloc(void) {
|
|
|
//Выделение памяти под данные приложения
|
|
|
app = malloc(sizeof(Unitemp));
|
|
|
- //Разрешение работы приложения
|
|
|
- app->processing = true;
|
|
|
+
|
|
|
+ app->sensors_ready = false;
|
|
|
|
|
|
//Открытие хранилища (?)
|
|
|
app->storage = furi_record_open(RECORD_STORAGE);
|
|
|
@@ -258,6 +253,7 @@ static bool unitemp_alloc(void) {
|
|
|
app->settings.heat_index = false;
|
|
|
|
|
|
app->gui = furi_record_open(RECORD_GUI);
|
|
|
+
|
|
|
//Диспетчер окон
|
|
|
app->view_dispatcher = view_dispatcher_alloc();
|
|
|
|
|
|
@@ -288,6 +284,9 @@ static bool unitemp_alloc(void) {
|
|
|
|
|
|
view_dispatcher_add_view(app->view_dispatcher, UnitempViewPopup, popup_get_view(app->popup));
|
|
|
|
|
|
+ view_dispatcher_set_tick_event_callback(
|
|
|
+ app->view_dispatcher, view_dispatcher_tick_event_callback, furi_ms_to_ticks(100));
|
|
|
+
|
|
|
view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen);
|
|
|
|
|
|
return true;
|
|
|
@@ -349,14 +348,18 @@ int32_t unitemp_app() {
|
|
|
|
|
|
//Загрузка настроек из SD-карты
|
|
|
unitemp_loadSettings();
|
|
|
+
|
|
|
//Применение настроек
|
|
|
if(app->settings.infinityBacklight == true) {
|
|
|
//Постоянное свечение подсветки
|
|
|
notification_message(app->notifications, &sequence_display_backlight_enforce_on);
|
|
|
}
|
|
|
+
|
|
|
app->settings.lastOTGState = furi_hal_power_is_otg_enabled();
|
|
|
+
|
|
|
//Загрузка датчиков из SD-карты
|
|
|
unitemp_sensors_load();
|
|
|
+
|
|
|
//Инициализация датчиков
|
|
|
unitemp_sensors_init();
|
|
|
|
|
|
@@ -366,11 +369,14 @@ int32_t unitemp_app() {
|
|
|
|
|
|
//Деинициализация датчиков
|
|
|
unitemp_sensors_deInit();
|
|
|
+
|
|
|
//Автоматическое управление подсветкой
|
|
|
if(app->settings.infinityBacklight == true)
|
|
|
notification_message(app->notifications, &sequence_display_backlight_enforce_auto);
|
|
|
+
|
|
|
//Освобождение памяти
|
|
|
unitemp_free();
|
|
|
+
|
|
|
//Выход
|
|
|
return 0;
|
|
|
}
|