diff options
| -rw-r--r-- | keyboards/atreus62/atreus62.h | 4 | ||||
| -rw-r--r-- | keyboards/atreus62/keymaps/atreus52/Makefile | 4 | ||||
| -rw-r--r-- | keyboards/atreus62/keymaps/atreus52/README.md | 10 | ||||
| -rw-r--r-- | keyboards/atreus62/keymaps/atreus52/config.h | 18 | ||||
| -rw-r--r-- | keyboards/atreus62/keymaps/atreus52/keymap.c | 99 |
5 files changed, 133 insertions, 2 deletions
diff --git a/keyboards/atreus62/atreus62.h b/keyboards/atreus62/atreus62.h index ca5cda8a8..d0bf68adc 100644 --- a/keyboards/atreus62/atreus62.h +++ b/keyboards/atreus62/atreus62.h | |||
| @@ -35,8 +35,8 @@ void promicro_bootloader_jmp(bool program); | |||
| 35 | { KC_##k00, KC_##k01, KC_##k02, KC_##k03, KC_##k04, KC_##k05, KC_NO, KC_##k06, KC_##k07, KC_##k08, KC_##k09, KC_##k0a, KC_##k0b }, \ | 35 | { KC_##k00, KC_##k01, KC_##k02, KC_##k03, KC_##k04, KC_##k05, KC_NO, KC_##k06, KC_##k07, KC_##k08, KC_##k09, KC_##k0a, KC_##k0b }, \ |
| 36 | { KC_##k10, KC_##k11, KC_##k12, KC_##k13, KC_##k14, KC_##k15, KC_NO, KC_##k16, KC_##k17, KC_##k18, KC_##k19, KC_##k1a, KC_##k1b }, \ | 36 | { KC_##k10, KC_##k11, KC_##k12, KC_##k13, KC_##k14, KC_##k15, KC_NO, KC_##k16, KC_##k17, KC_##k18, KC_##k19, KC_##k1a, KC_##k1b }, \ |
| 37 | { KC_##k20, KC_##k21, KC_##k22, KC_##k23, KC_##k24, KC_##k25, KC_NO, KC_##k26, KC_##k27, KC_##k28, KC_##k29, KC_##k2a, KC_##k2b }, \ | 37 | { KC_##k20, KC_##k21, KC_##k22, KC_##k23, KC_##k24, KC_##k25, KC_NO, KC_##k26, KC_##k27, KC_##k28, KC_##k29, KC_##k2a, KC_##k2b }, \ |
| 38 | { KC_##k30, KC_##k31, KC_##k32, KC_##k33, KC_##k34, KC_##k35, KC_##k46, KC_##k36, KC_##k37, KC_##k38, KC_##k39, KC_##k3a, KC_##k3b }, \ | 38 | { KC_##k30, KC_##k31, KC_##k32, KC_##k33, KC_##k34, KC_##k35, KC_##k47, KC_##k36, KC_##k37, KC_##k38, KC_##k39, KC_##k3a, KC_##k3b }, \ |
| 39 | { KC_##k40, KC_##k41, KC_##k42, KC_##k43, KC_##k44, KC_##k45, KC_##k47, KC_##k48, KC_##k49, KC_##k4a, KC_##k4b, KC_##k4c, KC_##k4d } \ | 39 | { KC_##k40, KC_##k41, KC_##k42, KC_##k43, KC_##k44, KC_##k45, KC_##k46, KC_##k48, KC_##k49, KC_##k4a, KC_##k4b, KC_##k4c, KC_##k4d } \ |
| 40 | } | 40 | } |
| 41 | 41 | ||
| 42 | #endif | 42 | #endif |
diff --git a/keyboards/atreus62/keymaps/atreus52/Makefile b/keyboards/atreus62/keymaps/atreus52/Makefile new file mode 100644 index 000000000..efa309d20 --- /dev/null +++ b/keyboards/atreus62/keymaps/atreus52/Makefile | |||
| @@ -0,0 +1,4 @@ | |||
| 1 | NKRO_ENABLE = true | ||
| 2 | MOUSEKEY_ENABLE = no | ||
| 3 | EXTRAKEY_ENABLE = yes | ||
| 4 | CONSOLE_ENABLE = no | ||
diff --git a/keyboards/atreus62/keymaps/atreus52/README.md b/keyboards/atreus62/keymaps/atreus52/README.md new file mode 100644 index 000000000..245df7deb --- /dev/null +++ b/keyboards/atreus62/keymaps/atreus52/README.md | |||
| @@ -0,0 +1,10 @@ | |||
| 1 | <!-- -*- mode: markdown; fill-column: 8192 -*- --> | ||
| 2 | |||
| 3 | Atreus52 Modification | ||
| 4 | ======================= | ||
| 5 | |||
| 6 | Firmware for my custom keyboard based on the Atreus layout, but with 5 rows and only 5 columns per hand. | ||
| 7 | More documentation coming soon. | ||
| 8 | |||
| 9 | # License | ||
| 10 | GPL-3+ | ||
diff --git a/keyboards/atreus62/keymaps/atreus52/config.h b/keyboards/atreus62/keymaps/atreus52/config.h new file mode 100644 index 000000000..ba0eaf0db --- /dev/null +++ b/keyboards/atreus62/keymaps/atreus52/config.h | |||
| @@ -0,0 +1,18 @@ | |||
| 1 | #include "../../config.h" | ||
| 2 | |||
| 3 | #undef MANUFACTURER | ||
| 4 | #undef PRODUCT | ||
| 5 | #undef DESCRIPTION | ||
| 6 | #undef MATRIX_ROW_PINS | ||
| 7 | #undef MATRIX_COL_PINS | ||
| 8 | #undef DIODE_DIRECTION | ||
| 9 | |||
| 10 | /* USB Device descriptor parameter */ | ||
| 11 | #define MANUFACTURER Mesh Industries | ||
| 12 | #define PRODUCT Atreus52 Treeboard | ||
| 13 | #define DESCRIPTION q.m.k. keyboard firmware for Atreus52 | ||
| 14 | |||
| 15 | #define MATRIX_ROW_PINS { C6, D7, E6, B4, B5 } | ||
| 16 | #define MATRIX_COL_PINS { B2, B1, F7, F6, F5, F4, B6, D3, D2, D1, D0, D4, B3 } | ||
| 17 | |||
| 18 | #define DIODE_DIRECTION COL2ROW | ||
diff --git a/keyboards/atreus62/keymaps/atreus52/keymap.c b/keyboards/atreus62/keymaps/atreus52/keymap.c new file mode 100644 index 000000000..4adfb9e3c --- /dev/null +++ b/keyboards/atreus62/keymaps/atreus52/keymap.c | |||
| @@ -0,0 +1,99 @@ | |||
| 1 | #include "atreus62.h" | ||
| 2 | |||
| 3 | // Layers | ||
| 4 | #define DVORAK 0 | ||
| 5 | #define QWERTY 1 | ||
| 6 | #define RAISE 2 | ||
| 7 | #define LOWER 3 | ||
| 8 | #define BDO 4 | ||
| 9 | #define RESETL 5 | ||
| 10 | |||
| 11 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 12 | [DVORAK] = KC_KEYMAP( | ||
| 13 | NO, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, NO, \ | ||
| 14 | NO, QUOT, COMM, DOT, P, Y, F, G, C, R, L, NO, \ | ||
| 15 | NO, A, O, E, U, I, D, H, T, N, S, NO, \ | ||
| 16 | NO, SCLN, Q, J, K, X, B, M, W, V, Z, NO, \ | ||
| 17 | NO, FN2, LALT, LCTL, FN1, LSFT, BSPC, ENT, SPC, FN0, LGUI, LEFT, RGHT, NO ), | ||
| 18 | |||
| 19 | [QWERTY] = KC_KEYMAP( | ||
| 20 | NO, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, NO, \ | ||
| 21 | NO, Q, W, E, R, T, Y, U, I, O, P, NO, \ | ||
| 22 | NO, A, S, D, F, G, H, J, K, L, SCLN, NO, \ | ||
| 23 | NO, Z, X, C, V, B, N, M, COMM, DOT, SLSH, NO, \ | ||
| 24 | NO, FN2, LALT, LCTL, FN1, LSFT, BSPC, ENT, SPC, FN0, LGUI, LEFT, RGHT, NO ), | ||
| 25 | |||
| 26 | [RAISE] = KC_KEYMAP( | ||
| 27 | NO, MRWD, MPRV, MPLY, MNXT, MFFD, TRNS, MUTE, VOLD, VOLU, DEL, NO, \ | ||
| 28 | NO, TILD, GRV, LCBR, RCBR, DQUO, QUOT, EQL, PLUS, MINS, QUES, NO, \ | ||
| 29 | NO, ESC, TAB, LPRN, RPRN, BSLS, SLSH, LEFT, DOWN, UP, RGHT, NO, \ | ||
| 30 | NO, TRNS, TRNS, LBRC, RBRC, TRNS, INS, PIPE, UNDS, TRNS, TRNS, NO, \ | ||
| 31 | NO, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, FN3, NO ), | ||
| 32 | |||
| 33 | [LOWER] = KC_KEYMAP( | ||
| 34 | NO, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, NO, \ | ||
| 35 | NO, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, NO, \ | ||
| 36 | NO, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, NO, \ | ||
| 37 | NO, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, DOT, TRNS, TRNS, TRNS, NO, \ | ||
| 38 | NO, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, TRNS, NO ), | ||
| 39 | |||
| 40 | [BDO] = KC_KEYMAP( | ||
| 41 | NO, ESC, 1, 2, 3, 4, 5, 0, SLSH, U, C, NO, \ | ||
| 42 | NO, TAB, Q, W, E, R, 6, Y, I, O, P, NO, \ | ||
| 43 | NO, LSFT, A, S, D, F, 7, G, H, J, K, NO, \ | ||
| 44 | NO, T, Z, X, C, V, 8, B, N, M, L, NO, \ | ||
| 45 | NO, LCTL, SPC, SPC, SPC, SPC, COMM, ENT, 9, NO, NO, NO, FN2, NO ), | ||
| 46 | |||
| 47 | [RESETL] = KEYMAP( | ||
| 48 | KC_NO, RESET, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, \ | ||
| 49 | KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, \ | ||
| 50 | KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, \ | ||
| 51 | KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, \ | ||
| 52 | KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_NO, KC_FN3,KC_NO ) | ||
| 53 | |||
| 54 | }; | ||
| 55 | |||
| 56 | const uint16_t PROGMEM fn_actions[] = { | ||
| 57 | [0] = ACTION_LAYER_MOMENTARY(RAISE), // Raise layer | ||
| 58 | [1] = ACTION_LAYER_MOMENTARY(LOWER), // Lower layer | ||
| 59 | [2] = ACTION_LAYER_TOGGLE(BDO), // BDO layer | ||
| 60 | [3] = ACTION_LAYER_TOGGLE(RESETL) // RESET layer | ||
| 61 | }; | ||
| 62 | |||
| 63 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | ||
| 64 | { | ||
| 65 | // MACRODOWN only works in this function | ||
| 66 | switch (id) { | ||
| 67 | case 0: | ||
| 68 | if (record->event.pressed) { | ||
| 69 | register_code(KC_RSFT); | ||
| 70 | } | ||
| 71 | else { | ||
| 72 | unregister_code(KC_RSFT); | ||
| 73 | } | ||
| 74 | break; | ||
| 75 | } | ||
| 76 | return MACRO_NONE; | ||
| 77 | }; | ||
| 78 | |||
| 79 | static uint8_t qw_dv_swap_state = 0; | ||
| 80 | |||
| 81 | bool process_record_user (uint16_t keycode, keyrecord_t *record) { | ||
| 82 | if (keycode == KC_LGUI) { | ||
| 83 | if (record->event.pressed) | ||
| 84 | qw_dv_swap_state |= 0b00000001; | ||
| 85 | else | ||
| 86 | qw_dv_swap_state &= ~(0b00000001); | ||
| 87 | } | ||
| 88 | if (keycode == KC_LCTL) { | ||
| 89 | if (record->event.pressed) | ||
| 90 | qw_dv_swap_state |= 0b00000010; | ||
| 91 | else | ||
| 92 | qw_dv_swap_state &= ~(0b00000010); | ||
| 93 | } | ||
| 94 | |||
| 95 | if (qw_dv_swap_state == 0b00000011) { | ||
| 96 | layer_invert(DVORAK); | ||
| 97 | } | ||
| 98 | return true; | ||
| 99 | } | ||
