add_adjust_layer (#9532)
This commit is contained in:
parent
598c392709
commit
2521b970e5
1 changed files with 15 additions and 29 deletions
|
@ -4,16 +4,13 @@ enum layers {
|
||||||
_QWERTY,
|
_QWERTY,
|
||||||
_LOWER,
|
_LOWER,
|
||||||
_RAISE,
|
_RAISE,
|
||||||
|
_ADJUST
|
||||||
};
|
};
|
||||||
|
|
||||||
#define LOWER MO(_LOWER)
|
#define LOWER MO(_LOWER)
|
||||||
#define RAISE MO(_RAISE)
|
#define RAISE MO(_RAISE)
|
||||||
#define TGLOWER TG(_LOWER)
|
#define TGLOWER TG(_LOWER)
|
||||||
|
|
||||||
static bool is_ctl_pressed;
|
|
||||||
static bool is_esc_pressed;
|
|
||||||
static bool is_bspc_pressed;
|
|
||||||
|
|
||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
|
|
||||||
[_QWERTY] = LAYOUT_ortho_4x12 (
|
[_QWERTY] = LAYOUT_ortho_4x12 (
|
||||||
|
@ -52,46 +49,35 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
// └───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┘
|
// └───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┘
|
||||||
),
|
),
|
||||||
|
|
||||||
|
[_ADJUST] = LAYOUT_ortho_4x12 (
|
||||||
|
// ┌───────┬───────┬───────┬───────┬───────┬───────┬───────┬───────┬───────┬───────┬───────┬───────┐
|
||||||
|
_______,RESET, _______,_______,_______,_______,_______,_______,_______,_______,_______,_______,
|
||||||
|
// ├───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┤
|
||||||
|
_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,
|
||||||
|
// ├───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┤
|
||||||
|
_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,
|
||||||
|
// ├───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┼───────┤
|
||||||
|
_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______,_______
|
||||||
|
// └───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┴───────┘
|
||||||
|
),
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
layer_state_t layer_state_set_user(layer_state_t state) {
|
layer_state_t layer_state_set_user(layer_state_t state) {
|
||||||
#ifdef JOTANCK_LEDS
|
#ifdef JOTANCK_LEDS
|
||||||
writePin(JOTANCK_LED1, (get_highest_layer(state) == _LOWER));
|
writePin(JOTANCK_LED1, (get_highest_layer(state) == _LOWER));
|
||||||
#endif
|
#endif
|
||||||
return state;
|
return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool led_update_user(led_t led_state) {
|
bool led_update_user(led_t led_state) {
|
||||||
|
|
||||||
// NumLock allways on
|
// NumLock allways on
|
||||||
if (!led_state.num_lock) {
|
if (!led_state.num_lock) {
|
||||||
tap_code(KC_NUMLOCK);
|
tap_code(KC_NUMLOCK);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef JOTANCK_LEDS
|
#ifdef JOTANCK_LEDS
|
||||||
// CapsLock led
|
// CapsLock led
|
||||||
writePin(JOTANCK_LED2, led_state.caps_lock);
|
writePin(JOTANCK_LED2, led_state.caps_lock);
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
||||||
switch (keycode) {
|
|
||||||
case KC_LCTL:
|
|
||||||
is_ctl_pressed = record->event.pressed;
|
|
||||||
break;
|
|
||||||
case KC_ESC:
|
|
||||||
is_esc_pressed = record->event.pressed;
|
|
||||||
break;
|
|
||||||
case KC_BSPC:
|
|
||||||
is_bspc_pressed = record->event.pressed;
|
|
||||||
break;
|
|
||||||
};
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void matrix_scan_user(void) {
|
|
||||||
if (is_ctl_pressed && is_esc_pressed && is_bspc_pressed) {
|
|
||||||
reset_keyboard();
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in a new issue