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

96 lines
2.1 KiB
C
Raw Normal View History

2016-06-08 07:25:08 +02:00
/**
* @file lv_refr.h
2018-06-19 09:49:58 +02:00
*
2016-06-08 07:25:08 +02:00
*/
2017-07-09 15:32:49 +02:00
#ifndef LV_REFR_H
#define LV_REFR_H
#ifdef __cplusplus
extern "C" {
#endif
2016-06-08 07:25:08 +02:00
/*********************
* INCLUDES
*********************/
#include "lv_obj.h"
#include <stdbool.h>
/*********************
* DEFINES
*********************/
/**********************
* TYPEDEFS
**********************/
/**********************
* STATIC PROTOTYPES
**********************/
/**********************
* STATIC VARIABLES
**********************/
/**********************
* MACROS
**********************/
/**********************
* GLOBAL FUNCTIONS
**********************/
/**
* Initialize the screen refresh subsystem
*/
2016-06-08 07:25:08 +02:00
void lv_refr_init(void);
2018-09-20 21:59:44 +02:00
/**
* Redraw the invalidated areas now.
2018-12-26 07:58:06 +01:00
* Normally the redrawing is periodically executed in `lv_task_handler` but a long blocking process can
2018-09-20 21:59:44 +02:00
* prevent the call of `lv_task_handler`. In this case if the the GUI is updated in the process (e.g. progress bar)
2018-12-26 07:58:06 +01:00
* this function can be called when the screen should be updated.
2018-09-20 21:59:44 +02:00
*/
void lv_refr_now(void);
/**
* Invalidate an area
* @param area_p pointer to area which should be invalidated
*/
2017-11-23 21:28:36 +01:00
void lv_inv_area(const lv_area_t * area_p);
2016-06-08 07:25:08 +02:00
2017-07-07 18:40:35 +02:00
/**
* Set a function to call after every refresh to announce the refresh time and the number of refreshed pixels
* @param cb pointer to a callback function (void my_refr_cb(uint32_t time_ms, uint32_t px_num))
*/
void lv_refr_set_monitor_cb(void (*cb)(uint32_t, uint32_t));
2017-07-09 15:32:49 +02:00
/**
* Called when an area is invalidated to modify the coordinates of the area.
* Special display controllers may require special coordinate rounding
* @param cb pointer to the a function which will modify the area
*/
2018-03-02 15:34:22 +01:00
void lv_refr_set_round_cb(void(*cb)(lv_area_t*));
/**
* Get the number of areas in the buffer
* @return number of invalid areas
*/
uint16_t lv_refr_get_buf_size(void);
/**
* Pop (delete) the last 'num' invalidated areas from the buffer
* @param num number of areas to delete
*/
void lv_refr_pop_from_buf(uint16_t num);
2016-06-08 07:25:08 +02:00
/**********************
* STATIC FUNCTIONS
**********************/
2017-07-09 15:32:49 +02:00
#ifdef __cplusplus
} /* extern "C" */
#endif
#endif /*LV_REFR_H*/