diff options
author | Konstantin Đorđević <vomindoraan@gmail.com> | 2018-10-19 17:42:01 +0200 |
---|---|---|
committer | Drashna Jaelre <drashna@live.com> | 2018-10-19 08:42:01 -0700 |
commit | 6c6897f7789f67076ea2f3f9cfe47da814e599fa (patch) | |
tree | 773a944681d74416dc6e418bc84616d99f2ca9b1 | |
parent | ae31eb564a340cab53f18fe5290ee5033704be1f (diff) | |
download | qmk_firmware-6c6897f7789f67076ea2f3f9cfe47da814e599fa.tar.gz qmk_firmware-6c6897f7789f67076ea2f3f9cfe47da814e599fa.zip |
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
-rw-r--r-- | keyboards/whitefox/keymaps/konstantin/config.h | 3 | ||||
-rw-r--r-- | keyboards/whitefox/keymaps/konstantin/keymap.c | 34 |
2 files changed, 22 insertions, 15 deletions
diff --git a/keyboards/whitefox/keymaps/konstantin/config.h b/keyboards/whitefox/keymaps/konstantin/config.h index ad40105a7..725609b46 100644 --- a/keyboards/whitefox/keymaps/konstantin/config.h +++ b/keyboards/whitefox/keymaps/konstantin/config.h | |||
@@ -12,3 +12,6 @@ | |||
12 | #define MOUSEKEY_TIME_TO_MAX 50 | 12 | #define MOUSEKEY_TIME_TO_MAX 50 |
13 | #define MOUSEKEY_WHEEL_MAX_SPEED 1 | 13 | #define MOUSEKEY_WHEEL_MAX_SPEED 1 |
14 | #define MOUSEKEY_WHEEL_TIME_TO_MAX 50 | 14 | #define MOUSEKEY_WHEEL_TIME_TO_MAX 50 |
15 | |||
16 | #undef IS_COMMAND | ||
17 | #define IS_COMMAND() (keyboard_report->mods == (MOD_BIT(KC_LSFT) | MOD_BIT(KC_RCTL))) | ||
diff --git a/keyboards/whitefox/keymaps/konstantin/keymap.c b/keyboards/whitefox/keymaps/konstantin/keymap.c index 6998798e3..247bc6bbf 100644 --- a/keyboards/whitefox/keymaps/konstantin/keymap.c +++ b/keyboards/whitefox/keymaps/konstantin/keymap.c | |||
@@ -2,9 +2,12 @@ | |||
2 | 2 | ||
3 | #define FN MO(L_FN) | 3 | #define FN MO(L_FN) |
4 | #define FN_CAPS LT(L_FN, KC_CAPS) | 4 | #define FN_CAPS LT(L_FN, KC_CAPS) |
5 | #define FN_RCTL TD(TD_FN_RCTL) // Unused | 5 | #define FN_RCTL TD(TD_FN_RCTL) // Unused |
6 | #define RLALT TD(TD_RLALT) // Unused | 6 | #define RLALT TD(TD_RLALT) // Unused |
7 | #define DESKTOP TD(TD_DESKTOP) | ||
7 | 8 | ||
9 | #define DESKT_L LCTL(LGUI(KC_LEFT)) | ||
10 | #define DESKT_R LCTL(LGUI(KC_RGHT)) | ||
8 | #define TOP LCTL(KC_HOME) | 11 | #define TOP LCTL(KC_HOME) |
9 | #define BOTTOM LCTL(KC_END) | 12 | #define BOTTOM LCTL(KC_END) |
10 | 13 | ||
@@ -46,8 +49,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) | |||
46 | layer_invert(L_NUMPAD); | 49 | layer_invert(L_NUMPAD); |
47 | bool num_lock = host_keyboard_leds() & 1<<USB_LED_NUM_LOCK; | 50 | bool num_lock = host_keyboard_leds() & 1<<USB_LED_NUM_LOCK; |
48 | if (num_lock != (bool)IS_LAYER_ON(L_NUMPAD)) { | 51 | if (num_lock != (bool)IS_LAYER_ON(L_NUMPAD)) { |
49 | register_code(KC_NLCK); // Toggle Num Lock to match layer state. | 52 | tap_code(KC_NLCK); // Toggle Num Lock to match layer state. |
50 | unregister_code(KC_NLCK); | ||
51 | } | 53 | } |
52 | } | 54 | } |
53 | return false; | 55 | return false; |
@@ -60,24 +62,26 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) | |||
60 | enum tap_dance { | 62 | enum tap_dance { |
61 | TD_FN_RCTL, | 63 | TD_FN_RCTL, |
62 | TD_RLALT, | 64 | TD_RLALT, |
65 | TD_DESKTOP, | ||
63 | }; | 66 | }; |
64 | 67 | ||
65 | void td_fn_ctrl_finished(qk_tap_dance_state_t *state, void *user_data) | 68 | void td_fn_rctl_finished(qk_tap_dance_state_t *state, void *user_data) |
66 | { | 69 | { |
67 | // Single tap → Fn, double tap → RCtrl, triple tap → Fn+RCtrl etc. | 70 | // Single tap → Fn, double tap → RCtrl, triple tap → Fn+RCtrl etc. |
68 | if (state->count & 1) { layer_on(L_FN); } | 71 | if (state->count & 1) { layer_on(L_FN); } |
69 | if (state->count & 2) { register_code(KC_RCTL); } | 72 | if (state->count & 2) { register_code(KC_RCTL); } |
70 | } | 73 | } |
71 | 74 | ||
72 | void td_fn_ctrl_reset(qk_tap_dance_state_t *state, void *user_data) | 75 | void td_fn_rctl_reset(qk_tap_dance_state_t *state, void *user_data) |
73 | { | 76 | { |
74 | if (state->count & 1) { layer_off(L_FN); } | 77 | if (state->count & 1) { layer_off(L_FN); } |
75 | if (state->count & 2) { unregister_code(KC_RCTL); } | 78 | if (state->count & 2) { unregister_code(KC_RCTL); } |
76 | } | 79 | } |
77 | 80 | ||
78 | qk_tap_dance_action_t tap_dance_actions[] = { | 81 | qk_tap_dance_action_t tap_dance_actions[] = { |
79 | [TD_FN_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, td_fn_ctrl_finished, td_fn_ctrl_reset), | 82 | [TD_FN_RCTL] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, td_fn_rctl_finished, td_fn_rctl_reset), |
80 | [TD_RLALT] = ACTION_TAP_DANCE_DOUBLE(KC_RALT, KC_LALT), | 83 | [TD_RLALT] = ACTION_TAP_DANCE_DOUBLE(KC_RALT, KC_LALT), |
84 | [TD_DESKTOP] = ACTION_TAP_DANCE_DOUBLE(LCTL(LGUI(KC_D)), LCTL(LGUI(KC_F4))), // Add/close virtual desktop | ||
81 | }; | 85 | }; |
82 | 86 | ||
83 | const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 87 | const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
@@ -89,17 +93,17 @@ const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
89 | * |---------------------------------------------------------------| | 93 | * |---------------------------------------------------------------| |
90 | * |FnCaps| A | S | D | F | G | H | J | K | L | ; | ' | Enter |PgU| | 94 | * |FnCaps| A | S | D | F | G | H | J | K | L | ; | ' | Enter |PgU| |
91 | * |---------------------------------------------------------------| | 95 | * |---------------------------------------------------------------| |
92 | * | LShift | Z | X | C | V | B | N | M | , | . | / | Fn | ↑ |PgD| | 96 | * | LShift | Z | X | C | V | B | N | M | , | . | / |RCtrl | ↑ |PgD| |
93 | * |---------------------------------------------------------------| | 97 | * |---------------------------------------------------------------| |
94 | * |LCtl|LGui|LAlt| Space |RAlt|RCtl| | ← | ↓ | → | | 98 | * |LCtl|LGui|LAlt| Space |RAlt| Fn | | ← | ↓ | → | |
95 | * `---------------------------------------------------------------' | 99 | * `---------------------------------------------------------------' |
96 | */ | 100 | */ |
97 | [L_BASE] = LAYOUT_truefox( \ | 101 | [L_BASE] = LAYOUT_truefox( \ |
98 | 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, \ | 102 | 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, \ |
99 | 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, \ | 103 | 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, \ |
100 | 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, \ | 104 | 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, \ |
101 | 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, \ | 105 | 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, \ |
102 | KC_LCTL,KC_LGUI,KC_LALT, KC_SPC, KC_RALT,KC_RCTL, KC_LEFT,KC_DOWN,KC_RGHT \ | 106 | KC_LCTL,KC_LGUI,KC_LALT, KC_SPC, KC_RALT,FN, KC_LEFT,KC_DOWN,KC_RGHT \ |
103 | ), | 107 | ), |
104 | 108 | ||
105 | /* Function layer | 109 | /* Function layer |
@@ -110,17 +114,17 @@ const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
110 | * |---------------------------------------------------------------| | 114 | * |---------------------------------------------------------------| |
111 | * | |M← |M↓ |M→ |MW↑| | | | | | | | |Top| | 115 | * | |M← |M↓ |M→ |MW↑| | | | | | | | |Top| |
112 | * |---------------------------------------------------------------| | 116 | * |---------------------------------------------------------------| |
113 | * | |MA0|MA2|MW←|MW→| | | |VoD|VoU|Mut| |PgU|Btm| | 117 | * | |MA0|MA2|MW←|MW→| | | |VoD|VoU|Mut| App |PgU|Btm| |
114 | * |---------------------------------------------------------------| | 118 | * |---------------------------------------------------------------| |
115 | * | | | | MW↓ | |Menu| |Hom|PgD|End| | 119 | * | |Dstp|Dst←| MW↓ |Dst→| | |Hom|PgD|End| |
116 | * `---------------------------------------------------------------' | 120 | * `---------------------------------------------------------------' |
117 | */ | 121 | */ |
118 | [L_FN] = LAYOUT_truefox( \ | 122 | [L_FN] = LAYOUT_truefox( \ |
119 | _______,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, \ | 123 | _______,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, \ |
120 | KC_BTN4,KC_BTN2,KC_MS_U,KC_BTN1,KC_BTN3,KC_BTN5,_______,_______,_______,KC_MSTP,KC_MPLY,KC_MPRV,KC_MNXT,CLEAR, KC_INS, \ | 124 | KC_BTN4,KC_BTN2,KC_MS_U,KC_BTN1,KC_BTN3,KC_BTN5,_______,_______,_______,KC_MSTP,KC_MPLY,KC_MPRV,KC_MNXT,CLEAR, KC_INS, \ |
121 | _______,KC_MS_L,KC_MS_D,KC_MS_R,KC_WH_U,_______,_______,_______,_______,_______,_______,_______, _______, TOP, \ | 125 | _______,KC_MS_L,KC_MS_D,KC_MS_R,KC_WH_U,_______,_______,_______,_______,_______,_______,_______, _______, TOP, \ |
122 | _______, KC_ACL0,KC_ACL2,KC_WH_L,KC_WH_R,_______,_______,_______,KC_VOLD,KC_VOLU,KC_MUTE,_______, KC_PGUP,BOTTOM, \ | 126 | _______, KC_ACL0,KC_ACL2,KC_WH_L,KC_WH_R,_______,_______,_______,KC_VOLD,KC_VOLU,KC_MUTE,KC_APP, KC_PGUP,BOTTOM, \ |
123 | _______,_______,_______, KC_WH_D, _______,KC_APP, KC_HOME,KC_PGDN,KC_END \ | 127 | _______,DESKTOP,DESKT_L, KC_WH_D, DESKT_R,_______, KC_HOME,KC_PGDN,KC_END \ |
124 | ), | 128 | ), |
125 | 129 | ||
126 | /* Numpad layer | 130 | /* Numpad layer |