1
mirror of https://github.com/DarkFlippers/unleashed-firmware.git synced 2025-12-12 04:34:43 +04:00

[FL-3729] Gui: unicode support, new canvas API (#3322)

* Revert "Rollback #3305 and #3297 fix various rendering issues (#3307)"

This reverts commit 531ba24e9a.

* Gui: refactor canvas to use proper coordinate system types. Furi: new furi_break check macros. Desktop: proper types for negative offset.

* Desktop: proper types in desktop_view_locked_doors_draw

* Examples: update images example, off it goes

---------

Co-authored-by: hedger <hedger@users.noreply.github.com>
This commit is contained in:
あく
2024-03-20 00:23:06 +09:00
committed by GitHub
parent acc39a4bc0
commit bcde0aefbd
10 changed files with 259 additions and 223 deletions

View File

@@ -11,35 +11,62 @@
//This arrays contains the font itself. You can use any u8g2 font you want //This arrays contains the font itself. You can use any u8g2 font you want
/* /*
Fontname: -Raccoon-Fixed4x6-Medium-R-Normal--6-60-75-75-P-40-ISO10646-1 Fontname: -Misc-Fixed-Medium-R-Normal--6-60-75-75-C-40-ISO10646-1
Copyright: Copyright: Public domain font. Share and enjoy.
Glyphs: 95/203 Glyphs: 191/919
BBX Build Mode: 0 BBX Build Mode: 0
*/ */
const uint8_t u8g2_font_tom_thumb_4x6_tr[725] = const uint8_t u8g2_font_4x6_t_cyrillic[] =
"_\0\2\2\2\3\3\4\4\3\6\0\377\5\377\5\0\0\352\1\330\2\270 \5\340\315\0!\6\265\310" "\277\0\2\2\3\3\2\4\4\4\6\0\377\5\377\5\377\0\356\1\334\2\301 \5\200\315\0!\6\351\310"
"\254\0\42\6\213\313$\25#\10\227\310\244\241\206\12$\10\227\310\215\70b\2%\10\227\310d\324F\1" "\254\0\42\6\223\313$\25#\12\254\310\244\64T\32*\1$\11\263\307\245\241\301H\11%\10\253\310d"
"&\10\227\310(\65R\22'\5\251\313\10(\6\266\310\251\62)\10\226\310\304\224\24\0*\6\217\312\244" "\324F\1&\11\254\310\305\24\253\230\2'\5\321\313\10(\7\362\307\251f\0)\10\262\307\304T)\0"
"\16+\7\217\311\245\225\0,\6\212\310)\0-\5\207\312\14.\5\245\310\4/\7\227\310Ve\4\60" "*\7\253\310\244j\65+\10\253\310\305\264b\2,\6\222\307)\0-\5\213\312\14.\5\311\310\4/"
"\7\227\310-k\1\61\6\226\310\255\6\62\10\227\310h\220\312\1\63\11\227\310h\220\62X\0\64\10\227" "\7\253\310Ve\4\60\10\253\310UCU\0\61\7\253\310%Y\15\62\7\253\310\65S\32\63\10\253\310"
"\310$\65b\1\65\10\227\310\214\250\301\2\66\10\227\310\315\221F\0\67\10\227\310\314TF\0\70\10\227" "\314\224\301\2\64\10\253\310$\65b\1\65\10\253\310\214\250\301\2\66\7\253\310M\325\2\67\10\253\310\314"
"\310\214\64\324\10\71\10\227\310\214\64\342\2:\6\255\311\244\0;\7\222\310e\240\0<\10\227\310\246\32" "TF\0\70\7\253\310\255\326\2\71\7\253\310\265\344\2:\6\341\310\304\0;\7\252\307e\250\0<\10"
"d\20=\6\217\311l\60>\11\227\310d\220A*\1\77\10\227\310\314\224a\2@\10\227\310UC\3" "\253\310\246\32d\20=\6\233\311l\60>\11\253\310d\220A*\1\77\11\253\310h\220\62L\0@\7"
"\1A\10\227\310UC\251\0B\10\227\310\250\264\322\2C\7\227\310\315\32\10D\10\227\310\250d-\0" "\253\310-\33\10A\10\253\310UC\251\0B\10\253\310\250\264\322\2C\10\253\310U\62U\0D\10\253"
"E\10\227\310\214\70\342\0F\10\227\310\214\70b\4G\10\227\310\315\221\222\0H\10\227\310$\65\224\12" "\310\250d-\0E\10\253\310\214\250\342\0F\10\253\310\214\250b\4G\10\253\310\315\244\222\0H\10\253"
"I\7\227\310\254X\15J\7\227\310\226\252\2K\10\227\310$\265\222\12L\7\227\310\304\346\0M\10\227" "\310$\65\224\12I\7\253\310\254X\15J\7\253\310\226\252\2K\10\253\310$\265\222\12L\7\253\310\304"
"\310\244\61\224\12N\10\227\310\244q\250\0O\7\227\310UV\5P\10\227\310\250\264b\4Q\10\227\310" "\346\0M\10\253\310\244\61\224\12N\10\253\310\252\241$\0O\7\253\310UV\5P\10\253\310\250\264b"
"Uj$\1R\10\227\310\250\64V\1S\10\227\310m\220\301\2T\7\227\310\254\330\2U\7\227\310$" "\4Q\10\263\307UV\15\2R\10\253\310\250\264\222\12S\10\253\310m\220\301\2T\7\253\310\254\330\2"
"W\22V\10\227\310$\253L\0W\10\227\310$\65\206\12X\10\227\310$\325R\1Y\10\227\310$U" "U\7\253\310$\327\10V\10\253\310$k\244\4W\10\253\310$\65\206\12X\10\253\310$\325R\1Y"
"V\0Z\7\227\310\314T\16[\7\227\310\214X\16\134\10\217\311d\220A\0]\7\227\310\314r\4^" "\10\253\310$UV\0Z\7\253\310\314T\16[\6\352\310\254J\134\11\253\310\304\14\62\210\1]\6\252"
"\5\213\313\65_\5\207\310\14`\6\212\313\304\0a\7\223\310\310\65\2b\10\227\310D\225\324\2c\7" "\310\250j^\5\223\313\65_\5\213\307\14`\6\322\313\304\0a\7\243\310-\225\4b\10\253\310D\225"
"\223\310\315\14\4d\10\227\310\246\245\222\0e\6\223\310\235\2f\10\227\310\246\264b\2g\10\227\307\35" "\324\2c\7\243\310\315\14\4d\10\253\310\246\245\222\0e\6\243\310USf\10\253\310\246\264b\2g"
"\61%\0h\10\227\310D\225\254\0i\6\265\310\244\1j\10\233\307f\30U\5k\10\227\310\304\264T" "\10\253\307\255$\27\0h\10\253\310D\225\254\0i\10\253\310e$\323\0j\10\263\307fX.\0k"
"\1l\7\227\310\310\326\0m\7\223\310<R\0n\7\223\310\250d\5o\7\223\310U\252\2p\10\227" "\10\253\310\304\264\222\12l\7\253\310\310\326\0m\10\243\310\244\241T\0n\7\243\310\250d\5o\7\243"
"\307\250\244V\4q\10\227\307-\225d\0r\6\223\310\315\22s\10\223\310\215\70\22\0t\10\227\310\245" "\310U\252\2p\10\253\307\250\264b\4q\10\253\307-\225d\0r\10\243\310\244\25#\0s\10\243\310"
"\25\243\0u\7\223\310$+\11v\10\223\310$\65R\2w\7\223\310\244q\4x\7\223\310\244\62\25" "\215\14\26\0t\10\253\310\245\25\63\10u\7\243\310$+\11v\7\243\310$\253\2w\10\243\310$\65"
"y\11\227\307$\225dJ\0z\7\223\310\254\221\6{\10\227\310\251\32D\1|\6\265\310(\1}\11" "T\0x\7\243\310\244\62\25y\10\253\307$\225\344\2z\7\243\310\314\224\6{\10\263\307\246$k\20"
"\227\310\310\14RR\0~\6\213\313\215\4\0\0\0\4\377\377\0"; "|\6\351\310\14\1}\11\263\307d\20UL\21~\7\224\313%\225\0\0\0\0\4\377\377\4\1\11\253"
"\310\244\261\342\0\4\2\11\253\310\214\250\222\12\4\3\10\253\310\16Y\2\4\4\11\253\310M\225\201\0\4"
"\5\11\253\310m\220\301\2\4\6\10\253\310\254X\15\4\7\11\253\310\244\221b\32\4\10\10\253\310\226\252"
"\2\4\11\11\254\310L\325Z\2\4\12\11\254\310\244\326JK\4\13\11\253\310\250\250\222\12\4\14\10\253"
"\310\312\264\12\4\16\11\263\307\244\32u\2\4\17\11\263\307$\327H\11\4\20\11\253\310UC\251\0\4"
"\21\11\253\310\214\250\322\2\4\22\11\253\310\250\264\322\2\4\23\10\253\310\214\330\4\4\24\11\263\307\254\245"
"\206\12\4\25\11\253\310\214\250\342\0\4\26\12\253\310\244\221\322H\1\4\27\12\253\310h\220\62X\0\4"
"\30\11\253\310\304\64T\14\4\31\11\263\307\315\64T\14\4\32\11\253\310$\265\222\12\4\33\10\253\310-"
"W\0\4\34\11\253\310\244\241\254\0\4\35\11\253\310$\65\224\12\4\36\10\253\310UV\5\4\37\10\253"
"\310\214\344\12\4 \11\253\310\250\264b\4\4!\11\253\310U\62U\0\4\42\10\253\310\254\330\2\4#"
"\11\263\307$\253L\21\4$\12\253\310\245\221FJ\0\4%\11\253\310$\325R\1\4&\10\253\310$"
"\327\10\4'\11\253\310$\225d\1\4(\11\253\310$\65\216\0\4)\12\264\307\244\326#\203\0\4*"
"\13\254\310h\220\201LI\1\4+\12\254\310D\271\324H\1\4,\11\253\310\304\250\322\2\4-\11\253"
"\310h\220\344\2\4.\12\254\310\244\244.\225\0\4/\11\253\310\255\264T\0\4\60\10\243\310-\225\4"
"\4\61\11\253\310\315\221*\0\4\62\11\243\310\14\225\26\0\4\63\10\243\310\214X\2\4\64\11\253\307-"
"\65T\0\4\65\7\243\310US\4\66\11\244\310$S%\1\4\67\11\243\310\254\14\26\0\4\70\11\243"
"\310\244\61T\0\4\71\11\253\310\244\326P\1\4:\10\243\310$\265\12\4;\7\243\310-+\4<\11"
"\243\310\244\241T\0\4=\11\243\310\244\241T\0\4>\10\243\310U\252\2\4\77\10\243\310\214d\5\4"
"@\11\253\307\250\264b\4\4A\10\243\310\315\14\4\4B\10\243\310\254X\1\4C\11\253\307$\225\344"
"\2\4D\12\263\307\305\224T\231\0\4E\10\243\310\244\62\25\4F\11\253\307$k\304\0\4G\11\243"
"\310$\225d\0\4H\10\243\310\244q\4\4I\11\254\307\244\364\310 \4J\12\244\310h SR\0"
"\4K\11\244\310\304\245F\12\4L\11\243\310D\225\26\0\4M\10\243\310H\271\0\4N\12\244\310\244"
"\244\226J\0\4O\10\243\310\255\264\2\4Q\10\253\310\244\326\24\4R\11\263\307D\25U\31\4S\11"
"\253\310\246\64b\4\4T\11\243\310\215\224\201\0\4U\11\243\310\215\14\26\0\4V\11\253\310e$\323"
"\0\4W\11\253\310\244\14d\32\4X\11\263\307fX.\0\4Y\10\244\310\251\326\22\4Z\11\244\310"
"\244\264\322\22\4[\11\253\310D\25U\1\4\134\10\253\310\312\264\12\4^\11\263\307\244\32u\2\4_"
"\11\253\307$k\244\4\4\220\10\253\310\16Y\2\4\221\10\243\310\16\31\1\4\222\11\253\310\251\264b\2"
"\4\223\11\243\310\251\264\22\0\0";
// Screen is 128x64 px // Screen is 128x64 px
static void app_draw_callback(Canvas* canvas, void* ctx) { static void app_draw_callback(Canvas* canvas, void* ctx) {
@@ -47,10 +74,11 @@ static void app_draw_callback(Canvas* canvas, void* ctx) {
canvas_clear(canvas); canvas_clear(canvas);
canvas_set_custom_u8g2_font(canvas, u8g2_font_tom_thumb_4x6_tr); canvas_set_custom_u8g2_font(canvas, u8g2_font_4x6_t_cyrillic);
canvas_draw_str(canvas, 0, 6, "This is a tiny custom font"); canvas_draw_str(canvas, 0, 6, "This is a tiny custom font");
canvas_draw_str(canvas, 0, 12, "012345.?! ,:;\"\'@#$%"); canvas_draw_str(canvas, 0, 12, "012345.?! ,:;\"\'@#$%");
canvas_draw_str(canvas, 0, 18, "И немного юникода");
} }
static void app_input_callback(InputEvent* input_event, void* ctx) { static void app_input_callback(InputEvent* input_event, void* ctx) {

View File

@@ -13,7 +13,7 @@
#include "example_images_icons.h" #include "example_images_icons.h"
typedef struct { typedef struct {
uint8_t x, y; int32_t x, y;
} ImagePosition; } ImagePosition;
static ImagePosition image_position = {.x = 0, .y = 0}; static ImagePosition image_position = {.x = 0, .y = 0};
@@ -23,7 +23,7 @@ static void app_draw_callback(Canvas* canvas, void* ctx) {
UNUSED(ctx); UNUSED(ctx);
canvas_clear(canvas); canvas_clear(canvas);
canvas_draw_icon(canvas, image_position.x % 128, image_position.y % 64, &I_dolphin_71x25); canvas_draw_icon(canvas, image_position.x, image_position.y, &I_dolphin_71x25);
} }
static void app_input_callback(InputEvent* input_event, void* ctx) { static void app_input_callback(InputEvent* input_event, void* ctx) {

View File

@@ -14,14 +14,14 @@
#define LOCKED_HINT_TIMEOUT_MS (1000) #define LOCKED_HINT_TIMEOUT_MS (1000)
#define UNLOCKED_HINT_TIMEOUT_MS (2000) #define UNLOCKED_HINT_TIMEOUT_MS (2000)
#define DOOR_OFFSET_START -55 #define DOOR_OFFSET_START (-55)
#define DOOR_OFFSET_END 0 #define DOOR_OFFSET_END (0)
#define DOOR_L_FINAL_POS 0 #define DOOR_L_FINAL_POS (0)
#define DOOR_R_FINAL_POS 60 #define DOOR_R_FINAL_POS (60)
#define UNLOCK_CNT 3 #define UNLOCK_CNT (3)
#define UNLOCK_RST_TIMEOUT 600 #define UNLOCK_RST_TIMEOUT (600)
struct DesktopViewLocked { struct DesktopViewLocked {
View* view; View* view;
@@ -63,10 +63,10 @@ static void locked_view_timer_callback(void* context) {
} }
static void desktop_view_locked_doors_draw(Canvas* canvas, DesktopViewLockedModel* model) { static void desktop_view_locked_doors_draw(Canvas* canvas, DesktopViewLockedModel* model) {
int8_t offset = model->door_offset; int32_t offset = model->door_offset;
uint8_t door_left_x = DOOR_L_FINAL_POS + offset; int32_t door_left_x = DOOR_L_FINAL_POS + offset;
uint8_t door_right_x = DOOR_R_FINAL_POS - offset; int32_t door_right_x = DOOR_R_FINAL_POS - offset;
uint8_t height = icon_get_height(&I_DoorLeft_70x55); size_t height = icon_get_height(&I_DoorLeft_70x55);
canvas_draw_icon(canvas, door_left_x, canvas_height(canvas) - height, &I_DoorLeft_70x55); canvas_draw_icon(canvas, door_left_x, canvas_height(canvas) - height, &I_DoorLeft_70x55);
canvas_draw_icon(canvas, door_right_x, canvas_height(canvas) - height, &I_DoorRight_70x55); canvas_draw_icon(canvas, door_right_x, canvas_height(canvas) - height, &I_DoorRight_70x55);
} }

View File

@@ -95,10 +95,10 @@ size_t canvas_get_buffer_size(const Canvas* canvas) {
void canvas_frame_set( void canvas_frame_set(
Canvas* canvas, Canvas* canvas,
uint8_t offset_x, int32_t offset_x,
uint8_t offset_y, int32_t offset_y,
uint8_t width, size_t width,
uint8_t height) { size_t height) {
furi_check(canvas); furi_check(canvas);
canvas->offset_x = offset_x; canvas->offset_x = offset_x;
canvas->offset_y = offset_y; canvas->offset_y = offset_y;
@@ -106,19 +106,19 @@ void canvas_frame_set(
canvas->height = height; canvas->height = height;
} }
uint8_t canvas_width(const Canvas* canvas) { size_t canvas_width(const Canvas* canvas) {
furi_check(canvas); furi_check(canvas);
return canvas->width; return canvas->width;
} }
uint8_t canvas_height(const Canvas* canvas) { size_t canvas_height(const Canvas* canvas) {
furi_check(canvas); furi_check(canvas);
return canvas->height; return canvas->height;
} }
uint8_t canvas_current_font_height(const Canvas* canvas) { size_t canvas_current_font_height(const Canvas* canvas) {
furi_check(canvas); furi_check(canvas);
uint8_t font_height = u8g2_GetMaxCharHeight(&canvas->fb); size_t font_height = u8g2_GetMaxCharHeight(&canvas->fb);
if(canvas->fb.font == u8g2_font_haxrcorp4089_tr) { if(canvas->fb.font == u8g2_font_haxrcorp4089_tr) {
font_height += 1; font_height += 1;
@@ -174,18 +174,18 @@ void canvas_set_custom_u8g2_font(Canvas* canvas, const uint8_t* font) {
u8g2_SetFont(&canvas->fb, font); u8g2_SetFont(&canvas->fb, font);
} }
void canvas_draw_str(Canvas* canvas, uint8_t x, uint8_t y, const char* str) { void canvas_draw_str(Canvas* canvas, int32_t x, int32_t y, const char* str) {
furi_check(canvas); furi_check(canvas);
if(!str) return; if(!str) return;
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
u8g2_DrawStr(&canvas->fb, x, y, str); u8g2_DrawUTF8(&canvas->fb, x, y, str);
} }
void canvas_draw_str_aligned( void canvas_draw_str_aligned(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
Align horizontal, Align horizontal,
Align vertical, Align vertical,
const char* str) { const char* str) {
@@ -198,10 +198,10 @@ void canvas_draw_str_aligned(
case AlignLeft: case AlignLeft:
break; break;
case AlignRight: case AlignRight:
x -= u8g2_GetStrWidth(&canvas->fb, str); x -= u8g2_GetUTF8Width(&canvas->fb, str);
break; break;
case AlignCenter: case AlignCenter:
x -= (u8g2_GetStrWidth(&canvas->fb, str) / 2); x -= (u8g2_GetUTF8Width(&canvas->fb, str) / 2);
break; break;
default: default:
furi_crash(); furi_crash();
@@ -222,26 +222,26 @@ void canvas_draw_str_aligned(
break; break;
} }
u8g2_DrawStr(&canvas->fb, x, y, str); u8g2_DrawUTF8(&canvas->fb, x, y, str);
} }
uint16_t canvas_string_width(Canvas* canvas, const char* str) { uint16_t canvas_string_width(Canvas* canvas, const char* str) {
furi_check(canvas); furi_check(canvas);
if(!str) return 0; if(!str) return 0;
return u8g2_GetStrWidth(&canvas->fb, str); return u8g2_GetUTF8Width(&canvas->fb, str);
} }
uint8_t canvas_glyph_width(Canvas* canvas, uint16_t symbol) { size_t canvas_glyph_width(Canvas* canvas, uint16_t symbol) {
furi_check(canvas); furi_check(canvas);
return u8g2_GetGlyphWidth(&canvas->fb, symbol); return u8g2_GetGlyphWidth(&canvas->fb, symbol);
} }
void canvas_draw_bitmap( void canvas_draw_bitmap(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
const uint8_t* compressed_bitmap_data) { const uint8_t* compressed_bitmap_data) {
furi_check(canvas); furi_check(canvas);
@@ -254,8 +254,8 @@ void canvas_draw_bitmap(
void canvas_draw_icon_animation( void canvas_draw_icon_animation(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
IconAnimation* icon_animation) { IconAnimation* icon_animation) {
furi_check(canvas); furi_check(canvas);
furi_check(icon_animation); furi_check(icon_animation);
@@ -350,28 +350,28 @@ static void canvas_draw_u8g2_bitmap_int(
void canvas_draw_u8g2_bitmap( void canvas_draw_u8g2_bitmap(
u8g2_t* u8g2, u8g2_t* u8g2,
u8g2_uint_t x, int32_t x,
u8g2_uint_t y, int32_t y,
u8g2_uint_t w, size_t width,
u8g2_uint_t h, size_t height,
const uint8_t* bitmap, const uint8_t* bitmap,
IconRotation rotation) { IconRotation rotation) {
#ifdef U8G2_WITH_INTERSECTION #ifdef U8G2_WITH_INTERSECTION
if(u8g2_IsIntersection(u8g2, x, y, x + w, y + h) == 0) return; if(u8g2_IsIntersection(u8g2, x, y, x + width, y + height) == 0) return;
#endif /* U8G2_WITH_INTERSECTION */ #endif /* U8G2_WITH_INTERSECTION */
switch(rotation) { switch(rotation) {
case IconRotation0: case IconRotation0:
canvas_draw_u8g2_bitmap_int(u8g2, x, y, w, h, 0, 0, bitmap); canvas_draw_u8g2_bitmap_int(u8g2, x, y, width, height, 0, 0, bitmap);
break; break;
case IconRotation90: case IconRotation90:
canvas_draw_u8g2_bitmap_int(u8g2, x, y, w, h, 0, 1, bitmap); canvas_draw_u8g2_bitmap_int(u8g2, x, y, width, height, 0, 1, bitmap);
break; break;
case IconRotation180: case IconRotation180:
canvas_draw_u8g2_bitmap_int(u8g2, x, y, w, h, 1, 0, bitmap); canvas_draw_u8g2_bitmap_int(u8g2, x, y, width, height, 1, 0, bitmap);
break; break;
case IconRotation270: case IconRotation270:
canvas_draw_u8g2_bitmap_int(u8g2, x, y, w, h, 1, 1, bitmap); canvas_draw_u8g2_bitmap_int(u8g2, x, y, width, height, 1, 1, bitmap);
break; break;
default: default:
break; break;
@@ -380,8 +380,8 @@ void canvas_draw_u8g2_bitmap(
void canvas_draw_icon_ex( void canvas_draw_icon_ex(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
const Icon* icon, const Icon* icon,
IconRotation rotation) { IconRotation rotation) {
furi_check(canvas); furi_check(canvas);
@@ -395,7 +395,7 @@ void canvas_draw_icon_ex(
&canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_data, rotation); &canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_data, rotation);
} }
void canvas_draw_icon(Canvas* canvas, uint8_t x, uint8_t y, const Icon* icon) { void canvas_draw_icon(Canvas* canvas, int32_t x, int32_t y, const Icon* icon) {
furi_check(canvas); furi_check(canvas);
furi_check(icon); furi_check(icon);
@@ -407,14 +407,14 @@ void canvas_draw_icon(Canvas* canvas, uint8_t x, uint8_t y, const Icon* icon) {
&canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_data, IconRotation0); &canvas->fb, x, y, icon_get_width(icon), icon_get_height(icon), icon_data, IconRotation0);
} }
void canvas_draw_dot(Canvas* canvas, uint8_t x, uint8_t y) { void canvas_draw_dot(Canvas* canvas, int32_t x, int32_t y) {
furi_check(canvas); furi_check(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_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { void canvas_draw_box(Canvas* canvas, int32_t x, int32_t y, size_t width, size_t height) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
@@ -423,18 +423,18 @@ void canvas_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_
void canvas_draw_rbox( void canvas_draw_rbox(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
uint8_t radius) { size_t radius) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
u8g2_DrawRBox(&canvas->fb, x, y, width, height, radius); u8g2_DrawRBox(&canvas->fb, x, y, width, height, radius);
} }
void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height) { void canvas_draw_frame(Canvas* canvas, int32_t x, int32_t y, size_t width, size_t height) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
@@ -443,18 +443,18 @@ void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint
void canvas_draw_rframe( void canvas_draw_rframe(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
uint8_t radius) { size_t radius) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
u8g2_DrawRFrame(&canvas->fb, x, y, width, height, radius); u8g2_DrawRFrame(&canvas->fb, x, y, width, height, radius);
} }
void canvas_draw_line(Canvas* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2) { void canvas_draw_line(Canvas* canvas, int32_t x1, int32_t y1, int32_t x2, int32_t y2) {
furi_check(canvas); furi_check(canvas);
x1 += canvas->offset_x; x1 += canvas->offset_x;
y1 += canvas->offset_y; y1 += canvas->offset_y;
@@ -463,14 +463,14 @@ void canvas_draw_line(Canvas* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_
u8g2_DrawLine(&canvas->fb, x1, y1, x2, y2); u8g2_DrawLine(&canvas->fb, x1, y1, x2, y2);
} }
void canvas_draw_circle(Canvas* canvas, uint8_t x, uint8_t y, uint8_t radius) { void canvas_draw_circle(Canvas* canvas, int32_t x, int32_t y, size_t radius) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
u8g2_DrawCircle(&canvas->fb, x, y, radius, U8G2_DRAW_ALL); u8g2_DrawCircle(&canvas->fb, x, y, radius, U8G2_DRAW_ALL);
} }
void canvas_draw_disc(Canvas* canvas, uint8_t x, uint8_t y, uint8_t radius) { void canvas_draw_disc(Canvas* canvas, int32_t x, int32_t y, size_t radius) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
@@ -479,10 +479,10 @@ void canvas_draw_disc(Canvas* canvas, uint8_t x, uint8_t y, uint8_t radius) {
void canvas_draw_triangle( void canvas_draw_triangle(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t base, size_t base,
uint8_t height, size_t height,
CanvasDirection dir) { CanvasDirection dir) {
furi_check(canvas); furi_check(canvas);
if(dir == CanvasDirectionBottomToTop) { if(dir == CanvasDirectionBottomToTop) {
@@ -506,18 +506,18 @@ void canvas_draw_triangle(
void canvas_draw_xbm( void canvas_draw_xbm(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t w, size_t width,
uint8_t h, size_t height,
const uint8_t* bitmap) { const uint8_t* bitmap) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
canvas_draw_u8g2_bitmap(&canvas->fb, x, y, w, h, bitmap, IconRotation0); canvas_draw_u8g2_bitmap(&canvas->fb, x, y, width, height, bitmap, IconRotation0);
} }
void canvas_draw_glyph(Canvas* canvas, uint8_t x, uint8_t y, uint16_t ch) { void canvas_draw_glyph(Canvas* canvas, int32_t x, int32_t y, uint16_t ch) {
furi_check(canvas); furi_check(canvas);
x += canvas->offset_x; x += canvas->offset_x;
y += canvas->offset_y; y += canvas->offset_y;
@@ -591,4 +591,4 @@ void canvas_remove_framebuffer_callback(
furi_check(CanvasCallbackPairArray_count(canvas->canvas_callback_pair, p) == 1); furi_check(CanvasCallbackPairArray_count(canvas->canvas_callback_pair, p) == 1);
CanvasCallbackPairArray_remove_val(canvas->canvas_callback_pair, p); CanvasCallbackPairArray_remove_val(canvas->canvas_callback_pair, p);
canvas_unlock(canvas); canvas_unlock(canvas);
} }

View File

@@ -6,6 +6,7 @@
#pragma once #pragma once
#include <stdint.h> #include <stdint.h>
#include <stddef.h>
#include <gui/icon_animation.h> #include <gui/icon_animation.h>
#include <gui/icon.h> #include <gui/icon.h>
@@ -101,7 +102,7 @@ void canvas_commit(Canvas* canvas);
* *
* @return width in pixels. * @return width in pixels.
*/ */
uint8_t canvas_width(const Canvas* canvas); size_t canvas_width(const Canvas* canvas);
/** Get Canvas height /** Get Canvas height
* *
@@ -109,7 +110,7 @@ uint8_t canvas_width(const Canvas* canvas);
* *
* @return height in pixels. * @return height in pixels.
*/ */
uint8_t canvas_height(const Canvas* canvas); size_t canvas_height(const Canvas* canvas);
/** Get current font height /** Get current font height
* *
@@ -117,7 +118,7 @@ uint8_t canvas_height(const Canvas* canvas);
* *
* @return height in pixels. * @return height in pixels.
*/ */
uint8_t canvas_current_font_height(const Canvas* canvas); size_t canvas_current_font_height(const Canvas* canvas);
/** Get font parameters /** Get font parameters
* *
@@ -141,8 +142,7 @@ void canvas_clear(Canvas* canvas);
*/ */
void canvas_set_color(Canvas* canvas, Color color); void canvas_set_color(Canvas* canvas, Color color);
/** Set font swap /** Set font swap Argument String Rotation Description
* Argument String Rotation Description
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param dir Direction font * @param dir Direction font
@@ -176,7 +176,7 @@ void canvas_set_custom_u8g2_font(Canvas* canvas, const uint8_t* font);
* @param y anchor point y coordinate * @param y anchor point y coordinate
* @param str C-string * @param str C-string
*/ */
void canvas_draw_str(Canvas* canvas, uint8_t x, uint8_t y, const char* str); void canvas_draw_str(Canvas* canvas, int32_t x, int32_t y, const char* str);
/** Draw aligned string defined by x, y. /** Draw aligned string defined by x, y.
* *
@@ -192,8 +192,8 @@ void canvas_draw_str(Canvas* canvas, uint8_t x, uint8_t y, const char* str);
*/ */
void canvas_draw_str_aligned( void canvas_draw_str_aligned(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
Align horizontal, Align horizontal,
Align vertical, Align vertical,
const char* str); const char* str);
@@ -214,37 +214,37 @@ uint16_t canvas_string_width(Canvas* canvas, const char* str);
* *
* @return width in pixels * @return width in pixels
*/ */
uint8_t canvas_glyph_width(Canvas* canvas, uint16_t symbol); size_t canvas_glyph_width(Canvas* canvas, uint16_t symbol);
/** Draw bitmap picture at position defined by x,y. /** Draw bitmap picture at position defined by x,y.
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
* @param width width of bitmap * @param width width of bitmap
* @param height height of bitmap * @param height height of bitmap
* @param compressed_bitmap_data compressed bitmap data * @param compressed_bitmap_data compressed bitmap data
*/ */
void canvas_draw_bitmap( void canvas_draw_bitmap(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
const uint8_t* compressed_bitmap_data); const uint8_t* compressed_bitmap_data);
/** Draw icon at position defined by x,y with rotation and flip. /** Draw icon at position defined by x,y with rotation and flip.
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
* @param icon Icon instance * @param icon Icon instance
* @param rotation IconRotation * @param rotation IconRotation
*/ */
void canvas_draw_icon_ex( void canvas_draw_icon_ex(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
const Icon* icon, const Icon* icon,
IconRotation rotation); IconRotation rotation);
@@ -257,8 +257,8 @@ void canvas_draw_icon_ex(
*/ */
void canvas_draw_icon_animation( void canvas_draw_icon_animation(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
IconAnimation* icon_animation); IconAnimation* icon_animation);
/** Draw icon at position defined by x,y. /** Draw icon at position defined by x,y.
@@ -268,23 +268,23 @@ void canvas_draw_icon_animation(
* @param y y coordinate * @param y y coordinate
* @param icon Icon instance * @param icon Icon instance
*/ */
void canvas_draw_icon(Canvas* canvas, uint8_t x, uint8_t y, const Icon* icon); void canvas_draw_icon(Canvas* canvas, int32_t x, int32_t y, const Icon* icon);
/** Draw XBM bitmap /** Draw XBM bitmap
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
* @param w bitmap width * @param[in] width bitmap width
* @param h bitmap height * @param[in] height bitmap height
* @param bitmap pointer to XBM bitmap data * @param bitmap pointer to XBM bitmap data
*/ */
void canvas_draw_xbm( void canvas_draw_xbm(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t w, size_t width,
uint8_t h, size_t height,
const uint8_t* bitmap); const uint8_t* bitmap);
/** Draw dot at x,y /** Draw dot at x,y
@@ -293,7 +293,7 @@ void canvas_draw_xbm(
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
*/ */
void canvas_draw_dot(Canvas* canvas, uint8_t x, uint8_t y); void canvas_draw_dot(Canvas* canvas, int32_t x, int32_t y);
/** Draw box of width, height at x,y /** Draw box of width, height at x,y
* *
@@ -303,7 +303,7 @@ void canvas_draw_dot(Canvas* canvas, uint8_t x, uint8_t y);
* @param width box width * @param width box width
* @param height box height * @param height box height
*/ */
void canvas_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); void canvas_draw_box(Canvas* canvas, int32_t x, int32_t y, size_t width, size_t height);
/** Draw frame of width, height at x,y /** Draw frame of width, height at x,y
* *
@@ -313,7 +313,7 @@ void canvas_draw_box(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_
* @param width frame width * @param width frame width
* @param height frame height * @param height frame height
*/ */
void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height); void canvas_draw_frame(Canvas* canvas, int32_t x, int32_t y, size_t width, size_t height);
/** Draw line from x1,y1 to x2,y2 /** Draw line from x1,y1 to x2,y2
* *
@@ -323,41 +323,42 @@ void canvas_draw_frame(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint
* @param x2 x2 coordinate * @param x2 x2 coordinate
* @param y2 y2 coordinate * @param y2 y2 coordinate
*/ */
void canvas_draw_line(Canvas* canvas, uint8_t x1, uint8_t y1, uint8_t x2, uint8_t y2); void canvas_draw_line(Canvas* canvas, int32_t x1, int32_t y1, int32_t x2, int32_t y2);
/** Draw circle at x,y with radius r /** Draw circle at x,y with radius r
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
* @param r radius * @param radius radius
*/ */
void canvas_draw_circle(Canvas* canvas, uint8_t x, uint8_t y, uint8_t r); void canvas_draw_circle(Canvas* canvas, int32_t x, int32_t y, size_t radius);
/** Draw disc at x,y with radius r /** Draw disc at x,y with radius r
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate * @param x x coordinate
* @param y y coordinate * @param y y coordinate
* @param r radius * @param radius radius
*/ */
void canvas_draw_disc(Canvas* canvas, uint8_t x, uint8_t y, uint8_t r); void canvas_draw_disc(Canvas* canvas, int32_t x, int32_t y, size_t radius);
/** Draw triangle with given base and height lengths and their intersection coordinate /** Draw triangle with given base and height lengths and their intersection
* coordinate
* *
* @param canvas Canvas instance * @param canvas Canvas instance
* @param x x coordinate of base and height intersection * @param x x coordinate of base and height intersection
* @param y y coordinate of base and height intersection * @param y y coordinate of base and height intersection
* @param base length of triangle side * @param base length of triangle side
* @param height length of triangle height * @param height length of triangle height
* @param dir CanvasDirection triangle orientation * @param dir CanvasDirection triangle orientation
*/ */
void canvas_draw_triangle( void canvas_draw_triangle(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t base, size_t base,
uint8_t height, size_t height,
CanvasDirection dir); CanvasDirection dir);
/** Draw glyph /** Draw glyph
@@ -367,7 +368,7 @@ void canvas_draw_triangle(
* @param y y coordinate * @param y y coordinate
* @param ch character * @param ch character
*/ */
void canvas_draw_glyph(Canvas* canvas, uint8_t x, uint8_t y, uint16_t ch); void canvas_draw_glyph(Canvas* canvas, int32_t x, int32_t y, uint16_t ch);
/** Set transparency mode /** Set transparency mode
* *
@@ -387,11 +388,11 @@ void canvas_set_bitmap_mode(Canvas* canvas, bool alpha);
*/ */
void canvas_draw_rframe( void canvas_draw_rframe(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
uint8_t radius); size_t radius);
/** Draw rounded-corner box of width, height at x,y, with round value raduis /** Draw rounded-corner box of width, height at x,y, with round value raduis
* *
@@ -404,11 +405,11 @@ void canvas_draw_rframe(
*/ */
void canvas_draw_rbox( void canvas_draw_rbox(
Canvas* canvas, Canvas* canvas,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
uint8_t radius); size_t radius);
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@@ -38,10 +38,10 @@ ALGO_DEF(CanvasCallbackPairArray, CanvasCallbackPairArray_t);
struct Canvas { struct Canvas {
u8g2_t fb; u8g2_t fb;
CanvasOrientation orientation; CanvasOrientation orientation;
uint8_t offset_x; size_t offset_x;
uint8_t offset_y; size_t offset_y;
uint8_t width; size_t width;
uint8_t height; size_t height;
CompressIcon* compress_icon; CompressIcon* compress_icon;
CanvasCallbackPairArray_t canvas_callback_pair; CanvasCallbackPairArray_t canvas_callback_pair;
FuriMutex* mutex; FuriMutex* mutex;
@@ -85,10 +85,10 @@ size_t canvas_get_buffer_size(const Canvas* canvas);
*/ */
void canvas_frame_set( void canvas_frame_set(
Canvas* canvas, Canvas* canvas,
uint8_t offset_x, int32_t offset_x,
uint8_t offset_y, int32_t offset_y,
uint8_t width, size_t width,
uint8_t height); size_t height);
/** Set canvas orientation /** Set canvas orientation
* *
@@ -117,10 +117,10 @@ CanvasOrientation canvas_get_orientation(const Canvas* canvas);
*/ */
void canvas_draw_u8g2_bitmap( void canvas_draw_u8g2_bitmap(
u8g2_t* u8g2, u8g2_t* u8g2,
uint8_t x, int32_t x,
uint8_t y, int32_t y,
uint8_t width, size_t width,
uint8_t height, size_t height,
const uint8_t* bitmap, const uint8_t* bitmap,
IconRotation rotation); IconRotation rotation);

View File

@@ -98,6 +98,13 @@ FURI_NORETURN void __furi_halt_implementation(void);
#define furi_assert(...) \ #define furi_assert(...) \
M_APPLY(__furi_assert, M_DEFAULT_ARGS(2, (__FURI_ASSERT_MESSAGE_FLAG), __VA_ARGS__)) M_APPLY(__furi_assert, M_DEFAULT_ARGS(2, (__FURI_ASSERT_MESSAGE_FLAG), __VA_ARGS__))
#define furi_break(__e) \
do { \
if(!(__e)) { \
asm volatile("bkpt 0"); \
} \
} while(0)
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@@ -67,7 +67,7 @@
Use 16 Bit mode for any display with more than 240 pixel in one Use 16 Bit mode for any display with more than 240 pixel in one
direction. direction.
*/ */
//#define U8G2_16BIT #define U8G2_16BIT
/* /*
The following macro switches the library into dynamic display buffer allocation mode. The following macro switches the library into dynamic display buffer allocation mode.

View File

@@ -712,27 +712,27 @@ Function,-,bzero,void,"void*, size_t"
Function,+,calloc,void*,"size_t, size_t" Function,+,calloc,void*,"size_t, size_t"
Function,+,canvas_clear,void,Canvas* Function,+,canvas_clear,void,Canvas*
Function,+,canvas_commit,void,Canvas* Function,+,canvas_commit,void,Canvas*
Function,+,canvas_current_font_height,uint8_t,const Canvas* Function,+,canvas_current_font_height,size_t,const Canvas*
Function,+,canvas_draw_bitmap,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t*" Function,+,canvas_draw_bitmap,void,"Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*"
Function,+,canvas_draw_box,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_box,void,"Canvas*, int32_t, int32_t, size_t, size_t"
Function,+,canvas_draw_circle,void,"Canvas*, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_circle,void,"Canvas*, int32_t, int32_t, size_t"
Function,+,canvas_draw_disc,void,"Canvas*, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_disc,void,"Canvas*, int32_t, int32_t, size_t"
Function,+,canvas_draw_dot,void,"Canvas*, uint8_t, uint8_t" Function,+,canvas_draw_dot,void,"Canvas*, int32_t, int32_t"
Function,+,canvas_draw_frame,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_frame,void,"Canvas*, int32_t, int32_t, size_t, size_t"
Function,+,canvas_draw_glyph,void,"Canvas*, uint8_t, uint8_t, uint16_t" Function,+,canvas_draw_glyph,void,"Canvas*, int32_t, int32_t, uint16_t"
Function,+,canvas_draw_icon,void,"Canvas*, uint8_t, uint8_t, const Icon*" Function,+,canvas_draw_icon,void,"Canvas*, int32_t, int32_t, const Icon*"
Function,+,canvas_draw_icon_animation,void,"Canvas*, uint8_t, uint8_t, IconAnimation*" Function,+,canvas_draw_icon_animation,void,"Canvas*, int32_t, int32_t, IconAnimation*"
Function,+,canvas_draw_icon_ex,void,"Canvas*, uint8_t, uint8_t, const Icon*, IconRotation" Function,+,canvas_draw_icon_ex,void,"Canvas*, int32_t, int32_t, const Icon*, IconRotation"
Function,+,canvas_draw_line,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_line,void,"Canvas*, int32_t, int32_t, int32_t, int32_t"
Function,+,canvas_draw_rbox,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_rbox,void,"Canvas*, int32_t, int32_t, size_t, size_t, size_t"
Function,+,canvas_draw_rframe,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_rframe,void,"Canvas*, int32_t, int32_t, size_t, size_t, size_t"
Function,+,canvas_draw_str,void,"Canvas*, uint8_t, uint8_t, const char*" Function,+,canvas_draw_str,void,"Canvas*, int32_t, int32_t, const char*"
Function,+,canvas_draw_str_aligned,void,"Canvas*, uint8_t, uint8_t, Align, Align, const char*" Function,+,canvas_draw_str_aligned,void,"Canvas*, int32_t, int32_t, Align, Align, const char*"
Function,+,canvas_draw_triangle,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, CanvasDirection" Function,+,canvas_draw_triangle,void,"Canvas*, int32_t, int32_t, size_t, size_t, CanvasDirection"
Function,+,canvas_draw_xbm,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t*" Function,+,canvas_draw_xbm,void,"Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*"
Function,+,canvas_get_font_params,const CanvasFontParameters*,"const Canvas*, Font" Function,+,canvas_get_font_params,const CanvasFontParameters*,"const Canvas*, Font"
Function,+,canvas_glyph_width,uint8_t,"Canvas*, uint16_t" Function,+,canvas_glyph_width,size_t,"Canvas*, uint16_t"
Function,+,canvas_height,uint8_t,const Canvas* Function,+,canvas_height,size_t,const Canvas*
Function,+,canvas_invert_color,void,Canvas* Function,+,canvas_invert_color,void,Canvas*
Function,+,canvas_reset,void,Canvas* Function,+,canvas_reset,void,Canvas*
Function,+,canvas_set_bitmap_mode,void,"Canvas*, _Bool" Function,+,canvas_set_bitmap_mode,void,"Canvas*, _Bool"
@@ -741,7 +741,7 @@ Function,+,canvas_set_custom_u8g2_font,void,"Canvas*, const uint8_t*"
Function,+,canvas_set_font,void,"Canvas*, Font" Function,+,canvas_set_font,void,"Canvas*, Font"
Function,+,canvas_set_font_direction,void,"Canvas*, CanvasDirection" Function,+,canvas_set_font_direction,void,"Canvas*, CanvasDirection"
Function,+,canvas_string_width,uint16_t,"Canvas*, const char*" Function,+,canvas_string_width,uint16_t,"Canvas*, const char*"
Function,+,canvas_width,uint8_t,const Canvas* Function,+,canvas_width,size_t,const Canvas*
Function,-,cbrt,double,double Function,-,cbrt,double,double
Function,-,cbrtf,float,float Function,-,cbrtf,float,float
Function,-,cbrtl,long double,long double Function,-,cbrtl,long double,long double
1 entry status name type params
712 Function + calloc void* size_t, size_t
713 Function + canvas_clear void Canvas*
714 Function + canvas_commit void Canvas*
715 Function + canvas_current_font_height uint8_t size_t const Canvas*
716 Function + canvas_draw_bitmap void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t* Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*
717 Function + canvas_draw_box void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t
718 Function + canvas_draw_circle void Canvas*, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t
719 Function + canvas_draw_disc void Canvas*, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t
720 Function + canvas_draw_dot void Canvas*, uint8_t, uint8_t Canvas*, int32_t, int32_t
721 Function + canvas_draw_frame void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t
722 Function + canvas_draw_glyph void Canvas*, uint8_t, uint8_t, uint16_t Canvas*, int32_t, int32_t, uint16_t
723 Function + canvas_draw_icon void Canvas*, uint8_t, uint8_t, const Icon* Canvas*, int32_t, int32_t, const Icon*
724 Function + canvas_draw_icon_animation void Canvas*, uint8_t, uint8_t, IconAnimation* Canvas*, int32_t, int32_t, IconAnimation*
725 Function + canvas_draw_icon_ex void Canvas*, uint8_t, uint8_t, const Icon*, IconRotation Canvas*, int32_t, int32_t, const Icon*, IconRotation
726 Function + canvas_draw_line void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, int32_t, int32_t
727 Function + canvas_draw_rbox void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t, size_t
728 Function + canvas_draw_rframe void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t, size_t
729 Function + canvas_draw_str void Canvas*, uint8_t, uint8_t, const char* Canvas*, int32_t, int32_t, const char*
730 Function + canvas_draw_str_aligned void Canvas*, uint8_t, uint8_t, Align, Align, const char* Canvas*, int32_t, int32_t, Align, Align, const char*
731 Function + canvas_draw_triangle void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, CanvasDirection Canvas*, int32_t, int32_t, size_t, size_t, CanvasDirection
732 Function + canvas_draw_xbm void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t* Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*
733 Function + canvas_get_font_params const CanvasFontParameters* const Canvas*, Font
734 Function + canvas_glyph_width uint8_t size_t Canvas*, uint16_t
735 Function + canvas_height uint8_t size_t const Canvas*
736 Function + canvas_invert_color void Canvas*
737 Function + canvas_reset void Canvas*
738 Function + canvas_set_bitmap_mode void Canvas*, _Bool
741 Function + canvas_set_font void Canvas*, Font
742 Function + canvas_set_font_direction void Canvas*, CanvasDirection
743 Function + canvas_string_width uint16_t Canvas*, const char*
744 Function + canvas_width uint8_t size_t const Canvas*
745 Function - cbrt double double
746 Function - cbrtf float float
747 Function - cbrtl long double long double

View File

@@ -780,27 +780,27 @@ Function,-,bzero,void,"void*, size_t"
Function,+,calloc,void*,"size_t, size_t" Function,+,calloc,void*,"size_t, size_t"
Function,+,canvas_clear,void,Canvas* Function,+,canvas_clear,void,Canvas*
Function,+,canvas_commit,void,Canvas* Function,+,canvas_commit,void,Canvas*
Function,+,canvas_current_font_height,uint8_t,const Canvas* Function,+,canvas_current_font_height,size_t,const Canvas*
Function,+,canvas_draw_bitmap,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t*" Function,+,canvas_draw_bitmap,void,"Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*"
Function,+,canvas_draw_box,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_box,void,"Canvas*, int32_t, int32_t, size_t, size_t"
Function,+,canvas_draw_circle,void,"Canvas*, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_circle,void,"Canvas*, int32_t, int32_t, size_t"
Function,+,canvas_draw_disc,void,"Canvas*, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_disc,void,"Canvas*, int32_t, int32_t, size_t"
Function,+,canvas_draw_dot,void,"Canvas*, uint8_t, uint8_t" Function,+,canvas_draw_dot,void,"Canvas*, int32_t, int32_t"
Function,+,canvas_draw_frame,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_frame,void,"Canvas*, int32_t, int32_t, size_t, size_t"
Function,+,canvas_draw_glyph,void,"Canvas*, uint8_t, uint8_t, uint16_t" Function,+,canvas_draw_glyph,void,"Canvas*, int32_t, int32_t, uint16_t"
Function,+,canvas_draw_icon,void,"Canvas*, uint8_t, uint8_t, const Icon*" Function,+,canvas_draw_icon,void,"Canvas*, int32_t, int32_t, const Icon*"
Function,+,canvas_draw_icon_animation,void,"Canvas*, uint8_t, uint8_t, IconAnimation*" Function,+,canvas_draw_icon_animation,void,"Canvas*, int32_t, int32_t, IconAnimation*"
Function,+,canvas_draw_icon_ex,void,"Canvas*, uint8_t, uint8_t, const Icon*, IconRotation" Function,+,canvas_draw_icon_ex,void,"Canvas*, int32_t, int32_t, const Icon*, IconRotation"
Function,+,canvas_draw_line,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_line,void,"Canvas*, int32_t, int32_t, int32_t, int32_t"
Function,+,canvas_draw_rbox,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_rbox,void,"Canvas*, int32_t, int32_t, size_t, size_t, size_t"
Function,+,canvas_draw_rframe,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t" Function,+,canvas_draw_rframe,void,"Canvas*, int32_t, int32_t, size_t, size_t, size_t"
Function,+,canvas_draw_str,void,"Canvas*, uint8_t, uint8_t, const char*" Function,+,canvas_draw_str,void,"Canvas*, int32_t, int32_t, const char*"
Function,+,canvas_draw_str_aligned,void,"Canvas*, uint8_t, uint8_t, Align, Align, const char*" Function,+,canvas_draw_str_aligned,void,"Canvas*, int32_t, int32_t, Align, Align, const char*"
Function,+,canvas_draw_triangle,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, CanvasDirection" Function,+,canvas_draw_triangle,void,"Canvas*, int32_t, int32_t, size_t, size_t, CanvasDirection"
Function,+,canvas_draw_xbm,void,"Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t*" Function,+,canvas_draw_xbm,void,"Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*"
Function,+,canvas_get_font_params,const CanvasFontParameters*,"const Canvas*, Font" Function,+,canvas_get_font_params,const CanvasFontParameters*,"const Canvas*, Font"
Function,+,canvas_glyph_width,uint8_t,"Canvas*, uint16_t" Function,+,canvas_glyph_width,size_t,"Canvas*, uint16_t"
Function,+,canvas_height,uint8_t,const Canvas* Function,+,canvas_height,size_t,const Canvas*
Function,+,canvas_invert_color,void,Canvas* Function,+,canvas_invert_color,void,Canvas*
Function,+,canvas_reset,void,Canvas* Function,+,canvas_reset,void,Canvas*
Function,+,canvas_set_bitmap_mode,void,"Canvas*, _Bool" Function,+,canvas_set_bitmap_mode,void,"Canvas*, _Bool"
@@ -809,7 +809,7 @@ Function,+,canvas_set_custom_u8g2_font,void,"Canvas*, const uint8_t*"
Function,+,canvas_set_font,void,"Canvas*, Font" Function,+,canvas_set_font,void,"Canvas*, Font"
Function,+,canvas_set_font_direction,void,"Canvas*, CanvasDirection" Function,+,canvas_set_font_direction,void,"Canvas*, CanvasDirection"
Function,+,canvas_string_width,uint16_t,"Canvas*, const char*" Function,+,canvas_string_width,uint16_t,"Canvas*, const char*"
Function,+,canvas_width,uint8_t,const Canvas* Function,+,canvas_width,size_t,const Canvas*
Function,-,cbrt,double,double Function,-,cbrt,double,double
Function,-,cbrtf,float,float Function,-,cbrtf,float,float
Function,-,cbrtl,long double,long double Function,-,cbrtl,long double,long double
1 entry status name type params
780 Function + calloc void* size_t, size_t
781 Function + canvas_clear void Canvas*
782 Function + canvas_commit void Canvas*
783 Function + canvas_current_font_height uint8_t size_t const Canvas*
784 Function + canvas_draw_bitmap void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t* Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*
785 Function + canvas_draw_box void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t
786 Function + canvas_draw_circle void Canvas*, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t
787 Function + canvas_draw_disc void Canvas*, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t
788 Function + canvas_draw_dot void Canvas*, uint8_t, uint8_t Canvas*, int32_t, int32_t
789 Function + canvas_draw_frame void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t
790 Function + canvas_draw_glyph void Canvas*, uint8_t, uint8_t, uint16_t Canvas*, int32_t, int32_t, uint16_t
791 Function + canvas_draw_icon void Canvas*, uint8_t, uint8_t, const Icon* Canvas*, int32_t, int32_t, const Icon*
792 Function + canvas_draw_icon_animation void Canvas*, uint8_t, uint8_t, IconAnimation* Canvas*, int32_t, int32_t, IconAnimation*
793 Function + canvas_draw_icon_ex void Canvas*, uint8_t, uint8_t, const Icon*, IconRotation Canvas*, int32_t, int32_t, const Icon*, IconRotation
794 Function + canvas_draw_line void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, int32_t, int32_t
795 Function + canvas_draw_rbox void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t, size_t
796 Function + canvas_draw_rframe void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, uint8_t Canvas*, int32_t, int32_t, size_t, size_t, size_t
797 Function + canvas_draw_str void Canvas*, uint8_t, uint8_t, const char* Canvas*, int32_t, int32_t, const char*
798 Function + canvas_draw_str_aligned void Canvas*, uint8_t, uint8_t, Align, Align, const char* Canvas*, int32_t, int32_t, Align, Align, const char*
799 Function + canvas_draw_triangle void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, CanvasDirection Canvas*, int32_t, int32_t, size_t, size_t, CanvasDirection
800 Function + canvas_draw_xbm void Canvas*, uint8_t, uint8_t, uint8_t, uint8_t, const uint8_t* Canvas*, int32_t, int32_t, size_t, size_t, const uint8_t*
801 Function + canvas_get_font_params const CanvasFontParameters* const Canvas*, Font
802 Function + canvas_glyph_width uint8_t size_t Canvas*, uint16_t
803 Function + canvas_height uint8_t size_t const Canvas*
804 Function + canvas_invert_color void Canvas*
805 Function + canvas_reset void Canvas*
806 Function + canvas_set_bitmap_mode void Canvas*, _Bool
809 Function + canvas_set_font void Canvas*, Font
810 Function + canvas_set_font_direction void Canvas*, CanvasDirection
811 Function + canvas_string_width uint16_t Canvas*, const char*
812 Function + canvas_width uint8_t size_t const Canvas*
813 Function - cbrt double double
814 Function - cbrtf float float
815 Function - cbrtl long double long double