1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-21 06:53:01 +08:00
lvgl/src/lv_objx/lv_spinbox.h

189 lines
4.5 KiB
C
Raw Normal View History

/**
2018-11-03 18:41:06 +01:00
* @file lv_spinbox.h
*
*/
#ifndef LV_SPINBOX_H
#define LV_SPINBOX_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"
#endif
#if LV_USE_SPINBOX != 0
2018-12-20 00:01:05 +01:00
/*Testing of dependencies*/
#if LV_USE_TA == 0
#error "lv_spinbox: lv_ta is required. Enable it in lv_conf.h (LV_USE_TA 1) "
2018-12-20 00:01:05 +01:00
#endif
#include "../lv_core/lv_obj.h"
#include "../lv_objx/lv_ta.h"
/*********************
* DEFINES
*********************/
2019-04-04 07:15:40 +02:00
#define LV_SPINBOX_MAX_DIGIT_COUNT 16
/**********************
* TYPEDEFS
**********************/
2018-11-03 18:41:06 +01:00
/*Data of spinbox*/
2019-04-04 07:15:40 +02:00
typedef struct
{
lv_ta_ext_t ta; /*Ext. of ancestor*/
/*New data for this type */
int32_t value;
2018-11-04 20:21:51 +01:00
int32_t range_max;
int32_t range_min;
int32_t step;
2019-04-04 07:15:40 +02:00
uint16_t digit_count : 4;
uint16_t dec_point_pos : 4; /*if 0, there is no separator and the number is an integer*/
uint16_t digit_padding_left : 4;
} lv_spinbox_ext_t;
/*Styles*/
enum {
LV_SPINBOX_STYLE_BG,
LV_SPINBOX_STYLE_SB,
LV_SPINBOX_STYLE_CURSOR,
};
typedef uint8_t lv_spinbox_style_t;
/**********************
* GLOBAL PROTOTYPES
**********************/
/**
2018-11-03 18:41:06 +01:00
* Create a spinbox objects
* @param par pointer to an object, it will be the parent of the new spinbox
* @param copy pointer to a spinbox object, if not NULL then the new object will be copied from it
* @return pointer to the created spinbox
*/
lv_obj_t * lv_spinbox_create(lv_obj_t * par, const lv_obj_t * copy);
/*=====================
* Setter functions
*====================*/
/**
2018-11-03 18:41:06 +01:00
* Set a style of a spinbox.
* @param templ pointer to template object
* @param type which style should be set
* @param style pointer to a style
*/
2019-06-06 06:05:40 +02:00
static inline void lv_spinbox_set_style(lv_obj_t * spinbox, lv_spinbox_style_t type, lv_style_t * style)
2018-11-04 20:21:51 +01:00
{
lv_ta_set_style(spinbox, type, style);
}
2018-11-03 18:41:06 +01:00
/**
* Set spinbox value
* @param spinbox pointer to spinbox
* @param i value to be set
*/
2018-12-20 00:01:05 +01:00
void lv_spinbox_set_value(lv_obj_t * spinbox, int32_t i);
2018-11-03 18:41:06 +01:00
/**
* Set spinbox digit format (digit count and decimal format)
* @param spinbox pointer to spinbox
* @param digit_count number of digit excluding the decimal separator and the sign
2019-04-04 07:15:40 +02:00
* @param separator_position number of digit before the decimal point. If 0, decimal point is not
* shown
2018-11-03 18:41:06 +01:00
*/
2019-06-06 06:05:40 +02:00
void lv_spinbox_set_digit_format(lv_obj_t * spinbox, uint8_t digit_count, uint8_t separator_position);
2018-11-03 18:41:06 +01:00
/**
2018-11-04 20:21:51 +01:00
* Set spinbox step
2018-11-03 18:41:06 +01:00
* @param spinbox pointer to spinbox
2018-11-04 20:21:51 +01:00
* @param step steps on increment/decrement
2018-11-03 18:41:06 +01:00
*/
2018-12-20 00:01:05 +01:00
void lv_spinbox_set_step(lv_obj_t * spinbox, uint32_t step);
2018-11-03 18:41:06 +01:00
/**
* Set spinbox value range
* @param spinbox pointer to spinbox
2018-11-04 20:21:51 +01:00
* @param range_min maximum value, inclusive
* @param range_max minimum value, inclusive
*/
2018-12-20 00:01:05 +01:00
void lv_spinbox_set_range(lv_obj_t * spinbox, int32_t range_min, int32_t range_max);
2018-11-05 14:48:33 +01:00
/**
* Set spinbox left padding in digits count (added between sign and first digit)
* @param spinbox pointer to spinbox
* @param cb Callback function called on value change event
*/
2018-12-20 00:01:05 +01:00
void lv_spinbox_set_padding_left(lv_obj_t * spinbox, uint8_t padding);
/*=====================
* Getter functions
*====================*/
/**
2018-11-03 18:41:06 +01:00
* Get style of a spinbox.
* @param templ pointer to template object
* @param type which style should be get
* @return style pointer to the style
*/
2019-04-11 19:59:55 +08:00
static inline const lv_style_t * lv_spinbox_get_style(lv_obj_t * spinbox, lv_spinbox_style_t type)
2018-11-04 20:21:51 +01:00
{
return lv_ta_get_style(spinbox, type);
}
2018-11-03 18:41:06 +01:00
/**
* Get the spinbox numeral value (user has to convert to float according to its digit format)
* @param spinbox pointer to spinbox
* @return value integer value of the spinbox
*/
2018-12-20 00:01:05 +01:00
int32_t lv_spinbox_get_value(lv_obj_t * spinbox);
/*=====================
* Other functions
*====================*/
2018-11-04 20:21:51 +01:00
/**
* Select next lower digit for edition by dividing the step by 10
* @param spinbox pointer to spinbox
*/
void lv_spinbox_step_next(lv_obj_t * spinbox);
/**
* Select next higher digit for edition by multiplying the step by 10
* @param spinbox pointer to spinbox
*/
2019-06-25 15:14:47 +02:00
void lv_spinbox_step_prev(lv_obj_t * spinbox);
2018-11-04 20:21:51 +01:00
/**
* Increment spinbox value by one step
* @param spinbox pointer to spinbox
*/
void lv_spinbox_increment(lv_obj_t * spinbox);
/**
* Decrement spinbox value by one step
* @param spinbox pointer to spinbox
*/
void lv_spinbox_decrement(lv_obj_t * spinbox);
/**********************
* MACROS
**********************/
2019-04-04 07:15:40 +02:00
#endif /*LV_USE_SPINBOX*/
#ifdef __cplusplus
} /* extern "C" */
#endif
2019-04-04 07:15:40 +02:00
#endif /*LV_SPINBOX_H*/