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

159 lines
3.7 KiB
C
Raw Normal View History

2017-08-18 17:43:14 +02:00
/**
* @file lv_sw.h
2018-06-19 09:49:58 +02:00
*
2017-08-18 17:43:14 +02:00
*/
#ifndef LV_SW_H
#define LV_SW_H
#ifdef __cplusplus
extern "C" {
#endif
/*********************
* INCLUDES
*********************/
#ifdef LV_CONF_INCLUDE_SIMPLE
#include "lv_conf.h"
#else
2017-11-26 23:57:39 +01:00
#include "../../lv_conf.h"
#endif
#if LV_USE_SW != 0
2017-08-18 17:43:14 +02:00
2017-08-18 21:14:11 +02:00
/*Testing of dependencies*/
#if LV_USE_SLIDER == 0
#error "lv_sw: lv_slider is required. Enable it in lv_conf.h (LV_USE_SLIDER 1)"
2017-08-18 21:14:11 +02:00
#endif
2017-11-30 11:35:33 +01:00
#include "../lv_core/lv_obj.h"
2017-08-18 21:14:11 +02:00
#include "lv_slider.h"
2017-08-18 17:43:14 +02:00
/*********************
* DEFINES
*********************/
2019-03-01 23:50:30 +01:00
#define LV_SW_MAX_VALUE 100
2017-08-18 17:43:14 +02:00
/**********************
* TYPEDEFS
**********************/
/*Data of switch*/
typedef struct
{
2017-11-09 17:13:04 +01:00
lv_slider_ext_t slider; /*Ext. of ancestor*/
2017-08-18 17:43:14 +02:00
/*New data for this type */
2018-11-16 17:42:29 +01:00
lv_style_t *style_knob_off; /*Style of the knob when the switch is OFF*/
lv_style_t *style_knob_on; /*Style of the knob when the switch is ON (NULL to use the same as OFF)*/
2018-11-20 07:33:32 +01:00
lv_coord_t start_x;
2018-11-19 06:35:11 +01:00
uint8_t changed :1; /*Indicates the switch state explicitly changed by drag*/
2018-11-20 07:33:32 +01:00
uint8_t slided :1;
#if LV_USE_ANIMATION
uint16_t anim_time; /*switch animation time */
#endif
2018-06-19 09:49:58 +02:00
} lv_sw_ext_t;
2017-08-18 17:43:14 +02:00
2018-09-18 13:59:40 +02:00
enum {
LV_SW_STYLE_BG,
LV_SW_STYLE_INDIC,
LV_SW_STYLE_KNOB_OFF,
LV_SW_STYLE_KNOB_ON,
2018-09-18 13:59:40 +02:00
};
typedef uint8_t lv_sw_style_t;
2017-08-18 17:43:14 +02:00
/**********************
* GLOBAL PROTOTYPES
**********************/
/**
* Create a switch objects
* @param par pointer to an object, it will be the parent of the new switch
* @param copy pointer to a switch object, if not NULL then the new object will be copied from it
* @return pointer to the created switch
*/
lv_obj_t * lv_sw_create(lv_obj_t * par, const lv_obj_t * copy);
2017-08-18 17:43:14 +02:00
2017-11-10 15:01:40 +01:00
/*=====================
* Setter functions
*====================*/
2017-08-18 17:43:14 +02:00
/**
2017-11-09 17:13:04 +01:00
* Turn ON the switch
2017-08-18 17:43:14 +02:00
* @param sw pointer to a switch object
2019-03-01 23:50:30 +01:00
* @param anim true: set the value with an animation; false: change the value immediatelly
2017-08-18 17:43:14 +02:00
*/
2019-03-01 23:50:30 +01:00
void lv_sw_on(lv_obj_t *sw, bool anim);
2017-11-09 17:13:04 +01:00
/**
* Turn OFF the switch
* @param sw pointer to a switch object
2019-03-01 23:50:30 +01:00
* @param anim true: set the value with an animation; false: change the value immediatelly
2017-11-09 17:13:04 +01:00
*/
2019-03-01 23:50:30 +01:00
void lv_sw_off(lv_obj_t *sw, bool anim);
2019-01-25 17:09:59 -08:00
/**
* Toggle the position of the switch
* @param sw pointer to a switch object
2019-03-01 23:50:30 +01:00
* @param anim true: set the value with an animation; false: change the value immediatelly
2019-01-25 17:09:59 -08:00
* @return resulting state of the switch.
*/
2019-03-01 23:50:30 +01:00
bool lv_sw_toggle(lv_obj_t *sw, bool anim);
2017-11-10 15:01:40 +01:00
/**
* Set a style of a switch
2017-11-10 15:01:40 +01:00
* @param sw pointer to a switch object
* @param type which style should be set
* @param style pointer to a style
2017-11-10 15:01:40 +01:00
*/
void lv_sw_set_style(lv_obj_t *sw, lv_sw_style_t type, lv_style_t *style);
2017-11-10 15:01:40 +01:00
#if LV_USE_ANIMATION
/**
* Set the animation time of the switch
* @param sw pointer to a switch object
* @param anim_time animation time
* @return style pointer to a style
*/
void lv_sw_set_anim_time(lv_obj_t *sw, uint16_t anim_time);
#endif
2017-11-10 15:01:40 +01:00
/*=====================
* Getter functions
*====================*/
/**
* Get the state of a switch
* @param sw pointer to a switch object
* @return false: OFF; true: ON
*/
static inline bool lv_sw_get_state(const lv_obj_t *sw)
{
2019-03-01 23:50:30 +01:00
return lv_bar_get_value(sw) < LV_SW_MAX_VALUE / 2 ? false : true;
}
/**
* Get a style of a switch
* @param sw pointer to a switch object
* @param type which style should be get
* @return style pointer to a style
*/
lv_style_t * lv_sw_get_style(const lv_obj_t *sw, lv_sw_style_t type);
2017-11-10 15:01:40 +01:00
/**
* Get the animation time of the switch
* @param sw pointer to a switch object
* @return style pointer to a style
*/
uint16_t lv_sw_get_anim_time(const lv_obj_t *sw);
2017-08-18 17:43:14 +02:00
/**********************
* MACROS
**********************/
#endif /*LV_USE_SW*/
2017-08-18 17:43:14 +02:00
#ifdef __cplusplus
} /* extern "C" */
#endif
#endif /*LV_SW_H*/