Timers(定时器)

显示原文

LVGL has a built-in timer system. You can register a function to have it be called periodically. The timers are handled and called in lv_timer_handler(), which needs to be called every few milliseconds. See Porting for more information.

Timers are non-preemptive, which means a timer cannot interrupt another timer. Therefore, you can call any LVGL related function in a timer.


LVGL有一个内置的定时器系统。您可以注册一个函数,让它定期被调用。这些定时器在 lv_timer_handler() 函数中进行处理和调用,该函数需要每隔几毫秒调用一次。更多信息请参阅 Porting

定时器是非抢占式的,这意味着一个定时器不能中断另一个定时器。因此,您可以在定时器中调用任何与LVGL相关的函数。

Create a timer(创建定时器)

显示原文

To create a new timer, use lv_timer_create(timer_cb, period_ms, user_data). It will create an lv_timer_t * variable, which can be used later to modify the parameters of the timer. lv_timer_create_basic() can also be used. This allows you to create a new timer without specifying any parameters.

A timer callback should have a void (*lv_timer_cb_t)(lv_timer_t *) prototype.

For example:

void my_timer(lv_timer_t * timer)
{
  /*Use the user_data*/
  uint32_t * user_data = timer->user_data;
  printf("my_timer called with user data: %d\n", *user_data);

  /*Do something with LVGL*/
  if(something_happened) {
    something_happened = false;
    lv_button_create(lv_screen_active(), NULL);
  }
}

...

static uint32_t user_data = 10;
lv_timer_t * timer = lv_timer_create(my_timer, 500,  &user_data);

要创建一个新定时器,使用 lv_timer_create(timer_cb, period_ms, user_data)。这将创建一个 lv_timer_t * 类型的变量,之后可以使用这个变量来修改定时器的参数。 lv_timer_create_basic() 也可以使用。这允许您在不指定任何参数的情况下创建一个新定时器。

定时器回调函数的原型应该是 void (*lv_timer_cb_t)(lv_timer_t *)

例如:

void my_timer(lv_timer_t * timer)
{
  /*Use the user_data*/
  uint32_t * user_data = timer->user_data;
  printf("my_timer called with user data: %d\n", *user_data);

  /*Do something with LVGL*/
  if(something_happened) {
    something_happened = false;
    lv_button_create(lv_screen_active(), NULL);
  }
}

...

static uint32_t user_data = 10;
lv_timer_t * timer = lv_timer_create(my_timer, 500,  &user_data);

Ready and Reset(准备与重置)

显示原文

lv_timer_ready(timer) makes a timer run on the next call of lv_timer_handler().

lv_timer_reset(timer) resets the period of a timer. It will be called again after the defined period of milliseconds has elapsed.


lv_timer_ready(timer) 使定时器在下一次调用 lv_timer_handler() 函数时运行。

lv_timer_reset(timer) 重置定时器的周期。在定义的毫秒周期过去后,它将再次被调用。

Set parameters(参数设置)

显示原文

You can modify some timer parameters later:


您可以稍后修改一些定时器参数:

Repeat count(设置重复次数)

显示原文

You can make a timer repeat only a given number of times with lv_timer_set_repeat_count(timer, count). The timer will automatically be deleted after it's called the defined number of times. Set the count to -1 to repeat indefinitely.


你可以使用 lv_timer_set_repeat_count(timer, count) 来让一个定时器只重复给定的次数。 当定时器在被调用指定次数后将自动被删除。将计数设置为 -1 表示无限重复。

Enable and Disable(启用和禁用)

显示原文

You can enable or disable a timer with lv_timer_enable(en).


你可以使用 lv_timer_enable(en) 来启用或禁用一个定时器。

Pause and Resume(暂停和恢复)

显示原文

lv_timer_pause(timer) pauses the specified timer.

lv_timer_resume(timer) resumes the specified timer.


lv_timer_pause(timer) 暂停指定的定时器。

lv_timer_resume(timer) 恢复指定的定时器。

