[Keymap] Support FX keys on Maxr1998's Contra
Using update_tri_layer() and more manual layer switching, also rename some layers & keycodesmaster
parent
17d3750f13
commit
795f743c04
|
@ -19,16 +19,17 @@
|
||||||
|
|
||||||
enum contra_layers {
|
enum contra_layers {
|
||||||
_QWERTZ,
|
_QWERTZ,
|
||||||
_FUNC,
|
_FN,
|
||||||
_NUMROW,
|
_NR,
|
||||||
_NUMROW_L3,
|
_NR_L3,
|
||||||
|
_FX,
|
||||||
_GAMING
|
_GAMING
|
||||||
};
|
};
|
||||||
|
|
||||||
#define KC_I3 LM(_NUMROW, MOD_LALT)
|
#define KC_I3 LM(_NR, MOD_LALT)
|
||||||
#define KC_NR MO(_NUMROW)
|
#define KC_NR SAFE_RANGE
|
||||||
#define NR_L3 SAFE_RANGE
|
#define KC_N3 (SAFE_RANGE + 1)
|
||||||
#define FUN MO(_FUNC)
|
#define KC_FN MO(_FN)
|
||||||
#define G_1 TO(_GAMING)
|
#define G_1 TO(_GAMING)
|
||||||
#define G_0 TG(_GAMING)
|
#define G_0 TG(_GAMING)
|
||||||
|
|
||||||
|
@ -49,7 +50,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
{KC_GESC, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
|
{KC_GESC, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
|
||||||
{KC_TAB, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, DE_PLUS, KC_ENT },
|
{KC_TAB, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, DE_PLUS, KC_ENT },
|
||||||
{KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_UP, KC_RSFT},
|
{KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_UP, KC_RSFT},
|
||||||
{KC_LCTL, KC_LGUI, KC_LALT, KC_I3, KC_NR, KC_SPC, KC_SPC, NR_L3, FUN, KC_LEFT, KC_DOWN, KC_RGHT}
|
{KC_LCTL, KC_LGUI, KC_LALT, KC_I3, KC_NR, KC_SPC, KC_SPC, KC_N3, KC_FN, KC_LEFT, KC_DOWN, KC_RGHT}
|
||||||
},
|
},
|
||||||
|
|
||||||
/* Function layer
|
/* Function layer
|
||||||
|
@ -60,10 +61,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
||||||
* | | | | | | | | RGBH-| RGBT | RGBH+| PgUp | |
|
* | | | | | | | | RGBH-| RGBT | RGBH+| PgUp | |
|
||||||
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
||||||
* | | | | ---- | ---- | | | ---- | ---- | Home | PgDn | End |
|
* | | | | ---- | ---- | | ---- | ---- | Home | PgDn | End |
|
||||||
* `-----------------------------------------------------------------------------------'
|
* `-----------------------------------------------------------------------------------'
|
||||||
*/
|
*/
|
||||||
[_FUNC] = {
|
[_FN] = {
|
||||||
{_______, _______, _______, _______, _______, _______, _______, DE_UE, _______, DE_OE, _______, KC_DEL },
|
{_______, _______, _______, _______, _______, _______, _______, DE_UE, _______, DE_OE, _______, KC_DEL },
|
||||||
{KC_LOCK, DE_AE, DE_SS, _______, _______, G_1, _______, RGB_M_P, RGB_M_B, RGB_M_SW,_______, _______},
|
{KC_LOCK, DE_AE, DE_SS, _______, _______, G_1, _______, RGB_M_P, RGB_M_B, RGB_M_SW,_______, _______},
|
||||||
{_______, _______, _______, _______, _______, _______, _______, RGB_HUD, RGB_TOG, RGB_HUI, KC_PGUP, _______},
|
{_______, _______, _______, _______, _______, _______, _______, RGB_HUD, RGB_TOG, RGB_HUI, KC_PGUP, _______},
|
||||||
|
@ -78,20 +79,38 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
||||||
* | | <> | | | | | | | | | | -_ | |
|
* | | <> | | | | | | | | | | -_ | |
|
||||||
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
||||||
* | | | | ---- | ---- | | | ---- | ---- | | | |
|
* | | | | ---- | ---- | | ---- | ---- | | | |
|
||||||
* `-----------------------------------------------------------------------------------'
|
* `-----------------------------------------------------------------------------------'
|
||||||
*/
|
*/
|
||||||
[_NUMROW] = {
|
[_NR] = {
|
||||||
{_______, DE_1, DE_2, DE_3, DE_4, DE_5, DE_6, DE_7, DE_8, DE_9, DE_0, _______},
|
{_______, DE_1, DE_2, DE_3, DE_4, DE_5, DE_6, DE_7, DE_8, DE_9, DE_0, _______},
|
||||||
{_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, DE_HASH, _______},
|
{_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, DE_HASH, _______},
|
||||||
{_______, DE_LESS, _______, _______, _______, _______, _______, _______, _______, _______, DE_MINS, _______},
|
{_______, DE_LESS, _______, _______, _______, _______, _______, _______, _______, _______, DE_MINS, _______},
|
||||||
{_______, _______, _______, XXXXXXX, XXXXXXX, _______, _______, XXXXXXX, XXXXXXX, _______, _______, _______}
|
{_______, _______, _______, XXXXXXX, _______, _______, _______, _______, XXXXXXX, _______, _______, _______}
|
||||||
},
|
},
|
||||||
[_NUMROW_L3] = {
|
[_NR_L3] = {
|
||||||
{_______, DE_1, DE_2, DE_3, DE_4, DE_5, DE_6, DE_7, DE_8, DE_9, DE_0, DE_SS },
|
{_______, DE_1, DE_2, DE_3, DE_4, DE_5, DE_6, DE_7, DE_8, DE_9, DE_0, DE_SS },
|
||||||
{_______, DE_Q, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
|
{_______, DE_Q, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
|
||||||
{_______, DE_LESS, _______, _______, _______, _______, _______, _______, _______, _______, DE_MINS, _______},
|
{_______, DE_LESS, _______, _______, _______, _______, _______, _______, _______, _______, DE_MINS, _______},
|
||||||
{_______, _______, _______, XXXXXXX, XXXXXXX, _______, _______, XXXXXXX, XXXXXXX, _______, _______, _______}
|
{_______, _______, _______, XXXXXXX, _______, _______, _______, _______, XXXXXXX, _______, _______, _______}
|
||||||
|
},
|
||||||
|
|
||||||
|
/* Function keys
|
||||||
|
* ,-----------------------------------------------------------------------------------.
|
||||||
|
* | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 |
|
||||||
|
* |------+------+------+------+------+-------------+------+------+------+------+------|
|
||||||
|
* | | | | | | | | | | | | |
|
||||||
|
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
||||||
|
* | | | | | | | | | | | | |
|
||||||
|
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
||||||
|
* | | | | | | | | | | | |
|
||||||
|
* `-----------------------------------------------------------------------------------'
|
||||||
|
*/
|
||||||
|
[_FX] = {
|
||||||
|
{KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12 },
|
||||||
|
{_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
|
||||||
|
{_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
|
||||||
|
{_______, _______, _______, XXXXXXX, _______, _______, _______, _______, XXXXXXX, _______, _______, _______}
|
||||||
},
|
},
|
||||||
|
|
||||||
/* Gaming
|
/* Gaming
|
||||||
|
@ -102,7 +121,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
* |------+------+------+------+------+------|------+------+------+------+------+------|
|
||||||
* | | | | | | | | | | | | |
|
* | | | | | | | | | | | | |
|
||||||
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
* |------+------+------+------+------+------+------+------+------+------+------+------|
|
||||||
* | Space| | | | | | | | Reset| | | |
|
* | Space| | | | | | | Leave| | | |
|
||||||
* `-----------------------------------------------------------------------------------'
|
* `-----------------------------------------------------------------------------------'
|
||||||
*/
|
*/
|
||||||
[_GAMING] = {
|
[_GAMING] = {
|
||||||
|
@ -113,6 +132,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void update_tri_layer_user(void);
|
||||||
|
|
||||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||||
switch(keycode) {
|
switch(keycode) {
|
||||||
case KC_BSPC:
|
case KC_BSPC:
|
||||||
|
@ -125,20 +146,36 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||||
unregister_code(DE_SS);
|
unregister_code(DE_SS);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case NR_L3:
|
case KC_NR:
|
||||||
if (record->event.pressed) {
|
if (record->event.pressed) {
|
||||||
register_code(KC_ALGR);
|
layer_on(_NR);
|
||||||
layer_on(_NUMROW_L3);
|
|
||||||
} else {
|
} else {
|
||||||
layer_off(_NUMROW_L3);
|
layer_off(_NR);
|
||||||
unregister_code(KC_ALGR);
|
|
||||||
}
|
}
|
||||||
|
update_tri_layer_user();
|
||||||
|
return false;
|
||||||
|
case KC_N3:
|
||||||
|
if (record->event.pressed) {
|
||||||
|
layer_on(_NR_L3);
|
||||||
|
} else {
|
||||||
|
layer_off(_NR_L3);
|
||||||
|
}
|
||||||
|
update_tri_layer_user();
|
||||||
return false;
|
return false;
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void update_tri_layer_user(void) {
|
||||||
|
update_tri_layer(_NR, _NR_L3, _FX);
|
||||||
|
if (layer_state_is(_NR_L3) && !layer_state_is(_FX)) {
|
||||||
|
register_code(KC_ALGR);
|
||||||
|
} else {
|
||||||
|
unregister_code(KC_ALGR);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void led_set_user(uint8_t usb_led) {
|
void led_set_user(uint8_t usb_led) {
|
||||||
// Force-enable Numlock
|
// Force-enable Numlock
|
||||||
if (!(usb_led & (1<<USB_LED_NUM_LOCK))) {
|
if (!(usb_led & (1<<USB_LED_NUM_LOCK))) {
|
||||||
|
|
Loading…
Reference in New Issue