2018-11-28 22:02:51 +01:00
|
|
|
/**
|
|
|
|
* @file lv_table.h
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LV_TABLE_H
|
|
|
|
#define LV_TABLE_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
|
|
|
#ifdef LV_CONF_INCLUDE_SIMPLE
|
|
|
|
#include "lv_conf.h"
|
|
|
|
#else
|
2019-03-17 08:33:03 +01:00
|
|
|
#include "../../../lv_conf.h"
|
2018-11-28 22:02:51 +01:00
|
|
|
#endif
|
|
|
|
|
2019-03-07 00:05:16 +01:00
|
|
|
#if LV_USE_TABLE != 0
|
2018-11-28 22:02:51 +01:00
|
|
|
|
2018-12-13 17:41:59 +01:00
|
|
|
/*Testing of dependencies*/
|
2019-03-07 00:05:16 +01:00
|
|
|
#if LV_USE_LABEL == 0
|
|
|
|
#error "lv_table: lv_label is required. Enable it in lv_conf.h (LV_USE_LABEL 1) "
|
2018-12-13 17:41:59 +01:00
|
|
|
#endif
|
|
|
|
|
2018-11-28 22:02:51 +01:00
|
|
|
#include "../lv_core/lv_obj.h"
|
2018-12-13 17:38:27 +01:00
|
|
|
#include "lv_label.h"
|
2018-11-28 22:02:51 +01:00
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
2018-12-13 17:41:59 +01:00
|
|
|
#ifndef LV_TABLE_COL_MAX
|
2018-11-28 22:02:51 +01:00
|
|
|
#define LV_TABLE_COL_MAX 12
|
2018-12-13 17:41:59 +01:00
|
|
|
#endif
|
2019-01-01 13:44:19 +01:00
|
|
|
|
|
|
|
#define LV_TABLE_CELL_STYLE_CNT 4
|
2018-11-28 22:02:51 +01:00
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
2018-11-29 08:52:21 +01:00
|
|
|
|
|
|
|
typedef union {
|
|
|
|
struct {
|
2019-01-10 16:06:06 +01:00
|
|
|
uint8_t align:2;
|
2018-11-29 08:52:21 +01:00
|
|
|
uint8_t right_merge:1;
|
2019-01-01 13:44:19 +01:00
|
|
|
uint8_t type:2;
|
2019-01-10 16:06:06 +01:00
|
|
|
uint8_t crop:1;
|
2019-03-15 19:41:54 -04:00
|
|
|
} s;
|
2018-11-29 08:52:21 +01:00
|
|
|
uint8_t format_byte;
|
|
|
|
}lv_table_cell_format_t;
|
|
|
|
|
2018-11-28 22:02:51 +01:00
|
|
|
/*Data of table*/
|
|
|
|
typedef struct {
|
|
|
|
/*New data for this type */
|
|
|
|
uint16_t col_cnt;
|
|
|
|
uint16_t row_cnt;
|
2018-11-29 08:52:21 +01:00
|
|
|
char ** cell_data;
|
2019-01-01 13:44:19 +01:00
|
|
|
lv_style_t * cell_style[LV_TABLE_CELL_STYLE_CNT];
|
2018-11-28 22:02:51 +01:00
|
|
|
lv_coord_t col_w[LV_TABLE_COL_MAX];
|
|
|
|
} lv_table_ext_t;
|
|
|
|
|
|
|
|
|
|
|
|
/*Styles*/
|
|
|
|
enum {
|
2018-12-13 17:38:27 +01:00
|
|
|
LV_TABLE_STYLE_BG,
|
2019-01-01 13:44:19 +01:00
|
|
|
LV_TABLE_STYLE_CELL1,
|
|
|
|
LV_TABLE_STYLE_CELL2,
|
|
|
|
LV_TABLE_STYLE_CELL3,
|
|
|
|
LV_TABLE_STYLE_CELL4,
|
2018-11-28 22:02:51 +01:00
|
|
|
};
|
|
|
|
typedef uint8_t lv_table_style_t;
|
|
|
|
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
2018-12-13 17:38:27 +01:00
|
|
|
* Create a table object
|
2018-11-28 22:02:51 +01:00
|
|
|
* @param par pointer to an object, it will be the parent of the new table
|
|
|
|
* @param copy pointer to a table object, if not NULL then the new object will be copied from it
|
|
|
|
* @return pointer to the created table
|
|
|
|
*/
|
|
|
|
lv_obj_t * lv_table_create(lv_obj_t * par, const lv_obj_t * copy);
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/*=====================
|
|
|
|
* Setter functions
|
|
|
|
*====================*/
|
2018-11-29 08:52:21 +01:00
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Set the value of a cell.
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @param txt text to display in the cell. It will be copied and saved so this variable is not required after this function call.
|
|
|
|
*/
|
|
|
|
void lv_table_set_cell_value(lv_obj_t * table, uint16_t row, uint16_t col, const char * txt);
|
2018-11-29 08:52:21 +01:00
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Set the number of rows
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param row_cnt number of rows
|
|
|
|
*/
|
2018-11-29 08:52:21 +01:00
|
|
|
void lv_table_set_row_cnt(lv_obj_t * table, uint16_t row_cnt);
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Set the number of columns
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param col_cnt number of columns. Must be < LV_TABLE_COL_MAX
|
|
|
|
*/
|
2018-11-29 08:52:21 +01:00
|
|
|
void lv_table_set_col_cnt(lv_obj_t * table, uint16_t col_cnt);
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Set the width of a column
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param col_id id of the column [0 .. LV_TABLE_COL_MAX -1]
|
|
|
|
* @param w width of the column
|
|
|
|
*/
|
|
|
|
void lv_table_set_col_width(lv_obj_t * table, uint16_t col_id, lv_coord_t w);
|
2018-11-28 22:02:51 +01:00
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Set the text align in a cell
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @param align LV_LABEL_ALIGN_LEFT or LV_LABEL_ALIGN_CENTER or LV_LABEL_ALIGN_RIGHT
|
|
|
|
*/
|
|
|
|
void lv_table_set_cell_align(lv_obj_t * table, uint16_t row, uint16_t col, lv_label_align_t align);
|
2018-11-28 22:02:51 +01:00
|
|
|
|
2019-01-01 13:44:19 +01:00
|
|
|
/**
|
|
|
|
* Set the type of a cell.
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @param type 1,2,3 or 4. The cell style will be chosen accordingly.
|
|
|
|
*/
|
|
|
|
void lv_table_set_cell_type(lv_obj_t * table, uint16_t row, uint16_t col, uint8_t type);
|
|
|
|
|
2019-01-10 16:06:06 +01:00
|
|
|
/**
|
|
|
|
* Set the cell crop. (Don't adjust the height of the cell according to its content)
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @param crop true: crop the cell content; false: set the cell height to the content.
|
|
|
|
*/
|
|
|
|
void lv_table_set_cell_crop(lv_obj_t * table, uint16_t row, uint16_t col, bool crop);
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Merge a cell with the right neighbor. The value of the cell to the right won't be displayed.
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @param en true: merge right; false: don't merge right
|
|
|
|
*/
|
|
|
|
void lv_table_set_cell_merge_right(lv_obj_t * table, uint16_t row, uint16_t col, bool en);
|
2018-11-28 22:02:51 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a style of a table.
|
|
|
|
* @param table pointer to table object
|
|
|
|
* @param type which style should be set
|
|
|
|
* @param style pointer to a style
|
|
|
|
*/
|
2018-12-13 17:38:27 +01:00
|
|
|
void lv_table_set_style(lv_obj_t * table, lv_table_style_t type, lv_style_t * style);
|
2018-11-28 22:02:51 +01:00
|
|
|
|
|
|
|
/*=====================
|
|
|
|
* Getter functions
|
|
|
|
*====================*/
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Get the value of a cell.
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @return text in the cell
|
|
|
|
*/
|
|
|
|
const char * lv_table_get_cell_value(lv_obj_t * table, uint16_t row, uint16_t col);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the number of rows.
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @return number of rows.
|
|
|
|
*/
|
|
|
|
uint16_t lv_table_get_row_cnt(lv_obj_t * table);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the number of columns.
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @return number of columns.
|
|
|
|
*/
|
|
|
|
uint16_t lv_table_get_col_cnt(lv_obj_t * table);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the width of a column
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param col_id id of the column [0 .. LV_TABLE_COL_MAX -1]
|
|
|
|
* @return width of the column
|
|
|
|
*/
|
|
|
|
lv_coord_t lv_table_get_col_width(lv_obj_t * table, uint16_t col_id);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the text align of a cell
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @return LV_LABEL_ALIGN_LEFT (default in case of error) or LV_LABEL_ALIGN_CENTER or LV_LABEL_ALIGN_RIGHT
|
|
|
|
*/
|
|
|
|
lv_label_align_t lv_table_get_cell_align(lv_obj_t * table, uint16_t row, uint16_t col);
|
|
|
|
|
2019-01-01 13:44:19 +01:00
|
|
|
/**
|
|
|
|
* Get the type of a cell
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @return 1,2,3 or 4
|
|
|
|
*/
|
|
|
|
lv_label_align_t lv_table_get_cell_type(lv_obj_t * table, uint16_t row, uint16_t col);
|
|
|
|
|
2019-01-10 16:06:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the crop property of a cell
|
|
|
|
* @param table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @return true: text crop enabled; false: disabled
|
|
|
|
*/
|
|
|
|
lv_label_align_t lv_table_get_cell_crop(lv_obj_t * table, uint16_t row, uint16_t col);
|
|
|
|
|
2018-12-13 17:38:27 +01:00
|
|
|
/**
|
|
|
|
* Get the cell merge attribute.
|
|
|
|
* @param table table pointer to a Table object
|
|
|
|
* @param row id of the row [0 .. row_cnt -1]
|
|
|
|
* @param col id of the column [0 .. col_cnt -1]
|
|
|
|
* @return true: merge right; false: don't merge right
|
|
|
|
*/
|
|
|
|
bool lv_table_get_cell_merge_right(lv_obj_t * table, uint16_t row, uint16_t col);
|
|
|
|
|
2018-11-28 22:02:51 +01:00
|
|
|
/**
|
|
|
|
* Get style of a table.
|
|
|
|
* @param table pointer to table object
|
|
|
|
* @param type which style should be get
|
|
|
|
* @return style pointer to the style
|
|
|
|
*/
|
|
|
|
lv_style_t * lv_table_get_style(const lv_obj_t * table, lv_table_style_t type);
|
|
|
|
|
|
|
|
/*=====================
|
|
|
|
* Other functions
|
|
|
|
*====================*/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
2019-03-07 00:05:16 +01:00
|
|
|
#endif /*LV_USE_TABLE*/
|
2018-11-28 22:02:51 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /*LV_TABLE_H*/
|