|
@@ -1,4 +1,3 @@
|
|
|
-#include "canvas.h"
|
|
|
|
|
#include "canvas_i.h"
|
|
#include "canvas_i.h"
|
|
|
#include "icon.h"
|
|
#include "icon.h"
|
|
|
#include "icon_i.h"
|
|
#include "icon_i.h"
|
|
@@ -6,40 +5,18 @@
|
|
|
#include <flipper.h>
|
|
#include <flipper.h>
|
|
|
#include <flipper_v2.h>
|
|
#include <flipper_v2.h>
|
|
|
|
|
|
|
|
-typedef struct {
|
|
|
|
|
- CanvasApi api;
|
|
|
|
|
-
|
|
|
|
|
|
|
+struct Canvas {
|
|
|
u8g2_t fb;
|
|
u8g2_t fb;
|
|
|
uint8_t offset_x;
|
|
uint8_t offset_x;
|
|
|
uint8_t offset_y;
|
|
uint8_t offset_y;
|
|
|
uint8_t width;
|
|
uint8_t width;
|
|
|
uint8_t height;
|
|
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 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);
|
|
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));
|
|
Canvas* canvas = furi_alloc(sizeof(Canvas));
|
|
|
|
|
|
|
|
u8g2_Setup_st7565_erc12864_alt_f(
|
|
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
|
|
// send init sequence to the display, display is in sleep mode after this
|
|
|
u8g2_InitDisplay(&canvas->fb);
|
|
u8g2_InitDisplay(&canvas->fb);
|
|
|
u8g2_SetContrast(&canvas->fb, 36);
|
|
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);
|
|
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_SetPowerSave(&canvas->fb, 0); // wake up display
|
|
|
u8g2_SendBuffer(&canvas->fb);
|
|
u8g2_SendBuffer(&canvas->fb);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
void canvas_frame_set(
|
|
void canvas_frame_set(
|
|
|
- CanvasApi* api,
|
|
|
|
|
|
|
+ Canvas* canvas,
|
|
|
uint8_t offset_x,
|
|
uint8_t offset_x,
|
|
|
uint8_t offset_y,
|
|
uint8_t offset_y,
|
|
|
uint8_t width,
|
|
uint8_t width,
|
|
|
uint8_t height) {
|
|
uint8_t height) {
|
|
|
- furi_assert(api);
|
|
|
|
|
- Canvas* canvas = (Canvas*)api;
|
|
|
|
|
|
|
+ furi_assert(canvas);
|
|
|
canvas->offset_x = offset_x;
|
|
canvas->offset_x = offset_x;
|
|
|
canvas->offset_y = offset_y;
|
|
canvas->offset_y = offset_y;
|
|
|
canvas->width = width;
|
|
canvas->width = width;
|
|
|
canvas->height = height;
|
|
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;
|
|
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;
|
|
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);
|
|
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);
|
|
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);
|
|
u8g2_SetFontMode(&canvas->fb, 1);
|
|
|
if(font == FontPrimary) {
|
|
if(font == FontPrimary) {
|
|
|
u8g2_SetFont(&canvas->fb, u8g2_font_helvB08_tf);
|
|
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;
|
|
if(!str) return;
|
|
|
- Canvas* canvas = (Canvas*)api;
|
|
|
|
|
x += canvas->offset_x;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawStr(&canvas->fb, x, y, str);
|
|
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;
|
|
if(!icon) return;
|
|
|
- Canvas* canvas = (Canvas*)api;
|
|
|
|
|
x += canvas->offset_x;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawXBM(
|
|
u8g2_DrawXBM(
|
|
|
&canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_get_data(icon));
|
|
&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;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawPixel(&canvas->fb, x, 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;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawBox(&canvas->fb, x, y, width, height);
|
|
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;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawFrame(&canvas->fb, x, y, width, height);
|
|
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;
|
|
x1 += canvas->offset_x;
|
|
|
y1 += canvas->offset_y;
|
|
y1 += canvas->offset_y;
|
|
|
x2 += canvas->offset_x;
|
|
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(
|
|
void canvas_draw_xbm(
|
|
|
- CanvasApi* api,
|
|
|
|
|
|
|
+ Canvas* canvas,
|
|
|
uint8_t x,
|
|
uint8_t x,
|
|
|
uint8_t y,
|
|
uint8_t y,
|
|
|
uint8_t w,
|
|
uint8_t w,
|
|
|
uint8_t h,
|
|
uint8_t h,
|
|
|
const uint8_t* bitmap) {
|
|
const uint8_t* bitmap) {
|
|
|
- furi_assert(api);
|
|
|
|
|
- Canvas* canvas = (Canvas*)api;
|
|
|
|
|
|
|
+ furi_assert(canvas);
|
|
|
x += canvas->offset_x;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawXBM(&canvas->fb, x, y, w, h, bitmap);
|
|
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;
|
|
x += canvas->offset_x;
|
|
|
y += canvas->offset_y;
|
|
y += canvas->offset_y;
|
|
|
u8g2_DrawGlyph(&canvas->fb, x, y, ch);
|
|
u8g2_DrawGlyph(&canvas->fb, x, y, ch);
|
|
|
-}
|
|
|
|
|
|
|
+}
|