From 8b19858c36da8ddfd9474f470f274d09e6417b8b Mon Sep 17 00:00:00 2001 From: brian cully Date: Tue, 13 Jan 2026 15:09:31 -0500 Subject: implement click toggle and click hold for fn1 --- keyboards/ploopyco/madromys/keymaps/bjc/keymap.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) (limited to 'keyboards/ploopyco/madromys/keymaps/bjc/keymap.c') 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; -- cgit v1.3