diff options
Diffstat (limited to 'keyboards/planck/keymaps/quotengrote/keymap.c')
| -rw-r--r-- | keyboards/planck/keymaps/quotengrote/keymap.c | 232 |
1 files changed, 232 insertions, 0 deletions
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; +} |