ff
This commit is contained in:
parent
2a55f202c5
commit
d2ca761b31
2 changed files with 49 additions and 39 deletions
|
@ -1,6 +1,16 @@
|
||||||
#include QMK_KEYBOARD_H
|
#include QMK_KEYBOARD_H
|
||||||
#include "keymap_german.h"
|
#include "keymap_german.h"
|
||||||
|
|
||||||
|
// layers
|
||||||
|
enum layers {
|
||||||
|
_BASE,
|
||||||
|
_NUM,
|
||||||
|
_SYM,
|
||||||
|
_MOV,
|
||||||
|
_MEDIA
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// rgb
|
// rgb
|
||||||
void keyboard_post_init_user(void) {
|
void keyboard_post_init_user(void) {
|
||||||
rgblight_enable_noeeprom(); // Enables RGB, without saving settings
|
rgblight_enable_noeeprom(); // Enables RGB, without saving settings
|
||||||
|
@ -94,20 +104,20 @@ enum combos {
|
||||||
C_WE // Windows Explorer
|
C_WE // Windows Explorer
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint16_t PROGMEM alt_combo[] = {LCTL_T(KC_E), KC_I, COMBO_END};
|
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 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 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 esc_combo[] = {LCTL_T(KC_S), LSFT_T(KC_T), COMBO_END};
|
||||||
const uint16_t PROGMEM med_combo[] = {LT(3, KC_DEL), MO(3), 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(0,KC_C), 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(0,KC_W), LCTL_T(KC_E), COMBO_END};
|
const uint16_t PROGMEM we_combo[] = {LT(_BASE,KC_W), LCTL_T(KC_E), COMBO_END};
|
||||||
|
|
||||||
combo_t key_combos[] = {
|
combo_t key_combos[] = {
|
||||||
[C_ALT] = COMBO(alt_combo, KC_LALT),
|
[C_ALT] = COMBO(alt_combo, KC_LALT),
|
||||||
[C_KA] = COMBO(ka_combo, LCTL(LALT(KC_A))),
|
[C_KA] = COMBO(ka_combo, LCTL(LALT(KC_A))),
|
||||||
[C_KK] = COMBO(kk_combo, LCTL(LALT(KC_K))),
|
[C_KK] = COMBO(kk_combo, LCTL(LALT(KC_K))),
|
||||||
[C_ESC] = COMBO(esc_combo, KC_ESC),
|
[C_ESC] = COMBO(esc_combo, KC_ESC),
|
||||||
[C_MED] = COMBO(med_combo, MO(4)),
|
[C_MED] = COMBO(med_combo, MO(_MEDIA)),
|
||||||
[C_SV] = COMBO(sv_combo, LCTL(KC_S)),
|
[C_SV] = COMBO(sv_combo, LCTL(KC_S)),
|
||||||
[C_WE] = COMBO(we_combo, LGUI(KC_E)),
|
[C_WE] = COMBO(we_combo, LGUI(KC_E)),
|
||||||
};
|
};
|
||||||
|
@ -115,35 +125,35 @@ combo_t key_combos[] = {
|
||||||
// keymap
|
// keymap
|
||||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
// Buchstaben - white
|
// Buchstaben - white
|
||||||
[0] = LAYOUT_split_3x5_3(
|
[_BASE] = LAYOUT_split_3x5_3(
|
||||||
LT(0,KC_Q), LT(0,KC_W), LT(0,KC_F), KC_P, KC_B, KC_J, KC_L, LT(0,KC_U), DE_Z, KC_BSPC,
|
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(0,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(0,KC_O),
|
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(0,DE_Y), LT(0,KC_X), LT(0,KC_C), LSFT_T(KC_D), LT(0,KC_V), KC_K, LSFT_T(KC_H), DE_COMM, DE_DOT, DE_MINS,
|
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(3, KC_DEL), LT(2, KC_ENT), LT(1, KC_SPC), MO(3), XXXXXXX
|
XXXXXXX, LT(_MOV, KC_DEL), LT(_SYM, KC_ENT), LT(_NUM, KC_SPC), MO(_MOV), XXXXXXX
|
||||||
),
|
),
|
||||||
// Zahlen - orange
|
// Zahlen - orange
|
||||||
[1] = LAYOUT_split_3x5_3(
|
[_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_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,
|
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,
|
QK_CAPS_WORD_TOGGLE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_F10, KC_F11, _______, _______, KC_F12,
|
||||||
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
||||||
),
|
),
|
||||||
// Sym - blue
|
// Sym - blue
|
||||||
[2] = LAYOUT_split_3x5_3(
|
[_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_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_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,
|
DE_TILD, DE_ACUT, XXXXXXX, LSFT(DE_ACUT), DE_LABK , DE_RABK , XXXXXXX, DE_PLUS, DE_EQL, DE_HASH,
|
||||||
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
||||||
),
|
),
|
||||||
// Move - green
|
// Move - green
|
||||||
[3] = LAYOUT_split_3x5_3(
|
[_MOV] = LAYOUT_split_3x5_3(
|
||||||
XXXXXXX, KC_HOME, KC_UP, KC_PGUP, XXXXXXX, XXXXXXX, KC_PGUP, KC_UP, KC_HOME, KC_BSPC,
|
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,
|
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, KC_END, KC_PGDN, XXXXXXX, XXXXXXX, XXXXXXX, KC_PGDN, XXXXXXX, KC_END, XXXXXXX,
|
||||||
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
XXXXXXX, _______, _______, _______, _______, XXXXXXX
|
||||||
),
|
),
|
||||||
// Media - yellow
|
// Media - yellow
|
||||||
[4] = LAYOUT_split_3x5_3(
|
[_MEDIA] = LAYOUT_split_3x5_3(
|
||||||
RGB_TOG, XXXXXXX, XXXXXXX, KC_PSCR, KC_VOLU, KC_VOLU, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
|
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, 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, XXXXXXX, KC_MPLY, KC_VOLD, KC_VOLD, KC_MPLY, XXXXXXX, XXXXXXX, XXXXXXX,
|
||||||
|
@ -155,61 +165,61 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
||||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||||
switch (keycode) {
|
switch (keycode) {
|
||||||
// "Tap and Hold"
|
// "Tap and Hold"
|
||||||
case LT(0,KC_X): // "LT(0,KC_X)" is the keycode that must be mapped
|
case LT(_BASE,KC_X): // "LT(_BASE,KC_X)" is the keycode that must be mapped
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X
|
tap_code16(LCTL(KC_X)); // Intercept hold function to send Ctrl-X
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true; // Return true for normal processing of tap keycode
|
return true; // Return true for normal processing of tap keycode
|
||||||
case LT(0,DE_Y):
|
case LT(_BASE,DE_Y):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(DE_PIPE);
|
tap_code16(DE_PIPE);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_C):
|
case LT(_BASE,KC_C):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(LCTL(KC_C));
|
tap_code16(LCTL(KC_C));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_V):
|
case LT(_BASE,KC_V):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(LCTL(KC_V));
|
tap_code16(LCTL(KC_V));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_Q):
|
case LT(_BASE,KC_Q):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(RALT(KC_Q));
|
tap_code16(RALT(KC_Q));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_F):
|
case LT(_BASE,KC_F):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(RALT(KC_E));
|
tap_code16(RALT(KC_E));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_A):
|
case LT(_BASE,KC_A):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(DE_ADIA);
|
tap_code16(DE_ADIA);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_O):
|
case LT(_BASE,KC_O):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(DE_ODIA);
|
tap_code16(DE_ODIA);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_U):
|
case LT(_BASE,KC_U):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(DE_UDIA);
|
tap_code16(DE_UDIA);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
case LT(0,KC_W):
|
case LT(_BASE,KC_W):
|
||||||
if (!record->tap.count && record->event.pressed) {
|
if (!record->tap.count && record->event.pressed) {
|
||||||
tap_code16(KC_LGUI);
|
tap_code16(KC_LGUI);
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -21,13 +21,13 @@ enum combos {
|
||||||
C_WE // Windows Explorer
|
C_WE // Windows Explorer
|
||||||
};
|
};
|
||||||
|
|
||||||
const uint16_t PROGMEM alt_combo[] = {LCTL_T(KC_E), KC_I, COMBO_END};
|
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 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 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 esc_combo[] = {LCTL_T(KC_S), LSFT_T(KC_T), COMBO_END};
|
||||||
const uint16_t PROGMEM med_combo[] = {LT(3, KC_DEL), MO(3), 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 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};
|
const uint16_t PROGMEM we_combo[] = {LT(_BASE,KC_W), LCTL_T(KC_E), COMBO_END};
|
||||||
|
|
||||||
combo_t key_combos[] = {
|
combo_t key_combos[] = {
|
||||||
[C_ALT] = COMBO(alt_combo, KC_LALT),
|
[C_ALT] = COMBO(alt_combo, KC_LALT),
|
||||||
|
|
Loading…
Reference in a new issue