mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-01-19 00:03:33 +00:00
Merge remote-tracking branch 'origin/develop' into xap
This commit is contained in:
commit
f9c168a698
@ -12,6 +12,9 @@ vpath %.hpp $(VPATH_SRC)
|
||||
vpath %.S $(VPATH_SRC)
|
||||
VPATH :=
|
||||
|
||||
# Helper to return the distinct elements of a list
|
||||
uniq = $(if $1,$(firstword $1) $(call uniq,$(filter-out $(firstword $1),$1)))
|
||||
|
||||
# Convert all SRC to OBJ
|
||||
define OBJ_FROM_SRC
|
||||
$(patsubst %.c,$1/%.o,$(patsubst %.cpp,$1/%.o,$(patsubst %.cc,$1/%.o,$(patsubst %.S,$1/%.o,$(patsubst %.clib,$1/%.a,$($1_SRC))))))
|
||||
@ -264,7 +267,7 @@ BEGIN = gccversion sizebefore
|
||||
# Note the obj.txt depeendency is there to force linking if a source file is deleted
|
||||
%.elf: $(OBJ) $(MASTER_OUTPUT)/cflags.txt $(MASTER_OUTPUT)/ldflags.txt $(MASTER_OUTPUT)/obj.txt | $(BEGIN)
|
||||
@$(SILENT) || printf "$(MSG_LINKING) $@" | $(AWK_CMD)
|
||||
$(eval CMD=MAKE=$(MAKE) $(CC) $(ALL_CFLAGS) $(filter-out %.txt,$^) --output $@ $(LDFLAGS))
|
||||
$(eval CMD=MAKE=$(MAKE) $(CC) $(ALL_CFLAGS) $(call uniq,$(OBJ)) --output $@ $(LDFLAGS))
|
||||
@$(BUILD_CMD)
|
||||
|
||||
|
||||
|
@ -53,3 +53,11 @@ The `qp_lvgl_detach` function stops the internal LVGL ticks and releases resourc
|
||||
## Enabling/Disabling LVGL features :id=lvgl-configuring
|
||||
|
||||
You can overwrite LVGL specific features in your `lv_conf.h` file.
|
||||
|
||||
## Changing the LVGL task frequency
|
||||
|
||||
When LVGL is running, your keyboard's responsiveness may decrease, causing missing keystrokes or encoder rotations, especially during the animation of dynamically-generated content. This occurs because LVGL operates as a scheduled task with a default task rate of five milliseconds. While a fast task rate is advantageous when LVGL is responsible for detecting and processing inputs, it can lead to excessive recalculations of displayed content, which may slow down QMK's matrix scanning. If you rely on QMK instead of LVGL for processing inputs, it can be beneficial to increase the time between calls to the LVGL task handler to better match your preferred display update rate. To do this, add this to your `config.h`:
|
||||
|
||||
```c
|
||||
#define QP_LVGL_TASK_PERIOD 40
|
||||
```
|
||||
|
@ -81,8 +81,8 @@ bool qp_lvgl_attach(painter_device_t device) {
|
||||
|
||||
lvgl_state_t *lv_task_handler_state = &lvgl_states[1];
|
||||
lv_task_handler_state->fnc_id = 1;
|
||||
lv_task_handler_state->delay_ms = 5;
|
||||
lv_task_handler_state->defer_token = defer_exec_advanced(lvgl_executors, 2, 5, tick_task_callback, lv_task_handler_state);
|
||||
lv_task_handler_state->delay_ms = QP_LVGL_TASK_PERIOD;
|
||||
lv_task_handler_state->defer_token = defer_exec_advanced(lvgl_executors, 2, QP_LVGL_TASK_PERIOD, tick_task_callback, lv_task_handler_state);
|
||||
|
||||
if (lv_task_handler_state->defer_token == INVALID_DEFERRED_TOKEN) {
|
||||
qp_dprintf("qp_lvgl_attach: fail (could not set up qp_lvgl executor)\n");
|
||||
|
@ -7,6 +7,10 @@
|
||||
#include "qp.h"
|
||||
#include "lvgl.h"
|
||||
|
||||
#ifndef QP_LVGL_TASK_PERIOD
|
||||
# define QP_LVGL_TASK_PERIOD 5
|
||||
#endif
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
// Quantum Painter - LVGL External API
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user