diff options
| -rw-r--r-- | keyboards/bastardkb/skeletyl/keymaps/default/keymap.c | 70 | ||||
| -rw-r--r-- | keyboards/bastardkb/skeletyl/keymaps/quotengrote/config.h | 21 | ||||
| -rw-r--r-- | keyboards/bastardkb/skeletyl/keymaps/quotengrote/keymap.c | 230 | ||||
| -rw-r--r-- | keyboards/bastardkb/skeletyl/keymaps/quotengrote/readme.md | 15 | ||||
| -rw-r--r-- | keyboards/bastardkb/skeletyl/keymaps/quotengrote/rules.mk | 4 | ||||
| -rw-r--r-- | keyboards/ferris/keymaps/quotengrote/config.h | 68 | ||||
| -rw-r--r-- | keyboards/ferris/keymaps/quotengrote/keymap.c | 146 | ||||
| -rw-r--r-- | keyboards/ferris/keymaps/quotengrote/readme.md | 11 | ||||
| -rw-r--r-- | keyboards/ferris/keymaps/quotengrote/rules.mk | 11 | ||||
| -rw-r--r-- | keyboards/planck/keymaps/quotengrote/config.h | 15 | ||||
| -rw-r--r-- | keyboards/planck/keymaps/quotengrote/keymap.c | 232 | ||||
| -rw-r--r-- | keyboards/planck/keymaps/quotengrote/rules.mk | 4 |
12 files changed, 827 insertions, 0 deletions
diff --git a/keyboards/bastardkb/skeletyl/keymaps/default/keymap.c b/keyboards/bastardkb/skeletyl/keymaps/default/keymap.c new file mode 100644 index 0000000000..56e56d9a43 --- /dev/null +++ b/keyboards/bastardkb/skeletyl/keymaps/default/keymap.c @@ -0,0 +1,70 @@ +/* + * Copyright 2021 Quentin LEBASTARD <qlebastard@gmail.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include QMK_KEYBOARD_H + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + + [0] = LAYOUT_split_3x5_3( + //,-----------------------------------------------------. ,-----------------------------------------------------. + KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, + //|--------+--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------| + KC_LGUI, KC_SPC , MO(1), MO(2), KC_ENT , KC_RALT + //`--------------------------' `--------------------------' + + ), + + [1] = LAYOUT_split_3x5_3( + //,-----------------------------------------------------. ,-----------------------------------------------------. + KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_UP,KC_RIGHT, XXXXXXX, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + //|--------+--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------| + KC_LGUI, KC_SPC, _______, MO(3), KC_ENT, KC_RALT + //`--------------------------' `--------------------------' + ), + + [2] = LAYOUT_split_3x5_3( + //,-----------------------------------------------------. ,-----------------------------------------------------. + KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_MINS, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE, + //|--------+--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------| + KC_LGUI, KC_SPC, MO(3), _______, KC_ENT, KC_RALT + //`--------------------------' `--------------------------' + ), + + [3] = LAYOUT_split_3x5_3( + //,-----------------------------------------------------. ,-----------------------------------------------------. + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + RGB_HUI, RGB_SAI, RGB_VAI, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + //|--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------| + RGB_HUD, RGB_SAD, RGB_VAD, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + //|--------+--------+--------+--------+--------+--------+--------| |--------+--------+--------+--------+--------+--------+--------| + KC_LGUI, KC_SPC, _______, _______, KC_ENT, KC_RALT + //`--------------------------' `--------------------------' + ) +}; diff --git a/keyboards/bastardkb/skeletyl/keymaps/quotengrote/config.h b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/config.h new file mode 100644 index 0000000000..9e62960f0d --- /dev/null +++ b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/config.h @@ -0,0 +1,21 @@ +// tap and hold +#define TAPPING_TERM 175 //in milliseconds +#define PERMISSIVE_HOLD +// VBUS detection +#define USB_VBUS_PIN GP19 +// autoshift +#define NO_AUTO_SHIFT_TAB +#define NO_AUTO_SHIFT_NUMERIC +#define NO_AUTO_SHIFT_ALPHA +// handedness +#undef MASTER_RIGHT +// rgb +#define RGB_MATRIX_STARTUP_MODE RGB_MATRIX_SOLID_COLOR +#define RGB_DISABLE_WHEN_USB_SUSPENDED true +#undef RGB_MATRIX_MAXIMUM_BRIGHTNESS +#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 220 +#define SPLIT_LAYER_STATE_ENABLE // for layer indicators +#define RGB_TRIGGER_ON_KEYDOWN // Triggers RGB keypress events on key down. This makes RGB control feel more responsive. This may cause RGB to not function properly on some boards +// rgb timeout; https://gist.github.com/aashreys/01cb34605a290a7cfb94a856bdabc94c?permalink_comment_id=4520204#gistcomment-4520204 +#define RGB_MATRIX_TIMEOUT 180000 // = 3min; number of milliseconds to wait until rgb automatically turns off +#define SPLIT_MODS_ENABLE diff --git a/keyboards/bastardkb/skeletyl/keymaps/quotengrote/keymap.c b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/keymap.c new file mode 100644 index 0000000000..083712c2a9 --- /dev/null +++ b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/keymap.c @@ -0,0 +1,230 @@ +#include QMK_KEYBOARD_H +#include "keymap_german.h" + +// layers +enum layers { + _BASE, + _NUM, + _SYM, + _MOV, + _MEDIA +}; + + +// rgb +void keyboard_post_init_user(void) { + rgblight_enable_noeeprom(); // Enables RGB, without saving settings + rgblight_sethsv(4, 75, 150); // warmwhite (werte = hue, saturation, value) + rgblight_mode_noeeprom(RGB_MATRIX_SOLID_COLOR); +} +bool rgb_matrix_indicators_advanced_user(uint8_t led_min, uint8_t led_max) { +// https://colorpicker.me/#fff115 + // shift rgb + uint8_t mods = get_mods() | get_weak_mods() | get_oneshot_mods(); + if ((mods) & MOD_MASK_SHIFT ) { + rgb_matrix_set_color_all(31, 206, 211); // turquoise + }; + // layer rgb + for (uint8_t i = led_min; i < led_max; i++) { + switch(get_highest_layer(layer_state|default_layer_state)) { + //base + case 0: + rgblight_sethsv(4, 75, 150); // warmwhite (werte = hue, saturation, value) + break; + // num + case 1: + // <led-index> {siehe ../../skeletyl.c) <rgb-wert> + // color thumbs + rgb_matrix_set_color(35, 255, 165, 0); // orange + rgb_matrix_set_color(34, 255, 165, 0); // orange + rgb_matrix_set_color(33, 255, 165, 0); // orange + break; + // sym + case 2: + // color thumbs + rgb_matrix_set_color(15, 0, 90, 255); // blue + rgb_matrix_set_color(16, 0, 90, 255); // blue + rgb_matrix_set_color(17, 0, 90, 255); // blue + // color pairs + // ´` + rgb_matrix_set_color(5, 20, 214, 22); // 50 shades of green + rgb_matrix_set_color(11, 20, 214, 22); // 50 shades of green + // [] + rgb_matrix_set_color(3, 44, 0, 232); // 50 shades of blue + rgb_matrix_set_color(21, 44, 0, 232); // 50 shades of blue + // () + rgb_matrix_set_color(8, 44, 0, 207); // 50 shades of blue + rgb_matrix_set_color(26, 44, 0, 207); // 50 shades of blue + // {} + rgb_matrix_set_color(9, 44, 0, 171); // 50 shades of blue + rgb_matrix_set_color(27, 44, 0, 171); // 50 shades of blue + // \/ + rgb_matrix_set_color(13, 235, 235, 19); // 50 shades of yellow + rgb_matrix_set_color(31, 235, 235, 19); // 50 shades of yellow + // <> + rgb_matrix_set_color(14, 235, 56, 19); // 50 shades of red + rgb_matrix_set_color(32, 235, 56, 19); // 50 shades of red + break; + // mov + case 3: + // color thumbs + rgb_matrix_set_color(35, 4, 147, 4); // green + rgb_matrix_set_color(34, 4, 147, 4); // green + rgb_matrix_set_color(33, 4, 147, 4); // green + rgb_matrix_set_color(15, 4, 147, 4); // green + rgb_matrix_set_color(16, 4, 147, 4); // green + rgb_matrix_set_color(17, 4, 147, 4); // green + break; + // media + case 4: + // color thumbs + rgb_matrix_set_color(35, 255, 241, 21); // yellow + rgb_matrix_set_color(34, 255, 241, 21); // yellow + rgb_matrix_set_color(33, 255, 241, 21); // yellow + rgb_matrix_set_color(15, 255, 241, 21); // yellow + rgb_matrix_set_color(16, 255, 241, 21); // yellow + rgb_matrix_set_color(17, 255, 241, 21); // yellow + break; + default: + rgblight_sethsv(4, 75, 150); // warmwhite (werte = hue, saturation, value) + break; + } + } + return false; +} + +// combos; https://github.com/qmk/qmk_firmware/blob/master/docs/feature_combo.md +enum combos { + C_ALT, + C_KA, + C_KK, + C_ESC, + C_MED, + C_SV, // Strg + S + C_WE // Windows Explorer +}; + +const uint16_t PROGMEM alt_combo[] = {LCTL_T(KC_E), KC_I, COMBO_END}; +const uint16_t PROGMEM ka_combo[] = {KC_R, LSFT_T(KC_T), COMBO_END}; +const uint16_t PROGMEM kk_combo[] = {LSFT_T(KC_N), KC_I, COMBO_END}; +const uint16_t PROGMEM esc_combo[] = {LCTL_T(KC_S), LSFT_T(KC_T), COMBO_END}; +const uint16_t PROGMEM med_combo[] = {LT(_MOV, KC_DEL), MO(_MOV), COMBO_END}; +const uint16_t PROGMEM sv_combo[] = {LCTL_T(KC_S), LT(_BASE,KC_C), COMBO_END}; +const uint16_t PROGMEM we_combo[] = {LT(_BASE,KC_W), LCTL_T(KC_E), COMBO_END}; + +combo_t key_combos[] = { + [C_ALT] = COMBO(alt_combo, KC_LALT), + [C_KA] = COMBO(ka_combo, LCTL(LALT(KC_A))), + [C_KK] = COMBO(kk_combo, LCTL(LALT(KC_K))), + [C_ESC] = COMBO(esc_combo, KC_ESC), + [C_MED] = COMBO(med_combo, MO(_MEDIA)), + [C_SV] = COMBO(sv_combo, LCTL(KC_S)), + [C_WE] = COMBO(we_combo, LGUI(KC_E)), +}; + +// keymap +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // Buchstaben - white + [_BASE] = LAYOUT_split_3x5_3( + LT(_BASE,KC_Q), LT(_BASE,KC_W), LT(_BASE,KC_F), KC_P, KC_B, KC_J, KC_L, LT(_BASE,KC_U), DE_Z, KC_BSPC, + LT(_BASE,KC_A), KC_R, LCTL_T(KC_S), LSFT_T(KC_T), KC_G, KC_M, LSFT_T(KC_N), LCTL_T(KC_E), KC_I, LT(_BASE,KC_O), + LT(_BASE,DE_Y), LT(_BASE,KC_X), LT(_BASE,KC_C), LSFT_T(KC_D), LT(_BASE,KC_V), KC_K, LSFT_T(KC_H), DE_COMM, DE_DOT, DE_MINS, + XXXXXXX, LT(_MOV, KC_DEL), LT(_SYM, KC_ENT), LT(_NUM, KC_SPC), MO(_MOV), XXXXXXX + ), + // Zahlen - orange + [_NUM] = LAYOUT_split_3x5_3( + KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_BSPC, + KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, + QK_CAPS_WORD_TOGGLE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_F10, KC_F11, _______, _______, KC_F12, + XXXXXXX, _______, _______, _______, _______, XXXXXXX + ), + // Sym - blue + [_SYM] = LAYOUT_split_3x5_3( + DE_CIRC, DE_LBRC, DE_LPRN, DE_LPRN, DE_SECT, DE_PERC, DE_RCBR, DE_RPRN, DE_RBRC, KC_BSPC, + DE_EXLM, DE_DQUO, DE_SS, DE_QUOT, DE_SLSH, RALT(DE_SS), DE_DLR, DE_AMPR, DE_ASTR, DE_QUES, + DE_TILD, DE_ACUT, XXXXXXX, LSFT(DE_ACUT), DE_LABK , DE_RABK , XXXXXXX, DE_PLUS, DE_EQL, DE_HASH, + XXXXXXX, _______, _______, _______, _______, XXXXXXX + ), + // Move - green + [_MOV] = LAYOUT_split_3x5_3( + XXXXXXX, KC_HOME, KC_UP, KC_PGUP, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_HOME, KC_BSPC, + KC_TAB, KC_LEFT, KC_DOWN, KC_RIGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RIGHT, KC_DEL, + XXXXXXX, KC_END, KC_PGDN, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, KC_END, XXXXXXX, + XXXXXXX, _______, _______, _______, _______, XXXXXXX + ), + // Media - yellow + [_MEDIA] = LAYOUT_split_3x5_3( + RGB_TOG, XXXXXXX, XXXXXXX, KC_PSCR, KC_VOLU, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_MUTE, KC_MUTE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + XXXXXXX, XXXXXXX, XXXXXXX, KC_MPLY, KC_VOLD, KC_VOLD, KC_MPLY, XXXXXXX, XXXXXXX, XXXXXXX, + XXXXXXX, _______, _______, _______, _______, XXXXXXX + ) +}; + +// https://github.com/qmk/qmk_firmware/blob/master/docs/mod_tap.md#changing-hold-function +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + // "Tap and Hold" + case LT(_BASE,KC_X): // "LT(_BASE,KC_X)" is the keycode that must be mapped + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X + return false; + } + return true; // Return true for normal processing of tap keycode + case LT(_BASE,DE_Y): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_PIPE); + return false; + } + return true; + case LT(_BASE,KC_C): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_C)); + return false; + } + return true; + case LT(_BASE,KC_V): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_V)); + return false; + } + return true; + case LT(_BASE,KC_Q): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_Q)); + return false; + } + return true; + case LT(_BASE,KC_F): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_E)); + return false; + } + return true; + case LT(_BASE,KC_A): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ADIA); + return false; + } + return true; + case LT(_BASE,KC_O): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ODIA); + return false; + } + return true; + case LT(_BASE,KC_U): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_UDIA); + return false; + } + return true; + case LT(_BASE,KC_W): + if (!record->tap.count && record->event.pressed) { + tap_code16(KC_LGUI); + return false; + } + return true; + } + return true; +} diff --git a/keyboards/bastardkb/skeletyl/keymaps/quotengrote/readme.md b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/readme.md new file mode 100644 index 0000000000..3153c1c15b --- /dev/null +++ b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/readme.md @@ -0,0 +1,15 @@ +# Readme + +## Compiling + +`qmk compile -kb bastardkb/skeletyl/v2/splinky_3 -km quotengrote` + +## Flashing + +1. Double Tap auf Reset +2. Kopiere auf "RP-RPI"-Laufwerk +3. Wiederholen auf der anderen Seite + +## "Main Side" + +- auf links gesetzt in `config.h`, trotzdem müssen beide Seiten geflashed werden diff --git a/keyboards/bastardkb/skeletyl/keymaps/quotengrote/rules.mk b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/rules.mk new file mode 100644 index 0000000000..dc68f099de --- /dev/null +++ b/keyboards/bastardkb/skeletyl/keymaps/quotengrote/rules.mk @@ -0,0 +1,4 @@ +CAPS_WORD_ENABLE = yes +AUTO_SHIFT_ENABLE = yes +COMBO_ENABLE = yes +RGB_MATRIX_ENABLE = yes diff --git a/keyboards/ferris/keymaps/quotengrote/config.h b/keyboards/ferris/keymaps/quotengrote/config.h new file mode 100644 index 0000000000..cffa10de2e --- /dev/null +++ b/keyboards/ferris/keymaps/quotengrote/config.h @@ -0,0 +1,68 @@ +// tap and hold +#define TAPPING_TERM 175 //in milliseconds +#define PERMISSIVE_HOLD +// autoshift +#define NO_AUTO_SHIFT_TAB +#define NO_AUTO_SHIFT_NUMERIC +#define NO_AUTO_SHIFT_ALPHA +// Handedness +// https://docs.qmk.fm/#/feature_split_keyboard?id=handedness-by-eeprom +// https://www.reddit.com/r/ErgoMechKeyboards/comments/rcq6u9/just_finished_configuring_my_ferris_one_half_have/ +#define EE_HANDS +// disable any LED modes +#undef RGBLIGHT_ANIMATIONS +#undef RGBLIGHT_EFFECT_BREATHING +#undef RGBLIGHT_EFFECT_RAINBOW_MOOD +#undef RGBLIGHT_EFFECT_RAINBOW_SWIRL +#undef RGBLIGHT_EFFECT_SNAKE +#undef RGBLIGHT_EFFECT_KNIGHT +#undef RGBLIGHT_EFFECT_CHRISTMAS +#undef RGBLIGHT_EFFECT_STATIC_GRADIENT +#undef RGBLIGHT_EFFECT_RGB_TEST +#undef RGBLIGHT_EFFECT_ALTERNATING +#undef RGBLIGHT_EFFECT_TWINKLE +#undef ENABLE_RGB_MATRIX_ALPHAS_MODS +#undef ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN +#undef ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT +#undef ENABLE_RGB_MATRIX_BREATHING +#undef ENABLE_RGB_MATRIX_BAND_SAT +#undef ENABLE_RGB_MATRIX_BAND_VAL +#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT +#undef ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL +#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT +#undef ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL +#undef ENABLE_RGB_MATRIX_CYCLE_ALL +#undef ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT +#undef ENABLE_RGB_MATRIX_CYCLE_UP_DOWN +#undef ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON +#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN +#undef ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL +#undef ENABLE_RGB_MATRIX_CYCLE_PINWHEEL +#undef ENABLE_RGB_MATRIX_CYCLE_SPIRAL +#undef ENABLE_RGB_MATRIX_DUAL_BEACON +#undef ENABLE_RGB_MATRIX_RAINBOW_BEACON +#undef ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS +#undef ENABLE_RGB_MATRIX_RAINDROPS +#undef ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS +#undef ENABLE_RGB_MATRIX_HUE_BREATHING +#undef ENABLE_RGB_MATRIX_HUE_PENDULUM +#undef ENABLE_RGB_MATRIX_HUE_WAVE +#undef ENABLE_RGB_MATRIX_PIXEL_FRACTAL +#undef ENABLE_RGB_MATRIX_PIXEL_FLOW +#undef ENABLE_RGB_MATRIX_PIXEL_RAIN + +#undef ENABLE_RGB_MATRIX_TYPING_HEATMAP +#undef ENABLE_RGB_MATRIX_DIGITAL_RAIN + +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS +#undef ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS +#undef ENABLE_RGB_MATRIX_SPLASH +#undef ENABLE_RGB_MATRIX_MULTISPLASH +#undef ENABLE_RGB_MATRIX_SOLID_SPLASH +#undef ENABLE_RGB_MATRIX_SOLID_MULTISPLASH diff --git a/keyboards/ferris/keymaps/quotengrote/keymap.c b/keyboards/ferris/keymaps/quotengrote/keymap.c new file mode 100644 index 0000000000..33d0b3ffc4 --- /dev/null +++ b/keyboards/ferris/keymaps/quotengrote/keymap.c @@ -0,0 +1,146 @@ +#include QMK_KEYBOARD_H +#include "keymap_german.h" + +// layers +enum layers { + _BASE, + _NUM, + _SYM, + _MOV, + _MEDIA +}; + +// combos; https://github.com/qmk/qmk_firmware/blob/master/docs/feature_combo.md +enum combos { + C_ALT, + C_KA, + C_KK, + C_ESC, + C_MED, + C_SV, // Strg + S + C_WE // Windows Explorer +}; + +const uint16_t PROGMEM alt_combo[] = {LCTL_T(KC_E), KC_I, COMBO_END}; +const uint16_t PROGMEM ka_combo[] = {KC_R, LSFT_T(KC_T), COMBO_END}; +const uint16_t PROGMEM kk_combo[] = {LSFT_T(KC_N), KC_I, COMBO_END}; +const uint16_t PROGMEM esc_combo[] = {LCTL_T(KC_S), LSFT_T(KC_T), COMBO_END}; +const uint16_t PROGMEM med_combo[] = {LT(_MOV, KC_DEL), MO(_MOV), COMBO_END}; +const uint16_t PROGMEM sv_combo[] = {LCTL_T(KC_S), LT(_BASE,KC_C), COMBO_END}; +const uint16_t PROGMEM we_combo[] = {LT(_BASE,KC_W), LCTL_T(KC_E), COMBO_END}; + +combo_t key_combos[] = { + [C_ALT] = COMBO(alt_combo, KC_LALT), + [C_KA] = COMBO(ka_combo, LCTL(LALT(KC_A))), + [C_KK] = COMBO(kk_combo, LCTL(LALT(KC_K))), + [C_ESC] = COMBO(esc_combo, KC_ESC), + [C_MED] = COMBO(med_combo, MO(_MEDIA)), + [C_SV] = COMBO(sv_combo, LCTL(KC_S)), + [C_WE] = COMBO(we_combo, LGUI(KC_E)), +}; + +// keymap +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // white + [_BASE] = LAYOUT_split_3x5_2( + LT(_BASE,KC_Q), LT(_BASE,KC_W), LT(_BASE,KC_F), KC_P, KC_B, KC_J, KC_L, LT(_BASE,KC_U), DE_Z, KC_BSPC, + LT(_BASE,KC_A), KC_R, LCTL_T(KC_S), LSFT_T(KC_T), KC_G, KC_M, LSFT_T(KC_N), LCTL_T(KC_E), KC_I, LT(_BASE,KC_O), + LT(_BASE,DE_Y), LT(_BASE,KC_X), LT(_BASE,KC_C), LSFT_T(KC_D), LT(_BASE,KC_V), KC_K, LSFT_T(KC_H), DE_COMM, DE_DOT, DE_MINS, + LT(_MOV, KC_DEL), LT(_SYM, KC_ENT), LT(_NUM, KC_SPC), MO(_MOV) + ), + // orange + [_NUM] = LAYOUT_split_3x5_2( + KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_BSPC, + KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, + QK_CAPS_WORD_TOGGLE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_F10, KC_F11, _______, _______, KC_F12, + _______, _______, _______, _______ + ), + // blue + [_SYM] = LAYOUT_split_3x5_2( + DE_CIRC, DE_LBRC, DE_LPRN, DE_LPRN, DE_SECT, DE_PERC, DE_RCBR, DE_RPRN, DE_RBRC, KC_BSPC, + DE_EXLM, DE_DQUO, DE_SS, DE_QUOT, DE_SLSH, RALT(DE_SS), DE_DLR, DE_AMPR, DE_ASTR, DE_QUES, + DE_TILD, DE_ACUT, XXXXXXX, LSFT(DE_ACUT), DE_LABK , DE_RABK , XXXXXXX, DE_PLUS, DE_EQL, DE_HASH, + _______, _______, _______, _______ + ), + // green + [_MOV] = LAYOUT_split_3x5_2( + XXXXXXX, KC_HOME, KC_UP, KC_PGUP, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_HOME, KC_BSPC, + KC_TAB, KC_LEFT, KC_DOWN, KC_RIGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RIGHT, KC_DEL, + XXXXXXX, KC_END, KC_PGDN, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, KC_END, XXXXXXX, + _______, _______, _______, _______ + ), + // yellow + [_MEDIA] = LAYOUT_split_3x5_2( + RGB_TOG, RGB_HUI, RGB_HUD, KC_PSCR, KC_VOLU, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + RGB_MOD, RGB_SAI, RGB_SAD, XXXXXXX, KC_MUTE, KC_MUTE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + RGB_RMOD, RGB_VAI, RGB_VAD, KC_MPLY, KC_VOLD, KC_VOLD, KC_MPLY, XXXXXXX, XXXXXXX, XXXXXXX, + _______, _______, _______, _______ + ) +}; +// https://github.com/qmk/qmk_firmware/blob/master/docs/mod_tap.md#changing-hold-function +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + // "Tap and Hold" + case LT(_BASE,KC_X): // "LT(_BASE,KC_X)" is the keycode that must be mapped + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X + return false; + } + return true; // Return true for normal processing of tap keycode + case LT(_BASE,DE_Y): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_PIPE); + return false; + } + return true; + case LT(_BASE,KC_C): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_C)); + return false; + } + return true; + case LT(_BASE,KC_V): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_V)); + return false; + } + return true; + case LT(_BASE,KC_Q): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_Q)); + return false; + } + return true; + case LT(_BASE,KC_F): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_E)); + return false; + } + return true; + case LT(_BASE,KC_A): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ADIA); + return false; + } + return true; + case LT(_BASE,KC_O): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ODIA); + return false; + } + return true; + case LT(_BASE,KC_U): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_UDIA); + return false; + } + return true; + case LT(_BASE,KC_W): + if (!record->tap.count && record->event.pressed) { + tap_code16(KC_LGUI); + return false; + } + return true; + } + return true; +} diff --git a/keyboards/ferris/keymaps/quotengrote/readme.md b/keyboards/ferris/keymaps/quotengrote/readme.md new file mode 100644 index 0000000000..2de8880600 --- /dev/null +++ b/keyboards/ferris/keymaps/quotengrote/readme.md @@ -0,0 +1,11 @@ +# Readme + +## Compiling + +`qmk compile -kb ferris/sweep -km quotengrote` + +## Flashing + +1. Reset-Button +2. QMK-Toolbox +3. Wiederholen auf der anderen Seite diff --git a/keyboards/ferris/keymaps/quotengrote/rules.mk b/keyboards/ferris/keymaps/quotengrote/rules.mk new file mode 100644 index 0000000000..b782fad97e --- /dev/null +++ b/keyboards/ferris/keymaps/quotengrote/rules.mk @@ -0,0 +1,11 @@ +CAPS_WORD_ENABLE = yes +AUTO_SHIFT_ENABLE = yes +COMBO_ENABLE = yes +# Optimizing build size +# https://docs.qmk.fm/#/squeezing_avr?id=squeezing-the-most-out-of-avr +LTO_ENABLE = yes +CONSOLE_ENABLE = no +MUSIC_ENABLE = no +SPACE_CADET_ENABLE = no +GRAVE_ESC_ENABLE = no +COMMAND_ENABLE = no diff --git a/keyboards/planck/keymaps/quotengrote/config.h b/keyboards/planck/keymaps/quotengrote/config.h new file mode 100644 index 0000000000..85e992dc5a --- /dev/null +++ b/keyboards/planck/keymaps/quotengrote/config.h @@ -0,0 +1,15 @@ +// tap and hold +#define TAPPING_TERM 175 //in milliseconds +#define PERMISSIVE_HOLD +// autoshift +#define NO_AUTO_SHIFT_TAB +#define NO_AUTO_SHIFT_NUMERIC +#define NO_AUTO_SHIFT_ALPHA +// rgb +#define RGB_MATRIX_STARTUP_MODE RGB_MATRIX_SOLID_COLOR +#define RGB_DISABLE_WHEN_USB_SUSPENDED true +#undef RGB_MATRIX_MAXIMUM_BRIGHTNESS +#define RGB_MATRIX_MAXIMUM_BRIGHTNESS 220 +#define RGB_TRIGGER_ON_KEYDOWN // Triggers RGB keypress events on key down. This makes RGB control feel more responsive. This may cause RGB to not function properly on some boards +// rgb timeout; https://gist.github.com/aashreys/01cb34605a290a7cfb94a856bdabc94c?permalink_comment_id=4520204#gistcomment-4520204 +#define RGB_MATRIX_TIMEOUT 180000 // = 3min; number of milliseconds to wait until rgb automatically turns off diff --git a/keyboards/planck/keymaps/quotengrote/keymap.c b/keyboards/planck/keymaps/quotengrote/keymap.c new file mode 100644 index 0000000000..76fb92c70a --- /dev/null +++ b/keyboards/planck/keymaps/quotengrote/keymap.c @@ -0,0 +1,232 @@ +#include QMK_KEYBOARD_H +#include "keymap_german.h" + +// layers +enum layers { + _BASE, + _NUM, + _SYM, + _MOV, + _MEDIA +}; + +// rgb +void keyboard_post_init_user(void) { + rgblight_enable_noeeprom(); // Enables RGB, without saving settings + rgblight_sethsv(0, 0, 0); // pure white (werte = hue, saturation, value) + rgblight_mode_noeeprom(RGB_MATRIX_SOLID_COLOR); +} +bool rgb_matrix_indicators_advanced_user(uint8_t led_min, uint8_t led_max) { + // https://colorpicker.me/#fff115 + // layer rgb + //../../ez/ez.c + // { 0, 1, 2, 3, 4, 5 }, { 6, 7, 8, 9, 10, 11 }, + // { 12, 13, 14, 15, 16, 17 }, { 18, 19, 20, 21, 22, 23 }, + // { 24, 25, 26, 27, 28, 29 }, { 30, 31, 32, 33, 34, 35 }, + // { 36, 37, 38, 45, 46, NO_LED }, { 42, 43, 44, 39, 40, 41 } + // arrays of LED indexes + const uint8_t led_sym_indexes[16] = {1, 5, 6, 10, 13, 14, 15, 16, 19, 20, 21, 22, 25, 32, 33, 34}; + const uint8_t led_mov_indexes[20] = {2, 3, 4, 7, 8, 9, 10, 11, 13, 14, 15, 16, 19, 20, 21, 22, 26, 27, 31, 33}; + const uint8_t led_media_indexes[6] = {1, 4, 5, 17, 28, 29}; + const uint8_t led_border_indexes[17] = {0, 12, 24, 36, 37, 38, 45, 46, 42, 43, 44, 39, 40, 41, 35, 23, 11}; + + for (uint8_t i = led_min; i < led_max; i++) { + switch(get_highest_layer(layer_state|default_layer_state)) { + //base + case 0: + // All + for (int i=0; i<=46; i++) { + rgb_matrix_set_color(i, 24, 158, 230); // blue + } + // only border + for (int i=0; i<17; i++) { + rgb_matrix_set_color(led_border_indexes[i], 255, 88, 0); // orange + } + break; + // num + case 1: + // https://www.reddit.com/r/olkb/comments/o3x5o6/how_to_do_a_basic_loop_in_qmkc/ + //F-Keys + for (int i=1; i<=10; i++) { + rgb_matrix_set_color(i, 20, 214, 2); + } + for (int i=33; i<=34; i++) { + rgb_matrix_set_color(i, 20, 214, 2); + } + // Numbers + for (int i=13; i<=22; i++) { + rgb_matrix_set_color(i, 44, 0, 232); // 50 shades of blue + } + // capsword + rgb_matrix_set_color(25, 235, 235, 19); // 50 shades of yellow + // only border + for (int i=0; i<17; i++) { + rgb_matrix_set_color(led_border_indexes[i], 255, 88, 0); // orange + } + break; + // sym + case 2: + // color pairs + // ´` + rgb_matrix_set_color(26, 20, 214, 22); // 50 shades of green + rgb_matrix_set_color(28, 20, 214, 22); // 50 shades of green + // [] + rgb_matrix_set_color(2, 44, 0, 232); // 50 shades of blue + rgb_matrix_set_color(9, 44, 0, 232); // 50 shades of blue + // () + rgb_matrix_set_color(3, 44, 0, 207); // 50 shades of blue + rgb_matrix_set_color(8, 44, 0, 207); // 50 shades of blue + // {} + rgb_matrix_set_color(4, 44, 0, 171); // 50 shades of blue + rgb_matrix_set_color(7, 44, 0, 171); // 50 shades of blue + // \/ + rgb_matrix_set_color(17, 235, 235, 19); // 50 shades of yellow + rgb_matrix_set_color(18, 235, 235, 19); // 50 shades of yellow + // <> + rgb_matrix_set_color(29, 235, 56, 19); // 50 shades of red + rgb_matrix_set_color(30, 235, 56, 19); // 50 shades of red + // rest + for (int i=0; i<16; i++) { + rgb_matrix_set_color(led_sym_indexes[i], 234, 221, 13); // other yellow + } + // only border + for (int i=0; i<17; i++) { + rgb_matrix_set_color(led_border_indexes[i], 255, 88, 0); // orange + } + break; + // mov + case 3: + for (int i=0; i<20; i++) { + rgb_matrix_set_color(led_mov_indexes[i], 4, 147, 4); // green + } + // only border + for (int i=0; i<17; i++) { + rgb_matrix_set_color(led_border_indexes[i], 255, 88, 0); // orange + } + break; + // media + case 4: + for (int i=0; i<6; i++) { + rgb_matrix_set_color(led_media_indexes[i], 235, 56, 19); // 50 shades of red + } + // only border + for (int i=0; i<17; i++) { + rgb_matrix_set_color(led_border_indexes[i], 255, 88, 0); // orange + } + break; + default: + break; + } + } + return false; +} + +// combos; https://github.com/qmk/qmk_firmware/blob/master/docs/feature_combo.md +enum combos { + C_MED, +}; +const uint16_t PROGMEM med_combo[] = {KC_DEL, KC_LEFT, COMBO_END}; +combo_t key_combos[] = { + [C_MED] = COMBO(med_combo, MO(_MEDIA)), +}; + +// keymap +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // white + [_BASE] = LAYOUT_planck_mit( + KC_ESC, LT(_BASE,KC_Q), KC_W, LT(_BASE,KC_F), KC_P, KC_B, KC_J, KC_L, LT(_BASE,KC_U), DE_Z, XXXXXXX, KC_BSPC, + KC_TAB, LT(_BASE,KC_A), KC_R, KC_S, KC_T, KC_G, KC_M, KC_N, KC_E, KC_I, LT(_BASE,KC_O), KC_ENT, + KC_LSFT, LT(_BASE,DE_Y), LT(_BASE,KC_X), LT(_BASE,KC_C), KC_D, LT(_BASE,KC_V), KC_K, KC_H, DE_COMM, DE_DOT, DE_MINS, DE_HASH, + KC_LCTL, KC_LGUI, KC_LALT, KC_DEL, MO(_SYM), LT(_MOV, KC_SPC), MO(_NUM), KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT + ), + // orange + [_NUM] = LAYOUT_planck_mit( + KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_BSPC, + KC_TAB, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_ENT, + KC_LSFT, QK_CAPS_WORD_TOGGLE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, _______, KC_F11, KC_F12, DE_HASH, + KC_LCTL, KC_LGUI, KC_LALT, KC_DEL, MO(_SYM), KC_SPC, MO(_NUM), KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT + ), + // blue + [_SYM] = LAYOUT_planck_mit( + KC_ESC, DE_CIRC, DE_LBRC, DE_LPRN, DE_LPRN, DE_SECT, DE_PERC, DE_RCBR, DE_RPRN, DE_RBRC, KC_BSPC, KC_BSPC, + KC_TAB, DE_EXLM, DE_DQUO, DE_SS, DE_QUOT, DE_SLSH, RALT(DE_SS), DE_DLR, DE_AMPR, DE_ASTR, DE_QUES, KC_ENT, + KC_LSFT, DE_TILD, DE_ACUT, XXXXXXX, LSFT(DE_ACUT), DE_LABK, DE_RABK, XXXXXXX, DE_PLUS, DE_EQL, DE_HASH, XXXXXXX, + KC_LCTL, KC_LGUI, KC_LALT, KC_DEL, MO(_SYM), KC_SPC, MO(_NUM), KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT + ), + // green + [_MOV] = LAYOUT_planck_mit( + KC_ESC, XXXXXXX, KC_HOME, KC_UP, KC_PGUP, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_HOME, KC_BSPC, KC_BSPC, + KC_TAB, KC_TAB, KC_LEFT, KC_DOWN, KC_RIGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RIGHT, KC_DEL, KC_ENT, + KC_LSFT, XXXXXXX, KC_END, KC_PGDN, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, KC_END, XXXXXXX, XXXXXXX, + KC_LCTL, KC_LGUI, KC_LALT, KC_DEL, MO(_SYM), KC_SPC, MO(_NUM), KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT + ), + // yellow + [_MEDIA] = LAYOUT_planck_mit( + KC_ESC, RGB_TOG, XXXXXXX, XXXXXXX, KC_PSCR, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_BSPC, + KC_TAB, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_MUTE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_ENT, + KC_LSFT, XXXXXXX, XXXXXXX, XXXXXXX, KC_MPLY, KC_VOLD, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, + KC_LCTL, KC_LGUI, KC_LALT, KC_DEL, MO(_SYM), KC_SPC, MO(_NUM), KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT + ) +}; + +// https://github.com/qmk/qmk_firmware/blob/master/docs/mod_tap.md#changing-hold-function +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + switch (keycode) { + // "Tap and Hold" + case LT(_BASE,KC_X): // "LT(_BASE,KC_X)" is the keycode that must be mapped + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X + return false; + } + return true; // Return true for normal processing of tap keycode + case LT(_BASE,DE_Y): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_PIPE); + return false; + } + return true; + case LT(_BASE,KC_C): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_C)); + return false; + } + return true; + case LT(_BASE,KC_V): + if (!record->tap.count && record->event.pressed) { + tap_code16(LCTL(KC_V)); + return false; + } + return true; + case LT(_BASE,KC_Q): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_Q)); + return false; + } + return true; + case LT(_BASE,KC_F): + if (!record->tap.count && record->event.pressed) { + tap_code16(RALT(KC_E)); + return false; + } + return true; + case LT(_BASE,KC_A): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ADIA); + return false; + } + return true; + case LT(_BASE,KC_O): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_ODIA); + return false; + } + return true; + case LT(_BASE,KC_U): + if (!record->tap.count && record->event.pressed) { + tap_code16(DE_UDIA); + return false; + } + return true; + } + return true; +} diff --git a/keyboards/planck/keymaps/quotengrote/rules.mk b/keyboards/planck/keymaps/quotengrote/rules.mk new file mode 100644 index 0000000000..dc68f099de --- /dev/null +++ b/keyboards/planck/keymaps/quotengrote/rules.mk @@ -0,0 +1,4 @@ +CAPS_WORD_ENABLE = yes +AUTO_SHIFT_ENABLE = yes +COMBO_ENABLE = yes +RGB_MATRIX_ENABLE = yes |