/** * @file lv_imgbtn.h * */ #ifndef LV_IMGBTN_H #define LV_IMGBTN_H #ifdef __cplusplus extern "C" { #endif /********************* * INCLUDES *********************/ #ifdef LV_CONF_INCLUDE_SIMPLE #include "lv_conf.h" #else #include "../../lv_conf.h" #endif #if USE_LV_IMGBTN != 0 /*Testing of dependencies*/ #if USE_LV_BTN == 0 #error "lv_imgbtn: lv_btn is required. Enable it in lv_conf.h (USE_LV_BTN 1) " #endif #include "../lv_core/lv_obj.h" #include "lv_btn.h" #include "../lv_draw/lv_draw_img.h" /********************* * DEFINES *********************/ /********************** * TYPEDEFS **********************/ /*Data of image button*/ typedef struct { lv_btn_ext_t btn; /*Ext. of ancestor*/ /*New data for this type */ void * img_src[LV_BTN_STATE_NUM]; /*Store images to each state*/ lv_img_cf_t act_cf; /*Color format of the currently active image*/ } lv_imgbtn_ext_t; /*Styles*/ typedef enum { LV_IMGBTN_STYLE_REL, LV_IMGBTN_STYLE_PR, LV_IMGBTN_STYLE_TGL_REL, LV_IMGBTN_STYLE_TGL_PR, LV_IMGBTN_STYLE_INA, } lv_imgbtn_style_t; /********************** * GLOBAL PROTOTYPES **********************/ /** * Create a image button objects * @param par pointer to an object, it will be the parent of the new image button * @param copy pointer to a image button object, if not NULL then the new object will be copied from it * @return pointer to the created image button */ lv_obj_t * lv_imgbtn_create(lv_obj_t * par, const lv_obj_t * copy); /*====================== * Add/remove functions *=====================*/ /*===================== * Setter functions *====================*/ /** * Set images for a state of the image button * @param imgbtn pointer to an image button object * @param state for which state set the new image (from `lv_btn_state_t`) ` * @param src pointer to an image source (a C array or path to a file) */ void lv_imgbtn_set_src(lv_obj_t * imgbtn, lv_btn_state_t state, void * src); /** * Enable the toggled states. On release the button will change from/to toggled state. * @param imgbtn pointer to an image button object * @param tgl true: enable toggled states, false: disable */ static inline void lv_imgbtn_set_toggle(lv_obj_t * imgbtn, bool tgl) { lv_btn_set_toggle(imgbtn, tgl); } /** * Set the state of the image button * @param imgbtn pointer to an image button object * @param state the new state of the button (from lv_btn_state_t enum) */ static inline void lv_imgbtn_set_state(lv_obj_t * imgbtn, lv_btn_state_t state) { lv_btn_set_state(imgbtn, state); } /** * Toggle the state of the image button (ON->OFF, OFF->ON) * @param imgbtn pointer to a image button object */ static inline void lv_imgbtn_toggle(lv_obj_t * imgbtn) { lv_btn_toggle(imgbtn); } /** * Set a function to call when a button event happens * @param imgbtn pointer to an image button object * @param action type of event form 'lv_action_t' (press, release, long press, long press repeat) */ static inline void lv_imgbtn_set_action(lv_obj_t * imgbtn, lv_btn_action_t type, lv_action_t action) { lv_btn_set_action(imgbtn, type, action); } /** * Set a style of a image button. * @param imgbtn pointer to image button object * @param type which style should be set * @param style pointer to a style */ void lv_imgbtn_set_style(lv_obj_t * imgbtn, lv_imgbtn_style_t type, lv_style_t *style); /*===================== * Getter functions *====================*/ /** * Get the images in a given state * @param imgbtn pointer to an image button object * @param state the state where to get the image (from `lv_btn_state_t`) ` * @return pointer to an image source (a C array or path to a file) */ void * lv_imgbtn_get_src(lv_obj_t * imgbtn, lv_btn_state_t state); /** * Get the current state of the image button * @param imgbtn pointer to a image button object * @return the state of the button (from lv_btn_state_t enum) */ static inline lv_btn_state_t lv_imgbtn_get_state(const lv_obj_t * imgbtn) { return lv_btn_get_state(imgbtn); } /** * Get the toggle enable attribute of the image button * @param imgbtn pointer to a image button object * @return ture: toggle enabled, false: disabled */ static inline bool lv_imgbtn_get_toggle(const lv_obj_t * imgbtn) { return lv_btn_get_toggle(imgbtn); } /** * Get the release action of a image button * @param imgbtn pointer to a image button object * @return pointer to the release action function */ static inline lv_action_t lv_imgbtn_get_action(const lv_obj_t * imgbtn, lv_btn_action_t type) { return lv_btn_get_action(imgbtn, type); } /** * Get style of a image button. * @param imgbtn pointer to image button object * @param type which style should be get * @return style pointer to the style */ lv_style_t * lv_imgbtn_get_style(const lv_obj_t * imgbtn, lv_imgbtn_style_t type); /*===================== * Other functions *====================*/ /********************** * MACROS **********************/ #endif /*USE_LV_IMGBTN*/ #ifdef __cplusplus } /* extern "C" */ #endif #endif /*LV_IMGBTN_H*/