2019-09-18 11:48:31 -07:00
|
|
|
/**
|
|
|
|
* @file lv_cpicker.h
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LV_CPICKER_H
|
|
|
|
#define LV_CPICKER_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
2019-12-26 02:49:30 +01:00
|
|
|
#include "../lv_conf_internal.h"
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
#if LV_USE_CPICKER != 0
|
|
|
|
|
|
|
|
#include "../lv_core/lv_obj.h"
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
enum {
|
|
|
|
LV_CPICKER_TYPE_RECT,
|
|
|
|
LV_CPICKER_TYPE_DISC,
|
|
|
|
};
|
|
|
|
typedef uint8_t lv_cpicker_type_t;
|
|
|
|
|
|
|
|
enum {
|
2019-09-18 21:23:56 -07:00
|
|
|
LV_CPICKER_COLOR_MODE_HUE,
|
|
|
|
LV_CPICKER_COLOR_MODE_SATURATION,
|
|
|
|
LV_CPICKER_COLOR_MODE_VALUE
|
2019-09-18 11:48:31 -07:00
|
|
|
};
|
2019-09-18 21:23:56 -07:00
|
|
|
typedef uint8_t lv_cpicker_color_mode_t;
|
2019-09-18 11:48:31 -07:00
|
|
|
|
2019-10-01 05:20:20 +02:00
|
|
|
|
|
|
|
|
|
|
|
/*Data of colorpicker*/
|
|
|
|
typedef struct {
|
|
|
|
lv_color_hsv_t hsv;
|
2019-10-01 21:16:30 +02:00
|
|
|
struct {
|
2020-02-11 06:41:03 +01:00
|
|
|
lv_style_list_t style_list;
|
2019-10-01 21:16:30 +02:00
|
|
|
lv_point_t pos;
|
|
|
|
uint8_t colored :1;
|
|
|
|
|
|
|
|
} indic;
|
2019-10-01 05:20:20 +02:00
|
|
|
uint32_t last_click_time;
|
2019-10-01 21:16:30 +02:00
|
|
|
uint32_t last_change_time;
|
2019-10-01 22:00:23 +02:00
|
|
|
lv_point_t last_press_point;
|
2019-10-01 21:16:30 +02:00
|
|
|
lv_cpicker_color_mode_t color_mode :2;
|
|
|
|
uint8_t color_mode_fixed :1;
|
|
|
|
lv_cpicker_type_t type :1;
|
2019-10-01 05:20:20 +02:00
|
|
|
} lv_cpicker_ext_t;
|
|
|
|
|
2020-02-11 06:41:03 +01:00
|
|
|
/*Parts*/
|
2019-10-01 05:20:20 +02:00
|
|
|
enum {
|
2020-02-11 06:41:03 +01:00
|
|
|
LV_CPICKER_PART_MAIN = LV_OBJ_PART_MAIN,
|
|
|
|
LV_CPICKER_PART_INDIC = _LV_OBJ_PART_VIRTUAL_LAST,
|
|
|
|
_LV_CPICKER_PART_VIRTUAL_LAST,
|
|
|
|
_LV_CPICKER_PART_REAL_LAST = _LV_OBJ_PART_REAL_LAST,
|
2019-10-01 05:20:20 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-09-18 11:48:31 -07:00
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a colorpicker objects
|
|
|
|
* @param par pointer to an object, it will be the parent of the new colorpicker
|
|
|
|
* @param copy pointer to a colorpicker object, if not NULL then the new object will be copied from it
|
|
|
|
* @return pointer to the created colorpicker
|
|
|
|
*/
|
|
|
|
lv_obj_t * lv_cpicker_create(lv_obj_t * par, const lv_obj_t * copy);
|
|
|
|
|
|
|
|
/*=====================
|
|
|
|
* Setter functions
|
|
|
|
*====================*/
|
|
|
|
|
2019-09-24 21:06:51 -07:00
|
|
|
/**
|
|
|
|
* Set a new type for a colorpicker
|
|
|
|
* @param cpicker pointer to a colorpicker object
|
|
|
|
* @param type new type of the colorpicker (from 'lv_cpicker_type_t' enum)
|
|
|
|
*/
|
2019-10-03 23:35:57 -07:00
|
|
|
void lv_cpicker_set_type(lv_obj_t * cpicker, lv_cpicker_type_t type);
|
2019-09-24 21:06:51 -07:00
|
|
|
|
2019-09-18 11:48:31 -07:00
|
|
|
/**
|
|
|
|
* Set the current hue of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-10-02 16:21:44 -07:00
|
|
|
* @param hue current selected hue [0..360]
|
|
|
|
* @return true if changed, otherwise false
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-10-02 16:21:44 -07:00
|
|
|
bool lv_cpicker_set_hue(lv_obj_t * cpicker, uint16_t hue);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the current saturation of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-10-02 16:21:44 -07:00
|
|
|
* @param saturation current selected saturation [0..100]
|
|
|
|
* @return true if changed, otherwise false
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-10-02 16:21:44 -07:00
|
|
|
bool lv_cpicker_set_saturation(lv_obj_t * cpicker, uint8_t saturation);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the current value of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-10-02 16:21:44 -07:00
|
|
|
* @param val current selected value [0..100]
|
|
|
|
* @return true if changed, otherwise false
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-10-02 16:21:44 -07:00
|
|
|
bool lv_cpicker_set_value(lv_obj_t * cpicker, uint8_t val);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
2019-09-30 07:00:34 -07:00
|
|
|
/**
|
|
|
|
* Set the current hsv of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @param hsv current selected hsv
|
2019-10-02 16:21:44 -07:00
|
|
|
* @return true if changed, otherwise false
|
2019-09-30 07:00:34 -07:00
|
|
|
*/
|
2019-10-02 16:21:44 -07:00
|
|
|
bool lv_cpicker_set_hsv(lv_obj_t * cpicker, lv_color_hsv_t hsv);
|
2019-09-30 07:00:34 -07:00
|
|
|
|
2019-09-18 11:48:31 -07:00
|
|
|
/**
|
|
|
|
* Set the current color of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @param color current selected color
|
2019-10-02 16:21:44 -07:00
|
|
|
* @return true if changed, otherwise false
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-10-02 16:21:44 -07:00
|
|
|
bool lv_cpicker_set_color(lv_obj_t * cpicker, lv_color_t color);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Set the current color mode.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-18 21:23:56 -07:00
|
|
|
* @param mode color mode (hue/sat/val)
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
void lv_cpicker_set_color_mode(lv_obj_t * cpicker, lv_cpicker_color_mode_t mode);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Set if the color mode is changed on long press on center
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-18 21:23:56 -07:00
|
|
|
* @param fixed color mode cannot be changed on long press
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
void lv_cpicker_set_color_mode_fixed(lv_obj_t * cpicker, bool fixed);
|
|
|
|
|
2019-10-01 21:16:30 +02:00
|
|
|
/**
|
|
|
|
* Make the indicator to be colored to the current color
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @param en true: color the indicator; false: not color the indicator
|
|
|
|
*/
|
|
|
|
void lv_cpicker_set_indic_colored(lv_obj_t * cpicker, bool en);
|
|
|
|
|
2019-09-18 21:23:56 -07:00
|
|
|
/*=====================
|
|
|
|
* Getter functions
|
|
|
|
*====================*/
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Get the current color mode.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-18 21:23:56 -07:00
|
|
|
* @return color mode (hue/sat/val)
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
lv_cpicker_color_mode_t lv_cpicker_get_color_mode(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
2019-09-18 21:23:56 -07:00
|
|
|
/**
|
|
|
|
* Get if the color mode is changed on long press on center
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @return mode cannot be changed on long press
|
|
|
|
*/
|
|
|
|
bool lv_cpicker_get_color_mode_fixed(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Get the current hue of a colorpicker.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-30 07:00:34 -07:00
|
|
|
* @return current selected hue
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
uint16_t lv_cpicker_get_hue(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Get the current saturation of a colorpicker.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-18 21:23:56 -07:00
|
|
|
* @return current selected saturation
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
uint8_t lv_cpicker_get_saturation(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Get the current hue of a colorpicker.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-18 21:23:56 -07:00
|
|
|
* @return current selected value
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
uint8_t lv_cpicker_get_value(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
2019-09-30 07:00:34 -07:00
|
|
|
/**
|
|
|
|
* Get the current selected hsv of a colorpicker.
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @return current selected hsv
|
|
|
|
*/
|
|
|
|
lv_color_hsv_t lv_cpicker_get_hsv(lv_obj_t * cpicker);
|
|
|
|
|
2019-09-18 11:48:31 -07:00
|
|
|
/**
|
2019-09-18 21:23:56 -07:00
|
|
|
* Get the current selected color of a colorpicker.
|
2019-09-18 11:48:31 -07:00
|
|
|
* @param cpicker pointer to colorpicker object
|
2019-09-30 07:00:34 -07:00
|
|
|
* @return current selected color
|
2019-09-18 11:48:31 -07:00
|
|
|
*/
|
2019-09-18 21:23:56 -07:00
|
|
|
lv_color_t lv_cpicker_get_color(lv_obj_t * cpicker);
|
2019-09-18 11:48:31 -07:00
|
|
|
|
2019-10-01 21:16:30 +02:00
|
|
|
/**
|
|
|
|
* Whether the indicator is colored to the current color or not
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @return true: color the indicator; false: not color the indicator
|
|
|
|
*/
|
|
|
|
bool lv_cpicker_get_indic_colored(lv_obj_t * cpicker);
|
|
|
|
|
2019-10-02 16:47:08 +02:00
|
|
|
/**
|
|
|
|
* Whether the preview is enabled or not
|
|
|
|
* @param cpicker pointer to colorpicker object
|
|
|
|
* @return en true: preview is enabled; false: preview is disabled
|
|
|
|
*/
|
|
|
|
bool lv_cpicker_get_preview(lv_obj_t * cpicker);
|
|
|
|
|
2019-09-18 11:48:31 -07:00
|
|
|
/*=====================
|
|
|
|
* Other functions
|
|
|
|
*====================*/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
2019-09-18 15:14:23 -07:00
|
|
|
#endif /*LV_USE_CPICKER*/
|
2019-09-18 11:48:31 -07:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /*LV_CPICKER_H*/
|