2021-10-03 13:36:05 +03:00
|
|
|
/**
|
|
|
|
* @file button_panel.h
|
|
|
|
* GUI: ButtonPanel view module API
|
|
|
|
*/
|
|
|
|
|
2021-06-25 16:52:27 +03:00
|
|
|
#pragma once
|
2021-10-03 13:36:05 +03:00
|
|
|
|
2021-06-25 16:52:27 +03:00
|
|
|
#include <gui/view.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** Button panel module descriptor */
|
|
|
|
typedef struct ButtonPanel ButtonPanel;
|
|
|
|
|
|
|
|
/** Callback type to call for handling selecting button_panel items */
|
|
|
|
typedef void (*ButtonItemCallback)(void* context, uint32_t index);
|
2021-10-03 13:36:05 +03:00
|
|
|
|
2021-06-25 16:52:27 +03:00
|
|
|
/** Allocate new button_panel module.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @return ButtonPanel instance
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
ButtonPanel* button_panel_alloc(void);
|
|
|
|
|
|
|
|
/** Free button_panel module.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
void button_panel_free(ButtonPanel* button_panel);
|
|
|
|
|
|
|
|
/** Free items from button_panel module. Preallocated matrix stays unchanged.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
2022-01-21 20:32:03 +03:00
|
|
|
void button_panel_reset(ButtonPanel* button_panel);
|
2021-06-25 16:52:27 +03:00
|
|
|
|
2022-08-27 01:44:12 +03:00
|
|
|
/** Resets selected_item_x and selected_item_y.
|
|
|
|
*
|
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
*/
|
|
|
|
void button_panel_reset_selection(ButtonPanel* button_panel);
|
|
|
|
|
2021-06-25 16:52:27 +03:00
|
|
|
/** Reserve space for adding items.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* One does not simply use button_panel_add_item() without this function. It
|
|
|
|
* should be allocated space for it first.
|
2021-06-25 16:52:27 +03:00
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
* @param reserve_x number of columns in button_panel
|
|
|
|
* @param reserve_y number of rows in button_panel
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
void button_panel_reserve(ButtonPanel* button_panel, size_t reserve_x, size_t reserve_y);
|
|
|
|
|
|
|
|
/** Add item to button_panel module.
|
|
|
|
*
|
|
|
|
* Have to set element in bounds of allocated size by X and by Y.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
* @param index value to pass to callback
|
|
|
|
* @param matrix_place_x coordinates by x-axis on virtual grid, it
|
2022-09-28 19:52:46 +03:00
|
|
|
* is only used for navigation
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param matrix_place_y coordinates by y-axis on virtual grid, it
|
2023-02-20 18:55:53 +03:00
|
|
|
* is only used for navigation
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param x x-coordinate to draw icon on
|
|
|
|
* @param y y-coordinate to draw icon on
|
|
|
|
* @param icon_name name of the icon to draw
|
|
|
|
* @param icon_name_selected name of the icon to draw when current
|
|
|
|
* element is selected
|
|
|
|
* @param callback function to call when specific element is
|
|
|
|
* selected (pressed Ok on selected item)
|
|
|
|
* @param callback_context context to pass to callback
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
void button_panel_add_item(
|
|
|
|
ButtonPanel* button_panel,
|
|
|
|
uint32_t index,
|
|
|
|
uint16_t matrix_place_x,
|
|
|
|
uint16_t matrix_place_y,
|
|
|
|
uint16_t x,
|
|
|
|
uint16_t y,
|
2021-07-07 11:57:49 +03:00
|
|
|
const Icon* icon_name,
|
|
|
|
const Icon* icon_name_selected,
|
2021-06-25 16:52:27 +03:00
|
|
|
ButtonItemCallback callback,
|
|
|
|
void* callback_context);
|
|
|
|
|
|
|
|
/** Get button_panel view.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
*
|
|
|
|
* @return acquired view
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
View* button_panel_get_view(ButtonPanel* button_panel);
|
|
|
|
|
|
|
|
/** Add label to button_panel module.
|
|
|
|
*
|
2021-10-03 13:36:05 +03:00
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
* @param x x-coordinate to place label
|
|
|
|
* @param y y-coordinate to place label
|
|
|
|
* @param font font to write label with
|
|
|
|
* @param label_str string label to write
|
2021-06-25 16:52:27 +03:00
|
|
|
*/
|
|
|
|
void button_panel_add_label(
|
|
|
|
ButtonPanel* button_panel,
|
|
|
|
uint16_t x,
|
|
|
|
uint16_t y,
|
|
|
|
Font font,
|
|
|
|
const char* label_str);
|
|
|
|
|
2023-08-23 21:24:47 +03:00
|
|
|
/** Add a non-button icon to button_panel module.
|
|
|
|
*
|
|
|
|
* @param button_panel ButtonPanel instance
|
|
|
|
* @param x x-coordinate to place icon
|
|
|
|
* @param y y-coordinate to place icon
|
|
|
|
* @param icon_name name of the icon to draw
|
|
|
|
*/
|
|
|
|
void button_panel_add_icon(
|
|
|
|
ButtonPanel* button_panel,
|
|
|
|
uint16_t x,
|
|
|
|
uint16_t y,
|
|
|
|
const Icon* icon_name);
|
|
|
|
|
2021-06-25 16:52:27 +03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|