2020-12-18 20:15:29 +00:00
|
|
|
#include "dolphin_i.h"
|
2021-03-25 17:48:58 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
// temporary main screen animation managment
|
|
|
|
void dolphin_scene_handler_set_scene(Dolphin* dolphin, IconName icon) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_main, (DolphinViewMainModel * model) {
|
|
|
|
model->animation = assets_icons_get(icon);
|
|
|
|
icon_start_animation(model->animation);
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
void dolphin_scene_handler_switch_scene(Dolphin* dolphin) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_main, (DolphinViewMainModel * model) {
|
|
|
|
if(icon_is_last_frame(model->animation)) {
|
|
|
|
model->animation = assets_icons_get(idle_scenes[model->scene_num]);
|
|
|
|
icon_start_animation(model->animation);
|
|
|
|
model->scene_num = random() % sizeof(idle_scenes);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
}
|
2020-12-18 20:15:29 +00:00
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
bool dolphin_view_first_start_input(InputEvent* event, void* context) {
|
|
|
|
furi_assert(event);
|
|
|
|
furi_assert(context);
|
2020-12-18 20:15:29 +00:00
|
|
|
Dolphin* dolphin = context;
|
2021-02-10 08:56:05 +00:00
|
|
|
if(event->type == InputTypeShort) {
|
|
|
|
if(event->key == InputKeyLeft) {
|
2021-02-03 09:52:54 +00:00
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_first_start, (DolphinViewFirstStartModel * model) {
|
|
|
|
if(model->page > 0) model->page--;
|
2021-02-10 09:06:29 +00:00
|
|
|
return true;
|
2021-02-03 09:52:54 +00:00
|
|
|
});
|
2021-02-10 08:56:05 +00:00
|
|
|
} else if(event->key == InputKeyRight) {
|
2021-01-08 04:42:48 +00:00
|
|
|
uint32_t page;
|
|
|
|
with_view_model(
|
2021-02-10 09:06:29 +00:00
|
|
|
dolphin->idle_view_first_start, (DolphinViewFirstStartModel * model) {
|
|
|
|
page = ++model->page;
|
|
|
|
return true;
|
|
|
|
});
|
2021-01-08 04:42:48 +00:00
|
|
|
if(page > 8) {
|
|
|
|
dolphin_save(dolphin);
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
}
|
|
|
|
}
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
2021-01-08 04:42:48 +00:00
|
|
|
// All events consumed
|
|
|
|
return true;
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
bool dolphin_view_idle_main_input(InputEvent* event, void* context) {
|
|
|
|
furi_assert(event);
|
|
|
|
furi_assert(context);
|
|
|
|
Dolphin* dolphin = context;
|
2020-12-18 20:15:29 +00:00
|
|
|
|
2021-02-10 08:56:05 +00:00
|
|
|
if(event->type == InputTypeShort) {
|
2021-03-25 17:48:58 +00:00
|
|
|
if(!dolphin->locked) {
|
|
|
|
if(event->key == InputKeyOk) {
|
|
|
|
with_value_mutex(
|
|
|
|
dolphin->menu_vm, (Menu * menu) { menu_ok(menu); });
|
|
|
|
} else if(event->key == InputKeyUp) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewLockMenu);
|
|
|
|
} else if(event->key == InputKeyLeft) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleUp);
|
|
|
|
} else if(event->key == InputKeyRight) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMeta);
|
|
|
|
} else if(event->key == InputKeyDown) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleDown);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(event->key == InputKeyBack) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if(event->key == InputKeyBack) {
|
|
|
|
dolphin->lock_count++;
|
|
|
|
if(dolphin->lock_count == 3) {
|
|
|
|
dolphin->locked = false;
|
|
|
|
dolphin->lock_count = 0;
|
|
|
|
view_dispatcher_switch_to_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
view_port_enabled_set(dolphin->lock_viewport, false);
|
|
|
|
}
|
|
|
|
}
|
2021-01-08 04:42:48 +00:00
|
|
|
}
|
2021-03-25 17:48:58 +00:00
|
|
|
dolphin_scene_handler_switch_scene(dolphin);
|
2021-01-08 04:42:48 +00:00
|
|
|
}
|
2021-03-25 17:48:58 +00:00
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
// All events consumed
|
|
|
|
return true;
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
|
|
|
|
2021-02-18 12:49:32 +00:00
|
|
|
bool dolphin_view_idle_up_input(InputEvent* event, void* context) {
|
2021-01-08 04:42:48 +00:00
|
|
|
furi_assert(event);
|
|
|
|
furi_assert(context);
|
2020-12-18 20:15:29 +00:00
|
|
|
Dolphin* dolphin = context;
|
|
|
|
|
2021-02-10 08:56:05 +00:00
|
|
|
if(event->type != InputTypeShort) return false;
|
2020-12-18 20:15:29 +00:00
|
|
|
|
2021-02-10 08:56:05 +00:00
|
|
|
if(event->key == InputKeyLeft) {
|
2020-12-18 20:15:29 +00:00
|
|
|
dolphin_deed(dolphin, DolphinDeedWrong);
|
2021-02-10 08:56:05 +00:00
|
|
|
} else if(event->key == InputKeyRight) {
|
2021-01-08 04:42:48 +00:00
|
|
|
dolphin_deed(dolphin, DolphinDeedIButtonRead);
|
2021-02-10 08:56:05 +00:00
|
|
|
} else if(event->key == InputKeyOk) {
|
2021-01-08 04:42:48 +00:00
|
|
|
dolphin_save(dolphin);
|
|
|
|
} else {
|
|
|
|
return false;
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
return true;
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
|
|
|
|
2021-03-25 17:48:58 +00:00
|
|
|
static void lock_menu_callback(void* context, uint8_t index) {
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
switch(index) {
|
|
|
|
case 0:
|
|
|
|
dolphin->locked = true;
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
view_port_enabled_set(dolphin->lock_viewport, true);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void meta_menu_callback(void* context, uint8_t index) {
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
switch(index) {
|
|
|
|
case 0:
|
|
|
|
view_port_enabled_set(dolphin->passport, true);
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void lock_icon_callback(Canvas* canvas, void* context) {
|
|
|
|
assert(context);
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
canvas_draw_icon(canvas, 0, 0, dolphin->lock_icon);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void draw_passport_callback(Canvas* canvas, void* context) {
|
|
|
|
assert(context);
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
|
|
|
|
char level[20];
|
|
|
|
uint32_t current_level = dolphin_state_get_level(dolphin->state);
|
|
|
|
uint32_t prev_cap = dolphin_state_xp_to_levelup(dolphin->state, current_level - 1, false);
|
|
|
|
uint32_t exp = (dolphin_state_xp_to_levelup(dolphin->state, current_level, true) * 63) /
|
|
|
|
(dolphin_state_xp_to_levelup(dolphin->state, current_level, false) - prev_cap);
|
|
|
|
|
|
|
|
canvas_clear(canvas);
|
|
|
|
|
|
|
|
// multipass
|
|
|
|
canvas_draw_icon_name(canvas, 0, 0, I_PassportLeft_6x47);
|
|
|
|
canvas_draw_icon_name(canvas, 0, 47, I_PassportBottom_128x17);
|
|
|
|
canvas_draw_line(canvas, 6, 0, 125, 0);
|
|
|
|
canvas_draw_line(canvas, 127, 2, 127, 47);
|
|
|
|
canvas_draw_dot(canvas, 126, 1);
|
|
|
|
|
|
|
|
//portrait frame
|
|
|
|
canvas_draw_line(canvas, 9, 6, 9, 53);
|
|
|
|
canvas_draw_line(canvas, 10, 5, 52, 5);
|
|
|
|
canvas_draw_line(canvas, 55, 8, 55, 53);
|
|
|
|
canvas_draw_line(canvas, 10, 54, 54, 54);
|
|
|
|
canvas_draw_line(canvas, 53, 5, 55, 7);
|
|
|
|
|
|
|
|
// portrait
|
|
|
|
canvas_draw_icon_name(canvas, 14, 11, I_DolphinOkay_41x43);
|
|
|
|
canvas_draw_line(canvas, 59, 18, 124, 18);
|
|
|
|
canvas_draw_line(canvas, 59, 31, 124, 31);
|
|
|
|
canvas_draw_line(canvas, 59, 44, 124, 44);
|
|
|
|
|
|
|
|
canvas_draw_str(canvas, 59, 15, api_hal_version_get_name_ptr());
|
|
|
|
canvas_draw_str(canvas, 59, 28, "Mood: OK");
|
|
|
|
|
|
|
|
snprintf(level, 20, "Level: %ld", current_level);
|
|
|
|
|
|
|
|
canvas_draw_str(canvas, 59, 41, level);
|
|
|
|
canvas_set_color(canvas, ColorWhite);
|
|
|
|
canvas_draw_box(canvas, 123 - exp, 48, exp + 1, 6);
|
|
|
|
canvas_set_color(canvas, ColorBlack);
|
|
|
|
canvas_draw_line(canvas, 123 - exp, 48, 123 - exp, 54);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void passport_input_callback(InputEvent* event, void* context) {
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
if(event->type == InputTypeShort) {
|
|
|
|
if(event->key == InputKeyBack) {
|
|
|
|
view_port_enabled_set(dolphin->passport, false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool dolphin_view_lockmenu_input(InputEvent* event, void* context) {
|
|
|
|
furi_assert(event);
|
|
|
|
furi_assert(context);
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
|
|
|
|
if(event->type != InputTypeShort) return false;
|
|
|
|
|
|
|
|
if(event->key == InputKeyUp) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->view_lockmenu, (DolphinViewMenuModel * model) {
|
|
|
|
if(model->idx <= 0)
|
|
|
|
model->idx = 0;
|
|
|
|
else
|
|
|
|
--model->idx;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyDown) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->view_lockmenu, (DolphinViewMenuModel * model) {
|
|
|
|
if(model->idx >= 2)
|
|
|
|
model->idx = 2;
|
|
|
|
else
|
|
|
|
++model->idx;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyOk) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->view_lockmenu, (DolphinViewMenuModel * model) {
|
|
|
|
lock_menu_callback(context, model->idx);
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyBack) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->view_lockmenu, (DolphinViewMenuModel * model) {
|
|
|
|
model->idx = 0;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
|
|
|
|
if(random() % 100 > 50)
|
|
|
|
dolphin_scene_handler_set_scene(dolphin, idle_scenes[random() % sizeof(idle_scenes)]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool dolphin_view_idle_meta_input(InputEvent* event, void* context) {
|
|
|
|
furi_assert(event);
|
|
|
|
furi_assert(context);
|
|
|
|
Dolphin* dolphin = context;
|
|
|
|
|
|
|
|
if(event->type != InputTypeShort) return false;
|
|
|
|
|
|
|
|
if(event->key == InputKeyLeft) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_meta, (DolphinViewMenuModel * model) {
|
|
|
|
if(model->idx <= 0)
|
|
|
|
model->idx = 0;
|
|
|
|
else
|
|
|
|
--model->idx;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyRight) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_meta, (DolphinViewMenuModel * model) {
|
|
|
|
if(model->idx >= 2)
|
|
|
|
model->idx = 2;
|
|
|
|
else
|
|
|
|
++model->idx;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyOk) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_meta, (DolphinViewMenuModel * model) {
|
|
|
|
meta_menu_callback(context, model->idx);
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
} else if(event->key == InputKeyBack) {
|
|
|
|
with_view_model(
|
|
|
|
dolphin->idle_view_meta, (DolphinViewMenuModel * model) {
|
|
|
|
model->idx = 0;
|
|
|
|
return true;
|
|
|
|
});
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
if(random() % 100 > 50)
|
|
|
|
dolphin_scene_handler_set_scene(dolphin, idle_scenes[random() % sizeof(idle_scenes)]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2020-12-18 20:15:29 +00:00
|
|
|
Dolphin* dolphin_alloc() {
|
|
|
|
Dolphin* dolphin = furi_alloc(sizeof(Dolphin));
|
2021-01-08 04:42:48 +00:00
|
|
|
// Message queue
|
|
|
|
dolphin->event_queue = osMessageQueueNew(8, sizeof(DolphinEvent), NULL);
|
|
|
|
furi_check(dolphin->event_queue);
|
|
|
|
// State
|
|
|
|
dolphin->state = dolphin_state_alloc();
|
|
|
|
// Menu
|
[FL-140] Core api dynamic records (#296)
* SYSTEM: tickless mode with deep sleep.
* Move FreeRTOS ticks to lptim2
* API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source.
* API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode.
* NFC: support for tickless mode.
* API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications.
* BLE: prevent sleep while core2 starting
* HAL: nap while in insomnia mode
* init records work
* try to implement record delete
* tests and flapp
* flapp subsystem
* new core functions to get app stat, simplify core code
* fix thread termination
* add strdup to core
* fix tests
* Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage
* Refactoring: update furi record api usage, cleanup code
* Fix broken merge for freertos apps
* Core, Target: fix compilation warnings
* Drop firmware target local
* HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode.
* SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial.
* delete old app example-ipc
* delete old app fatfs list
* fix strobe app, add input header
* delete old display driver
* comment old app qr-code
* fix sd-card test, add forced widget update
* remove unused new core test
* increase heap to 128k
* comment and assert old core tests
* fix syntax
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2021-01-20 16:09:26 +00:00
|
|
|
dolphin->menu_vm = furi_record_open("menu");
|
2021-01-08 04:42:48 +00:00
|
|
|
// GUI
|
|
|
|
dolphin->idle_view_dispatcher = view_dispatcher_alloc();
|
|
|
|
// First start View
|
|
|
|
dolphin->idle_view_first_start = view_alloc();
|
|
|
|
view_allocate_model(
|
|
|
|
dolphin->idle_view_first_start, ViewModelTypeLockFree, sizeof(DolphinViewFirstStartModel));
|
|
|
|
view_set_context(dolphin->idle_view_first_start, dolphin);
|
|
|
|
view_set_draw_callback(dolphin->idle_view_first_start, dolphin_view_first_start_draw);
|
|
|
|
view_set_input_callback(dolphin->idle_view_first_start, dolphin_view_first_start_input);
|
|
|
|
view_dispatcher_add_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewFirstStart, dolphin->idle_view_first_start);
|
|
|
|
// Main Idle View
|
|
|
|
dolphin->idle_view_main = view_alloc();
|
|
|
|
view_set_context(dolphin->idle_view_main, dolphin);
|
2021-03-25 17:48:58 +00:00
|
|
|
view_allocate_model(
|
|
|
|
dolphin->idle_view_main, ViewModelTypeLockFree, sizeof(DolphinViewIdleUpModel));
|
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
view_set_draw_callback(dolphin->idle_view_main, dolphin_view_idle_main_draw);
|
|
|
|
view_set_input_callback(dolphin->idle_view_main, dolphin_view_idle_main_input);
|
|
|
|
view_dispatcher_add_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleMain, dolphin->idle_view_main);
|
|
|
|
// Stats Idle View
|
2021-02-18 12:49:32 +00:00
|
|
|
dolphin->idle_view_up = view_alloc();
|
|
|
|
view_set_context(dolphin->idle_view_up, dolphin);
|
2021-03-25 17:48:58 +00:00
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
view_allocate_model(
|
2021-03-25 17:48:58 +00:00
|
|
|
dolphin->idle_view_up, ViewModelTypeLockFree, sizeof(DolphinViewMainModel));
|
2021-02-18 12:49:32 +00:00
|
|
|
view_set_draw_callback(dolphin->idle_view_up, dolphin_view_idle_up_draw);
|
|
|
|
view_set_input_callback(dolphin->idle_view_up, dolphin_view_idle_up_input);
|
|
|
|
view_set_previous_callback(dolphin->idle_view_up, dolphin_view_idle_back);
|
2021-01-08 04:42:48 +00:00
|
|
|
view_dispatcher_add_view(
|
2021-02-18 12:49:32 +00:00
|
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleUp, dolphin->idle_view_up);
|
2021-03-25 17:48:58 +00:00
|
|
|
// Lock Menu View
|
|
|
|
dolphin->view_lockmenu = view_alloc();
|
|
|
|
view_set_context(dolphin->view_lockmenu, dolphin);
|
|
|
|
view_allocate_model(
|
|
|
|
dolphin->view_lockmenu, ViewModelTypeLockFree, sizeof(DolphinViewMenuModel));
|
|
|
|
view_set_draw_callback(dolphin->view_lockmenu, dolphin_view_lockmenu_draw);
|
|
|
|
view_set_input_callback(dolphin->view_lockmenu, dolphin_view_lockmenu_input);
|
|
|
|
view_set_previous_callback(dolphin->view_lockmenu, dolphin_view_idle_back);
|
|
|
|
view_dispatcher_add_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewLockMenu, dolphin->view_lockmenu);
|
|
|
|
// Meta View
|
|
|
|
dolphin->idle_view_meta = view_alloc();
|
|
|
|
view_set_context(dolphin->idle_view_meta, dolphin);
|
|
|
|
view_allocate_model(
|
|
|
|
dolphin->idle_view_meta, ViewModelTypeLockFree, sizeof(DolphinViewMenuModel));
|
|
|
|
view_set_draw_callback(dolphin->idle_view_meta, dolphin_view_idle_meta_draw);
|
|
|
|
view_set_input_callback(dolphin->idle_view_meta, dolphin_view_idle_meta_input);
|
|
|
|
view_set_previous_callback(dolphin->idle_view_meta, dolphin_view_idle_back);
|
|
|
|
view_dispatcher_add_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleMeta, dolphin->idle_view_meta);
|
2021-02-18 12:49:32 +00:00
|
|
|
// Down Idle View
|
|
|
|
dolphin->idle_view_down = view_alloc();
|
|
|
|
view_set_draw_callback(dolphin->idle_view_down, dolphin_view_idle_down_draw);
|
|
|
|
view_set_previous_callback(dolphin->idle_view_down, dolphin_view_idle_back);
|
2021-01-08 04:42:48 +00:00
|
|
|
view_dispatcher_add_view(
|
2021-02-18 12:49:32 +00:00
|
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleDown, dolphin->idle_view_down);
|
|
|
|
// HW Mismatch
|
|
|
|
dolphin->view_hw_mismatch = view_alloc();
|
|
|
|
view_set_draw_callback(dolphin->view_hw_mismatch, dolphin_view_hw_mismatch_draw);
|
|
|
|
view_set_previous_callback(dolphin->view_hw_mismatch, dolphin_view_idle_back);
|
|
|
|
view_dispatcher_add_view(
|
|
|
|
dolphin->idle_view_dispatcher, DolphinViewHwMismatch, dolphin->view_hw_mismatch);
|
2020-12-18 20:15:29 +00:00
|
|
|
|
2021-03-25 17:48:58 +00:00
|
|
|
// Lock icon
|
|
|
|
dolphin->lock_icon = assets_icons_get(I_Lock_8x8);
|
|
|
|
dolphin->lock_viewport = view_port_alloc();
|
|
|
|
view_port_set_width(dolphin->lock_viewport, icon_get_width(dolphin->lock_icon));
|
|
|
|
view_port_draw_callback_set(dolphin->lock_viewport, lock_icon_callback, dolphin);
|
|
|
|
view_port_enabled_set(dolphin->lock_viewport, false);
|
|
|
|
|
|
|
|
// Passport
|
|
|
|
dolphin->passport = view_port_alloc();
|
|
|
|
view_port_draw_callback_set(dolphin->passport, draw_passport_callback, dolphin);
|
|
|
|
view_port_input_callback_set(dolphin->passport, passport_input_callback, dolphin);
|
|
|
|
view_port_enabled_set(dolphin->passport, false);
|
|
|
|
|
|
|
|
// Main screen animation
|
|
|
|
dolphin_scene_handler_set_scene(dolphin, idle_scenes[random() % sizeof(idle_scenes)]);
|
|
|
|
|
2020-12-18 20:15:29 +00:00
|
|
|
return dolphin;
|
|
|
|
}
|
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
void dolphin_save(Dolphin* dolphin) {
|
|
|
|
furi_assert(dolphin);
|
|
|
|
DolphinEvent event;
|
|
|
|
event.type = DolphinEventTypeSave;
|
|
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
|
|
}
|
|
|
|
|
2020-12-18 20:15:29 +00:00
|
|
|
void dolphin_deed(Dolphin* dolphin, DolphinDeed deed) {
|
2021-01-08 04:42:48 +00:00
|
|
|
furi_assert(dolphin);
|
2020-12-18 20:15:29 +00:00
|
|
|
DolphinEvent event;
|
|
|
|
event.type = DolphinEventTypeDeed;
|
|
|
|
event.deed = deed;
|
|
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
|
|
}
|
|
|
|
|
2021-02-12 17:24:34 +00:00
|
|
|
int32_t dolphin_task() {
|
2020-12-18 20:15:29 +00:00
|
|
|
Dolphin* dolphin = dolphin_alloc();
|
|
|
|
|
[FL-140] Core api dynamic records (#296)
* SYSTEM: tickless mode with deep sleep.
* Move FreeRTOS ticks to lptim2
* API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source.
* API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode.
* NFC: support for tickless mode.
* API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications.
* BLE: prevent sleep while core2 starting
* HAL: nap while in insomnia mode
* init records work
* try to implement record delete
* tests and flapp
* flapp subsystem
* new core functions to get app stat, simplify core code
* fix thread termination
* add strdup to core
* fix tests
* Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage
* Refactoring: update furi record api usage, cleanup code
* Fix broken merge for freertos apps
* Core, Target: fix compilation warnings
* Drop firmware target local
* HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode.
* SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial.
* delete old app example-ipc
* delete old app fatfs list
* fix strobe app, add input header
* delete old display driver
* comment old app qr-code
* fix sd-card test, add forced widget update
* remove unused new core test
* increase heap to 128k
* comment and assert old core tests
* fix syntax
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2021-01-20 16:09:26 +00:00
|
|
|
Gui* gui = furi_record_open("gui");
|
2021-03-25 17:48:58 +00:00
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
view_dispatcher_attach_to_gui(dolphin->idle_view_dispatcher, gui, ViewDispatcherTypeWindow);
|
2021-03-25 17:48:58 +00:00
|
|
|
gui_add_view_port(gui, dolphin->lock_viewport, GuiLayerStatusBarLeft);
|
|
|
|
|
|
|
|
gui_add_view_port(gui, dolphin->passport, GuiLayerFullscreen);
|
|
|
|
|
2021-01-08 04:42:48 +00:00
|
|
|
if(dolphin_state_load(dolphin->state)) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
|
|
} else {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewFirstStart);
|
|
|
|
}
|
FL-53: new NFC worker, A/B/F/V poll and display. (#283)
* GUI: view. Flooper-blooper fix compilation error.
* GUI: view and viewdispatcher bones
* GUI: view implementation, view models, view dispatcher
* GUI: view navigation, model refinement. Power: use view, view dispatcher.
* HAL Flash: proper page write. Dolphin: views. Power: views
* Dolphin: transition idle scree to Views
* Dolphin: input events on stats view. Format sources.
* HAL: flash erase. Dolphin: permanent state storage.
* Dolphin: first start welcome. HAL: flash operation status, errata 2.2.9 crutch.
* NFC: rewrite worker
* NFC: add support for B,F,V.
* NFC: replace rfal irq hanlder with realtime thread, more details about cards.
* Bootloader: LSE and RTS shenanigans, LED control, morse code for LSE failure error.
* F4: stop in Error_Handler
* BLE: handle working FUS, but empty radio stack.
* HAL: alive FUS is now sufficient for flash controller access
* Dolphin: update model after state load
* NFC: detect navigation
* RFAL: use osPriorityISR for isr thread
* NFC: emulation
* Bootloader: rollback incorrectly merged rename
* Dolphin: rollback incorrectly merged changes
* RFAL: remove volatile from thread attr
* RFAL: do not call platform ErrorHandler, error codes is enough
* NFC: improved error handling
* Format sources
* NFC: reset detect view model on start
* Format sources
* update codeowners
* NFC: hide last info if no card detected
2021-01-11 12:42:25 +00:00
|
|
|
with_view_model(
|
2021-02-18 12:49:32 +00:00
|
|
|
dolphin->idle_view_up, (DolphinViewIdleUpModel * model) {
|
FL-53: new NFC worker, A/B/F/V poll and display. (#283)
* GUI: view. Flooper-blooper fix compilation error.
* GUI: view and viewdispatcher bones
* GUI: view implementation, view models, view dispatcher
* GUI: view navigation, model refinement. Power: use view, view dispatcher.
* HAL Flash: proper page write. Dolphin: views. Power: views
* Dolphin: transition idle scree to Views
* Dolphin: input events on stats view. Format sources.
* HAL: flash erase. Dolphin: permanent state storage.
* Dolphin: first start welcome. HAL: flash operation status, errata 2.2.9 crutch.
* NFC: rewrite worker
* NFC: add support for B,F,V.
* NFC: replace rfal irq hanlder with realtime thread, more details about cards.
* Bootloader: LSE and RTS shenanigans, LED control, morse code for LSE failure error.
* F4: stop in Error_Handler
* BLE: handle working FUS, but empty radio stack.
* HAL: alive FUS is now sufficient for flash controller access
* Dolphin: update model after state load
* NFC: detect navigation
* RFAL: use osPriorityISR for isr thread
* NFC: emulation
* Bootloader: rollback incorrectly merged rename
* Dolphin: rollback incorrectly merged changes
* RFAL: remove volatile from thread attr
* RFAL: do not call platform ErrorHandler, error codes is enough
* NFC: improved error handling
* Format sources
* NFC: reset detect view model on start
* Format sources
* update codeowners
* NFC: hide last info if no card detected
2021-01-11 12:42:25 +00:00
|
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
2021-02-10 09:06:29 +00:00
|
|
|
return true;
|
FL-53: new NFC worker, A/B/F/V poll and display. (#283)
* GUI: view. Flooper-blooper fix compilation error.
* GUI: view and viewdispatcher bones
* GUI: view implementation, view models, view dispatcher
* GUI: view navigation, model refinement. Power: use view, view dispatcher.
* HAL Flash: proper page write. Dolphin: views. Power: views
* Dolphin: transition idle scree to Views
* Dolphin: input events on stats view. Format sources.
* HAL: flash erase. Dolphin: permanent state storage.
* Dolphin: first start welcome. HAL: flash operation status, errata 2.2.9 crutch.
* NFC: rewrite worker
* NFC: add support for B,F,V.
* NFC: replace rfal irq hanlder with realtime thread, more details about cards.
* Bootloader: LSE and RTS shenanigans, LED control, morse code for LSE failure error.
* F4: stop in Error_Handler
* BLE: handle working FUS, but empty radio stack.
* HAL: alive FUS is now sufficient for flash controller access
* Dolphin: update model after state load
* NFC: detect navigation
* RFAL: use osPriorityISR for isr thread
* NFC: emulation
* Bootloader: rollback incorrectly merged rename
* Dolphin: rollback incorrectly merged changes
* RFAL: remove volatile from thread attr
* RFAL: do not call platform ErrorHandler, error codes is enough
* NFC: improved error handling
* Format sources
* NFC: reset detect view model on start
* Format sources
* update codeowners
* NFC: hide last info if no card detected
2021-01-11 12:42:25 +00:00
|
|
|
});
|
2020-12-18 20:15:29 +00:00
|
|
|
|
[FL-140] Core api dynamic records (#296)
* SYSTEM: tickless mode with deep sleep.
* Move FreeRTOS ticks to lptim2
* API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source.
* API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode.
* NFC: support for tickless mode.
* API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications.
* BLE: prevent sleep while core2 starting
* HAL: nap while in insomnia mode
* init records work
* try to implement record delete
* tests and flapp
* flapp subsystem
* new core functions to get app stat, simplify core code
* fix thread termination
* add strdup to core
* fix tests
* Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage
* Refactoring: update furi record api usage, cleanup code
* Fix broken merge for freertos apps
* Core, Target: fix compilation warnings
* Drop firmware target local
* HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode.
* SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial.
* delete old app example-ipc
* delete old app fatfs list
* fix strobe app, add input header
* delete old display driver
* comment old app qr-code
* fix sd-card test, add forced widget update
* remove unused new core test
* increase heap to 128k
* comment and assert old core tests
* fix syntax
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
2021-01-20 16:09:26 +00:00
|
|
|
furi_record_create("dolphin", dolphin);
|
2020-12-18 20:15:29 +00:00
|
|
|
|
2021-02-18 12:49:32 +00:00
|
|
|
if(!api_hal_version_do_i_belong_here()) {
|
|
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewHwMismatch);
|
|
|
|
}
|
2020-12-18 20:15:29 +00:00
|
|
|
DolphinEvent event;
|
|
|
|
while(1) {
|
|
|
|
furi_check(osMessageQueueGet(dolphin->event_queue, &event, NULL, osWaitForever) == osOK);
|
|
|
|
if(event.type == DolphinEventTypeDeed) {
|
|
|
|
dolphin_state_on_deed(dolphin->state, event.deed);
|
2021-01-08 04:42:48 +00:00
|
|
|
with_view_model(
|
2021-02-18 12:49:32 +00:00
|
|
|
dolphin->idle_view_up, (DolphinViewIdleUpModel * model) {
|
2021-01-08 04:42:48 +00:00
|
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
2021-02-10 09:06:29 +00:00
|
|
|
return true;
|
2021-01-08 04:42:48 +00:00
|
|
|
});
|
|
|
|
} else if(event.type == DolphinEventTypeSave) {
|
|
|
|
dolphin_state_save(dolphin->state);
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|
|
|
|
}
|
2021-02-12 17:24:34 +00:00
|
|
|
return 0;
|
2020-12-18 20:15:29 +00:00
|
|
|
}
|