mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-01-16 06:39:25 +00:00
[Keymap] jonavin quefrency keymap (#13751)
add winkeylock and rgb functions Co-authored-by: Jonavin <=>
This commit is contained in:
parent
104cdef329
commit
219ce2b58a
@ -37,3 +37,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
//Always send Escape if Control is pressed
|
||||
|
||||
#define TAPPING_TERM 180
|
||||
|
||||
#ifdef RGBLIGHT_ENABLE
|
||||
#define RGBLIGHT_LAYERS
|
||||
#define RGBLIGHT_SLEEP
|
||||
#endif // RGBLIGHT_ENABLE
|
||||
|
||||
|
@ -17,7 +17,6 @@
|
||||
|
||||
#include QMK_KEYBOARD_H
|
||||
|
||||
|
||||
// Each layer gets a name for readability, which is then used in the keymap matrix below.
|
||||
// The underscores don't mean anything - you can have a layer called STUFF or any other name.
|
||||
// Layer names don't all need to be of the same length, obviously, and you can also skip them
|
||||
@ -31,6 +30,7 @@ enum custom_layers {
|
||||
|
||||
enum custom_keycodes {
|
||||
DOUBLEZERO = SAFE_RANGE,
|
||||
KC_WINLCK, //Toggles Win key on and off
|
||||
};
|
||||
|
||||
// Tap Dance Definitions
|
||||
@ -45,19 +45,12 @@ qk_tap_dance_action_t tap_dance_actions[] = {
|
||||
|
||||
#define KC_LSFTCAPS TD(TD_LSFT_CAPSLOCK)
|
||||
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||
switch (keycode) {
|
||||
case DOUBLEZERO:
|
||||
if (record->event.pressed) {
|
||||
// when keycode DOUBLEZERO is pressed
|
||||
SEND_STRING("00");
|
||||
} else {
|
||||
// when keycode DOUBLEZERO is released
|
||||
}
|
||||
break;
|
||||
}
|
||||
return true;
|
||||
};
|
||||
bool _isWinKeyDisabled = false;
|
||||
|
||||
#ifdef RGBLIGHT_ENABLE
|
||||
// Custom RGB Colours
|
||||
#define RGB_GODSPEED 0x00, 0xE4, 0xFF // colour for matching keycaps
|
||||
#endif // RGBLIGHT_ENABLE
|
||||
|
||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
[_BASE] = LAYOUT_65(
|
||||
@ -68,10 +61,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
KC_LCTL, KC_LGUI, KC_LALT, LT(_FN1, KC_SPC), KC_SPC, KC_SPC, KC_SPC, KC_RALT, MO(_FN1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT),
|
||||
[_FN1] = LAYOUT_65(
|
||||
KC_TRNS, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_F13, KC_CALC, KC_NO,
|
||||
RGB_TOG, RGB_MOD, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_PSCR, KC_SLCK, KC_PAUS, KC_NO, KC_NO, KC_NO, KC_NO, KC_DEL,
|
||||
KC_CAPS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_HOME,
|
||||
KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, RCTL(KC_PGUP), KC_END,
|
||||
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_APP, RCTL(KC_LEFT), RCTL(KC_PGDN), RCTL(KC_RIGHT)),
|
||||
RGB_TOG, RGB_MOD, RGB_VAI, KC_NO, KC_NO, KC_NO, KC_NO, KC_PSCR, KC_SLCK, KC_PAUS, KC_NO, KC_NO, KC_NO, KC_NO, KC_DEL,
|
||||
KC_CAPS, KC_NO, RGB_VAD, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_HOME,
|
||||
KC_TRNS, KC_NO, RGB_HUI, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_TRNS, RGB_MOD, KC_END,
|
||||
KC_TRNS, KC_WINLCK, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_APP, RGB_SPD, RGB_RMOD, RGB_SPI),
|
||||
[_MO2] = LAYOUT_65(
|
||||
KC_TRNS, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_P7, KC_P8, KC_P9, KC_P0, KC_PMNS, KC_PPLS, KC_PSLS, KC_PEQL, KC_TRNS,
|
||||
KC_TAB, KC_HOME, KC_UP, KC_END, KC_PGUP, KC_NO, KC_NO, KC_P4, KC_P5, KC_P6, KC_NO, KC_NO, KC_NO, KC_TRNS, KC_TRNS,
|
||||
@ -86,6 +79,31 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
|
||||
};
|
||||
|
||||
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||
switch (keycode) {
|
||||
case DOUBLEZERO:
|
||||
if (record->event.pressed) {
|
||||
// when keycode DOUBLEZERO is pressed
|
||||
SEND_STRING("00");
|
||||
} else {
|
||||
// when keycode DOUBLEZERO is released
|
||||
}
|
||||
break;
|
||||
case KC_WINLCK:
|
||||
if (record->event.pressed) {
|
||||
_isWinKeyDisabled = !_isWinKeyDisabled; //toggle status
|
||||
if(_isWinKeyDisabled) {
|
||||
process_magic(GUI_OFF, record);
|
||||
} else {
|
||||
process_magic(GUI_ON, record);
|
||||
}
|
||||
} else unregister_code16(keycode);
|
||||
break;
|
||||
}
|
||||
return true;
|
||||
};
|
||||
|
||||
#ifdef ENCODER_ENABLE // Encoder Functionality
|
||||
bool encoder_update_user(uint8_t index, bool clockwise) {
|
||||
switch (index)
|
||||
@ -128,3 +146,62 @@ bool encoder_update_user(uint8_t index, bool clockwise) {
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef RGBLIGHT_ENABLE
|
||||
|
||||
enum custom_rgblight_layers
|
||||
{
|
||||
_rgbCAPS,
|
||||
_rgbWINLOCK,
|
||||
_rgbFN,
|
||||
_rgbNUMPAD,
|
||||
};
|
||||
|
||||
// RGB map LEFT 1, 2, 3, 12, 13, 14, 15, 0 RIGHT 7, 6, 5, 4, 11, 10, 9, 8
|
||||
const rgblight_segment_t PROGMEM _rgb_capslock_layer[] = RGBLIGHT_LAYER_SEGMENTS(
|
||||
{14, 1, HSV_RED} // Light 4 LEDs, starting with LED 6
|
||||
);
|
||||
const rgblight_segment_t PROGMEM _rgb_winlock_layer[] = RGBLIGHT_LAYER_SEGMENTS(
|
||||
{13, 1, HSV_PURPLE} // Light 4 LEDs, starting with LED 6
|
||||
);
|
||||
const rgblight_segment_t PROGMEM _rgb_fn_layer[] = RGBLIGHT_LAYER_SEGMENTS(
|
||||
{9, 2, HSV_ORANGE},
|
||||
{12, 2, HSV_ORANGE}
|
||||
);
|
||||
// Light LEDs 9 & 10 in cyan when keyboard layer 1 is active
|
||||
const rgblight_segment_t PROGMEM _rgb_numpad_layer[] = RGBLIGHT_LAYER_SEGMENTS(
|
||||
{4, 3, HSV_PURPLE},
|
||||
{9, 3, HSV_PURPLE}
|
||||
);
|
||||
|
||||
const rgblight_segment_t* const PROGMEM _rgb_layers[] = RGBLIGHT_LAYERS_LIST(
|
||||
_rgb_capslock_layer,
|
||||
_rgb_winlock_layer,
|
||||
_rgb_fn_layer,
|
||||
_rgb_numpad_layer
|
||||
);
|
||||
|
||||
bool led_update_user(led_t led_state) {
|
||||
rgblight_set_layer_state(_rgbCAPS, led_state.caps_lock);
|
||||
rgblight_set_layer_state(_rgbWINLOCK, _isWinKeyDisabled);
|
||||
return true;
|
||||
}
|
||||
|
||||
layer_state_t layer_state_set_user(layer_state_t state) {
|
||||
rgblight_set_layer_state(_rgbFN, layer_state_cmp(state, _FN1));
|
||||
rgblight_set_layer_state(_rgbNUMPAD, layer_state_cmp(state, _MO2));
|
||||
return state;
|
||||
}
|
||||
#endif // RGBLIGHT_ENABLE
|
||||
|
||||
void keyboard_post_init_user(void) {
|
||||
|
||||
if (IS_HOST_LED_ON(USB_LED_NUM_LOCK)) { // turn on Num lock by defautl so that the numpad layer always has predictable results
|
||||
tap_code(KC_NUMLOCK);
|
||||
}
|
||||
#ifdef RGBLIGHT_ENABLE
|
||||
rgblight_mode(1); // single colour mode
|
||||
rgblight_setrgb(RGB_GODSPEED); // Default startup colour
|
||||
rgblight_layers = _rgb_layers;
|
||||
#endif
|
||||
}
|
||||
|
@ -7,12 +7,24 @@
|
||||
- ESC is set to GRAVESC (Esc when pressed, Shift-Esc is ~ and Win-ESC is `), plus handling for Ctrl-Shift-ESC to bring up Task Manager in Windows
|
||||
- Layer 2 left spacebar Backspace
|
||||
- add double tap of Left Shift to toggle Caps Lock
|
||||
- add Win Key lock function using Fn+Win
|
||||
- additional encoder functionality
|
||||
- holding L shift, Navigate page up/down
|
||||
- holding Left Ctrl, navigate prev/next word
|
||||
- holding Left Alt, change media prev/next track
|
||||
- default is change volume
|
||||
- RGB Functionality
|
||||
- additional RGB function key binds to arrow on Fn layer
|
||||
- Add capslock indicator, win key lock indicator
|
||||
- Fn and layer 2 indicators using RGB underglow
|
||||
|
||||
## All layers diagram
|
||||
|
||||
![image](https://user-images.githubusercontent.com/71780717/118903429-c52cc800-b8e5-11eb-9c45-3d9815a50123.png)
|
||||
Default Layer
|
||||
![image](https://user-images.githubusercontent.com/71780717/127251683-ad445b40-95a9-4d2a-b164-a96f3a13464e.png)
|
||||
|
||||
MO(1) / FN layer
|
||||
![image](https://user-images.githubusercontent.com/71780717/127251736-047f2f73-dfff-4fcc-bf0e-a5378e2fee08.png)
|
||||
|
||||
MO(2) / Numpad layer
|
||||
![image](https://user-images.githubusercontent.com/71780717/127251985-4f564a56-8836-4db0-9cbd-ec859755a8d9.png)
|
||||
|
Loading…
Reference in New Issue
Block a user