mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-12-12 05:06:38 +06:00
212 lines
6.1 KiB
C
212 lines
6.1 KiB
C
#include QMK_KEYBOARD_H
|
|
|
|
extern keymap_config_t keymap_config;
|
|
|
|
#ifdef BACKLIGHT_ENABLE
|
|
#include "backlight.h"
|
|
#endif
|
|
|
|
#ifdef AUDIO_ENABLE
|
|
#include "audio.h"
|
|
#endif
|
|
|
|
void backlight_toggle(void){
|
|
};
|
|
|
|
enum roadkit_layers {
|
|
_NUMPAD,
|
|
_FPH,
|
|
_FPHNOISY,
|
|
_ADJUST,
|
|
_DYN
|
|
};
|
|
|
|
enum roadkit_keycodes {
|
|
NUMPAD = SAFE_RANGE,
|
|
FPH_1,
|
|
FPH_2,
|
|
FPH_3,
|
|
FPH_4,
|
|
FPH_5,
|
|
FPH_6,
|
|
FPH_7,
|
|
FPH_8,
|
|
FPH_9,
|
|
FN_0,
|
|
BACKLIT,
|
|
MACSLEEP,
|
|
DYNAMIC_MACRO_RANGE,
|
|
};
|
|
|
|
#include "dynamic_macro.h"
|
|
|
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
[_NUMPAD] = LAYOUT_numpad_4x4( /* Numpad */
|
|
KC_KP_7, KC_KP_8, KC_KP_9, KC_KP_PLUS, \
|
|
KC_KP_4, KC_KP_5, KC_KP_6, \
|
|
KC_KP_1, KC_KP_2, KC_KP_3, KC_KP_ENTER, \
|
|
LT(_ADJUST, KC_KP_0), KC_KP_DOT \
|
|
),
|
|
[_FPH] = LAYOUT_numpad_4x4( /* Quiet T9 */
|
|
FPH_7, FPH_8, FPH_9, KC_KP_PLUS, \
|
|
FPH_4, FPH_5, FPH_6, \
|
|
FPH_1, FPH_2, FPH_3, SFT_T(KC_KP_ENTER), \
|
|
LT(_ADJUST, KC_SPACE), KC_KP_DOT \
|
|
),
|
|
[_FPHNOISY] = LAYOUT_numpad_4x4( /* Noisy T9 */
|
|
FPH_7, FPH_8, FPH_9, KC_KP_PLUS, \
|
|
FPH_4, FPH_5, FPH_6, \
|
|
FPH_1, FPH_2, FPH_3, SFT_T(KC_KP_ENTER), \
|
|
LT(_ADJUST, KC_SPACE), KC_KP_DOT \
|
|
),
|
|
[_ADJUST] = LAYOUT_numpad_4x4( /* Adjustments */
|
|
KC_NUMLOCK, TG(_FPHNOISY), TG(_FPH), TG(_NUMPAD), \
|
|
KC_BSPC, BACKLIT, KC_DEL, \
|
|
MACSLEEP, _______, _______, _______, \
|
|
_______, MO(_DYN) \
|
|
),
|
|
[_DYN] = LAYOUT_numpad_4x4( /* DYNAMIC MACRO */
|
|
DYN_REC_START1, DYN_REC_START2, _______, DYN_REC_STOP, \
|
|
_______, _______, _______, \
|
|
DYN_MACRO_PLAY1, DYN_MACRO_PLAY2, _______, _______, \
|
|
_______, _______ \
|
|
),
|
|
};
|
|
|
|
void persistant_default_layer_set(uint16_t default_layer) {
|
|
eeconfig_update_default_layer(default_layer);
|
|
default_layer_set(default_layer);
|
|
}
|
|
|
|
uint16_t fph_tap_qty = false;
|
|
uint16_t fph_keycode = 0; // stores which spacebar was used, either raise or lower...
|
|
|
|
uint16_t get_render_keycode(uint16_t keycode, uint16_t tap_qty){ // maybe replace shift with "mods"
|
|
tap_qty--; // reduce by one to match array indexes.
|
|
switch(keycode){
|
|
case FPH_2:
|
|
{uint16_t kc[] = {KC_A, KC_B, KC_C};
|
|
if(tap_qty % 6 > 2)
|
|
return LSFT(kc[tap_qty % 3]);
|
|
return kc[tap_qty % 3];}
|
|
break;
|
|
case FPH_3:
|
|
{uint16_t kc[] = {KC_D, KC_E, KC_F};
|
|
if(tap_qty % 6 > 2)
|
|
return LSFT(kc[tap_qty % 3]);
|
|
return kc[tap_qty % 3];}
|
|
break;
|
|
case FPH_4:
|
|
{uint16_t kc[] = {KC_G, KC_H, KC_I};
|
|
if(tap_qty % 6 > 2)
|
|
return LSFT(kc[tap_qty % 3]);
|
|
return kc[tap_qty % 3];}
|
|
break;
|
|
case FPH_5:
|
|
{uint16_t kc[] = {KC_J, KC_K, KC_L};
|
|
if(tap_qty % 6 > 2)
|
|
return LSFT(kc[tap_qty % 3]);
|
|
return kc[tap_qty % 3];}
|
|
break;
|
|
case FPH_6:
|
|
{uint16_t kc[] = {KC_M, KC_N, KC_O};
|
|
if(tap_qty % 6 > 2)
|
|
return LSFT(kc[tap_qty % 3]);
|
|
return kc[tap_qty % 3];}
|
|
break;
|
|
case FPH_7:
|
|
{uint16_t kc[] = {KC_P, KC_Q, KC_R, KC_S};
|
|
if(tap_qty % 8 > 2)
|
|
return LSFT(kc[tap_qty % 4]);
|
|
return kc[tap_qty % 4];}
|
|
break;
|
|
case FPH_8:
|
|
{uint16_t kc[] = {KC_T, KC_U, KC_V};
|
|
if(tap_qty % 8 > 2)
|
|
return LSFT(kc[tap_qty % 4]);
|
|
return kc[tap_qty % 4];}
|
|
break;
|
|
case FPH_9:
|
|
{uint16_t kc[] = {KC_W, KC_X, KC_Y, KC_Z};
|
|
if(tap_qty % 8 > 2)
|
|
return LSFT(kc[tap_qty % 4]);
|
|
return kc[tap_qty % 4];}
|
|
break;
|
|
case FPH_1:
|
|
{uint16_t kc[] = {KC_COMM, LSFT(KC_SLSH), KC_EXLM, KC_AT, KC_MINS, KC_UNDS, KC_PLUS, \
|
|
KC_SCLN, LSFT(KC_SCLN), KC_QUOT, LSFT(KC_QUOT), KC_TILD, \
|
|
KC_PIPE, KC_BSLS, KC_HASH, LSFT(KC_4), KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, \
|
|
KC_LBRC, KC_RBRC, KC_LCBR, KC_RCBR, LSFT(KC_COMM), LSFT(KC_DOT)};
|
|
return kc[tap_qty % 26];}
|
|
}
|
|
return KC_NO;
|
|
}
|
|
|
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
if (!process_record_dynamic_macro(keycode, record)) {
|
|
return false;
|
|
}
|
|
uint8_t layer;
|
|
layer = biton32(layer_state);
|
|
|
|
switch (keycode) {
|
|
case FPH_1 ... FPH_9:
|
|
if(layer == _FPHNOISY){
|
|
if (record->event.pressed) {
|
|
if(fph_keycode != keycode) { // key change
|
|
fph_tap_qty = 0;
|
|
fph_keycode = keycode;
|
|
} else { // same key tapped again so erase and increment.
|
|
register_code(KC_BSPC);
|
|
unregister_code(KC_BSPC);
|
|
fph_tap_qty++;
|
|
}
|
|
uint16_t render_keycode = get_render_keycode(keycode, fph_tap_qty);
|
|
// find mods? Apply mods..
|
|
register_code(render_keycode);
|
|
unregister_code(render_keycode);
|
|
} else {
|
|
// do we need to do anything on key-release?
|
|
}
|
|
} else { // not noisy, be demure .
|
|
if (record->event.pressed) {
|
|
if(fph_keycode != keycode) { // key change, kill everything.
|
|
uint16_t render_keycode = get_render_keycode(fph_keycode, fph_tap_qty);
|
|
// find mods? Apply mods..
|
|
register_code(render_keycode);
|
|
unregister_code(render_keycode);
|
|
fph_keycode = keycode;
|
|
fph_tap_qty = 0;
|
|
} else { // same key tapped again so increment counter silently
|
|
fph_tap_qty++;
|
|
}
|
|
} else {
|
|
// do we need to do anything on key-release?
|
|
// maybe start a timer on this one?
|
|
}
|
|
}
|
|
return false;
|
|
break;
|
|
case BACKLIT:
|
|
if (record->event.pressed) {
|
|
#ifdef BACKLIGHT_ENABLE
|
|
backlight_step();
|
|
#endif
|
|
}
|
|
return false;
|
|
break;
|
|
case MACSLEEP:
|
|
if (record->event.pressed) {
|
|
register_code(KC_RSFT);
|
|
register_code(KC_RCTL);
|
|
register_code(KC_POWER);
|
|
unregister_code(KC_POWER);
|
|
unregister_code(KC_RCTL);
|
|
unregister_code(KC_RSFT);
|
|
}
|
|
return false;
|
|
break;
|
|
}
|
|
return true;
|
|
}
|