diff options
| author | brian cully <bjc@spork.org> | 2026-01-13 15:09:31 -0500 |
|---|---|---|
| committer | brian cully <bjc@spork.org> | 2026-01-13 15:09:31 -0500 |
| commit | 8b19858c36da8ddfd9474f470f274d09e6417b8b (patch) | |
| tree | 5e0127bbbf699d6397d6fa8c1bc328bd9ff988a6 /keyboards/ploopyco/madromys/keymaps/bjc | |
| parent | cf35cb6f9081d11e19a428248876058f89180744 (diff) | |
| download | qmk-userspace-8b19858c36da8ddfd9474f470f274d09e6417b8b.tar.gz qmk-userspace-8b19858c36da8ddfd9474f470f274d09e6417b8b.zip | |
implement click toggle and click hold for fn1
Diffstat (limited to 'keyboards/ploopyco/madromys/keymaps/bjc')
| -rw-r--r-- | keyboards/ploopyco/madromys/keymaps/bjc/keymap.c | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/keyboards/ploopyco/madromys/keymaps/bjc/keymap.c b/keyboards/ploopyco/madromys/keymaps/bjc/keymap.c index 6602aed..aa5a127 100644 --- a/keyboards/ploopyco/madromys/keymaps/bjc/keymap.c +++ b/keyboards/ploopyco/madromys/keymaps/bjc/keymap.c @@ -29,10 +29,11 @@ enum { // top left left, top left, top right, top right right, bottom left, bottom right const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [DEFAULT] = LAYOUT(MS_BTN4, MS_BTN5, MS_BTN3, MS_BTN2, MS_BTN1, KC_TOG_HOLD), - [FN1] = LAYOUT(KC_MISSION_CONTROL, QK_BOOT, KC_BRIGHTNESS_DOWN, KC_BRIGHTNESS_UP, KC_MEDIA_PLAY_PAUSE, KC_TRNS) + [FN1] = LAYOUT(KC_BRIU, QK_BOOT, KC_MPLY, KC_MCTL, KC_BRID, KC_TRNS) }; static bool fn1_layer_on = false; +static uint16_t fn1_release_timer = 0; // probably shouldn't be doing this, but beats trying to keep track of // it myself and getting out of sync. @@ -50,15 +51,20 @@ layer_state_t layer_state_set_user(layer_state_t state) { bool process_record_user(uint16_t keycode, keyrecord_t *record) { switch (keycode) { case KC_TOG_HOLD: - if (!record->event.pressed) { - toggle_drag_scroll(); + if (record->event.pressed) { fn1_layer_on = !fn1_layer_on; - if (is_drag_scroll) { - layer_on(FN1); - } else { - layer_off(FN1); + } else { + if (timer_elapsed(fn1_release_timer) > 100) { + fn1_layer_on = false; } } + + if (fn1_layer_on) { + layer_on(FN1); + fn1_release_timer = timer_read(); + } else { + layer_off(FN1); + } break; } return true; |
