mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-11 20:28:54 +00:00
68a3f6b4b7
* Add F5 target, lp5562 driver and api-hal-light. Update api-usage, switch to F5 by default. * API HAL: add i2c and hardware version api. Dolphin: show hardware version. * OTP version generator and flashing utility. * Assets script: fix code formatting * Backport F5 changes to F4 * F4: disable insomnia, prevent damage to BLE RX path * F5 HAL API Light: remove magic delay to fix magic BLE * Dolphin: HW target validation on start * invert RSSI indication in sub-1 * API HAL: rename board to body in version api * Gpio tester: detach and release viewport on exit Co-authored-by: aanper <mail@s3f.ru>
178 lines
6.8 KiB
C
178 lines
6.8 KiB
C
#include "dolphin_i.h"
|
|
|
|
bool dolphin_view_first_start_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
if(event->type == InputTypeShort) {
|
|
if(event->key == InputKeyLeft) {
|
|
with_view_model(
|
|
dolphin->idle_view_first_start, (DolphinViewFirstStartModel * model) {
|
|
if(model->page > 0) model->page--;
|
|
return true;
|
|
});
|
|
} else if(event->key == InputKeyRight) {
|
|
uint32_t page;
|
|
with_view_model(
|
|
dolphin->idle_view_first_start, (DolphinViewFirstStartModel * model) {
|
|
page = ++model->page;
|
|
return true;
|
|
});
|
|
if(page > 8) {
|
|
dolphin_save(dolphin);
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
}
|
|
}
|
|
}
|
|
// All events consumed
|
|
return true;
|
|
}
|
|
|
|
bool dolphin_view_idle_main_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
|
|
if(event->type == InputTypeShort) {
|
|
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, DolphinViewIdleUp);
|
|
} else if(event->key == InputKeyDown) {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleDown);
|
|
}
|
|
}
|
|
// All events consumed
|
|
return true;
|
|
}
|
|
|
|
bool dolphin_view_idle_up_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
|
|
if(event->type != InputTypeShort) return false;
|
|
|
|
if(event->key == InputKeyLeft) {
|
|
dolphin_deed(dolphin, DolphinDeedWrong);
|
|
} else if(event->key == InputKeyRight) {
|
|
dolphin_deed(dolphin, DolphinDeedIButtonRead);
|
|
} else if(event->key == InputKeyOk) {
|
|
dolphin_save(dolphin);
|
|
} else {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
Dolphin* dolphin_alloc() {
|
|
Dolphin* dolphin = furi_alloc(sizeof(Dolphin));
|
|
// Message queue
|
|
dolphin->event_queue = osMessageQueueNew(8, sizeof(DolphinEvent), NULL);
|
|
furi_check(dolphin->event_queue);
|
|
// State
|
|
dolphin->state = dolphin_state_alloc();
|
|
// Menu
|
|
dolphin->menu_vm = furi_record_open("menu");
|
|
// 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);
|
|
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
|
|
dolphin->idle_view_up = view_alloc();
|
|
view_set_context(dolphin->idle_view_up, dolphin);
|
|
view_allocate_model(
|
|
dolphin->idle_view_up, ViewModelTypeLockFree, sizeof(DolphinViewIdleUpModel));
|
|
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);
|
|
view_dispatcher_add_view(
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleUp, dolphin->idle_view_up);
|
|
// 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);
|
|
view_dispatcher_add_view(
|
|
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);
|
|
|
|
return dolphin;
|
|
}
|
|
|
|
void dolphin_save(Dolphin* dolphin) {
|
|
furi_assert(dolphin);
|
|
DolphinEvent event;
|
|
event.type = DolphinEventTypeSave;
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
}
|
|
|
|
void dolphin_deed(Dolphin* dolphin, DolphinDeed deed) {
|
|
furi_assert(dolphin);
|
|
DolphinEvent event;
|
|
event.type = DolphinEventTypeDeed;
|
|
event.deed = deed;
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
}
|
|
|
|
int32_t dolphin_task() {
|
|
Dolphin* dolphin = dolphin_alloc();
|
|
|
|
Gui* gui = furi_record_open("gui");
|
|
view_dispatcher_attach_to_gui(dolphin->idle_view_dispatcher, gui, ViewDispatcherTypeWindow);
|
|
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);
|
|
}
|
|
with_view_model(
|
|
dolphin->idle_view_up, (DolphinViewIdleUpModel * model) {
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
|
return true;
|
|
});
|
|
|
|
furi_record_create("dolphin", dolphin);
|
|
|
|
if(!api_hal_version_do_i_belong_here()) {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewHwMismatch);
|
|
}
|
|
|
|
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);
|
|
with_view_model(
|
|
dolphin->idle_view_up, (DolphinViewIdleUpModel * model) {
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
|
return true;
|
|
});
|
|
} else if(event.type == DolphinEventTypeSave) {
|
|
dolphin_state_save(dolphin->state);
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|