Keymap: Update whitefox/konstantin keymap (#4169)
* td_fn_ctrl_* → td_fn_rctl_* * Swap Fn and RCtrl * Change key combination for Command feature * Replace register/unregister_code call with tap_code * Add virtual desktop controls to keymap * Add/close virtual desktop on Fn+GUI tap dance
This commit is contained in:
		
							parent
							
								
									ae31eb564a
								
							
						
					
					
						commit
						6c6897f778
					
				
					 2 changed files with 22 additions and 15 deletions
				
			
		| 
						 | 
				
			
			@ -12,3 +12,6 @@
 | 
			
		|||
#define MOUSEKEY_TIME_TO_MAX 50
 | 
			
		||||
#define MOUSEKEY_WHEEL_MAX_SPEED 1
 | 
			
		||||
#define MOUSEKEY_WHEEL_TIME_TO_MAX 50
 | 
			
		||||
 | 
			
		||||
#undef  IS_COMMAND
 | 
			
		||||
#define IS_COMMAND() (keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RCTL)))
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2,9 +2,12 @@
 | 
			
		|||
 | 
			
		||||
#define FN      MO(L_FN)
 | 
			
		||||
#define FN_CAPS LT(L_FN, KC_CAPS)
 | 
			
		||||
#define FN_RCTL TD(TD_FN_RCTL) // Unused
 | 
			
		||||
#define RLALT   TD(TD_RLALT)   // Unused
 | 
			
		||||
#define FN_RCTL TD(TD_FN_RCTL)    // Unused
 | 
			
		||||
#define RLALT   TD(TD_RLALT)      // Unused
 | 
			
		||||
#define DESKTOP TD(TD_DESKTOP)
 | 
			
		||||
 | 
			
		||||
#define DESKT_L LCTL(LGUI(KC_LEFT))
 | 
			
		||||
#define DESKT_R LCTL(LGUI(KC_RGHT))
 | 
			
		||||
#define TOP     LCTL(KC_HOME)
 | 
			
		||||
#define BOTTOM  LCTL(KC_END)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -46,8 +49,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record)
 | 
			
		|||
      layer_invert(L_NUMPAD);
 | 
			
		||||
      bool num_lock = host_keyboard_leds() & 1<<USB_LED_NUM_LOCK;
 | 
			
		||||
      if (num_lock != (bool)IS_LAYER_ON(L_NUMPAD)) {
 | 
			
		||||
        register_code(KC_NLCK); // Toggle Num Lock to match layer state.
 | 
			
		||||
        unregister_code(KC_NLCK);
 | 
			
		||||
        tap_code(KC_NLCK); // Toggle Num Lock to match layer state.
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    return false;
 | 
			
		||||
| 
						 | 
				
			
			@ -60,24 +62,26 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record)
 | 
			
		|||
enum tap_dance {
 | 
			
		||||
  TD_FN_RCTL,
 | 
			
		||||
  TD_RLALT,
 | 
			
		||||
  TD_DESKTOP,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
void td_fn_ctrl_finished(qk_tap_dance_state_t *state, void *user_data)
 | 
			
		||||
void td_fn_rctl_finished(qk_tap_dance_state_t *state, void *user_data)
 | 
			
		||||
{
 | 
			
		||||
  // Single tap → Fn, double tap → RCtrl, triple tap → Fn+RCtrl etc.
 | 
			
		||||
  if (state->count & 1) { layer_on(L_FN); }
 | 
			
		||||
  if (state->count & 2) { register_code(KC_RCTL); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void td_fn_ctrl_reset(qk_tap_dance_state_t *state, void *user_data)
 | 
			
		||||
void td_fn_rctl_reset(qk_tap_dance_state_t *state, void *user_data)
 | 
			
		||||
{
 | 
			
		||||
  if (state->count & 1) { layer_off(L_FN); }
 | 
			
		||||
  if (state->count & 2) { unregister_code(KC_RCTL); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
qk_tap_dance_action_t tap_dance_actions[] = {
 | 
			
		||||
  [TD_FN_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, td_fn_ctrl_finished, td_fn_ctrl_reset),
 | 
			
		||||
  [TD_FN_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, td_fn_rctl_finished, td_fn_rctl_reset),
 | 
			
		||||
  [TD_RLALT]   = ACTION_TAP_DANCE_DOUBLE(KC_RALT, KC_LALT),
 | 
			
		||||
  [TD_DESKTOP] = ACTION_TAP_DANCE_DOUBLE(LCTL(LGUI(KC_D)), LCTL(LGUI(KC_F4))), // Add/close virtual desktop
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
			
		||||
| 
						 | 
				
			
			@ -89,17 +93,17 @@ const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
			
		|||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * |FnCaps| A | S | D | F | G | H | J | K | L | ; | ' | Enter  |PgU|
 | 
			
		||||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * | LShift | Z | X | C | V | B | N | M | , | . | / |  Fn  | ↑ |PgD|
 | 
			
		||||
   * | LShift | Z | X | C | V | B | N | M | , | . | / |RCtrl | ↑ |PgD|
 | 
			
		||||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * |LCtl|LGui|LAlt|         Space          |RAlt|RCtl| | ← | ↓ | → |
 | 
			
		||||
   * |LCtl|LGui|LAlt|         Space          |RAlt| Fn | | ← | ↓ | → |
 | 
			
		||||
   * `---------------------------------------------------------------'
 | 
			
		||||
   */
 | 
			
		||||
  [L_BASE] = LAYOUT_truefox( \
 | 
			
		||||
    KC_ESC, KC_1,   KC_2,   KC_3,   KC_4,   KC_5,   KC_6,   KC_7,   KC_8,   KC_9,   KC_0,   KC_MINS,KC_EQL, KC_BSLS,KC_GRV, KC_PSCR, \
 | 
			
		||||
    KC_TAB, KC_Q,   KC_W,   KC_E,   KC_R,   KC_T,   KC_Y,   KC_U,   KC_I,   KC_O,   KC_P,   KC_LBRC,KC_RBRC,KC_BSPC,        KC_DEL,  \
 | 
			
		||||
    FN_CAPS,KC_A,   KC_S,   KC_D,   KC_F,   KC_G,   KC_H,   KC_J,   KC_K,   KC_L,   KC_SCLN,KC_QUOT,        KC_ENT,         KC_PGUP, \
 | 
			
		||||
    KC_LSFT,        KC_Z,   KC_X,   KC_C,   KC_V,   KC_B,   KC_N,   KC_M,   KC_COMM,KC_DOT, KC_SLSH,FN,             KC_UP,  KC_PGDN, \
 | 
			
		||||
    KC_LCTL,KC_LGUI,KC_LALT,                        KC_SPC,                 KC_RALT,KC_RCTL,                KC_LEFT,KC_DOWN,KC_RGHT  \
 | 
			
		||||
    KC_LSFT,        KC_Z,   KC_X,   KC_C,   KC_V,   KC_B,   KC_N,   KC_M,   KC_COMM,KC_DOT, KC_SLSH,KC_RCTL,        KC_UP,  KC_PGDN, \
 | 
			
		||||
    KC_LCTL,KC_LGUI,KC_LALT,                        KC_SPC,                 KC_RALT,FN,                     KC_LEFT,KC_DOWN,KC_RGHT  \
 | 
			
		||||
  ),
 | 
			
		||||
 | 
			
		||||
  /* Function layer
 | 
			
		||||
| 
						 | 
				
			
			@ -110,17 +114,17 @@ const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
			
		|||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * |      |M← |M↓ |M→ |MW↑|   |   |   |   |   |   |   |        |Top|
 | 
			
		||||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * |        |MA0|MA2|MW←|MW→|   |   |   |VoD|VoU|Mut|      |PgU|Btm|
 | 
			
		||||
   * |        |MA0|MA2|MW←|MW→|   |   |   |VoD|VoU|Mut| App  |PgU|Btm|
 | 
			
		||||
   * |---------------------------------------------------------------|
 | 
			
		||||
   * |    |    |    |          MW↓           |    |Menu| |Hom|PgD|End|
 | 
			
		||||
   * |    |Dstp|Dst←|          MW↓           |Dst→|    | |Hom|PgD|End|
 | 
			
		||||
   * `---------------------------------------------------------------'
 | 
			
		||||
   */
 | 
			
		||||
  [L_FN] = LAYOUT_truefox( \
 | 
			
		||||
    _______,KC_F1,  KC_F2,  KC_F3,  KC_F4,  KC_F5,  KC_F6,  KC_F7,  KC_F8,  KC_F9,  KC_F10, KC_F11, KC_F12, NUMPAD, KC_SLCK,KC_PAUS, \
 | 
			
		||||
    KC_BTN4,KC_BTN2,KC_MS_U,KC_BTN1,KC_BTN3,KC_BTN5,_______,_______,_______,KC_MSTP,KC_MPLY,KC_MPRV,KC_MNXT,CLEAR,          KC_INS,  \
 | 
			
		||||
    _______,KC_MS_L,KC_MS_D,KC_MS_R,KC_WH_U,_______,_______,_______,_______,_______,_______,_______,        _______,        TOP,     \
 | 
			
		||||
    _______,        KC_ACL0,KC_ACL2,KC_WH_L,KC_WH_R,_______,_______,_______,KC_VOLD,KC_VOLU,KC_MUTE,_______,        KC_PGUP,BOTTOM,  \
 | 
			
		||||
    _______,_______,_______,                        KC_WH_D,                _______,KC_APP,                 KC_HOME,KC_PGDN,KC_END   \
 | 
			
		||||
    _______,        KC_ACL0,KC_ACL2,KC_WH_L,KC_WH_R,_______,_______,_______,KC_VOLD,KC_VOLU,KC_MUTE,KC_APP,         KC_PGUP,BOTTOM,  \
 | 
			
		||||
    _______,DESKTOP,DESKT_L,                        KC_WH_D,                DESKT_R,_______,                KC_HOME,KC_PGDN,KC_END   \
 | 
			
		||||
  ),
 | 
			
		||||
 | 
			
		||||
  /* Numpad layer
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue