diff options
author | jack <0x6A73@pm.me> | 2022-12-17 12:55:12 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-12-17 11:55:12 -0800 |
commit | a73014fa27c24d2b0f7b12037583507d13f9aa96 (patch) | |
tree | 713a012256a5edc8b9c9e3d65ec3ffd7ee066ad4 | |
parent | f21443d6a2be8e2068164f0f3646a175ffed2df4 (diff) |
[Keyboard] tkc/portico75 — Fix layers & move to encoder map (#19359)
-rw-r--r-- | keyboards/tkc/portico75/keymaps/via/keymap.c | 45 | ||||
-rw-r--r-- | keyboards/tkc/portico75/keymaps/via/rules.mk | 1 |
2 files changed, 10 insertions, 36 deletions
diff --git a/keyboards/tkc/portico75/keymaps/via/keymap.c b/keyboards/tkc/portico75/keymaps/via/keymap.c index cee94c4a1d..82f610292e 100644 --- a/keyboards/tkc/portico75/keymaps/via/keymap.c +++ b/keyboards/tkc/portico75/keymaps/via/keymap.c @@ -18,15 +18,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. #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: // EF_INC, EF_DEC, // next/previous backlight effect // 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 [1] = LAYOUT_75_via( @@ -60,7 +51,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, - _______, _______, _______, _______, _______, MO(1), _______, _______, _______ + _______, _______, _______, _______, _______, _______, _______, _______, _______ ), #endif [2] = LAYOUT_75_via( @@ -81,29 +72,11 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { ) }; -void encoder_action_unregister(void) { - for (int index = 0; index < ENCODERS; ++index) { - if (encoder_state[index]) { - keyevent_t encoder_event = (keyevent_t) { - .key = encoder_state[index] >> 1 ? encoder_cw[index] : encoder_ccw[index], - .pressed = false, - .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; +#ifdef ENCODER_MAP_ENABLE +const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = { + [0] = {ENCODER_CCW_CW(KC_VOLD, KC_VOLU)}, + [1] = {ENCODER_CCW_CW(KC_PGUP, KC_PGDN)}, + [2] = {ENCODER_CCW_CW(_______, _______)}, + [3] = {ENCODER_CCW_CW(_______, _______)} }; +#endif diff --git a/keyboards/tkc/portico75/keymaps/via/rules.mk b/keyboards/tkc/portico75/keymaps/via/rules.mk index 9680dd9373..3e4e4a229d 100644 --- a/keyboards/tkc/portico75/keymaps/via/rules.mk +++ b/keyboards/tkc/portico75/keymaps/via/rules.mk @@ -1,6 +1,7 @@ VIA_ENABLE = yes LTO_ENABLE = yes RGB_MATRIX_ENABLE = no # Use RGB matrix +ENCODER_MAP_ENABLE = yes # project specific files SRC += keyboards/wilba_tech/wt_main.c \ |