mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-18 10:51:54 +03:00
89a6c09a7a
* Documentation: add Doxyfile, prepare sources for doxygen. * Update ReadMe and remove obsolete CLA * Add contribution guide * Contributing: update text * Correct spelling
141 lines
3.5 KiB
C
141 lines
3.5 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
|
|
|
|
/** Draw progress bar.
|
|
* @param x - progress bar position on X axis
|
|
* @param y - progress bar position on Y axis
|
|
* @param width - progress bar width
|
|
* @param progress - progress in unnamed metric
|
|
* @param total - total amount in unnamed metric
|
|
*/
|
|
void elements_progress_bar(
|
|
Canvas* canvas,
|
|
uint8_t x,
|
|
uint8_t y,
|
|
uint8_t width,
|
|
uint8_t progress,
|
|
uint8_t total);
|
|
|
|
/** Draw scrollbar on canvas at specific position.
|
|
* @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.
|
|
* width 3px, height equal to canvas height
|
|
* @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 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 str - button text
|
|
*/
|
|
void elements_button_left(Canvas* canvas, const char* str);
|
|
|
|
/** Draw button in right corner
|
|
* @param str - button text
|
|
*/
|
|
void elements_button_right(Canvas* canvas, const char* str);
|
|
|
|
/** Draw button in center
|
|
* @param str - button text
|
|
*/
|
|
void elements_button_center(Canvas* canvas, const char* str);
|
|
|
|
/** Draw aligned multiline text
|
|
* @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 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 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 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 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 bubble frame for text
|
|
* @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);
|
|
|
|
/** Trim string buffer to fit width in pixels
|
|
* @param string - string to trim
|
|
* @param width - max width
|
|
*/
|
|
void elements_string_fit_width(Canvas* canvas, string_t string, uint8_t width);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|