From d3ff7878645569698d8a0947a3087e552eefe81c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=81=82=E3=81=8F?= Date: Mon, 14 Dec 2020 13:50:32 +0300 Subject: [PATCH] GUI: abolish API injection into instances. (#265) * GUI: abolish API injection into instances. Update usage by 3rd party apps. * GUI: update documentation. Cleanup api usage. Adjust status bar item spacing. --- applications/app-loader/app-loader.c | 18 +-- applications/applications.h | 2 - applications/bt/bt.c | 20 +-- applications/bt/bt_i.h | 11 +- .../cc1101-workaround/cc1101-workaround.cpp | 36 ++--- applications/floopper-bloopper | 2 +- applications/gpio-tester/gpio-tester.c | 18 +-- applications/gui/canvas.c | 140 ++++++------------ applications/gui/canvas.h | 93 +++++++++--- applications/gui/canvas_i.h | 27 +++- applications/gui/elements.c | 32 ++-- applications/gui/elements.h | 15 +- applications/gui/gui.c | 48 +++--- applications/gui/gui.h | 18 ++- applications/gui/icon.c | 1 - applications/gui/icon.h | 22 +++ applications/gui/icon_i.h | 8 + applications/gui/widget.c | 10 +- applications/gui/widget.h | 11 +- applications/gui/widget_i.h | 15 +- applications/ibutton/ibutton.cpp | 16 +- applications/ibutton/ibutton.h | 6 +- .../ibutton/ibutton_mode_cyfral_emulate.h | 8 +- .../ibutton/ibutton_mode_cyfral_read.h | 8 +- .../ibutton/ibutton_mode_dallas_emulate.h | 8 +- .../ibutton/ibutton_mode_dallas_read.h | 8 +- applications/ibutton/ibutton_mode_template.h | 2 +- applications/irda/irda.c | 56 +++---- applications/irukagotchi/irukagotchi.c | 26 ++-- applications/lf-rfid/lf-rfid.c | 20 +-- applications/menu/menu.c | 41 +++-- applications/music-player/music-player.c | 52 +++---- applications/nfc/nfc.c | 38 +++-- applications/power/power.c | 20 +-- applications/sd-card-test/sd-card-test.cpp | 10 +- applications/sd-nfc/sdnfc.cpp | 10 +- applications/template/template.c.example | 8 +- lib/app-template/app-template.cpp | 10 +- lib/app-template/app-template.h | 14 +- 39 files changed, 486 insertions(+), 422 deletions(-) diff --git a/applications/app-loader/app-loader.c b/applications/app-loader/app-loader.c index 4ff94d16..0038818e 100644 --- a/applications/app-loader/app-loader.c +++ b/applications/app-loader/app-loader.c @@ -19,16 +19,16 @@ typedef struct { // TODO add mutex for contex -static void render_callback(CanvasApi* canvas, void* _ctx) { +static void render_callback(Canvas* canvas, void* _ctx) { AppLoaderState* ctx = (AppLoaderState*)_ctx; - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 32, ctx->current_app->name); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 32, ctx->current_app->name); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 44, "press back to exit"); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 44, "press back to exit"); } static void input_callback(InputEvent* input_event, void* _ctx) { @@ -92,12 +92,12 @@ void app_loader(void* p) { Cli* cli = furi_open("cli"); // Open GUI and register widget - GuiApi* gui = furi_open("gui"); + Gui* gui = furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, state.widget, GuiLayerFullscreen); + gui_add_widget(gui, state.widget, GuiLayerFullscreen); // FURI startup const size_t flipper_app_count = sizeof(FLIPPER_APPS) / sizeof(FLIPPER_APPS[0]); diff --git a/applications/applications.h b/applications/applications.h index 266ec715..c2615166 100644 --- a/applications/applications.h +++ b/applications/applications.h @@ -229,8 +229,6 @@ const FlipperStartupApp FLIPPER_APPS[] = { .icon = A_iButton_14}, #endif - {.app = NULL, .name = "Bluetooth", .libs = {0}, .icon = A_Bluetooth_14}, - #ifdef BUILD_GPIO_DEMO {.app = app_gpio_test, .name = "GPIO", .libs = {1, FURI_LIB{"gui_task"}}, .icon = A_GPIO_14}, #endif diff --git a/applications/bt/bt.c b/applications/bt/bt.c index ce1e3e61..d77293e2 100644 --- a/applications/bt/bt.c +++ b/applications/bt/bt.c @@ -6,17 +6,20 @@ Bt* bt_alloc() { bt->statusbar_icon = assets_icons_get(I_Bluetooth_5x8); bt->statusbar_widget = widget_alloc(); - widget_set_width(bt->statusbar_widget, icon_get_width(bt->statusbar_icon) + 2); + widget_set_width(bt->statusbar_widget, icon_get_width(bt->statusbar_icon)); widget_draw_callback_set(bt->statusbar_widget, bt_draw_statusbar_callback, bt); widget_enabled_set(bt->statusbar_widget, false); + bt->menu_icon = assets_icons_get(A_Bluetooth_14); + bt->menu_item = menu_item_alloc_menu("Bluetooth", bt->menu_icon); + return bt; } -void bt_draw_statusbar_callback(CanvasApi* canvas, void* context) { +void bt_draw_statusbar_callback(Canvas* canvas, void* context) { assert(context); Bt* bt = context; - canvas->draw_icon(canvas, 0, 0, bt->statusbar_icon); + canvas_draw_icon(canvas, 0, 0, bt->statusbar_icon); } void bt_cli_info(string_t args, void* context) { @@ -40,12 +43,11 @@ void bt_task() { furiac_exit(NULL); } - FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); - furi_assert(gui_record); - GuiApi* gui = furi_take(gui_record); - furi_assert(gui); - gui->add_widget(gui, bt->statusbar_widget, GuiLayerStatusBarLeft); - furi_commit(gui_record); + Gui* gui = furi_open("gui"); + gui_add_widget(gui, bt->statusbar_widget, GuiLayerStatusBarLeft); + + with_value_mutex( + furi_open("menu"), (Menu * menu) { menu_item_add(menu, bt->menu_item); }); furiac_ready(); diff --git a/applications/bt/bt_i.h b/applications/bt/bt_i.h index a3d98abf..a6eec8ff 100644 --- a/applications/bt/bt_i.h +++ b/applications/bt/bt_i.h @@ -3,17 +3,26 @@ #include "bt.h" #include + #include #include + #include #include +#include +#include + typedef struct { Cli* cli; + // Status bar Icon* statusbar_icon; Widget* statusbar_widget; + // Menu + Icon* menu_icon; + MenuItem* menu_item; } Bt; Bt* bt_alloc(); -void bt_draw_statusbar_callback(CanvasApi* canvas, void* context); +void bt_draw_statusbar_callback(Canvas* canvas, void* context); diff --git a/applications/cc1101-workaround/cc1101-workaround.cpp b/applications/cc1101-workaround/cc1101-workaround.cpp index 3de02fe3..ef8565a7 100644 --- a/applications/cc1101-workaround/cc1101-workaround.cpp +++ b/applications/cc1101-workaround/cc1101-workaround.cpp @@ -329,15 +329,15 @@ typedef struct { bool need_cc1101_conf; } State; -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); if(!state) return; - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 12, "cc1101 workaround"); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 12, "cc1101 workaround"); { char buf[24]; @@ -345,21 +345,21 @@ static void render_callback(CanvasApi* canvas, void* ctx) { float freq = conf.band->base_freq + CHAN_SPA * conf.channel; sprintf(buf, "freq: %ld.%02ld MHz", (uint32_t)freq, (uint32_t)(freq * 100.) % 100); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, buf); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, buf); } { - canvas->set_font(canvas, FontSecondary); + canvas_set_font(canvas, FontSecondary); if(state->need_cc1101_conf) { - canvas->draw_str(canvas, 2, 36, "mode: configuring..."); + canvas_draw_str(canvas, 2, 36, "mode: configuring..."); } else if(state->mode == ModeRx) { - canvas->draw_str(canvas, 2, 36, "mode: RX"); + canvas_draw_str(canvas, 2, 36, "mode: RX"); } else if(state->mode == ModeTx) { - canvas->draw_str(canvas, 2, 36, "mode: TX"); + canvas_draw_str(canvas, 2, 36, "mode: TX"); } else { - canvas->draw_str(canvas, 2, 36, "mode: unknown"); + canvas_draw_str(canvas, 2, 36, "mode: unknown"); } } @@ -368,8 +368,8 @@ static void render_callback(CanvasApi* canvas, void* ctx) { char buf[24]; sprintf(buf, "RSSI: %d dBm", state->last_rssi); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 48, buf); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 48, buf); } } @@ -377,8 +377,8 @@ static void render_callback(CanvasApi* canvas, void* ctx) { char buf[24]; sprintf(buf, "tx level: %d dBm", TX_LEVELS[state->tx_level].dbm); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 63, buf); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 63, buf); } release_mutex((ValueMutex*)ctx, state); @@ -416,12 +416,12 @@ extern "C" void cc1101_workaround(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("[cc1101] gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); gpio_init(&debug_0, GpioModeOutputPushPull); gpio_write((GpioPin*)&debug_0, false); diff --git a/applications/floopper-bloopper b/applications/floopper-bloopper index 20399498..4adfd876 160000 --- a/applications/floopper-bloopper +++ b/applications/floopper-bloopper @@ -1 +1 @@ -Subproject commit 2039949856df06d7f6fa7698897acc48f4714976 +Subproject commit 4adfd876167429ff9280db8e8b286b6c880e0c0a diff --git a/applications/gpio-tester/gpio-tester.c b/applications/gpio-tester/gpio-tester.c index 8fad7ade..e21deb75 100644 --- a/applications/gpio-tester/gpio-tester.c +++ b/applications/gpio-tester/gpio-tester.c @@ -33,15 +33,15 @@ typedef struct { uint8_t gpio_index; } State; -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 10, "GPIO demo"); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, GPIO_PINS[state->gpio_index].name); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 10, "GPIO demo"); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, GPIO_PINS[state->gpio_index].name); release_mutex((ValueMutex*)ctx, state); } @@ -74,12 +74,12 @@ void app_gpio_test(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("[gpio-tester] gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); // configure pin for(uint8_t i = 0; i < sizeof(GPIO_PINS) / sizeof(GPIO_PINS[0]); i++) { diff --git a/applications/gui/canvas.c b/applications/gui/canvas.c index f91d145f..b77a1091 100644 --- a/applications/gui/canvas.c +++ b/applications/gui/canvas.c @@ -1,4 +1,3 @@ -#include "canvas.h" #include "canvas_i.h" #include "icon.h" #include "icon_i.h" @@ -6,40 +5,18 @@ #include #include -typedef struct { - CanvasApi api; - +struct Canvas { u8g2_t fb; uint8_t offset_x; uint8_t offset_y; uint8_t width; uint8_t height; -} Canvas; - -uint8_t canvas_width(CanvasApi* api); -uint8_t canvas_height(CanvasApi* api); -void canvas_clear(CanvasApi* api); -void canvas_color_set(CanvasApi* api, uint8_t color); -void canvas_font_set(CanvasApi* api, Font font); -void canvas_str_draw(CanvasApi* api, uint8_t x, uint8_t y, const char* str); -void canvas_icon_draw(CanvasApi* api, uint8_t x, uint8_t y, Icon* icon); -void canvas_dot_draw(CanvasApi* api, uint8_t x, uint8_t y); -void canvas_box_draw(CanvasApi* api, uint8_t x, uint8_t y, uint8_t width, uint8_t height); -void canvas_draw_frame(CanvasApi* api, uint8_t x, uint8_t y, uint8_t width, uint8_t height); -void canvas_draw_line(CanvasApi* api, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2); -void canvas_draw_xbm( - CanvasApi* canvas, - uint8_t x, - uint8_t y, - uint8_t w, - uint8_t h, - const uint8_t* bitmap); -void canvas_draw_glyph(CanvasApi* canvas, uint8_t x, uint8_t y, uint16_t ch); +}; uint8_t u8g2_gpio_and_delay_stm32(u8x8_t* u8x8, uint8_t msg, uint8_t arg_int, void* arg_ptr); uint8_t u8x8_hw_spi_stm32(u8x8_t* u8x8, uint8_t msg, uint8_t arg_int, void* arg_ptr); -CanvasApi* canvas_api_init() { +Canvas* canvas_init() { Canvas* canvas = furi_alloc(sizeof(Canvas)); u8g2_Setup_st7565_erc12864_alt_f( @@ -48,86 +25,65 @@ CanvasApi* canvas_api_init() { // send init sequence to the display, display is in sleep mode after this u8g2_InitDisplay(&canvas->fb); u8g2_SetContrast(&canvas->fb, 36); - - u8g2_SetPowerSave(&canvas->fb, 0); // wake up display + // wake up display + u8g2_SetPowerSave(&canvas->fb, 0); u8g2_SendBuffer(&canvas->fb); - canvas->api.width = canvas_width; - canvas->api.height = canvas_height; - canvas->api.clear = canvas_clear; - canvas->api.set_color = canvas_color_set; - canvas->api.set_font = canvas_font_set; - canvas->api.draw_str = canvas_str_draw; - canvas->api.draw_icon = canvas_icon_draw; - canvas->api.draw_dot = canvas_dot_draw; - canvas->api.draw_box = canvas_box_draw; - canvas->api.draw_frame = canvas_draw_frame; - canvas->api.draw_line = canvas_draw_line; - canvas->api.draw_xbm = canvas_draw_xbm; - canvas->api.draw_glyph = canvas_draw_glyph; - - return (CanvasApi*)canvas; + return canvas; } -void canvas_api_free(CanvasApi* api) { - furi_assert(api); - free(api); +void canvas_free(Canvas* canvas) { + furi_assert(canvas); + free(canvas); } -void canvas_reset(CanvasApi* api) { - assert(api); - canvas_color_set(api, ColorBlack); - canvas_font_set(api, FontSecondary); +void canvas_reset(Canvas* canvas) { + furi_assert(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontSecondary); } -void canvas_commit(CanvasApi* api) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_commit(Canvas* canvas) { + furi_assert(canvas); u8g2_SetPowerSave(&canvas->fb, 0); // wake up display u8g2_SendBuffer(&canvas->fb); } void canvas_frame_set( - CanvasApi* api, + Canvas* canvas, uint8_t offset_x, uint8_t offset_y, uint8_t width, uint8_t height) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; + furi_assert(canvas); canvas->offset_x = offset_x; canvas->offset_y = offset_y; canvas->width = width; canvas->height = height; } -uint8_t canvas_width(CanvasApi* api) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +uint8_t canvas_width(Canvas* canvas) { + furi_assert(canvas); return canvas->width; } -uint8_t canvas_height(CanvasApi* api) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +uint8_t canvas_height(Canvas* canvas) { + furi_assert(canvas); return canvas->height; } -void canvas_clear(CanvasApi* api) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_clear(Canvas* canvas) { + furi_assert(canvas); u8g2_ClearBuffer(&canvas->fb); } -void canvas_color_set(CanvasApi* api, Color color) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_set_color(Canvas* canvas, Color color) { + furi_assert(canvas); u8g2_SetDrawColor(&canvas->fb, color); } -void canvas_font_set(CanvasApi* api, Font font) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_set_font(Canvas* canvas, Font font) { + furi_assert(canvas); u8g2_SetFontMode(&canvas->fb, 1); if(font == FontPrimary) { u8g2_SetFont(&canvas->fb, u8g2_font_helvB08_tf); @@ -140,52 +96,46 @@ void canvas_font_set(CanvasApi* api, Font font) { } } -void canvas_str_draw(CanvasApi* api, uint8_t x, uint8_t y, const char* str) { - furi_assert(api); +void canvas_draw_str(Canvas* canvas, uint8_t x, uint8_t y, const char* str) { + furi_assert(canvas); if(!str) return; - Canvas* canvas = (Canvas*)api; x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawStr(&canvas->fb, x, y, str); } -void canvas_icon_draw(CanvasApi* api, uint8_t x, uint8_t y, Icon* icon) { - furi_assert(api); +void canvas_draw_icon(Canvas* canvas, uint8_t x, uint8_t y, Icon* icon) { + furi_assert(canvas); if(!icon) return; - Canvas* canvas = (Canvas*)api; x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawXBM( &canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_get_data(icon)); } -void canvas_dot_draw(CanvasApi* api, uint8_t x, uint8_t y) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_draw_dot(Canvas* canvas, uint8_t x, uint8_t y) { + furi_assert(canvas); x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawPixel(&canvas->fb, x, y); } -void canvas_box_draw(CanvasApi* api, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { + furi_assert(canvas); x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawBox(&canvas->fb, x, y, width, height); } -void canvas_draw_frame(CanvasApi* api, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { + furi_assert(canvas); x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawFrame(&canvas->fb, x, y, width, height); } -void canvas_draw_line(CanvasApi* api, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_draw_line(Canvas* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2) { + furi_assert(canvas); x1 += canvas->offset_x; y1 += canvas->offset_y; x2 += canvas->offset_x; @@ -194,23 +144,21 @@ void canvas_draw_line(CanvasApi* api, uint8_t x1, uint8_t y1, uint8_t x2, uint8_ } void canvas_draw_xbm( - CanvasApi* api, + Canvas* canvas, uint8_t x, uint8_t y, uint8_t w, uint8_t h, const uint8_t* bitmap) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; + furi_assert(canvas); x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawXBM(&canvas->fb, x, y, w, h, bitmap); } -void canvas_draw_glyph(CanvasApi* api, uint8_t x, uint8_t y, uint16_t ch) { - furi_assert(api); - Canvas* canvas = (Canvas*)api; +void canvas_draw_glyph(Canvas* canvas, uint8_t x, uint8_t y, uint16_t ch) { + furi_assert(canvas); x += canvas->offset_x; y += canvas->offset_y; u8g2_DrawGlyph(&canvas->fb, x, y, ch); -} \ No newline at end of file +} diff --git a/applications/gui/canvas.h b/applications/gui/canvas.h index 07201c06..a232b8ce 100644 --- a/applications/gui/canvas.h +++ b/applications/gui/canvas.h @@ -11,28 +11,77 @@ typedef enum { typedef enum { FontPrimary = 0x00, FontSecondary = 0x01, FontGlyph = 0x02 } Font; -typedef struct CanvasApi CanvasApi; -struct CanvasApi { - uint8_t (*width)(CanvasApi* canvas); - uint8_t (*height)(CanvasApi* canvas); +typedef struct Canvas Canvas; - void (*clear)(CanvasApi* canvas); +/* + * Canvas width + * @return width in pixels. + */ +uint8_t canvas_width(Canvas* canvas); - void (*set_color)(CanvasApi* canvas, Color color); - void (*set_font)(CanvasApi* canvas, Font font); +/* + * Canvas height + * @return height in pixels. + */ +uint8_t canvas_height(Canvas* canvas); - void (*draw_str)(CanvasApi* canvas, uint8_t x, uint8_t y, const char* str); - void (*draw_icon)(CanvasApi* canvas, uint8_t x, uint8_t y, Icon* icon); - void (*draw_xbm)( - CanvasApi* canvas, - uint8_t x, - uint8_t y, - uint8_t w, - uint8_t h, - const uint8_t* bitmap); - void (*draw_dot)(CanvasApi* canvas, uint8_t x, uint8_t y); - void (*draw_box)(CanvasApi* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); - void (*draw_frame)(CanvasApi* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); - void (*draw_line)(CanvasApi* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2); - void (*draw_glyph)(CanvasApi* canvas, uint8_t x, uint8_t y, uint16_t ch); -}; +/* + * Clear canvas, clear rendering buffer + */ +void canvas_clear(Canvas* canvas); + +/* + * Set drawing color + */ +void canvas_set_color(Canvas* canvas, Color color); + +/* + * Set drawing font + */ +void canvas_set_font(Canvas* canvas, Font font); + +/* + * Draw string at position of baseline defined by x, y. + */ +void canvas_draw_str(Canvas* canvas, uint8_t x, uint8_t y, const char* str); + +/* + * Draw icon at position defined by x,y. + */ +void canvas_draw_icon(Canvas* canvas, uint8_t x, uint8_t y, Icon* icon); + +/* + * Draw xbm icon of width, height at position defined by x,y. + */ +void canvas_draw_xbm( + Canvas* canvas, + uint8_t x, + uint8_t y, + uint8_t w, + uint8_t h, + const uint8_t* bitmap); + +/* + * Draw dot at x,y + */ +void canvas_draw_dot(Canvas* canvas, uint8_t x, uint8_t y); + +/* + * Draw box of width, height at x,y + */ +void canvas_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); + +/* + * Draw frame of width, height at x,y + */ +void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); + +/* + * Draw line from x1,y1 to x2,y2 + */ +void canvas_draw_line(Canvas* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2); + +/* + * Draw glyph + */ +void canvas_draw_glyph(Canvas* canvas, uint8_t x, uint8_t y, uint16_t ch); diff --git a/applications/gui/canvas_i.h b/applications/gui/canvas_i.h index 1104f75e..23c87372 100644 --- a/applications/gui/canvas_i.h +++ b/applications/gui/canvas_i.h @@ -1,15 +1,32 @@ #pragma once -CanvasApi* canvas_api_init(); +#include "canvas.h" -void canvas_api_free(CanvasApi* api); +/* + * Allocate memory and initialize canvas + */ +Canvas* canvas_init(); -void canvas_reset(CanvasApi* api); +/* + * Free canvas memory + */ +void canvas_free(Canvas* canvas); -void canvas_commit(CanvasApi* api); +/* + * Reset canvas drawing tools configuration + */ +void canvas_reset(Canvas* canvas); +/* + * Commit canvas. Send buffer to display + */ +void canvas_commit(Canvas* canvas); + +/* + * Set drawing region relative to real screen buffer + */ void canvas_frame_set( - CanvasApi* api, + Canvas* canvas, uint8_t offset_x, uint8_t offset_y, uint8_t width, diff --git a/applications/gui/elements.c b/applications/gui/elements.c index fef63634..2d5d4599 100644 --- a/applications/gui/elements.c +++ b/applications/gui/elements.c @@ -1,31 +1,31 @@ #include "elements.h" -void elements_scrollbar(CanvasApi* canvas, uint8_t pos, uint8_t total) { - uint8_t width = canvas->width(canvas); - uint8_t height = canvas->height(canvas); +void elements_scrollbar(Canvas* canvas, uint8_t pos, uint8_t total) { + uint8_t width = canvas_width(canvas); + uint8_t height = canvas_height(canvas); // prevent overflows - canvas->set_color(canvas, ColorWhite); - canvas->draw_box(canvas, width - 3, 0, 3, height); + canvas_set_color(canvas, ColorWhite); + canvas_draw_box(canvas, width - 3, 0, 3, height); // dot line - canvas->set_color(canvas, ColorBlack); + canvas_set_color(canvas, ColorBlack); for(uint8_t i = 0; i < height; i += 2) { - canvas->draw_dot(canvas, width - 2, i); + canvas_draw_dot(canvas, width - 2, i); } // Position block if(total) { uint8_t block_h = ((float)height) / total; - canvas->draw_box(canvas, width - 3, block_h * pos, 3, block_h); + canvas_draw_box(canvas, width - 3, block_h * pos, 3, block_h); } } -void elements_frame(CanvasApi* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { - canvas->draw_line(canvas, x + 2, y, x + width - 2, y); - canvas->draw_line(canvas, x + 1, y + height - 1, x + width, y + height - 1); - canvas->draw_line(canvas, x + 2, y + height, x + width - 1, y + height); +void elements_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { + canvas_draw_line(canvas, x + 2, y, x + width - 2, y); + canvas_draw_line(canvas, x + 1, y + height - 1, x + width, y + height - 1); + canvas_draw_line(canvas, x + 2, y + height, x + width - 1, y + height); - canvas->draw_line(canvas, x, y + 2, x, y + height - 2); - canvas->draw_line(canvas, x + width - 1, y + 1, x + width - 1, y + height - 2); - canvas->draw_line(canvas, x + width, y + 2, x + width, y + height - 2); + canvas_draw_line(canvas, x, y + 2, x, y + height - 2); + canvas_draw_line(canvas, x + width - 1, y + 1, x + width - 1, y + height - 2); + canvas_draw_line(canvas, x + width, y + 2, x + width, y + height - 2); - canvas->draw_dot(canvas, x + 1, y + 1); + canvas_draw_dot(canvas, x + 1, y + 1); } \ No newline at end of file diff --git a/applications/gui/elements.h b/applications/gui/elements.h index 812ce99c..d2bec004 100644 --- a/applications/gui/elements.h +++ b/applications/gui/elements.h @@ -3,6 +3,17 @@ #include #include "canvas.h" -void elements_scrollbar(CanvasApi* canvas, uint8_t pos, uint8_t total); +/* + * Draw scrollbar on canvas. + * width 3px, height equal to canvas height + * @param pos - current element of total elements + * @param total - total elements + */ +void elements_scrollbar(Canvas* canvas, uint8_t pos, uint8_t total); -void elements_frame(CanvasApi* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); +/* + * Draw rounded frame + * @param x, y - top left corner coordinates + * @param width, height - frame width and height + */ +void elements_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); diff --git a/applications/gui/gui.c b/applications/gui/gui.c index 2bd6feec..fdce8eab 100644 --- a/applications/gui/gui.c +++ b/applications/gui/gui.c @@ -15,9 +15,8 @@ ARRAY_DEF(WidgetArray, Widget*, M_PTR_OPLIST); struct Gui { - GuiApi api; GuiEvent* event; - CanvasApi* canvas_api; + Canvas* canvas; WidgetArray_t layers[GuiLayerMAX]; osMutexId_t mutex; }; @@ -41,10 +40,10 @@ void gui_update(Gui* gui) { } bool gui_redraw_fs(Gui* gui) { - canvas_frame_set(gui->canvas_api, 0, 0, GUI_DISPLAY_WIDTH, GUI_DISPLAY_HEIGHT); + canvas_frame_set(gui->canvas, 0, 0, GUI_DISPLAY_WIDTH, GUI_DISPLAY_HEIGHT); Widget* widget = gui_widget_find_enabled(gui->layers[GuiLayerFullscreen]); if(widget) { - widget_draw(widget, gui->canvas_api); + widget_draw(widget, gui->canvas); return true; } else { return false; @@ -67,9 +66,9 @@ void gui_redraw_status_bar(Gui* gui) { width = widget_get_width(widget); if(!width) width = 8; x_used += width; - x -= width; - canvas_frame_set(gui->canvas_api, x, GUI_STATUS_BAR_Y, width, GUI_STATUS_BAR_HEIGHT); - widget_draw(widget, gui->canvas_api); + x -= (width + 2); + canvas_frame_set(gui->canvas, x, GUI_STATUS_BAR_Y, width, GUI_STATUS_BAR_HEIGHT); + widget_draw(widget, gui->canvas); } WidgetArray_next(it); } @@ -83,29 +82,29 @@ void gui_redraw_status_bar(Gui* gui) { width = widget_get_width(widget); if(!width) width = 8; x_used += width; - canvas_frame_set(gui->canvas_api, x, GUI_STATUS_BAR_Y, width, GUI_STATUS_BAR_HEIGHT); - widget_draw(widget, gui->canvas_api); - x += width; + canvas_frame_set(gui->canvas, x, GUI_STATUS_BAR_Y, width, GUI_STATUS_BAR_HEIGHT); + widget_draw(widget, gui->canvas); + x += (width + 2); } WidgetArray_next(it); } } bool gui_redraw_normal(Gui* gui) { - canvas_frame_set(gui->canvas_api, GUI_MAIN_X, GUI_MAIN_Y, GUI_MAIN_WIDTH, GUI_MAIN_HEIGHT); + canvas_frame_set(gui->canvas, GUI_MAIN_X, GUI_MAIN_Y, GUI_MAIN_WIDTH, GUI_MAIN_HEIGHT); Widget* widget = gui_widget_find_enabled(gui->layers[GuiLayerMain]); if(widget) { - widget_draw(widget, gui->canvas_api); + widget_draw(widget, gui->canvas); return true; } return false; } bool gui_redraw_none(Gui* gui) { - canvas_frame_set(gui->canvas_api, GUI_MAIN_X, GUI_MAIN_Y, GUI_MAIN_WIDTH, GUI_MAIN_HEIGHT); + canvas_frame_set(gui->canvas, GUI_MAIN_X, GUI_MAIN_Y, GUI_MAIN_WIDTH, GUI_MAIN_HEIGHT); Widget* widget = gui_widget_find_enabled(gui->layers[GuiLayerNone]); if(widget) { - widget_draw(widget, gui->canvas_api); + widget_draw(widget, gui->canvas); return true; } @@ -116,7 +115,7 @@ void gui_redraw(Gui* gui) { furi_assert(gui); gui_lock(gui); - canvas_reset(gui->canvas_api); + canvas_reset(gui->canvas); if(!gui_redraw_fs(gui)) { if(!gui_redraw_normal(gui)) { @@ -125,7 +124,7 @@ void gui_redraw(Gui* gui) { gui_redraw_status_bar(gui); } - canvas_commit(gui->canvas_api); + canvas_commit(gui->canvas); gui_unlock(gui); } @@ -156,11 +155,10 @@ void gui_unlock(Gui* gui) { furi_check(osMutexRelease(gui->mutex) == osOK); } -void gui_add_widget(GuiApi* gui_api, Widget* widget, GuiLayer layer) { - furi_assert(gui_api); +void gui_add_widget(Gui* gui, Widget* widget, GuiLayer layer) { + furi_assert(gui); furi_assert(widget); furi_check(layer < GuiLayerMAX); - Gui* gui = (Gui*)gui_api; gui_lock(gui); WidgetArray_push_back(gui->layers[layer], widget); @@ -169,10 +167,9 @@ void gui_add_widget(GuiApi* gui_api, Widget* widget, GuiLayer layer) { gui_update(gui); } -void gui_remove_widget(GuiApi* gui_api, Widget* widget) { - furi_assert(gui_api); +void gui_remove_widget(Gui* gui, Widget* widget) { + furi_assert(gui); furi_assert(widget); - Gui* gui = (Gui*)gui_api; gui_lock(gui); @@ -193,16 +190,13 @@ void gui_remove_widget(GuiApi* gui_api, Widget* widget) { Gui* gui_alloc() { Gui* gui = furi_alloc(sizeof(Gui)); - // Set API functions - gui->api.add_widget = gui_add_widget; - gui->api.remove_widget = gui_remove_widget; // Allocate mutex gui->mutex = osMutexNew(NULL); furi_check(gui->mutex); // Event dispatcher gui->event = gui_event_alloc(); - // Drawing canvas api - gui->canvas_api = canvas_api_init(); + // Drawing canvas + gui->canvas = canvas_init(); // Compose Layers for(size_t i = 0; i < GuiLayerMAX; i++) { WidgetArray_init(gui->layers[i]); diff --git a/applications/gui/gui.h b/applications/gui/gui.h index c7fe1ced..d05de799 100644 --- a/applications/gui/gui.h +++ b/applications/gui/gui.h @@ -27,8 +27,16 @@ typedef enum { GuiLayerMAX /* Don't use or move, special value */ } GuiLayer; -typedef struct GuiApi GuiApi; -struct GuiApi { - void (*add_widget)(GuiApi* gui_api, Widget* widget, GuiLayer layer); - void (*remove_widget)(GuiApi* gui_api, Widget* widget); -}; +typedef struct Gui Gui; + +/* + * Add widget to widget tree + * @remarks thread safe + */ +void gui_add_widget(Gui* gui, Widget* widget, GuiLayer layer); + +/* + * Remove widget from rendering tree + * @remarks thread safe + */ +void gui_remove_widget(Gui* gui, Widget* widget); diff --git a/applications/gui/icon.c b/applications/gui/icon.c index dabff14f..8f02cf6d 100644 --- a/applications/gui/icon.c +++ b/applications/gui/icon.c @@ -1,4 +1,3 @@ -#include "icon.h" #include "icon_i.h" #include diff --git a/applications/gui/icon.h b/applications/gui/icon.h index 8d16cb1d..4df2ed36 100644 --- a/applications/gui/icon.h +++ b/applications/gui/icon.h @@ -6,16 +6,38 @@ typedef struct IconData IconData; typedef struct Icon Icon; +/* + * Allocate icon instance with const icon data. + * always returns Icon or stops system if not enough memory + */ Icon* icon_alloc(const IconData* data); +/* + * Release icon instance + */ void icon_free(Icon* icon); +/* + * Get icon width + */ uint8_t icon_get_width(Icon* icon); +/* + * Get icon height + */ uint8_t icon_get_height(Icon* icon); +/* + * Check if icon is animated + */ bool icon_is_animated(Icon* icon); +/* + * Start icon animation + */ void icon_start_animation(Icon* icon); +/* + * Stop icon animation + */ void icon_stop_animation(Icon* icon); diff --git a/applications/gui/icon_i.h b/applications/gui/icon_i.h index 22b98316..aaefbdae 100644 --- a/applications/gui/icon_i.h +++ b/applications/gui/icon_i.h @@ -1,5 +1,7 @@ #pragma once +#include "icon.h" + #include struct IconData { @@ -16,6 +18,12 @@ struct Icon { uint32_t tick; }; +/* + * Get pointer to current frame data + */ const uint8_t* icon_get_data(Icon* icon); +/* + * Advance to next frame + */ void icon_next_frame(Icon* icon); diff --git a/applications/gui/widget.c b/applications/gui/widget.c index 2df0853b..e1470261 100644 --- a/applications/gui/widget.c +++ b/applications/gui/widget.c @@ -1,4 +1,3 @@ -#include "widget.h" #include "widget_i.h" #include @@ -75,16 +74,17 @@ void widget_update(Widget* widget) { void widget_gui_set(Widget* widget, Gui* gui) { furi_assert(widget); furi_assert(gui); + widget->gui = gui; } -void widget_draw(Widget* widget, CanvasApi* canvas_api) { +void widget_draw(Widget* widget, Canvas* canvas) { furi_assert(widget); - furi_assert(canvas_api); - + furi_assert(canvas); furi_check(widget->gui); + if(widget->draw_callback) { - widget->draw_callback(canvas_api, widget->draw_callback_context); + widget->draw_callback(canvas, widget->draw_callback_context); } } diff --git a/applications/gui/widget.h b/applications/gui/widget.h index d93b21a4..629d54e6 100644 --- a/applications/gui/widget.h +++ b/applications/gui/widget.h @@ -5,7 +5,16 @@ typedef struct Widget Widget; -typedef void (*WidgetDrawCallback)(CanvasApi* api, void* context); +/* + * Widget Draw callback + * @warning called from GUI thread + */ +typedef void (*WidgetDrawCallback)(Canvas* api, void* context); + +/* + * Widget Input callback + * @warning called from GUI thread + */ typedef void (*WidgetInputCallback)(InputEvent* event, void* context); /* diff --git a/applications/gui/widget_i.h b/applications/gui/widget_i.h index e48a08f7..8de17a4c 100644 --- a/applications/gui/widget_i.h +++ b/applications/gui/widget_i.h @@ -1,32 +1,39 @@ #pragma once #include "gui_i.h" +#include "widget.h" struct Widget { Gui* gui; bool is_enabled; + uint8_t width; uint8_t height; + WidgetDrawCallback draw_callback; void* draw_callback_context; + WidgetInputCallback input_callback; void* input_callback_context; }; /* - * Set GUI referenec. + * Set GUI reference. + * To be used by GUI, called upon widget tree insert * @param gui - gui instance pointer. */ void widget_gui_set(Widget* widget, Gui* gui); /* * Process draw call. Calls draw callback. - * @param canvas_api - canvas to draw at. + * To be used by GUI, called on tree redraw. + * @param canvas - canvas to draw at. */ -void widget_draw(Widget* widget, CanvasApi* canvas_api); +void widget_draw(Widget* widget, Canvas* canvas); /* - * Process input. Calls input callback. + * Process input. Calls input callbac + * To be used by GUI, called on input dispatch. * @param event - pointer to input event. */ void widget_input(Widget* widget, InputEvent* event); diff --git a/applications/ibutton/ibutton.cpp b/applications/ibutton/ibutton.cpp index a9bf79ff..e0637f76 100644 --- a/applications/ibutton/ibutton.cpp +++ b/applications/ibutton/ibutton.cpp @@ -56,15 +56,15 @@ void AppiButton::run() { } // render app -void AppiButton::render(CanvasApi* canvas) { - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 12, "iButton"); +void AppiButton::render(Canvas* canvas) { + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 12, "iButton"); mode[state.mode_index]->render(canvas, &state); } -void AppiButton::render_dallas_list(CanvasApi* canvas, AppiButtonState* state) { +void AppiButton::render_dallas_list(Canvas* canvas, AppiButtonState* state) { const uint8_t buffer_size = 50; char buf[buffer_size]; for(uint8_t i = 0; i < state->dallas_address_count; i++) { @@ -82,11 +82,11 @@ void AppiButton::render_dallas_list(CanvasApi* canvas, AppiButtonState* state) { state->dallas_address[i][5], state->dallas_address[i][6], state->dallas_address[i][7]); - canvas->draw_str(canvas, 2, 37 + i * 12, buf); + canvas_draw_str(canvas, 2, 37 + i * 12, buf); } } -void AppiButton::render_cyfral_list(CanvasApi* canvas, AppiButtonState* state) { +void AppiButton::render_cyfral_list(Canvas* canvas, AppiButtonState* state) { const uint8_t buffer_size = 50; char buf[buffer_size]; for(uint8_t i = 0; i < state->cyfral_address_count; i++) { @@ -100,7 +100,7 @@ void AppiButton::render_cyfral_list(CanvasApi* canvas, AppiButtonState* state) { state->cyfral_address[i][1], state->cyfral_address[i][2], state->cyfral_address[i][3]); - canvas->draw_str(canvas, 2, 37 + i * 12, buf); + canvas_draw_str(canvas, 2, 37 + i * 12, buf); } } diff --git a/applications/ibutton/ibutton.h b/applications/ibutton/ibutton.h index 599bcc20..6bfcaabe 100644 --- a/applications/ibutton/ibutton.h +++ b/applications/ibutton/ibutton.h @@ -60,9 +60,9 @@ public: AppTemplateMode* mode[modes_count]; void run(); - void render(CanvasApi* canvas); - void render_dallas_list(CanvasApi* canvas, AppiButtonState* state); - void render_cyfral_list(CanvasApi* canvas, AppiButtonState* state); + void render(Canvas* canvas); + void render_dallas_list(Canvas* canvas, AppiButtonState* state); + void render_cyfral_list(Canvas* canvas, AppiButtonState* state); void blink_red(); void blink_green(); diff --git a/applications/ibutton/ibutton_mode_cyfral_emulate.h b/applications/ibutton/ibutton_mode_cyfral_emulate.h index 1ef92091..157e15ca 100644 --- a/applications/ibutton/ibutton_mode_cyfral_emulate.h +++ b/applications/ibutton/ibutton_mode_cyfral_emulate.h @@ -9,7 +9,7 @@ public: CyfralEmulator* cyfral_emulator; void event(AppiButtonEvent* event, AppiButtonState* state); - void render(CanvasApi* canvas, AppiButtonState* state); + void render(Canvas* canvas, AppiButtonState* state); void acquire(); void release(); @@ -39,9 +39,9 @@ void AppiButtonModeCyfralEmulate::event(AppiButtonEvent* event, AppiButtonState* } } -void AppiButtonModeCyfralEmulate::render(CanvasApi* canvas, AppiButtonState* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "< Cyfral emulate"); +void AppiButtonModeCyfralEmulate::render(Canvas* canvas, AppiButtonState* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "< Cyfral emulate"); app->render_cyfral_list(canvas, state); } diff --git a/applications/ibutton/ibutton_mode_cyfral_read.h b/applications/ibutton/ibutton_mode_cyfral_read.h index 68f4cbb8..82866283 100644 --- a/applications/ibutton/ibutton_mode_cyfral_read.h +++ b/applications/ibutton/ibutton_mode_cyfral_read.h @@ -9,7 +9,7 @@ public: CyfralReader* reader; void event(AppiButtonEvent* event, AppiButtonState* state); - void render(CanvasApi* canvas, AppiButtonState* state); + void render(Canvas* canvas, AppiButtonState* state); void acquire(); void release(); @@ -37,9 +37,9 @@ void AppiButtonModeCyfralRead::event(AppiButtonEvent* event, AppiButtonState* st } } -void AppiButtonModeCyfralRead::render(CanvasApi* canvas, AppiButtonState* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "< Cyfral read >"); +void AppiButtonModeCyfralRead::render(Canvas* canvas, AppiButtonState* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "< Cyfral read >"); app->render_cyfral_list(canvas, state); } diff --git a/applications/ibutton/ibutton_mode_dallas_emulate.h b/applications/ibutton/ibutton_mode_dallas_emulate.h index 1e5abbba..be458ce2 100644 --- a/applications/ibutton/ibutton_mode_dallas_emulate.h +++ b/applications/ibutton/ibutton_mode_dallas_emulate.h @@ -11,7 +11,7 @@ public: DS1990 key; void event(AppiButtonEvent* event, AppiButtonState* state); - void render(CanvasApi* canvas, AppiButtonState* state); + void render(Canvas* canvas, AppiButtonState* state); void acquire(); void release(); @@ -46,9 +46,9 @@ void AppiButtonModeDallasEmulate::event(AppiButtonEvent* event, AppiButtonState* } } -void AppiButtonModeDallasEmulate::render(CanvasApi* canvas, AppiButtonState* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "< Dallas emulate >"); +void AppiButtonModeDallasEmulate::render(Canvas* canvas, AppiButtonState* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "< Dallas emulate >"); app->render_dallas_list(canvas, state); } diff --git a/applications/ibutton/ibutton_mode_dallas_read.h b/applications/ibutton/ibutton_mode_dallas_read.h index 765ed127..0ea554c9 100644 --- a/applications/ibutton/ibutton_mode_dallas_read.h +++ b/applications/ibutton/ibutton_mode_dallas_read.h @@ -10,7 +10,7 @@ public: OneWireGpio* onewire; void event(AppiButtonEvent* event, AppiButtonState* state); - void render(CanvasApi* canvas, AppiButtonState* state); + void render(Canvas* canvas, AppiButtonState* state); void acquire(); void release(); @@ -69,9 +69,9 @@ void AppiButtonModeDallasRead::event(AppiButtonEvent* event, AppiButtonState* st } } -void AppiButtonModeDallasRead::render(CanvasApi* canvas, AppiButtonState* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "Dallas read >"); +void AppiButtonModeDallasRead::render(Canvas* canvas, AppiButtonState* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "Dallas read >"); app->render_dallas_list(canvas, state); } diff --git a/applications/ibutton/ibutton_mode_template.h b/applications/ibutton/ibutton_mode_template.h index 001bd7e3..677422fe 100644 --- a/applications/ibutton/ibutton_mode_template.h +++ b/applications/ibutton/ibutton_mode_template.h @@ -5,7 +5,7 @@ template class AppTemplateMode { public: const char* name; virtual void event(TEvents* event, TState* state) = 0; - virtual void render(CanvasApi* canvas, TState* state) = 0; + virtual void render(Canvas* canvas, TState* state) = 0; virtual void acquire() = 0; virtual void release() = 0; }; diff --git a/applications/irda/irda.c b/applications/irda/irda.c index 08043e34..e8bad541 100644 --- a/applications/irda/irda.c +++ b/applications/irda/irda.c @@ -27,15 +27,15 @@ typedef struct { } State; typedef void (*ModeInput)(AppEvent*, State*); -typedef void (*ModeRender)(CanvasApi*, State*); +typedef void (*ModeRender)(Canvas*, State*); void input_carrier(AppEvent* event, State* state); -void render_carrier(CanvasApi* canvas, State* state); +void render_carrier(Canvas* canvas, State* state); void input_nec(AppEvent* event, State* state); -void render_nec(CanvasApi* canvas, State* state); -void render_carrier(CanvasApi* canvas, State* state); +void render_nec(Canvas* canvas, State* state); +void render_carrier(Canvas* canvas, State* state); void input_samsung(AppEvent* event, State* state); -void render_samsung(CanvasApi* canvas, State* state); +void render_samsung(Canvas* canvas, State* state); typedef struct { ModeRender render; @@ -76,24 +76,24 @@ const SamsungPacket samsung_packets[] = { const float duty_cycles[] = {0.1, 0.25, 0.333, 0.5, 1.0}; -void render_carrier(CanvasApi* canvas, State* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "carrier mode >"); - canvas->draw_str(canvas, 2, 37, "? /\\ freq | \\/ duty cycle"); +void render_carrier(Canvas* canvas, State* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "carrier mode >"); + canvas_draw_str(canvas, 2, 37, "? /\\ freq | \\/ duty cycle"); { char buf[24]; sprintf(buf, "frequency: %u Hz", state->carrier_freq); - canvas->draw_str(canvas, 2, 50, buf); + canvas_draw_str(canvas, 2, 50, buf); sprintf( buf, "duty cycle: %d/1000", (int)(duty_cycles[state->carrier_duty_cycle_id] * 1000)); - canvas->draw_str(canvas, 2, 62, buf); + canvas_draw_str(canvas, 2, 62, buf); } } -void render_nec(CanvasApi* canvas, State* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "< nec mode >"); - canvas->draw_str(canvas, 2, 37, "? /\\ \\/ packet"); +void render_nec(Canvas* canvas, State* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "< nec mode >"); + canvas_draw_str(canvas, 2, 37, "? /\\ \\/ packet"); { char buf[24]; sprintf( @@ -101,14 +101,14 @@ void render_nec(CanvasApi* canvas, State* state) { "packet: %02X %02X", nec_packets[state->nec_packet_id].addr, nec_packets[state->nec_packet_id].data); - canvas->draw_str(canvas, 2, 50, buf); + canvas_draw_str(canvas, 2, 50, buf); } } -void render_samsung(CanvasApi* canvas, State* state) { - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 25, "< samsung32 mode"); - canvas->draw_str(canvas, 2, 37, "? /\\ \\/ packet"); +void render_samsung(Canvas* canvas, State* state) { + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 25, "< samsung32 mode"); + canvas_draw_str(canvas, 2, 37, "? /\\ \\/ packet"); { char buf[24]; sprintf( @@ -116,7 +116,7 @@ void render_samsung(CanvasApi* canvas, State* state) { "packet: %02X %02X", samsung_packets[state->samsung_packet_id].addr, samsung_packets[state->samsung_packet_id].data); - canvas->draw_str(canvas, 2, 50, buf); + canvas_draw_str(canvas, 2, 50, buf); } } @@ -206,13 +206,13 @@ void input_samsung(AppEvent* event, State* state) { } } -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 12, "irda test"); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 12, "irda test"); modes[state->mode_id].render(canvas, state); @@ -256,12 +256,12 @@ void irda(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); // Red LED // TODO open record diff --git a/applications/irukagotchi/irukagotchi.c b/applications/irukagotchi/irukagotchi.c index 3ca6ad20..bafa9049 100644 --- a/applications/irukagotchi/irukagotchi.c +++ b/applications/irukagotchi/irukagotchi.c @@ -15,17 +15,17 @@ struct Irukagotchi { ValueMutex* menu_vm; }; -void irukagotchi_draw_callback(CanvasApi* canvas, void* context) { +void irukagotchi_draw_callback(Canvas* canvas, void* context) { Irukagotchi* irukagotchi = context; - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->draw_icon(canvas, 128 - 80, 0, irukagotchi->icon); - canvas->set_font(canvas, FontSecondary); - canvas->draw_str(canvas, 2, 10, TARGET " " BUILD_DATE); - canvas->draw_str(canvas, 2, 22, GIT_BRANCH); - canvas->draw_str(canvas, 2, 34, GIT_BRANCH_NUM); - canvas->draw_str(canvas, 2, 46, GIT_COMMIT); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_draw_icon(canvas, 128 - 80, 0, irukagotchi->icon); + canvas_set_font(canvas, FontSecondary); + canvas_draw_str(canvas, 2, 10, TARGET " " BUILD_DATE); + canvas_draw_str(canvas, 2, 22, GIT_BRANCH); + canvas_draw_str(canvas, 2, 34, GIT_BRANCH_NUM); + canvas_draw_str(canvas, 2, 46, GIT_COMMIT); } void irukagotchi_input_callback(InputEvent* event, void* context) { @@ -56,12 +56,8 @@ Irukagotchi* irukagotchi_alloc() { void irukagotchi_task() { Irukagotchi* irukagotchi = irukagotchi_alloc(); - FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); - furi_check(gui_record); - GuiApi* gui = furi_take(gui_record); - furi_check(gui); - gui->add_widget(gui, irukagotchi->widget, GuiLayerNone); - furi_commit(gui_record); + Gui* gui = furi_open("gui"); + gui_add_widget(gui, irukagotchi->widget, GuiLayerNone); furiac_ready(); diff --git a/applications/lf-rfid/lf-rfid.c b/applications/lf-rfid/lf-rfid.c index e1fdc79d..d75ccfff 100644 --- a/applications/lf-rfid/lf-rfid.c +++ b/applications/lf-rfid/lf-rfid.c @@ -22,24 +22,24 @@ typedef struct { uint32_t em_data; } State; -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); - canvas->clear(canvas); + canvas_clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 12, "LF RFID"); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 12, "LF RFID"); - canvas->draw_str(canvas, 2, 24, state->on ? "Reading" : "Emulating"); + canvas_draw_str(canvas, 2, 24, state->on ? "Reading" : "Emulating"); char buf[14]; sprintf(buf, "%d kHz", (int)state->freq_khz); - canvas->draw_str(canvas, 2, 36, buf); + canvas_draw_str(canvas, 2, 36, buf); sprintf(buf, "%02d:%010ld", state->customer_id, state->em_data); - canvas->draw_str(canvas, 2, 45, buf); + canvas_draw_str(canvas, 2, 45, buf); release_mutex((ValueMutex*)ctx, state); } @@ -202,12 +202,12 @@ void lf_rfid_workaround(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); AppEvent event; uint32_t prev_dwt; diff --git a/applications/menu/menu.c b/applications/menu/menu.c index edcd2636..67c00c0a 100644 --- a/applications/menu/menu.c +++ b/applications/menu/menu.c @@ -24,7 +24,7 @@ struct Menu { MenuItem* current; }; -void menu_widget_callback(CanvasApi* canvas, void* context); +void menu_widget_callback(Canvas* canvas, void* context); ValueMutex* menu_init() { Menu* menu = furi_alloc(sizeof(Menu)); @@ -42,9 +42,9 @@ ValueMutex* menu_init() { menu->widget = widget_alloc(); // Open GUI and register fullscreen widget - GuiApi* gui = furi_open("gui"); + Gui* gui = furi_open("gui"); furi_check(gui); - gui->add_widget(gui, menu->widget, GuiLayerFullscreen); + gui_add_widget(gui, menu->widget, GuiLayerFullscreen); widget_enabled_set(menu->widget, false); widget_draw_callback_set(menu->widget, menu_widget_callback, menu_mutex); @@ -57,11 +57,6 @@ void menu_build_main(Menu* menu) { furi_assert(menu); // Root point menu->root = menu_item_alloc_menu(NULL, NULL); - - Icon* icon = assets_icons_get(A_Bluetooth_14); - menu->settings = menu_item_alloc_menu("Setting", icon); - - // menu_item_add(menu, menu->settings); } void menu_item_add(Menu* menu, MenuItem* item) { @@ -72,13 +67,13 @@ void menu_settings_item_add(Menu* menu, MenuItem* item) { menu_item_subitem_add(menu->settings, item); } -void menu_draw_primary(Menu* menu, CanvasApi* canvas) { +void menu_draw_primary(Menu* menu, Canvas* canvas) { } -void menu_draw_secondary(Menu* menu, CanvasApi* canvas) { +void menu_draw_secondary(Menu* menu, Canvas* canvas) { } -void menu_widget_callback(CanvasApi* canvas, void* context) { +void menu_widget_callback(Canvas* canvas, void* context) { furi_assert(canvas); furi_assert(context); @@ -87,8 +82,8 @@ void menu_widget_callback(CanvasApi* canvas, void* context) { furi_assert(menu->current); - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); size_t position = menu_item_get_position(menu->current); MenuItemArray_t* items = menu_item_get_subitems(menu->current); @@ -97,30 +92,30 @@ void menu_widget_callback(CanvasApi* canvas, void* context) { MenuItem* item; size_t shift_position; // First line - canvas->set_font(canvas, FontSecondary); + canvas_set_font(canvas, FontSecondary); shift_position = (0 + position + items_count - 1) % (MenuItemArray_size(*items)); item = *MenuItemArray_get(*items, shift_position); - canvas->draw_icon(canvas, 4, 3, menu_item_get_icon(item)); - canvas->draw_str(canvas, 22, 14, menu_item_get_label(item)); + canvas_draw_icon(canvas, 4, 3, menu_item_get_icon(item)); + canvas_draw_str(canvas, 22, 14, menu_item_get_label(item)); // Second line main - canvas->set_font(canvas, FontPrimary); + canvas_set_font(canvas, FontPrimary); shift_position = (1 + position + items_count - 1) % (MenuItemArray_size(*items)); item = *MenuItemArray_get(*items, shift_position); - canvas->draw_icon(canvas, 4, 25, menu_item_get_icon(item)); - canvas->draw_str(canvas, 22, 36, menu_item_get_label(item)); + canvas_draw_icon(canvas, 4, 25, menu_item_get_icon(item)); + canvas_draw_str(canvas, 22, 36, menu_item_get_label(item)); // Third line - canvas->set_font(canvas, FontSecondary); + canvas_set_font(canvas, FontSecondary); shift_position = (2 + position + items_count - 1) % (MenuItemArray_size(*items)); item = *MenuItemArray_get(*items, shift_position); - canvas->draw_icon(canvas, 4, 47, menu_item_get_icon(item)); - canvas->draw_str(canvas, 22, 58, menu_item_get_label(item)); + canvas_draw_icon(canvas, 4, 47, menu_item_get_icon(item)); + canvas_draw_str(canvas, 22, 58, menu_item_get_label(item)); // Frame and scrollbar // elements_frame(canvas, 0, 0, 128 - 5, 21); elements_frame(canvas, 0, 21, 128 - 5, 21); // elements_frame(canvas, 0, 42, 128 - 5, 21); elements_scrollbar(canvas, position, items_count); } else { - canvas->draw_str(canvas, 2, 32, "Empty"); + canvas_draw_str(canvas, 2, 32, "Empty"); elements_scrollbar(canvas, 0, 0); } diff --git a/applications/music-player/music-player.c b/applications/music-player/music-player.c index fd37df28..d6e38e12 100644 --- a/applications/music-player/music-player.c +++ b/applications/music-player/music-player.c @@ -226,13 +226,13 @@ const char* get_note_len_name(const MelodyEventRecord* note_record) { } } -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 0, 12, "MusicPlayer"); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 0, 12, "MusicPlayer"); uint8_t x_pos = 0; uint8_t y_pos = 24; @@ -247,24 +247,24 @@ static void render_callback(CanvasApi* canvas, void* ctx) { // white keys for(size_t i = 0; i < 7; i++) { if(is_white_note(state->note_record, i)) { - canvas->draw_box(canvas, x_pos + white_w * i, y_pos, white_w + 1, white_h); + canvas_draw_box(canvas, x_pos + white_w * i, y_pos, white_w + 1, white_h); } else { - canvas->draw_frame(canvas, x_pos + white_w * i, y_pos, white_w + 1, white_h); + canvas_draw_frame(canvas, x_pos + white_w * i, y_pos, white_w + 1, white_h); } } // black keys for(size_t i = 0; i < 7; i++) { if(i != 2 && i != 6) { - canvas->set_color(canvas, ColorWhite); - canvas->draw_box( + canvas_set_color(canvas, ColorWhite); + canvas_draw_box( canvas, x_pos + white_w * i + black_x, y_pos + black_y, black_w + 1, black_h); - canvas->set_color(canvas, ColorBlack); + canvas_set_color(canvas, ColorBlack); if(is_black_note(state->note_record, i)) { - canvas->draw_box( + canvas_draw_box( canvas, x_pos + white_w * i + black_x, y_pos + black_y, black_w + 1, black_h); } else { - canvas->draw_frame( + canvas_draw_frame( canvas, x_pos + white_w * i + black_x, y_pos + black_y, black_w + 1, black_h); } } @@ -274,28 +274,28 @@ static void render_callback(CanvasApi* canvas, void* ctx) { x_pos = 124; y_pos = 0; const uint8_t volume_h = (64 / (state->volume_id_max - 1)) * state->volume_id; - canvas->draw_frame(canvas, x_pos, y_pos, 4, 64); - canvas->draw_box(canvas, x_pos, y_pos + (64 - volume_h), 4, volume_h); + canvas_draw_frame(canvas, x_pos, y_pos, 4, 64); + canvas_draw_box(canvas, x_pos, y_pos + (64 - volume_h), 4, volume_h); // note stack widget x_pos = 73; y_pos = 0; - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_frame(canvas, x_pos, y_pos, 49, 64); - canvas->draw_line(canvas, x_pos + 28, 0, x_pos + 28, 64); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_frame(canvas, x_pos, y_pos, 49, 64); + canvas_draw_line(canvas, x_pos + 28, 0, x_pos + 28, 64); for(uint8_t i = 0; i < note_stack_size; i++) { if(i == 0) { - canvas->draw_box(canvas, x_pos, y_pos + 48, 49, 16); - canvas->set_color(canvas, ColorWhite); + canvas_draw_box(canvas, x_pos, y_pos + 48, 49, 16); + canvas_set_color(canvas, ColorWhite); } else { - canvas->set_color(canvas, ColorBlack); + canvas_set_color(canvas, ColorBlack); } - canvas->draw_str(canvas, x_pos + 4, 64 - 16 * i - 3, get_note_name(state->note_stack[i])); - canvas->draw_str( + canvas_draw_str(canvas, x_pos + 4, 64 - 16 * i - 3, get_note_name(state->note_stack[i])); + canvas_draw_str( canvas, x_pos + 31, 64 - 16 * i - 3, get_note_len_name(state->note_stack[i])); - canvas->draw_line(canvas, x_pos, 64 - 16 * i, x_pos + 48, 64 - 16 * i); + canvas_draw_line(canvas, x_pos, 64 - 16 * i, x_pos + 48, 64 - 16 * i); } release_mutex((ValueMutex*)ctx, state); @@ -376,12 +376,12 @@ void music_player(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); // open input record PubSub* input_events_record = furi_open("input_events"); diff --git a/applications/nfc/nfc.c b/applications/nfc/nfc.c index 26ae41bf..e983f287 100644 --- a/applications/nfc/nfc.c +++ b/applications/nfc/nfc.c @@ -2,37 +2,37 @@ #include "nfc_i.h" #include "nfc_worker.h" -void nfc_draw_callback(CanvasApi* canvas, void* context) { +void nfc_draw_callback(Canvas* canvas, void* context) { furi_assert(canvas); furi_assert(context); Nfc* nfc = context; dispatcher_lock(nfc->dispatcher); - canvas->clear(canvas); - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); + canvas_clear(canvas); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); if(nfc->screen == 0) { char status[128 / 8]; if(nfc->ret == ERR_WRONG_STATE) - canvas->draw_str(canvas, 2, 16, "NFC Wrong State"); + canvas_draw_str(canvas, 2, 16, "NFC Wrong State"); else if(nfc->ret == ERR_PARAM) - canvas->draw_str(canvas, 2, 16, "NFC Wrong Param"); + canvas_draw_str(canvas, 2, 16, "NFC Wrong Param"); else if(nfc->ret == ERR_IO) - canvas->draw_str(canvas, 2, 16, "NFC IO Error"); + canvas_draw_str(canvas, 2, 16, "NFC IO Error"); else if(nfc->ret == ERR_NONE) - canvas->draw_str(canvas, 2, 16, "NFC Device Found"); + canvas_draw_str(canvas, 2, 16, "NFC Device Found"); else if(nfc->ret == ERR_TIMEOUT) - canvas->draw_str(canvas, 2, 16, "NFC Timeout"); + canvas_draw_str(canvas, 2, 16, "NFC Timeout"); else - canvas->draw_str(canvas, 2, 16, "NFC error"); + canvas_draw_str(canvas, 2, 16, "NFC error"); - canvas->set_font(canvas, FontSecondary); + canvas_set_font(canvas, FontSecondary); snprintf(status, sizeof(status), "Found: %d", nfc->devCnt); if(nfc->devCnt > 0) { - canvas->draw_str(canvas, 2, 32, status); - canvas->draw_str(canvas, 2, 42, nfc->current); + canvas_draw_str(canvas, 2, 32, status); + canvas_draw_str(canvas, 2, 42, nfc->current); snprintf( status, @@ -40,10 +40,10 @@ void nfc_draw_callback(CanvasApi* canvas, void* context) { "ATQA:%d SAK:%d", nfc->first_atqa.anticollisionInfo, nfc->first_sak.sak); - canvas->draw_str(canvas, 2, 52, status); + canvas_draw_str(canvas, 2, 52, status); } } else { - canvas->draw_str(canvas, 2, 16, "Not implemented"); + canvas_draw_str(canvas, 2, 16, "Not implemented"); } dispatcher_unlock(nfc->dispatcher); @@ -166,13 +166,9 @@ Nfc* nfc_alloc() { void nfc_task(void* p) { Nfc* nfc = nfc_alloc(); - FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); - furi_check(gui_record); - GuiApi* gui = furi_take(gui_record); - furi_check(gui); + Gui* gui = furi_open("gui"); widget_enabled_set(nfc->widget, false); - gui->add_widget(gui, nfc->widget, GuiLayerFullscreen); - furi_commit(gui_record); + gui_add_widget(gui, nfc->widget, GuiLayerFullscreen); with_value_mutex( nfc->menu_vm, (Menu * menu) { menu_item_add(menu, nfc->menu); }); diff --git a/applications/power/power.c b/applications/power/power.c index 15c26db2..dc19b754 100644 --- a/applications/power/power.c +++ b/applications/power/power.c @@ -24,18 +24,18 @@ struct Power { uint8_t charge; }; -void power_draw_usb_callback(CanvasApi* canvas, void* context) { +void power_draw_usb_callback(Canvas* canvas, void* context) { assert(context); Power* power = context; - canvas->draw_icon(canvas, 0, 0, power->usb_icon); + canvas_draw_icon(canvas, 0, 0, power->usb_icon); } -void power_draw_battery_callback(CanvasApi* canvas, void* context) { +void power_draw_battery_callback(Canvas* canvas, void* context) { assert(context); Power* power = context; - canvas->draw_icon(canvas, 0, 0, power->battery_icon); - canvas->draw_box(canvas, 2, 2, (float)power->charge / 100 * 14, 4); + canvas_draw_icon(canvas, 0, 0, power->battery_icon); + canvas_draw_box(canvas, 2, 2, (float)power->charge / 100 * 14, 4); } void power_off_callback(void* context) { @@ -134,13 +134,9 @@ void power_task(void* p) { cli_add_command(power->cli, "power_otg_off", power_cli_otg_off, power); } - FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); - assert(gui_record); - GuiApi* gui = furi_take(gui_record); - assert(gui); - gui->add_widget(gui, power->usb_widget, GuiLayerStatusBarLeft); - gui->add_widget(gui, power->battery_widget, GuiLayerStatusBarRight); - furi_commit(gui_record); + Gui* gui = furi_open("gui"); + gui_add_widget(gui, power->usb_widget, GuiLayerStatusBarLeft); + gui_add_widget(gui, power->battery_widget, GuiLayerStatusBarRight); with_value_mutex( power->menu_vm, (Menu * menu) { menu_item_add(menu, power->menu); }); diff --git a/applications/sd-card-test/sd-card-test.cpp b/applications/sd-card-test/sd-card-test.cpp index d1b2d3be..c2361511 100644 --- a/applications/sd-card-test/sd-card-test.cpp +++ b/applications/sd-card-test/sd-card-test.cpp @@ -50,7 +50,7 @@ public: // funcs void run(); - void render(CanvasApi* canvas); + void render(Canvas* canvas); template void set_text(std::initializer_list list); template void set_error(std::initializer_list list); const char* fatfs_error_desc(FRESULT res); @@ -833,11 +833,11 @@ template void SdTest::set_text(std::initializer_list list) { } // render app -void SdTest::render(CanvasApi* canvas) { - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontSecondary); +void SdTest::render(Canvas* canvas) { + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontSecondary); for(uint8_t i = 0; i < state.lines_count; i++) { - canvas->draw_str(canvas, 0, (i + 1) * 10, state.line[i]); + canvas_draw_str(canvas, 0, (i + 1) * 10, state.line[i]); } } diff --git a/applications/sd-nfc/sdnfc.cpp b/applications/sd-nfc/sdnfc.cpp index 7705c067..1a63715a 100644 --- a/applications/sd-nfc/sdnfc.cpp +++ b/applications/sd-nfc/sdnfc.cpp @@ -51,7 +51,7 @@ public: GpioPin* green_led_record; void run(); - void render(CanvasApi* canvas); + void render(Canvas* canvas); void set_error(const char* text); void set_text(const char* text); void light_red(); @@ -117,10 +117,10 @@ void AppSdNFC::run() { } // render app -void AppSdNFC::render(CanvasApi* canvas) { - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, 12, state.name); +void AppSdNFC::render(Canvas* canvas) { + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, 12, state.name); } void AppSdNFC::set_error(const char* text) { diff --git a/applications/template/template.c.example b/applications/template/template.c.example index 3f4f55e8..fffcb07c 100644 --- a/applications/template/template.c.example +++ b/applications/template/template.c.example @@ -18,10 +18,10 @@ typedef struct { // describe state here } State; -static void render_callback(CanvasApi* canvas, void* ctx) { +static void render_callback(Canvas* canvas, void* ctx) { State* state = (State*)acquire_mutex((ValueMutex*)ctx, 25); - canvas->clear(canvas); + canvas_clear(canvas); // draw your app @@ -54,12 +54,12 @@ void template_app(void* p) { widget_input_callback_set(widget, input_callback, event_queue); // Open GUI and register widget - GuiApi* gui = (GuiApi*)furi_open("gui"); + Gui* gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); } - gui->add_widget(gui, widget, /* specify UI layer */); + gui_add_widget(gui, widget, /* specify UI layer */); Event event; while(1) { diff --git a/lib/app-template/app-template.cpp b/lib/app-template/app-template.cpp index cf614f7f..c754783e 100644 --- a/lib/app-template/app-template.cpp +++ b/lib/app-template/app-template.cpp @@ -46,7 +46,7 @@ public: class AppExample : public AppTemplate { public: void run(); - void render(CanvasApi* canvas); + void render(Canvas* canvas); }; // start app @@ -87,12 +87,12 @@ void AppExample::run() { } // render app -void AppExample::render(CanvasApi* canvas) { +void AppExample::render(Canvas* canvas) { // here you dont need to call acquire_state or release_state // to read or write app state, that already handled by caller - canvas->set_color(canvas, ColorBlack); - canvas->set_font(canvas, FontPrimary); - canvas->draw_str(canvas, 2, state.example_data, "Example app"); + canvas_set_color(canvas, ColorBlack); + canvas_set_font(canvas, FontPrimary); + canvas_draw_str(canvas, 2, state.example_data, "Example app"); } // app enter function diff --git a/lib/app-template/app-template.h b/lib/app-template/app-template.h index 570c9e53..960db047 100644 --- a/lib/app-template/app-template.h +++ b/lib/app-template/app-template.h @@ -10,13 +10,13 @@ public: osMessageQueueId_t event_queue; TState state; ValueMutex state_mutex; - GuiApi* gui; + Gui* gui; AppTemplate(); ~AppTemplate(); void input_callback(InputEvent* input_event, void* ctx); - void draw_callback(CanvasApi* canvas, void* ctx); - virtual void render(CanvasApi* canvas) = 0; + void draw_callback(Canvas* canvas, void* ctx); + virtual void render(Canvas* canvas) = 0; void acquire_state(void); void release_state(void); bool get_event(TEvent* event, uint32_t timeout); @@ -37,7 +37,7 @@ template AppTemplate::AppTemplate() } // open gui - gui = (GuiApi*)furi_open("gui"); + gui = (Gui*)furi_open("gui"); if(gui == NULL) { printf("gui is not available\n"); furiac_exit(NULL); @@ -63,11 +63,11 @@ void AppTemplate::input_callback(InputEvent* input_event, void* // generic draw callback template -void AppTemplate::draw_callback(CanvasApi* canvas, void* ctx) { +void AppTemplate::draw_callback(Canvas* canvas, void* ctx) { AppTemplate* app = static_cast(ctx); app->acquire_state(); - canvas->clear(canvas); + canvas_clear(canvas); app->render(canvas); app->release_state(); @@ -100,7 +100,7 @@ template void AppTemplate::app_read widget_draw_callback_set(widget, draw_cb_ref, this); // add widget - gui->add_widget(gui, widget, GuiLayerFullscreen); + gui_add_widget(gui, widget, GuiLayerFullscreen); // signal that our app ready to work furiac_ready();