Measure idle time(测量空闲时间)

显示原文

You can get the idle percentage time of lv_timer_handler() with lv_timer_get_idle(). Note that, it doesn't measure the idle time of the overall system, only lv_timer_handler(). It can be misleading if you use an operating system and call lv_timer_handler() in a timer, as it won't actually measure the time the OS spends in an idle thread.


您可以使用 lv_timer_get_idle 函数获取 lv_timer_handler() 函数的空闲百分比时间。 请注意,它并不测量整个系统的空闲时间,仅测量 lv_timer_handler() 的空闲时间。 如果您使用操作系统并在定时器中调用 lv_timer_handler(),这可能会产生误导,因为它实际上不能测量操作系统在空闲线程中的消耗时间。

Timer handler resume callback(定时器处理程序恢复回调)

显示原文

When the lv_timer_handler is stopped, if you want to pay attention to the wake-up timing of the lv_timer_handler, you can set a resume callback using lv_timer_handler_set_resume_cb(cb, user_data). The callback should have a void (*lv_timer_handler_resume_cb_t)(void*) prototype.


lv_timer_handler 被停止后,如果你想要关注 lv_timer_handler 的唤醒时机,你可以使用 lv_timer_handler_set_resume_cb(cb, user_data) 来设置一个恢复回调函数。 回调函数的原型应该是 void (*lv_timer_handler_resume_cb_t)(void*)

Asynchronous calls(异步调用)

显示原文

In some cases, you can't perform an action immediately. For example, you can't delete an object because something else is still using it, or you don't want to block the execution now. For these cases, lv_async_call(my_function, data_p) can be used to call my_function on the next invocation of lv_timer_handler(). data_p will be passed to the function when it's called. Note that only the data pointer is saved, so you need to ensure that the variable will be "alive" while the function is called. It can be static, global or dynamically allocated data. If you want to cancel an asynchronous call, call lv_async_call_cancel(my_function, data_p), which will clear all asynchronous calls matching my_function and data_p.

For example:

void my_screen_clean_up(void * scr)
{
  /*Free some resources related to `scr`*/

  /*Finally delete the screen*/
  lv_obj_delete(scr);
}

...

/*Do something with the object on the current screen*/

/*Delete screen on next call of `lv_timer_handler`, not right now.*/
lv_async_call(my_screen_clean_up, lv_screen_active());

/*The screen is still valid so you can do other things with it*/

If you just want to delete an object and don't need to clean anything up in my_screen_cleanup you could just use lv_obj_delete_async() which will delete the object on the next call to lv_timer_handler().


在某些情况下,您不能立即执行某个操作。例如,你不能删除一个对象,因为还有其他东西正在使用它,或者你现在不想阻塞执行。 对于这些情况,可以使用 lv_async_call(my_function, data_p) 在下一次调用 lv_timer_handler() 时调用 my_functiondata_p``将在函数被调用时传递给该函数。请注意,只保存数据指针,因此您需要确保在调用函数时变量仍然有效。 它可以是 *静态*、全局或动态分配的数据。如果您想要取消异步调用,请调用 :cpp:expr:`lv_async_call_cancel(my_function, data_p)`, 它将清除与 ``my_functiondata_p 匹配的所有异步调用。

例如:

void my_screen_clean_up(void * scr)
{
  /*释放与`scr`相关的一些资源*/

  /*最后删除屏幕*/
  lv_obj_delete(scr);
}

...

/*在当前屏幕上执行一些操作*/

/*在下一次调用`lv_timer_handler`时删除屏幕,而不是立即删除。*/
lv_async_call(my_screen_clean_up, lv_screen_active());

/*屏幕仍然有效,因此您可以对其进行其他操作*/

如果您只想删除一个对象,而不需要在 my_screen_cleanup 中进行任何清理操作, 可以直接使用 lv_obj_delete_async() ,它将在下一次调用 lv_timer_handler() 时删除该对象。

API

lv_api_map_v8.h

lv_types.h

lv_timer.h