forked from forks/qmk_firmware
[Keyboard] tkc/portico75 — Fix layers & move to encoder map (#19359)
This commit is contained in:
parent
f21443d6a2
commit
a73014fa27
|
@ -18,15 +18,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
#include QMK_KEYBOARD_H
|
#include QMK_KEYBOARD_H
|
||||||
|
|
||||||
#define ENCODERS 1
|
|
||||||
|
|
||||||
#define ENCODERS_CW_KEY { { 14, 3 } }
|
|
||||||
#define ENCODERS_CCW_KEY { { 14, 4 } }
|
|
||||||
|
|
||||||
static uint8_t encoder_state[ENCODERS] = {0};
|
|
||||||
static keypos_t encoder_cw[ENCODERS] = ENCODERS_CW_KEY;
|
|
||||||
static keypos_t encoder_ccw[ENCODERS] = ENCODERS_CCW_KEY;
|
|
||||||
|
|
||||||
// WT RGB-specific keys:
|
// WT RGB-specific keys:
|
||||||
// EF_INC, EF_DEC, // next/previous backlight effect
|
// EF_INC, EF_DEC, // next/previous backlight effect
|
||||||
// H1_INC, H1_DEC, // Color 1 hue increase/decrease
|
// H1_INC, H1_DEC, // Color 1 hue increase/decrease
|
||||||
|
@ -51,7 +42,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, MO(1), _______, _______, _______
|
_______, _______, _______, _______, _______, _______, _______, _______, _______
|
||||||
),
|
),
|
||||||
#else
|
#else
|
||||||
[1] = LAYOUT_75_via(
|
[1] = LAYOUT_75_via(
|
||||||
|
@ -60,7 +51,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
|
||||||
_______, _______, _______, _______, _______, MO(1), _______, _______, _______
|
_______, _______, _______, _______, _______, _______, _______, _______, _______
|
||||||
),
|
),
|
||||||
#endif
|
#endif
|
||||||
[2] = LAYOUT_75_via(
|
[2] = LAYOUT_75_via(
|
||||||
|
@ -81,29 +72,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
|
||||||
void encoder_action_unregister(void) {
|
#ifdef ENCODER_MAP_ENABLE
|
||||||
for (int index = 0; index < ENCODERS; ++index) {
|
const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
|
||||||
if (encoder_state[index]) {
|
[0] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU)},
|
||||||
keyevent_t encoder_event = (keyevent_t) {
|
[1] = {ENCODER_CCW_CW(KC_PGUP, KC_PGDN)},
|
||||||
.key = encoder_state[index] >> 1 ? encoder_cw[index] : encoder_ccw[index],
|
[2] = {ENCODER_CCW_CW(_______, _______)},
|
||||||
.pressed = false,
|
[3] = {ENCODER_CCW_CW(_______, _______)}
|
||||||
.time = (timer_read() | 1)
|
|
||||||
};
|
|
||||||
encoder_state[index] = 0;
|
|
||||||
action_exec(encoder_event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void encoder_action_register(uint8_t index, bool clockwise) {
|
|
||||||
keyevent_t encoder_event = (keyevent_t){.key = clockwise ? encoder_cw[index] : encoder_ccw[index], .pressed = true, .time = (timer_read() | 1)};
|
|
||||||
encoder_state[index] = (clockwise ^ 1) | (clockwise << 1);
|
|
||||||
action_exec(encoder_event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void matrix_scan_user(void) { encoder_action_unregister(); }
|
|
||||||
|
|
||||||
bool encoder_update_user(uint8_t index, bool clockwise) {
|
|
||||||
encoder_action_register(index, clockwise);
|
|
||||||
return false;
|
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
VIA_ENABLE = yes
|
VIA_ENABLE = yes
|
||||||
LTO_ENABLE = yes
|
LTO_ENABLE = yes
|
||||||
RGB_MATRIX_ENABLE = no # Use RGB matrix
|
RGB_MATRIX_ENABLE = no # Use RGB matrix
|
||||||
|
ENCODER_MAP_ENABLE = yes
|
||||||
|
|
||||||
# project specific files
|
# project specific files
|
||||||
SRC += keyboards/wilba_tech/wt_main.c \
|
SRC += keyboards/wilba_tech/wt_main.c \
|
||||||
|
|
Loading…
Reference in a new issue