 24987b95cd
			
		
	
	
		24987b95cd
		
			
		
	
	
	
	
		
			
			* [FL-2131] IR: Show universal remote loading * Remove unused hal rtc. Gui: cleanup loading module. Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			222 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			222 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /**
 | |
|  * @file elements.h
 | |
|  * GUI: Elements API
 | |
|  * 
 | |
|  * Canvas helpers and UI building blocks.
 | |
|  * 
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <stdint.h>
 | |
| #include <m-string.h>
 | |
| #include "canvas.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| #define ELEMENTS_MAX_LINES_NUM (7)
 | |
| #define ELEMENTS_BOLD_MARKER '#'
 | |
| #define ELEMENTS_MONO_MARKER '*'
 | |
| #define ELEMENTS_INVERSED_MARKER '!'
 | |
| 
 | |
| /** Draw progress bar.
 | |
|  *
 | |
|  * @param   canvas      Canvas instance
 | |
|  * @param   x           progress bar position on X axis
 | |
|  * @param   y           progress bar position on Y axis
 | |
|  * @param   width       progress bar width
 | |
|  * @param   progress    progress (0.0 - 1.0)
 | |
|  */
 | |
| void elements_progress_bar(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, float progress);
 | |
| 
 | |
| /** Draw scrollbar on canvas at specific position.
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   x       scrollbar position on X axis
 | |
|  * @param   y       scrollbar position on Y axis
 | |
|  * @param   height  scrollbar height
 | |
|  * @param   pos     current element
 | |
|  * @param   total   total elements
 | |
|  */
 | |
| void elements_scrollbar_pos(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     uint8_t height,
 | |
|     uint16_t pos,
 | |
|     uint16_t total);
 | |
| 
 | |
| /** Draw scrollbar on canvas.
 | |
|  * @note    width 3px, height equal to canvas height
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   pos     current element of total elements
 | |
|  * @param   total   total elements
 | |
|  */
 | |
| void elements_scrollbar(Canvas* canvas, uint16_t pos, uint16_t total);
 | |
| 
 | |
| /** Draw rounded frame
 | |
|  *
 | |
|  * @param   canvas          Canvas instance
 | |
|  * @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);
 | |
| 
 | |
| /** Draw button in left corner
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   str     button text
 | |
|  */
 | |
| void elements_button_left(Canvas* canvas, const char* str);
 | |
| 
 | |
| /** Draw button in right corner
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   str     button text
 | |
|  */
 | |
| void elements_button_right(Canvas* canvas, const char* str);
 | |
| 
 | |
| /** Draw button in center
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   str     button text
 | |
|  */
 | |
| void elements_button_center(Canvas* canvas, const char* str);
 | |
| 
 | |
| /** Draw aligned multiline text
 | |
|  *
 | |
|  * @param   canvas                  Canvas instance
 | |
|  * @param   x, y                    coordinates based on align param
 | |
|  * @param   horizontal, vertical    aligment of multiline text
 | |
|  * @param   text                    string (possible multiline)
 | |
|  */
 | |
| void elements_multiline_text_aligned(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     Align horizontal,
 | |
|     Align vertical,
 | |
|     const char* text);
 | |
| 
 | |
| /** Draw multiline text
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   x, y    top left corner coordinates
 | |
|  * @param   text    string (possible multiline)
 | |
|  */
 | |
| void elements_multiline_text(Canvas* canvas, uint8_t x, uint8_t y, const char* text);
 | |
| 
 | |
| /** Draw framed multiline text
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   x, y    top left corner coordinates
 | |
|  * @param   text    string (possible multiline)
 | |
|  */
 | |
| void elements_multiline_text_framed(Canvas* canvas, uint8_t x, uint8_t y, const char* text);
 | |
| 
 | |
| /** Draw slightly rounded frame
 | |
|  *
 | |
|  * @param   canvas          Canvas instance
 | |
|  * @param   x, y            top left corner coordinates
 | |
|  * @param   width, height   size of frame
 | |
|  */
 | |
| void elements_slightly_rounded_frame(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     uint8_t width,
 | |
|     uint8_t height);
 | |
| 
 | |
| /** Draw slightly rounded box
 | |
|  *
 | |
|  * @param   canvas          Canvas instance
 | |
|  * @param   x, y            top left corner coordinates
 | |
|  * @param   width, height   size of box
 | |
|  */
 | |
| void elements_slightly_rounded_box(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     uint8_t width,
 | |
|     uint8_t height);
 | |
| 
 | |
| /** Draw bold rounded frame
 | |
|  *
 | |
|  * @param   canvas          Canvas instance
 | |
|  * @param   x, y            top left corner coordinates
 | |
|  * @param   width, height   size of frame
 | |
|  */
 | |
| void elements_bold_rounded_frame(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     uint8_t width,
 | |
|     uint8_t height);
 | |
| 
 | |
| /** Draw bubble frame for text
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   x       left x coordinates
 | |
|  * @param   y       top y coordinate
 | |
|  * @param   width   bubble width
 | |
|  * @param   height  bubble height
 | |
|  */
 | |
| void elements_bubble(Canvas* canvas, uint8_t x, uint8_t y, uint8_t width, uint8_t height);
 | |
| 
 | |
| /** Draw bubble frame for text with corner
 | |
|  *
 | |
|  * @param   canvas      Canvas instance
 | |
|  * @param   x           left x coordinates
 | |
|  * @param   y           top y coordinate
 | |
|  * @param   width       bubble width
 | |
|  * @param   height      bubble height
 | |
|  * @param   horizontal  horizontal aligning
 | |
|  * @param   vertical    aligning
 | |
|  */
 | |
| void elements_bubble_str(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     const char* text,
 | |
|     Align horizontal,
 | |
|     Align vertical);
 | |
| 
 | |
| /** Trim string buffer to fit width in pixels
 | |
|  *
 | |
|  * @param   canvas  Canvas instance
 | |
|  * @param   string  string to trim
 | |
|  * @param   width   max width
 | |
|  */
 | |
| void elements_string_fit_width(Canvas* canvas, string_t string, uint8_t width);
 | |
| 
 | |
| /** Draw text box element
 | |
|  *
 | |
|  * @param       canvas      Canvas instance
 | |
|  * @param       x           x coordinate
 | |
|  * @param       y           y coordinate
 | |
|  * @param       width       width to fit text
 | |
|  * @param       height      height to fit text
 | |
|  * @param       horizontal  Align instance
 | |
|  * @param       vertical    Align instance
 | |
|  * @param[in]   text        Formatted text. The following formats are available:
 | |
|  *                          "\e#Bold text\e#" - bold font is used
 | |
|  *                          "\e*Monospaced text\e*" - monospaced font is used
 | |
|  *                          "\e#Inversed text\e#" - white text on black background
 | |
|  */
 | |
| void elements_text_box(
 | |
|     Canvas* canvas,
 | |
|     uint8_t x,
 | |
|     uint8_t y,
 | |
|     uint8_t width,
 | |
|     uint8_t height,
 | |
|     Align horizontal,
 | |
|     Align vertical,
 | |
|     const char* text);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |