2016-06-08 07:25:08 +02:00
|
|
|
/**
|
2016-12-15 16:19:23 +01:00
|
|
|
* @file lv_obj.h
|
2016-06-08 07:25:08 +02:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LV_OBJ_H
|
|
|
|
#define LV_OBJ_H
|
|
|
|
|
2017-07-09 15:32:49 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
2017-04-21 09:15:39 +02:00
|
|
|
#include "lv_conf.h"
|
2016-06-08 07:25:08 +02:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdbool.h>
|
2017-10-05 11:29:21 +02:00
|
|
|
#include "misc/gfx/area.h"
|
2016-06-08 07:25:08 +02:00
|
|
|
#include "misc/mem/dyn_mem.h"
|
|
|
|
#include "misc/mem/linked_list.h"
|
2017-04-21 09:15:39 +02:00
|
|
|
#include "misc/gfx/color.h"
|
2017-04-13 10:20:35 +02:00
|
|
|
#include "lv_style.h"
|
2016-06-08 07:25:08 +02:00
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
2017-04-21 09:15:39 +02:00
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/*Error check of lv_conf.h*/
|
|
|
|
#if LV_HOR_RES == 0 || LV_VER_RES == 0
|
|
|
|
#error "LV: LV_HOR_RES and LV_VER_RES must be greater then 0"
|
|
|
|
#endif
|
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
#if LV_ANTIALIAS != 0 && LV_ANTIALIAS != 1
|
|
|
|
#error "LV: LV_ATIALIAS can be only 0 or 1"
|
2016-06-08 07:25:08 +02:00
|
|
|
#endif
|
|
|
|
|
2017-01-09 08:50:38 +01:00
|
|
|
#if LV_VDB_SIZE == 0 && LV_ANTIALIAS != 0
|
2017-01-09 18:09:28 +01:00
|
|
|
#error "LV: If LV_VDB_SIZE == 0 the antialaissing must be disabled"
|
2016-06-08 07:25:08 +02:00
|
|
|
#endif
|
|
|
|
|
2017-06-17 09:08:12 +02:00
|
|
|
#if LV_VDB_SIZE != 0 && LV_VDB_SIZE < LV_HOR_RES && LV_ANTIALIAS == 0
|
|
|
|
#error "LV: Small Virtual Display Buffer (lv_conf.h: LV_VDB_SIZE >= LV_HOR_RES)"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if LV_VDB_SIZE != 0 && LV_VDB_SIZE < 2 *LV_HOR_RES && LV_ANTIALIAS != 0
|
|
|
|
#error "LV: Small Virtual Display Buffer (lv_conf.h: LV_VDB_SIZE >= (2 * LV_HOR_RES))"
|
|
|
|
#endif
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/*New defines*/
|
2017-10-20 10:17:02 +02:00
|
|
|
#define LV_OBJ_DEF_WIDTH (80 << LV_ANTIALIAS)
|
|
|
|
#define LV_OBJ_DEF_HEIGHT (60 << LV_ANTIALIAS)
|
2016-06-15 09:38:20 +02:00
|
|
|
|
2016-07-12 15:05:17 +02:00
|
|
|
#define ANIM_IN 0x00 /*Animation to show an object. 'OR' it with lv_anim_builtin_t*/
|
|
|
|
#define ANIM_OUT 0x80 /*Animation to hide an object. 'OR' it with lv_anim_builtin_t*/
|
|
|
|
#define ANIM_DIR_MASK 0x80 /*ANIM_IN/ANIM_OUT mask*/
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
struct __LV_OBJ_T;
|
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
2016-10-04 09:45:39 +02:00
|
|
|
LV_DESIGN_DRAW_MAIN,
|
|
|
|
LV_DESIGN_DRAW_POST,
|
2016-06-08 07:25:08 +02:00
|
|
|
LV_DESIGN_COVER_CHK,
|
|
|
|
}lv_design_mode_t;
|
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
typedef bool (* lv_design_func_t) (struct __LV_OBJ_T * obj, const area_t * mask_p, lv_design_mode_t mode);
|
2016-06-08 07:25:08 +02:00
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
2017-07-20 12:26:34 +02:00
|
|
|
/*General signals*/
|
2016-06-08 07:25:08 +02:00
|
|
|
LV_SIGNAL_CLEANUP,
|
2017-07-20 12:26:34 +02:00
|
|
|
LV_SIGNAL_CHILD_CHG,
|
|
|
|
LV_SIGNAL_CORD_CHG,
|
|
|
|
LV_SIGNAL_STYLE_CHG,
|
|
|
|
LV_SIGNAL_REFR_EXT_SIZE,
|
|
|
|
|
2017-10-09 15:21:26 +02:00
|
|
|
/*Input device related*/
|
2016-06-08 07:25:08 +02:00
|
|
|
LV_SIGNAL_PRESSED,
|
2017-07-20 12:26:34 +02:00
|
|
|
LV_SIGNAL_PRESSING,
|
2016-06-08 07:25:08 +02:00
|
|
|
LV_SIGNAL_PRESS_LOST,
|
|
|
|
LV_SIGNAL_RELEASED,
|
|
|
|
LV_SIGNAL_LONG_PRESS,
|
2016-12-17 12:02:30 +01:00
|
|
|
LV_SIGNAL_LONG_PRESS_REP,
|
2016-06-08 07:25:08 +02:00
|
|
|
LV_SIGNAL_DRAG_BEGIN,
|
2017-07-20 12:26:34 +02:00
|
|
|
LV_SIGNAL_DRAG_END,
|
|
|
|
|
|
|
|
/*Group related*/
|
2017-07-25 09:02:21 +02:00
|
|
|
LV_SIGNAL_FOCUS,
|
|
|
|
LV_SIGNAL_DEFOCUS,
|
|
|
|
LV_SIGNAL_CONTROLL,
|
2016-06-08 07:25:08 +02:00
|
|
|
}lv_signal_t;
|
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
typedef bool (* lv_signal_func_t) (struct __LV_OBJ_T * obj, lv_signal_t sign, void * param);
|
2016-06-08 07:25:08 +02:00
|
|
|
|
|
|
|
typedef struct __LV_OBJ_T
|
|
|
|
{
|
2017-05-01 16:47:27 +02:00
|
|
|
struct __LV_OBJ_T * par; /*Pointer to the parent object*/
|
|
|
|
ll_dsc_t child_ll; /*Linked list to store the children objects*/
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
area_t coords; /*Coordinates of the object (x1, y1, x2, y2)*/
|
2016-06-20 18:18:36 +02:00
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
lv_signal_func_t signal_func; /*Object type specific signal function*/
|
|
|
|
lv_design_func_t design_func; /*Object type specific design function*/
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-10-20 10:17:02 +02:00
|
|
|
void * ext_attr; /*Object type specific extended data*/
|
2017-05-01 16:47:27 +02:00
|
|
|
lv_style_t * style_p; /*Pointer to the object's style*/
|
2016-06-20 18:18:36 +02:00
|
|
|
|
2017-10-20 22:11:18 +02:00
|
|
|
#if LV_OBJ_FREE_PTR != 0
|
2017-10-20 10:17:02 +02:00
|
|
|
void * free_ptr; /*Application specific pointer (set it freely)*/
|
2016-06-20 18:18:36 +02:00
|
|
|
#endif
|
|
|
|
|
2017-07-19 15:19:10 +02:00
|
|
|
void * group_p; /*Pointer to the group of the object*/
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/*Attributes and states*/
|
2017-10-20 10:17:02 +02:00
|
|
|
uint8_t click :1; /*1: Can be pressed by an input device*/
|
|
|
|
uint8_t drag :1; /*1: Enable the dragging*/
|
|
|
|
uint8_t drag_throw:1; /*1: Enable throwing with drag*/
|
2017-05-01 16:47:27 +02:00
|
|
|
uint8_t drag_parent :1; /*1: Parent will be dragged instead*/
|
2017-01-03 17:09:35 +01:00
|
|
|
uint8_t hidden :1; /*1: Object is hidden*/
|
2017-10-20 10:17:02 +02:00
|
|
|
uint8_t top :1; /*1: If the object or its children is clicked it goes to the foreground*/
|
2017-01-03 17:09:35 +01:00
|
|
|
uint8_t reserved :1;
|
|
|
|
|
|
|
|
uint8_t protect; /*Automatically happening actions can be prevented. 'OR'ed values from lv_obj_prot_t*/
|
|
|
|
|
2017-05-01 16:47:27 +02:00
|
|
|
cord_t ext_size; /*EXTtend the size of the object in every direction. E.g. for shadow drawing*/
|
2016-06-20 18:18:36 +02:00
|
|
|
|
2017-10-20 22:11:18 +02:00
|
|
|
#if LV_OBJ_FREE_NUM != 0
|
2017-01-03 17:09:35 +01:00
|
|
|
uint8_t free_num; /*Application specific identifier (set it freely)*/
|
2017-04-11 10:50:57 +02:00
|
|
|
#endif
|
2016-06-08 07:25:08 +02:00
|
|
|
}lv_obj_t;
|
|
|
|
|
2017-01-08 13:06:41 +01:00
|
|
|
/*Protect some attributes (max. 8 bit)*/
|
2017-01-03 17:09:35 +01:00
|
|
|
typedef enum
|
|
|
|
{
|
2017-01-08 13:06:41 +01:00
|
|
|
LV_PROTECT_NONE = 0x00,
|
|
|
|
LV_PROTECT_CHILD_CHG = 0x01, /*Disable the child change signal. Used by the library*/
|
2017-04-11 10:50:57 +02:00
|
|
|
LV_PROTECT_PARENT = 0x02, /*Prevent automatic parent change (e.g. in lv_page)*/
|
2017-07-07 23:02:08 +02:00
|
|
|
LV_PROTECT_POS = 0x04, /*Prevent automatic positioning (e.g. in lv_cont layout)*/
|
2017-07-09 15:32:49 +02:00
|
|
|
LV_PROTECT_FOLLOW = 0x08, /*Prevent the object be followed in automatic ordering (e.g. in lv_cont PRETTY layout)*/
|
2017-01-08 15:58:31 +01:00
|
|
|
}lv_protect_t;
|
2017-01-03 17:09:35 +01:00
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
LV_ALIGN_CENTER = 0,
|
2017-05-01 16:47:27 +02:00
|
|
|
LV_ALIGN_IN_TOP_LEFT,
|
|
|
|
LV_ALIGN_IN_TOP_MID,
|
|
|
|
LV_ALIGN_IN_TOP_RIGHT,
|
|
|
|
LV_ALIGN_IN_BOTTOM_LEFT,
|
|
|
|
LV_ALIGN_IN_BOTTOM_MID,
|
|
|
|
LV_ALIGN_IN_BOTTOM_RIGHT,
|
|
|
|
LV_ALIGN_IN_LEFT_MID,
|
|
|
|
LV_ALIGN_IN_RIGHT_MID,
|
|
|
|
LV_ALIGN_OUT_TOP_LEFT,
|
|
|
|
LV_ALIGN_OUT_TOP_MID,
|
|
|
|
LV_ALIGN_OUT_TOP_RIGHT,
|
|
|
|
LV_ALIGN_OUT_BOTTOM_LEFT,
|
|
|
|
LV_ALIGN_OUT_BOTTOM_MID,
|
|
|
|
LV_ALIGN_OUT_BOTTOM_RIGHT,
|
|
|
|
LV_ALIGN_OUT_LEFT_TOP,
|
|
|
|
LV_ALIGN_OUT_LEFT_MID,
|
|
|
|
LV_ALIGN_OUT_LEFT_BOTTOM,
|
|
|
|
LV_ALIGN_OUT_RIGHT_TOP,
|
|
|
|
LV_ALIGN_OUT_RIGHT_MID,
|
|
|
|
LV_ALIGN_OUT_RIGHT_BOTTOM,
|
2016-06-08 07:25:08 +02:00
|
|
|
}lv_align_t;
|
|
|
|
|
2016-07-12 15:05:17 +02:00
|
|
|
typedef enum
|
|
|
|
{
|
2016-07-12 15:07:57 +02:00
|
|
|
LV_ANIM_NONE = 0,
|
2016-09-27 13:43:01 +02:00
|
|
|
LV_ANIM_FLOAT_TOP, /*Float from/to the top*/
|
|
|
|
LV_ANIM_FLOAT_LEFT, /*Float from/to the left*/
|
|
|
|
LV_ANIM_FLOAT_BOTTOM, /*Float from/to the bottom*/
|
|
|
|
LV_ANIM_FLOAT_RIGHT, /*Float from/to the right*/
|
|
|
|
LV_ANIM_GROW_H, /*Grow/shrink horizontally*/
|
|
|
|
LV_ANIM_GROW_V, /*Grow/shrink vertically*/
|
2016-07-12 15:05:17 +02:00
|
|
|
}lv_anim_builtin_t;
|
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Init. the 'lv' library.
|
|
|
|
*/
|
2016-06-08 07:25:08 +02:00
|
|
|
void lv_init(void);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a basic object
|
|
|
|
* @param parent pointer to a parent object.
|
|
|
|
* If NULL then a screen will be created
|
|
|
|
* @param copy pointer to a base object, if not NULL then the new object will be copied from it
|
|
|
|
* @return pointer to the new object
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
lv_obj_t * lv_obj_create(lv_obj_t * parent, lv_obj_t * copy);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete 'obj' and all of its children
|
2017-05-01 16:47:27 +02:00
|
|
|
* @param obj pointer to an object to delete
|
2017-01-13 23:27:49 +01:00
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_del(lv_obj_t * obj);
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-10-31 16:25:52 +01:00
|
|
|
/**
|
|
|
|
* Delete all children of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
*/
|
|
|
|
void lv_obj_clear(lv_obj_t *obj);
|
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Signal function of the basic object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param sign signal type
|
|
|
|
* @param param parameter for the signal (depends on signal type)
|
|
|
|
* @return false: the object become invalid (e.g. deleted)
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_signal(lv_obj_t * obj, lv_signal_t sign, void * param);
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-05-12 16:09:37 +02:00
|
|
|
/**
|
|
|
|
* Mark the object as invalid therefore its current position will be redrawn by 'lv_refr_task'
|
|
|
|
* @param obj pointer to an object
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_invalidate(lv_obj_t * obj);
|
2017-05-12 16:09:37 +02:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Load a new screen
|
|
|
|
* @param scr pointer to a screen
|
|
|
|
*/
|
2017-10-20 15:37:50 +02:00
|
|
|
void lv_scr_load(lv_obj_t * scr);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a new parent for an object. Its relative position will be the same.
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param parent pointer to the new parent object
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_parent(lv_obj_t * obj, lv_obj_t * parent);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set relative the position of an object (relative to the parent)
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param x new distance from the left side of the parent
|
|
|
|
* @param y new distance from the top of the parent
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_pos(lv_obj_t * obj, cord_t x, cord_t y);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set relative the position of an object (relative to the parent).
|
2017-05-12 16:09:37 +02:00
|
|
|
* The coordinates will be upscaled with LV_DOWNSCALE.
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param x new distance from the left side of the parent. (will be multiplied with LV_DOWNSCALE)
|
|
|
|
* @param y new distance from the top of the parent. (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_pos_scale(lv_obj_t * obj, cord_t x, cord_t y);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the x coordinate of a object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param x new distance from the left side from the parent
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_x(lv_obj_t * obj, cord_t x);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the x coordinate of a object.
|
2017-05-12 16:09:37 +02:00
|
|
|
* The coordinate will be upscaled with LV_DOWNSCALE.
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param x new distance from the left side from the parent. (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_x_scale(lv_obj_t * obj, cord_t x);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the y coordinate of a object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param y new distance from the top of the parent
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_y(lv_obj_t * obj, cord_t y);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the y coordinate of a object.
|
2017-05-12 16:09:37 +02:00
|
|
|
* The coordinate will be upscaled with LV_DOWNSCALE.
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param y new distance from the top of the parent. (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_y_scale(lv_obj_t * obj, cord_t y);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the size of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param w new width
|
|
|
|
* @param h new height
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_size(lv_obj_t * obj, cord_t w, cord_t h);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-05-12 16:09:37 +02:00
|
|
|
* Set the size of an object. The coordinates will be upscaled with LV_DOWNSCALE.
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param w new width (will be multiplied with LV_DOWNSCALE)
|
|
|
|
* @param h new height (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_size_scale(lv_obj_t * obj, cord_t w, cord_t h);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the width of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param w new width
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_width(lv_obj_t * obj, cord_t w);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-05-12 16:09:37 +02:00
|
|
|
* Set the width of an object. The width will be upscaled with LV_DOWNSCALE
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param w new width (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_width_scale(lv_obj_t * obj, cord_t w);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the height of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param h new height
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_set_height(lv_obj_t * obj, cord_t h);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-05-12 16:09:37 +02:00
|
|
|
* Set the height of an object. The height will be upscaled with LV_DOWNSCALE
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param h new height (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_height_scale(lv_obj_t * obj, cord_t h);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Align an object to an other object.
|
|
|
|
* @param obj pointer to an object to align
|
|
|
|
* @param base pointer to an object (if NULL the parent is used). 'obj' will be aligned to it.
|
|
|
|
* @param align type of alignment (see 'lv_align_t' enum)
|
|
|
|
* @param x_mod x coordinate shift after alignment
|
|
|
|
* @param y_mod y coordinate shift after alignment
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
void lv_obj_align(lv_obj_t * obj,lv_obj_t * base, lv_align_t align, cord_t x_mod, cord_t y_mod);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-05-12 16:09:37 +02:00
|
|
|
* Align an object to an other object. The coordinates will be upscaled with LV_DOWNSCALE.
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object to align
|
|
|
|
* @param base pointer to an object (if NULL the parent is used). 'obj' will be aligned to it.
|
|
|
|
* @param align type of alignment (see 'lv_align_t' enum)
|
|
|
|
* @param x_mod x coordinate shift after alignment (will be multiplied with LV_DOWNSCALE)
|
|
|
|
* @param y_mod y coordinate shift after alignment (will be multiplied with LV_DOWNSCALE)
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_align_scale(lv_obj_t * obj,lv_obj_t * base, lv_align_t align, cord_t x_mod, cord_t y_mod);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the extended size of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param ext_size the extended size
|
|
|
|
*/
|
2016-10-27 14:20:22 +02:00
|
|
|
void lv_obj_set_ext_size(lv_obj_t * obj, cord_t ext_size);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a new style for an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param style_p pointer to the new style
|
|
|
|
*/
|
2017-04-13 10:20:35 +02:00
|
|
|
void lv_obj_set_style(lv_obj_t * obj, lv_style_t * style);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-05-12 16:09:37 +02:00
|
|
|
/**
|
|
|
|
* Notify an object about its style is modified
|
|
|
|
* @param obj pointer to an object
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_refresh_style(lv_obj_t * obj);
|
2017-05-12 16:09:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notify all object if a style is modified
|
|
|
|
* @param style pointer to a style. Only the objects with this style will be notified
|
|
|
|
* (NULL to notify all objects)
|
|
|
|
*/
|
|
|
|
void lv_style_refr_objs(void * style);
|
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Hide an object. It won't be visible and clickable.
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: hide the object
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_hidden(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable or disable the clicking of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: make the object clickable
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_click(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable to bring this object to the foreground if it
|
|
|
|
* or any of its children is clicked
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: enable the auto top feature
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_top(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable the dragging of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: make the object dragable
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_drag(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable the throwing of an object after is is dragged
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: enable the drag throw
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_drag_throw(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable to use parent for drag related operations.
|
|
|
|
* If trying to drag the object the parent will be moved instead
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param en true: enable the 'drag parent' for the object
|
|
|
|
*/
|
2016-12-15 10:31:30 +01:00
|
|
|
void lv_obj_set_drag_parent(lv_obj_t * obj, bool en);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a bit or bits in the protect filed
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param prot 'OR'-ed values from lv_obj_prot_t
|
|
|
|
*/
|
2017-01-03 17:09:35 +01:00
|
|
|
void lv_obj_set_protect(lv_obj_t * obj, uint8_t prot);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear a bit or bits in the protect filed
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param prot 'OR'-ed values from lv_obj_prot_t
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_clear_protect(lv_obj_t * obj, uint8_t prot);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the signal function of an object.
|
|
|
|
* Always call the previous signal function in the new.
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param fp the new signal function
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_signal_func(lv_obj_t * obj, lv_signal_func_t fp);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a new design function for an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param fp the new design function
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_design_func(lv_obj_t * obj, lv_design_func_t fp);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocate a new ext. data for an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param ext_size the size of the new ext. data
|
|
|
|
* @return Normal pointer to the allocated ext
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void * lv_obj_allocate_ext_attr(lv_obj_t * obj, uint16_t ext_size);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Send a 'LV_SIGNAL_REFR_EXT_SIZE' signal to the object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_refresh_ext_size(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-10-20 15:37:50 +02:00
|
|
|
#if LV_OBJ_FREE_NUM != 0
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Set an application specific number for an object.
|
|
|
|
* It can help to identify objects in the application.
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param free_num the new free number
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_free_number(lv_obj_t * obj, uint8_t free_number);
|
2017-05-01 16:47:27 +02:00
|
|
|
#endif
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-10-20 15:37:50 +02:00
|
|
|
#if LV_OBJ_FREE_PTR != 0
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Set an application specific pointer for an object.
|
|
|
|
* It can help to identify objects in the application.
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param free_p the new free pinter
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_set_free_pointer(lv_obj_t * obj, void * free_pointer);
|
2017-05-01 16:47:27 +02:00
|
|
|
#endif
|
2017-07-19 15:19:10 +02:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Animate an object
|
|
|
|
* @param obj pointer to an object to animate
|
|
|
|
* @param type type of animation from 'lv_anim_builtin_t'. 'OR' it with ANIM_IN or ANIM_OUT
|
|
|
|
* @param time time of animation in milliseconds
|
|
|
|
* @param delay delay before the animation in milliseconds
|
|
|
|
* @param cb a function to call when the animation is ready
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_animate(lv_obj_t * obj, lv_anim_builtin_t type, uint16_t time, uint16_t delay, void (*cb) (lv_obj_t *));
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return with the actual screen
|
|
|
|
* @return pointer to to the actual screen object
|
|
|
|
*/
|
2017-10-20 15:37:50 +02:00
|
|
|
lv_obj_t * lv_scr_act(void);lv_obj_t * lv_layer_top(void);
|
2017-10-10 16:17:23 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return with the system layer. (Same on every screen and it is above the all other layers)
|
|
|
|
* It is used for example by the cursor
|
|
|
|
* @return pointer to the system layer object (transparent screen sized lv_obj)
|
|
|
|
*/
|
2017-10-11 09:11:29 +02:00
|
|
|
lv_obj_t * lv_layer_sys(void);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return with the screen of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return pointer to a screen
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
lv_obj_t * lv_obj_get_screen(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns with the parent of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return pointer to the parent of 'obj'
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
lv_obj_t * lv_obj_get_parent(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Iterate through the children of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param child NULL at first call to get the next children
|
|
|
|
* and the previous return value later
|
|
|
|
* @return the child after 'act_child' or NULL if no more child
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
lv_obj_t * lv_obj_get_child(lv_obj_t * obj, lv_obj_t * child);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-10-31 16:25:52 +01:00
|
|
|
/**
|
|
|
|
* Iterate through the children of an object (start from the "oldest")
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param child NULL at first call to get the next children
|
|
|
|
* and the previous return value later
|
|
|
|
* @return the child after 'act_child' or NULL if no more child
|
|
|
|
*/
|
|
|
|
lv_obj_t * lv_obj_get_child_back(lv_obj_t * obj, lv_obj_t * child);
|
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Count the children of an object (only children directly on 'obj')
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return children number of 'obj'
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
uint16_t lv_obj_count_children(lv_obj_t * obj);
|
2016-12-16 07:41:34 +01:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Copy the coordinates of an object to an area
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param cords_p pointer to an area to store the coordinates
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void lv_obj_get_coords(lv_obj_t * obj, area_t * cords_p);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the x coordinate of object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return distance of 'obj' from the left side of its parent
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
cord_t lv_obj_get_x(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the y coordinate of object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return distance of 'obj' from the top of its parent
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
cord_t lv_obj_get_y(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the width of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the width
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
cord_t lv_obj_get_width(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the height of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the height
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
cord_t lv_obj_get_height(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the extended size attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the extended size attribute
|
|
|
|
*/
|
2017-04-28 16:12:35 +02:00
|
|
|
cord_t lv_obj_get_ext_size(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-05-12 16:09:37 +02:00
|
|
|
* Get the style pointer of an object (if NULL get style of the parent)
|
2017-01-13 23:27:49 +01:00
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return pointer to a style
|
|
|
|
*/
|
2017-04-13 10:20:35 +02:00
|
|
|
lv_style_t * lv_obj_get_style(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the hidden attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: the object is hidden
|
|
|
|
*/
|
|
|
|
bool lv_obj_get_hidden(lv_obj_t * obj);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the click enable attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: the object is clickable
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_get_click(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the top enable attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: the auto top feture is enabled
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_get_top(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the drag enable attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: the object is dragable
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_get_drag(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the drag thow enable attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: drag throw is enabled
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_get_drag_throw(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the drag parent attribute of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return true: drag parent is enabled
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
bool lv_obj_get_drag_parent(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the protect field of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return protect field ('OR'ed values of lv_obj_prot_t)
|
|
|
|
*/
|
2017-01-03 17:09:35 +01:00
|
|
|
uint8_t lv_obj_get_protect(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check at least one bit of a given protect bitfield is set
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @param prot protect bits to test ('OR'ed values of lv_obj_prot_t)
|
|
|
|
* @return false: none of the given bits are set, true: at least one bit is set
|
|
|
|
*/
|
2017-01-03 17:09:35 +01:00
|
|
|
bool lv_obj_is_protected(lv_obj_t * obj, uint8_t prot);
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Get the signal function of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the signal function
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
lv_signal_func_t lv_obj_get_signal_func(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the design function of an object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the design function
|
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
lv_design_func_t lv_obj_get_design_func(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the ext pointer
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the ext pointer but not the dynamic version
|
2017-10-20 10:17:02 +02:00
|
|
|
* Use it as ext->data1, and NOT da(ext_attr)->data1
|
2017-01-13 23:27:49 +01:00
|
|
|
*/
|
2017-10-20 10:17:02 +02:00
|
|
|
void * lv_obj_get_ext_attr(lv_obj_t * obj);
|
2017-01-13 23:27:49 +01:00
|
|
|
|
2017-05-01 16:47:27 +02:00
|
|
|
#if LV_OBJ_FREE_NUM != 0
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Get the free number
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the free number
|
|
|
|
*/
|
2016-10-07 11:15:46 +02:00
|
|
|
uint8_t lv_obj_get_free_num(lv_obj_t * obj);
|
2017-05-01 16:47:27 +02:00
|
|
|
#endif
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-10-20 15:37:50 +02:00
|
|
|
#if LV_OBJ_FREE_PTR != 0
|
2017-01-13 23:27:49 +01:00
|
|
|
/**
|
|
|
|
* Get the free pointer
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the free pointer
|
|
|
|
*/
|
|
|
|
void * lv_obj_get_free_p(lv_obj_t * obj);
|
2017-05-01 16:47:27 +02:00
|
|
|
#endif
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-07-20 01:09:20 +02:00
|
|
|
#if LV_OBJ_GROUP != 0
|
|
|
|
/**
|
|
|
|
* Get the group of the object
|
|
|
|
* @param obj pointer to an object
|
|
|
|
* @return the pointer to group of the object
|
|
|
|
*/
|
|
|
|
void * lv_obj_get_group(lv_obj_t * obj);
|
|
|
|
#endif
|
2017-10-20 15:37:50 +02:00
|
|
|
|
2016-06-08 07:25:08 +02:00
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
2017-10-20 15:37:50 +02:00
|
|
|
#define LV_SCALE(x) (x << LV_ANTIALIAS)
|
2016-06-08 07:25:08 +02:00
|
|
|
|
2017-07-09 15:32:49 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
2016-06-08 07:25:08 +02:00
|
|
|
#endif
|
2017-07-09 15:32:49 +02:00
|
|
|
|
|
|
|
#endif /*LV_OBJ_H*/
|