# 如何启用屏保

屏保是一个普通窗口,定时切换不同的图片或者动态绘制一些图形,以到达保护屏幕的效果。

# 一、设置屏保定时器时间

用函数 window_manager_set_screen_saver_time 设置屏保时间。

/**
 * @method window_manager_set_screen_saver_time
 * 设置屏保时间。
 * @annotation ["scriptable"]
 * @param {widget_t*} widget 窗口管理器对象。
 * @param {uint32_t}  screen_saver_time 屏保时间(单位毫秒)。
 *
 * @return {ret_t} 返回 RET_OK 表示成功,否则表示失败。
 */
ret_t window_manager_set_screen_saver_time(widget_t* widget, uint32_t screen_saver_time);
window_manager_set_screen_saver_time(window_manager(), 180 * 1000);

# 二、注册事件并打开屏保窗口

示例:

static ret_t close_window_on_event(void* ctx, event_t* e) {
  window_close(WIDGET(ctx));

  return RET_REMOVE;
}

static ret_t on_screen_saver(void* ctx, event_t* e) {
  widget_t* win = NULL;
  const char* screen_saver_win = "image_animation";

  if (widget_child(window_manager(), screen_saver_win) != NULL) {
    log_debug("screen saver exist.\n");
    return RET_OK;
  }

  win = window_open(screen_saver_win);
  widget_on(win, EVT_POINTER_MOVE, close_window_on_event, win);
  widget_on(win, EVT_POINTER_UP, close_window_on_event, win);
  widget_on(win, EVT_KEY_UP, close_window_on_event, win);

  return RET_OK;
}

ret_t application_init() {
  tk_ext_widgets_init();

  /*enable screen saver*/
  window_manager_set_screen_saver_time(window_manager(), 180 * 1000);
  widget_on(window_manager(), EVT_SCREEN_SAVER, on_screen_saver, NULL);

  return show_preload_res_window();
}

可以在 XML 设置 window 的 fullscreen 属性,让屏保窗口进入全屏状态。

# 三、扩展用法

有时需求可能是这样的:

  • 用户 m 秒没有操作,返回到主屏

  • 用户 n 秒没有操作,启动屏保

  • 用户 k 秒没有操作,进入睡眠。

其中 m < n < k

此时可以把 screen_saver_time 设置短一点(比如 5s),每次收到屏保事件则更新用户没有操作的时间,根据这个时间做适当的处理。