|
@@ -1,6 +1,5 @@
|
|
|
#include "hex_viewer.h"
|
|
#include "hex_viewer.h"
|
|
|
|
|
|
|
|
-
|
|
|
|
|
bool hex_viewer_custom_event_callback(void* context, uint32_t event) {
|
|
bool hex_viewer_custom_event_callback(void* context, uint32_t event) {
|
|
|
furi_assert(context);
|
|
furi_assert(context);
|
|
|
HexViewer* app = context;
|
|
HexViewer* app = context;
|
|
@@ -29,7 +28,7 @@ HexViewer* hex_viewer_app_alloc() {
|
|
|
app->gui = furi_record_open(RECORD_GUI);
|
|
app->gui = furi_record_open(RECORD_GUI);
|
|
|
app->storage = furi_record_open(RECORD_STORAGE);
|
|
app->storage = furi_record_open(RECORD_STORAGE);
|
|
|
app->notification = furi_record_open(RECORD_NOTIFICATION);
|
|
app->notification = furi_record_open(RECORD_NOTIFICATION);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
//Turn backlight on, believe me this makes testing your app easier
|
|
//Turn backlight on, believe me this makes testing your app easier
|
|
|
notification_message(app->notification, &sequence_display_backlight_on);
|
|
notification_message(app->notification, &sequence_display_backlight_on);
|
|
|
|
|
|
|
@@ -39,10 +38,15 @@ HexViewer* hex_viewer_app_alloc() {
|
|
|
|
|
|
|
|
app->scene_manager = scene_manager_alloc(&hex_viewer_scene_handlers, app);
|
|
app->scene_manager = scene_manager_alloc(&hex_viewer_scene_handlers, app);
|
|
|
view_dispatcher_set_event_callback_context(app->view_dispatcher, app);
|
|
view_dispatcher_set_event_callback_context(app->view_dispatcher, app);
|
|
|
- view_dispatcher_set_navigation_event_callback(app->view_dispatcher, hex_viewer_navigation_event_callback);
|
|
|
|
|
- view_dispatcher_set_tick_event_callback(app->view_dispatcher, hex_viewer_tick_event_callback, 100);
|
|
|
|
|
- view_dispatcher_set_custom_event_callback(app->view_dispatcher, hex_viewer_custom_event_callback);
|
|
|
|
|
|
|
+ view_dispatcher_set_navigation_event_callback(
|
|
|
|
|
+ app->view_dispatcher, hex_viewer_navigation_event_callback);
|
|
|
|
|
+ view_dispatcher_set_tick_event_callback(
|
|
|
|
|
+ app->view_dispatcher, hex_viewer_tick_event_callback, 100);
|
|
|
|
|
+ view_dispatcher_set_custom_event_callback(
|
|
|
|
|
+ app->view_dispatcher, hex_viewer_custom_event_callback);
|
|
|
|
|
+
|
|
|
app->submenu = submenu_alloc();
|
|
app->submenu = submenu_alloc();
|
|
|
|
|
+ app->text_input = text_input_alloc();
|
|
|
|
|
|
|
|
// Set defaults, in case no config loaded
|
|
// Set defaults, in case no config loaded
|
|
|
app->haptic = 1;
|
|
app->haptic = 1;
|
|
@@ -57,18 +61,32 @@ HexViewer* hex_viewer_app_alloc() {
|
|
|
// Load configs
|
|
// Load configs
|
|
|
hex_viewer_read_settings(app);
|
|
hex_viewer_read_settings(app);
|
|
|
|
|
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdMenu, submenu_get_view(app->submenu));
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher, HexViewerViewIdMenu, submenu_get_view(app->submenu));
|
|
|
app->hex_viewer_startscreen = hex_viewer_startscreen_alloc();
|
|
app->hex_viewer_startscreen = hex_viewer_startscreen_alloc();
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdStartscreen, hex_viewer_startscreen_get_view(app->hex_viewer_startscreen));
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher,
|
|
|
|
|
+ HexViewerViewIdStartscreen,
|
|
|
|
|
+ hex_viewer_startscreen_get_view(app->hex_viewer_startscreen));
|
|
|
app->hex_viewer_scene_1 = hex_viewer_scene_1_alloc();
|
|
app->hex_viewer_scene_1 = hex_viewer_scene_1_alloc();
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdScene1, hex_viewer_scene_1_get_view(app->hex_viewer_scene_1));
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher,
|
|
|
|
|
+ HexViewerViewIdScene1,
|
|
|
|
|
+ hex_viewer_scene_1_get_view(app->hex_viewer_scene_1));
|
|
|
app->hex_viewer_scene_2 = hex_viewer_scene_2_alloc();
|
|
app->hex_viewer_scene_2 = hex_viewer_scene_2_alloc();
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdScene2, hex_viewer_scene_2_get_view(app->hex_viewer_scene_2));
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher,
|
|
|
|
|
+ HexViewerViewIdScene2,
|
|
|
|
|
+ hex_viewer_scene_2_get_view(app->hex_viewer_scene_2));
|
|
|
app->button_menu = button_menu_alloc();
|
|
app->button_menu = button_menu_alloc();
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdScene3, button_menu_get_view(app->button_menu));
|
|
|
|
|
-
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher, HexViewerViewIdScene3, button_menu_get_view(app->button_menu));
|
|
|
|
|
+
|
|
|
app->variable_item_list = variable_item_list_alloc();
|
|
app->variable_item_list = variable_item_list_alloc();
|
|
|
- view_dispatcher_add_view(app->view_dispatcher, HexViewerViewIdSettings, variable_item_list_get_view(app->variable_item_list));
|
|
|
|
|
|
|
+ view_dispatcher_add_view(
|
|
|
|
|
+ app->view_dispatcher,
|
|
|
|
|
+ HexViewerViewIdSettings,
|
|
|
|
|
+ variable_item_list_get_view(app->variable_item_list));
|
|
|
|
|
|
|
|
//End Scene Additions
|
|
//End Scene Additions
|
|
|
|
|
|
|
@@ -79,7 +97,7 @@ void hex_viewer_app_free(HexViewer* app) {
|
|
|
furi_assert(app);
|
|
furi_assert(app);
|
|
|
|
|
|
|
|
if(app->model->stream) buffered_file_stream_close(app->model->stream);
|
|
if(app->model->stream) buffered_file_stream_close(app->model->stream);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
// Scene manager
|
|
// Scene manager
|
|
|
scene_manager_free(app->scene_manager);
|
|
scene_manager_free(app->scene_manager);
|
|
|
|
|
|
|
@@ -88,12 +106,14 @@ void hex_viewer_app_free(HexViewer* app) {
|
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdScene1);
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdScene1);
|
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdScene2);
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdScene2);
|
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdSettings);
|
|
view_dispatcher_remove_view(app->view_dispatcher, HexViewerViewIdSettings);
|
|
|
|
|
+
|
|
|
submenu_free(app->submenu);
|
|
submenu_free(app->submenu);
|
|
|
|
|
+ text_input_free(app->text_input);
|
|
|
|
|
|
|
|
view_dispatcher_free(app->view_dispatcher);
|
|
view_dispatcher_free(app->view_dispatcher);
|
|
|
furi_record_close(RECORD_STORAGE);
|
|
furi_record_close(RECORD_STORAGE);
|
|
|
furi_record_close(RECORD_GUI);
|
|
furi_record_close(RECORD_GUI);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
app->storage = NULL;
|
|
app->storage = NULL;
|
|
|
app->gui = NULL;
|
|
app->gui = NULL;
|
|
|
app->notification = NULL;
|
|
app->notification = NULL;
|
|
@@ -111,9 +131,9 @@ void hex_viewer_app_free(HexViewer* app) {
|
|
|
int32_t hex_viewer_app(void* p) {
|
|
int32_t hex_viewer_app(void* p) {
|
|
|
UNUSED(p);
|
|
UNUSED(p);
|
|
|
HexViewer* app = hex_viewer_app_alloc();
|
|
HexViewer* app = hex_viewer_app_alloc();
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen);
|
|
view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
scene_manager_next_scene(app->scene_manager, HexViewerSceneStartscreen);
|
|
scene_manager_next_scene(app->scene_manager, HexViewerSceneStartscreen);
|
|
|
|
|
|
|
|
furi_hal_power_suppress_charge_enter();
|
|
furi_hal_power_suppress_charge_enter();
|
|
@@ -121,12 +141,9 @@ int32_t hex_viewer_app(void* p) {
|
|
|
view_dispatcher_run(app->view_dispatcher);
|
|
view_dispatcher_run(app->view_dispatcher);
|
|
|
|
|
|
|
|
hex_viewer_save_settings(app);
|
|
hex_viewer_save_settings(app);
|
|
|
-
|
|
|
|
|
|
|
+
|
|
|
furi_hal_power_suppress_charge_exit();
|
|
furi_hal_power_suppress_charge_exit();
|
|
|
hex_viewer_app_free(app);
|
|
hex_viewer_app_free(app);
|
|
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
|
}
|
|
}
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|