056446dfed
* storage: added global #defines for /int, /ext & /any * storage: introduced PATH_EXT, PATH_INT& PATH_ANY macros * core apps: moved hardcoded config files names to separate headers; prefixed them with "."; updater: added file name migration to new naming convention on backup extraction * storage: fixed storage_merge_recursive handling of complex directory structures; storage_move_to_sd: changed data migration logic to all non-dot files & all folders * core: added macro aliases for core record names * Bumped protobuf commit pointer * storage: reserved 5 pages in /int; denying write&creation of non-dot files when running out of free space Co-authored-by: あく <alleteam@gmail.com>
68 lines
2.3 KiB
C
68 lines
2.3 KiB
C
#include <furi.h>
|
|
#include <furi_hal.h>
|
|
|
|
#include <gui/gui.h>
|
|
#include <input/input.h>
|
|
#include <notification/notification_messages.h>
|
|
|
|
void vibro_test_draw_callback(Canvas* canvas, void* ctx) {
|
|
UNUSED(ctx);
|
|
canvas_clear(canvas);
|
|
canvas_set_font(canvas, FontPrimary);
|
|
canvas_draw_str(canvas, 2, 10, "Vibro application");
|
|
canvas_set_font(canvas, FontSecondary);
|
|
canvas_draw_str(canvas, 2, 22, "Press OK turns on vibro");
|
|
canvas_set_font(canvas, FontSecondary);
|
|
canvas_draw_str(canvas, 2, 34, "Release OK turns off vibro");
|
|
}
|
|
|
|
void vibro_test_input_callback(InputEvent* input_event, void* ctx) {
|
|
furi_assert(ctx);
|
|
FuriMessageQueue* event_queue = ctx;
|
|
furi_message_queue_put(event_queue, input_event, FuriWaitForever);
|
|
}
|
|
|
|
int32_t vibro_test_app(void* p) {
|
|
UNUSED(p);
|
|
FuriMessageQueue* event_queue = furi_message_queue_alloc(8, sizeof(InputEvent));
|
|
|
|
// Configure view port
|
|
ViewPort* view_port = view_port_alloc();
|
|
view_port_draw_callback_set(view_port, vibro_test_draw_callback, NULL);
|
|
view_port_input_callback_set(view_port, vibro_test_input_callback, event_queue);
|
|
|
|
// Register view port in GUI
|
|
Gui* gui = furi_record_open(RECORD_GUI);
|
|
gui_add_view_port(gui, view_port, GuiLayerFullscreen);
|
|
|
|
NotificationApp* notification = furi_record_open(RECORD_NOTIFICATION);
|
|
|
|
InputEvent event;
|
|
|
|
while(furi_message_queue_get(event_queue, &event, FuriWaitForever) == FuriStatusOk) {
|
|
if(event.type == InputTypeShort && event.key == InputKeyBack) {
|
|
notification_message(notification, &sequence_reset_vibro);
|
|
notification_message(notification, &sequence_reset_green);
|
|
break;
|
|
}
|
|
if(event.key == InputKeyOk) {
|
|
if(event.type == InputTypePress) {
|
|
notification_message(notification, &sequence_set_vibro_on);
|
|
notification_message(notification, &sequence_set_green_255);
|
|
} else if(event.type == InputTypeRelease) {
|
|
notification_message(notification, &sequence_reset_vibro);
|
|
notification_message(notification, &sequence_reset_green);
|
|
}
|
|
}
|
|
}
|
|
|
|
gui_remove_view_port(gui, view_port);
|
|
view_port_free(view_port);
|
|
furi_message_queue_free(event_queue);
|
|
|
|
furi_record_close(RECORD_NOTIFICATION);
|
|
furi_record_close(RECORD_GUI);
|
|
|
|
return 0;
|
|
}
|