2021-10-03 10:36:05 +00:00
|
|
|
/**
|
|
|
|
* @file canvas_i.h
|
|
|
|
* GUI: internal Canvas API
|
|
|
|
*/
|
|
|
|
|
Display and UI implementation (#169)
* Menu app. Lib: add mlib submodule.
* Menu: new startup lib dependency definition
* Menu: hierarchy in menu. Cube: fix heap1/4 inconsistency, stack protection.
* GUI: rendering pipeline initial version.
* GUI: layered widget composing, FURI record. Menu: FURI record, api.
* GUI: input dispatching. Menu: switch to input from GUI.
* GUI, MENU: code style cleanup, fix type conversion warnings.
* GUI, Menu: syntax check.
* Makefile: check and reinit submodules, format.
* Menu: lock on event processing. Makefile: proper submodule initialization.
* Menu: fix stack corruption by queue.
* GUI: refactor.
* Makefile: format rule fix, st-util pid.
* GUI, Menu, FURI: format with clang-format.
* GUI, MENU: locks in critical sections, fix stack corruption, ready signaling.
* Makefile: clang format rule cleanup.
* GUI,MENU: migrate to new API.
* Applications: PRODUCTION_HW variable, skip drivers build on local target.
* refactor production build
* add git to dockerfile
* GUI: uncomment lock block
Co-authored-by: Aleksandr Kutuzov <aku@plooks.com>
2020-10-14 10:21:55 +00:00
|
|
|
#pragma once
|
|
|
|
|
2020-12-14 10:50:32 +00:00
|
|
|
#include "canvas.h"
|
2021-02-03 09:52:54 +00:00
|
|
|
#include <u8g2.h>
|
2023-03-22 17:00:48 +00:00
|
|
|
#include <toolbox/compress.h>
|
2024-02-07 02:38:20 +00:00
|
|
|
#include <m-array.h>
|
|
|
|
#include <m-algo.h>
|
|
|
|
#include <furi.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef void (*CanvasCommitCallback)(
|
|
|
|
uint8_t* data,
|
|
|
|
size_t size,
|
|
|
|
CanvasOrientation orientation,
|
|
|
|
void* context);
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
CanvasCommitCallback callback;
|
|
|
|
void* context;
|
|
|
|
} CanvasCallbackPair;
|
|
|
|
|
|
|
|
ARRAY_DEF(CanvasCallbackPairArray, CanvasCallbackPair, M_POD_OPLIST);
|
|
|
|
|
|
|
|
#define M_OPL_CanvasCallbackPairArray_t() ARRAY_OPLIST(CanvasCallbackPairArray, M_POD_OPLIST)
|
|
|
|
|
|
|
|
ALGO_DEF(CanvasCallbackPairArray, CanvasCallbackPairArray_t);
|
2021-02-03 09:52:54 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Canvas structure
|
|
|
|
*/
|
2021-02-03 09:52:54 +00:00
|
|
|
struct Canvas {
|
|
|
|
u8g2_t fb;
|
2021-05-19 09:43:15 +00:00
|
|
|
CanvasOrientation orientation;
|
2021-02-03 09:52:54 +00:00
|
|
|
uint8_t offset_x;
|
|
|
|
uint8_t offset_y;
|
|
|
|
uint8_t width;
|
|
|
|
uint8_t height;
|
2023-03-22 17:00:48 +00:00
|
|
|
CompressIcon* compress_icon;
|
2024-02-07 02:38:20 +00:00
|
|
|
CanvasCallbackPairArray_t canvas_callback_pair;
|
|
|
|
FuriMutex* mutex;
|
2021-02-03 09:52:54 +00:00
|
|
|
};
|
Display and UI implementation (#169)
* Menu app. Lib: add mlib submodule.
* Menu: new startup lib dependency definition
* Menu: hierarchy in menu. Cube: fix heap1/4 inconsistency, stack protection.
* GUI: rendering pipeline initial version.
* GUI: layered widget composing, FURI record. Menu: FURI record, api.
* GUI: input dispatching. Menu: switch to input from GUI.
* GUI, MENU: code style cleanup, fix type conversion warnings.
* GUI, Menu: syntax check.
* Makefile: check and reinit submodules, format.
* Menu: lock on event processing. Makefile: proper submodule initialization.
* Menu: fix stack corruption by queue.
* GUI: refactor.
* Makefile: format rule fix, st-util pid.
* GUI, Menu, FURI: format with clang-format.
* GUI, MENU: locks in critical sections, fix stack corruption, ready signaling.
* Makefile: clang format rule cleanup.
* GUI,MENU: migrate to new API.
* Applications: PRODUCTION_HW variable, skip drivers build on local target.
* refactor production build
* add git to dockerfile
* GUI: uncomment lock block
Co-authored-by: Aleksandr Kutuzov <aku@plooks.com>
2020-10-14 10:21:55 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Allocate memory and initialize canvas
|
|
|
|
*
|
|
|
|
* @return Canvas instance
|
2020-12-14 10:50:32 +00:00
|
|
|
*/
|
|
|
|
Canvas* canvas_init();
|
Display and UI implementation (#169)
* Menu app. Lib: add mlib submodule.
* Menu: new startup lib dependency definition
* Menu: hierarchy in menu. Cube: fix heap1/4 inconsistency, stack protection.
* GUI: rendering pipeline initial version.
* GUI: layered widget composing, FURI record. Menu: FURI record, api.
* GUI: input dispatching. Menu: switch to input from GUI.
* GUI, MENU: code style cleanup, fix type conversion warnings.
* GUI, Menu: syntax check.
* Makefile: check and reinit submodules, format.
* Menu: lock on event processing. Makefile: proper submodule initialization.
* Menu: fix stack corruption by queue.
* GUI: refactor.
* Makefile: format rule fix, st-util pid.
* GUI, Menu, FURI: format with clang-format.
* GUI, MENU: locks in critical sections, fix stack corruption, ready signaling.
* Makefile: clang format rule cleanup.
* GUI,MENU: migrate to new API.
* Applications: PRODUCTION_HW variable, skip drivers build on local target.
* refactor production build
* add git to dockerfile
* GUI: uncomment lock block
Co-authored-by: Aleksandr Kutuzov <aku@plooks.com>
2020-10-14 10:21:55 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Free canvas memory
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
2020-12-14 10:50:32 +00:00
|
|
|
*/
|
|
|
|
void canvas_free(Canvas* canvas);
|
2020-10-29 07:11:16 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get canvas buffer.
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
*
|
|
|
|
* @return pointer to buffer
|
2021-02-13 11:40:20 +00:00
|
|
|
*/
|
|
|
|
uint8_t* canvas_get_buffer(Canvas* canvas);
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get canvas buffer size.
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
*
|
|
|
|
* @return size of canvas in bytes
|
2021-02-13 11:40:20 +00:00
|
|
|
*/
|
2023-02-09 04:58:01 +00:00
|
|
|
size_t canvas_get_buffer_size(const Canvas* canvas);
|
2021-02-13 11:40:20 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Set drawing region relative to real screen buffer
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
* @param offset_x x coordinate offset
|
|
|
|
* @param offset_y y coordinate offset
|
|
|
|
* @param width width
|
|
|
|
* @param height height
|
2020-12-14 10:50:32 +00:00
|
|
|
*/
|
Display and UI implementation (#169)
* Menu app. Lib: add mlib submodule.
* Menu: new startup lib dependency definition
* Menu: hierarchy in menu. Cube: fix heap1/4 inconsistency, stack protection.
* GUI: rendering pipeline initial version.
* GUI: layered widget composing, FURI record. Menu: FURI record, api.
* GUI: input dispatching. Menu: switch to input from GUI.
* GUI, MENU: code style cleanup, fix type conversion warnings.
* GUI, Menu: syntax check.
* Makefile: check and reinit submodules, format.
* Menu: lock on event processing. Makefile: proper submodule initialization.
* Menu: fix stack corruption by queue.
* GUI: refactor.
* Makefile: format rule fix, st-util pid.
* GUI, Menu, FURI: format with clang-format.
* GUI, MENU: locks in critical sections, fix stack corruption, ready signaling.
* Makefile: clang format rule cleanup.
* GUI,MENU: migrate to new API.
* Applications: PRODUCTION_HW variable, skip drivers build on local target.
* refactor production build
* add git to dockerfile
* GUI: uncomment lock block
Co-authored-by: Aleksandr Kutuzov <aku@plooks.com>
2020-10-14 10:21:55 +00:00
|
|
|
void canvas_frame_set(
|
2020-12-14 10:50:32 +00:00
|
|
|
Canvas* canvas,
|
Display and UI implementation (#169)
* Menu app. Lib: add mlib submodule.
* Menu: new startup lib dependency definition
* Menu: hierarchy in menu. Cube: fix heap1/4 inconsistency, stack protection.
* GUI: rendering pipeline initial version.
* GUI: layered widget composing, FURI record. Menu: FURI record, api.
* GUI: input dispatching. Menu: switch to input from GUI.
* GUI, MENU: code style cleanup, fix type conversion warnings.
* GUI, Menu: syntax check.
* Makefile: check and reinit submodules, format.
* Menu: lock on event processing. Makefile: proper submodule initialization.
* Menu: fix stack corruption by queue.
* GUI: refactor.
* Makefile: format rule fix, st-util pid.
* GUI, Menu, FURI: format with clang-format.
* GUI, MENU: locks in critical sections, fix stack corruption, ready signaling.
* Makefile: clang format rule cleanup.
* GUI,MENU: migrate to new API.
* Applications: PRODUCTION_HW variable, skip drivers build on local target.
* refactor production build
* add git to dockerfile
* GUI: uncomment lock block
Co-authored-by: Aleksandr Kutuzov <aku@plooks.com>
2020-10-14 10:21:55 +00:00
|
|
|
uint8_t offset_x,
|
|
|
|
uint8_t offset_y,
|
|
|
|
uint8_t width,
|
|
|
|
uint8_t height);
|
2021-05-19 09:43:15 +00:00
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Set canvas orientation
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
* @param orientation CanvasOrientation
|
2021-05-19 09:43:15 +00:00
|
|
|
*/
|
|
|
|
void canvas_set_orientation(Canvas* canvas, CanvasOrientation orientation);
|
|
|
|
|
2021-10-03 10:36:05 +00:00
|
|
|
/** Get canvas orientation
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
*
|
|
|
|
* @return CanvasOrientation
|
2021-05-19 09:43:15 +00:00
|
|
|
*/
|
|
|
|
CanvasOrientation canvas_get_orientation(const Canvas* canvas);
|
2023-04-06 03:36:12 +00:00
|
|
|
|
|
|
|
/** Draw a u8g2 bitmap
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
* @param x x coordinate
|
|
|
|
* @param y y coordinate
|
|
|
|
* @param width width
|
|
|
|
* @param height height
|
|
|
|
* @param bitmap bitmap
|
|
|
|
* @param rotation rotation
|
|
|
|
*/
|
|
|
|
void canvas_draw_u8g2_bitmap(
|
|
|
|
u8g2_t* u8g2,
|
|
|
|
uint8_t x,
|
|
|
|
uint8_t y,
|
|
|
|
uint8_t width,
|
|
|
|
uint8_t height,
|
|
|
|
const uint8_t* bitmap,
|
2023-12-22 11:08:46 +00:00
|
|
|
uint8_t rotation);
|
2024-02-07 02:38:20 +00:00
|
|
|
|
|
|
|
/** Add canvas commit callback.
|
|
|
|
*
|
|
|
|
* This callback will be called upon Canvas commit.
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
* @param callback CanvasCommitCallback
|
|
|
|
* @param context CanvasCommitCallback context
|
|
|
|
*/
|
|
|
|
void canvas_add_framebuffer_callback(Canvas* canvas, CanvasCommitCallback callback, void* context);
|
|
|
|
|
|
|
|
/** Remove canvas commit callback.
|
|
|
|
*
|
|
|
|
* @param canvas Canvas instance
|
|
|
|
* @param callback CanvasCommitCallback
|
|
|
|
* @param context CanvasCommitCallback context
|
|
|
|
*/
|
|
|
|
void canvas_remove_framebuffer_callback(
|
|
|
|
Canvas* canvas,
|
|
|
|
CanvasCommitCallback callback,
|
|
|
|
void* context);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|