mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-12-28 20:18:49 +06:00
7960302242
* copied mjt keymaps from archive * All mjt boards now compile * fixed jd45-mjt breathing * Updates to fix SpaceFN but not tested yet. * Still missing either spacebar or an adjacent keypress. * Debugging rigged up for use with hid_listen. * Reverted the default keymap to use tap_layer_key rather than custom. Moved custom approach to keymap_debug.c * Fixed the lower-left side of the keymap, which needed more spacers due to the matrix being directly put into the array rather than using the keymap function. * Cleaned up JD45 keymap that uses tapkey. * Redid minivan keymap with numsym rather than raise/lower. Untested. * Created my MJT keymap for HHKB Enabled dynamic macros and moved somoe of the shortcuts around. * Minor keymap fixes to make them compile without errors. * Added home/end to right arrow cluster on DYN layer. * Added more keys to fn and dyn layers. * It wasn't using my custom layer last time somehow...? Now it will. * Compiled and installed at end of day on 8/23 * Moved macros to FKEY layer because Adjust was too hard to get into and out of without some sort of feedback. * Fixed volume controls... were reversed and disabled. * Added F13-F15 back to fkeys layer in Minivan * Created new Planck Keymap that uses the NumSym and FKeys layer approach like the Minivan. * Removed DYN layer. * Fixed diagram in planck numsym. * Cleanup for pull request. * Roadkit flip phone warning. * Replaced PLAY_NOTES_ARRAY to PLAY_SONG * reset the submodules * checked out specific commits for submodules * Removed debugging from JD45 shared config.h * Moved custom rules.mk to apropriate keymap Reset the shared rules.mk file. * Trailing return issue in rules.mk Gotta make for a smooth pull request :-)
281 lines
7.1 KiB
C
281 lines
7.1 KiB
C
#include "gherkin.h"
|
|
#include "action_layer.h"
|
|
#ifdef AUDIO_ENABLE
|
|
#include "audio.h"
|
|
#endif
|
|
#include "eeconfig.h"
|
|
|
|
extern keymap_config_t keymap_config;
|
|
|
|
//Tap Dance Declarations
|
|
enum {
|
|
TD_Z_LCTL = 0,
|
|
TD_X_LGUI = 1,
|
|
TD_C_LALT = 2,
|
|
TD_A_TAB = 3,
|
|
TD_Q_ESC = 4,
|
|
// M(0)
|
|
};
|
|
|
|
//Friendly Layer Names
|
|
enum gherkin_layers {
|
|
_QWERTY,
|
|
_SONGS,
|
|
_NUMBERS,
|
|
_SYMBOLS,
|
|
_PLOVER,
|
|
_ADJUST
|
|
};
|
|
|
|
// custom keycodes
|
|
enum gherkin_keycodes {
|
|
QWERTY = SAFE_RANGE,
|
|
NUMBERS,
|
|
SYMBOLS,
|
|
SONGS,
|
|
PLOVER,
|
|
BACKLIT,
|
|
MACSLEEP,
|
|
EXT_PLV
|
|
};
|
|
|
|
// Fillers to make layering more clear
|
|
#define _______ KC_TRNS
|
|
#define XXXXXXX KC_NO
|
|
|
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
[_QWERTY] = KEYMAP(
|
|
TD(TD_Q_ESC), KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,
|
|
TD(TD_A_TAB), LT(_SYMBOLS,KC_S), KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, LT(_ADJUST,KC_SPC),
|
|
TD(TD_Z_LCTL), TD(TD_X_LGUI), TD(TD_C_LALT), KC_V, KC_B, LT(_NUMBERS, KC_N), KC_M, KC_COMM, KC_DOT, SFT_T(KC_ENT))
|
|
,
|
|
[_NUMBERS] = KEYMAP(
|
|
KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,
|
|
KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_HOME, KC_PGDN, KC_PGUP, KC_END ,
|
|
KC_F7, KC_F8, KC_F9, KC_F10, LT(_ADJUST,KC_F11), _______, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT)
|
|
,
|
|
[_SYMBOLS] = KEYMAP(
|
|
KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN,
|
|
KC_GRV, _______, XXXXXXX, KC_LBRC, KC_RBRC, KC_BSLS, KC_MINS, KC_EQL , KC_SCLN, KC_QUOT,
|
|
KC_TILD, MO(_ADJUST), XXXXXXX, KC_LCBR, KC_RCBR, KC_PIPE, KC_UNDS, KC_PLUS, S(KC_SCLN), S(KC_QUOT))
|
|
,
|
|
[_PLOVER] = KEYMAP(
|
|
KC_Q, KC_W, KC_E, KC_R, KC_1, KC_U, KC_I, KC_O, KC_P, KC_LBRC,
|
|
KC_A, KC_S, KC_D, KC_F, KC_G, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT,
|
|
EXT_PLV, XXXXXXX, KC_C, KC_V, XXXXXXX, KC_N, KC_M, XXXXXXX, XXXXXXX, XXXXXXX)
|
|
,
|
|
[_ADJUST] = KEYMAP(
|
|
RESET, _______, _______, _______, _______, QWERTY, NUMBERS, SYMBOLS, PLOVER, SONGS,
|
|
MUV_DE, MUV_IN, MU_ON, MU_OFF, _______, _______, _______, _______, MACSLEEP, _______,
|
|
BACKLIT, _______, _______, _______, _______, _______, _______, _______, _______, _______)
|
|
};
|
|
|
|
#ifdef AUDIO_ENABLE
|
|
|
|
float tone_startup[][2] = SONG(STARTUP_SOUND);
|
|
float tone_qwerty[][2] = SONG(QWERTY_SOUND);
|
|
float tone_dvorak[][2] = SONG(DVORAK_SOUND);
|
|
float tone_colemak[][2] = SONG(COLEMAK_SOUND);
|
|
float tone_plover[][2] = SONG(PLOVER_SOUND);
|
|
float tone_plover_gb[][2] = SONG(PLOVER_GOODBYE_SOUND);
|
|
float music_scale[][2] = SONG(MUSIC_SCALE_SOUND);
|
|
|
|
float tone_goodbye[][2] = SONG(GOODBYE_SOUND);
|
|
#endif
|
|
|
|
void persistant_default_layer_set(uint16_t default_layer) {
|
|
eeconfig_update_default_layer(default_layer);
|
|
default_layer_set(default_layer);
|
|
}
|
|
|
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|
switch (keycode) {
|
|
case QWERTY:
|
|
if (record->event.pressed) {
|
|
#ifdef AUDIO_ENABLE
|
|
PLAY_SONG(tone_qwerty);
|
|
#endif
|
|
persistant_default_layer_set(1UL<<_QWERTY);
|
|
}
|
|
return false;
|
|
break;
|
|
case NUMBERS:
|
|
if (record->event.pressed) {
|
|
#ifdef AUDIO_ENABLE
|
|
PLAY_SONG(tone_dvorak);
|
|
#endif
|
|
persistant_default_layer_set(1UL<<_NUMBERS);
|
|
}
|
|
return false;
|
|
break;
|
|
case SYMBOLS:
|
|
if (record->event.pressed) {
|
|
#ifdef AUDIO_ENABLE
|
|
PLAY_SONG(tone_colemak);
|
|
#endif
|
|
persistant_default_layer_set(1UL<<_SYMBOLS);
|
|
}
|
|
return false;
|
|
break;
|
|
case PLOVER:
|
|
if (record->event.pressed) {
|
|
#ifdef AUDIO_ENABLE
|
|
stop_all_notes();
|
|
PLAY_SONG(tone_plover);
|
|
#endif
|
|
layer_off(_NUMBERS);
|
|
layer_off(_SYMBOLS);
|
|
layer_off(_ADJUST);
|
|
layer_on(_PLOVER);
|
|
if (!eeconfig_is_enabled()) {
|
|
eeconfig_init();
|
|
}
|
|
keymap_config.raw = eeconfig_read_keymap();
|
|
keymap_config.nkro = 1;
|
|
eeconfig_update_keymap(keymap_config.raw);
|
|
}
|
|
return false;
|
|
break;
|
|
case EXT_PLV:
|
|
if (record->event.pressed) {
|
|
#ifdef AUDIO_ENABLE
|
|
PLAY_SONG(tone_plover_gb);
|
|
#endif
|
|
layer_off(_PLOVER);
|
|
}
|
|
return false;
|
|
break;
|
|
case MACSLEEP:
|
|
if (record->event.pressed) {
|
|
// ACTION_MODS_KEY(MOD_LCTL | MOD_LSFT, KC_POWER);
|
|
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;
|
|
case BACKLIT:
|
|
if (record->event.pressed) {
|
|
register_code(KC_RSFT);
|
|
#ifdef BACKLIGHT_ENABLE
|
|
backlight_step();
|
|
#endif
|
|
} else {
|
|
unregister_code(KC_RSFT);
|
|
}
|
|
return false;
|
|
break;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
/*
|
|
const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
|
|
keyevent_t event = record->event;
|
|
|
|
switch (id) {
|
|
case 0: {
|
|
if (record->event.pressed) {
|
|
key_timer = timer_read(); // if the key is being pressed, we start the timer.
|
|
}
|
|
else { // this means the key was just released, so we can figure out how long it was pressed for (tap or "held down").
|
|
if (timer_elapsed(key_timer) > 150) { // 150 being 150ms, the threshhold we pick for counting something as a tap.
|
|
return MACRO( D(LSFT), END );
|
|
}
|
|
else {
|
|
return MACRO( T(N), END );
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
return MACRO_NONE;
|
|
}*/
|
|
|
|
void matrix_init_user(void) {
|
|
#ifdef AUDIO_ENABLE
|
|
startup_user();
|
|
#endif
|
|
}
|
|
|
|
#ifdef AUDIO_ENABLE
|
|
|
|
void startup_user()
|
|
{
|
|
_delay_ms(20); // gets rid of tick
|
|
PLAY_SONG(tone_startup);
|
|
}
|
|
|
|
void shutdown_user()
|
|
{
|
|
PLAY_SONG(tone_goodbye);
|
|
_delay_ms(150);
|
|
stop_all_notes();
|
|
}
|
|
|
|
void music_on_user(void)
|
|
{
|
|
music_scale_user();
|
|
}
|
|
|
|
void music_scale_user(void)
|
|
{
|
|
PLAY_SONG(music_scale);
|
|
}
|
|
|
|
#endif
|
|
|
|
void matrix_scan_user(void) {
|
|
}
|
|
|
|
//Tap Dance Definitions
|
|
qk_tap_dance_action_t tap_dance_actions[] = {
|
|
//Tap once for Esc, twice for Caps Lock
|
|
[TD_Z_LCTL] = ACTION_TAP_DANCE_DOUBLE(KC_Z, KC_LCTL),
|
|
[TD_X_LGUI] = ACTION_TAP_DANCE_DOUBLE(KC_X, KC_LGUI),
|
|
[TD_C_LALT] = ACTION_TAP_DANCE_DOUBLE(KC_C, KC_LALT),
|
|
[TD_A_TAB] = ACTION_TAP_DANCE_DOUBLE(KC_A, KC_TAB),
|
|
[TD_Q_ESC] = ACTION_TAP_DANCE_DOUBLE(KC_Q, KC_ESC)
|
|
};
|
|
|
|
// don't know what this is doing...
|
|
/*
|
|
void led_set_user(uint8_t usb_led) {
|
|
|
|
if (usb_led & (1 << USB_LED_NUM_LOCK)) {
|
|
DDRD |= (1 << 5); PORTD &= ~(1 << 5);
|
|
} else {
|
|
DDRD &= ~(1 << 5); PORTD &= ~(1 << 5);
|
|
}
|
|
|
|
if (usb_led & (1 << USB_LED_CAPS_LOCK)) {
|
|
DDRB |= (1 << 0); PORTB &= ~(1 << 0);
|
|
} else {
|
|
DDRB &= ~(1 << 0); PORTB &= ~(1 << 0);
|
|
}
|
|
|
|
if (usb_led & (1 << USB_LED_SCROLL_LOCK)) {
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
if (usb_led & (1 << USB_LED_COMPOSE)) {
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
if (usb_led & (1 << USB_LED_KANA)) {
|
|
|
|
} else {
|
|
|
|
}
|
|
|
|
}
|
|
*/
|