aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJon Olsson <jon.olsson@gmail.com>2018-09-01 18:23:10 +0200
committerDrashna Jaelre <drashna@live.com>2018-09-01 09:23:10 -0700
commit8eb674b257147efa4ba7829fb294254497aec7c6 (patch)
tree111e0d454c836bc016b68a4a8ecfa7a20092dbbf
parentdedffb5f6dcf3519f787692aca69851cb4049708 (diff)
downloadqmk_firmware-8eb674b257147efa4ba7829fb294254497aec7c6.tar.gz
qmk_firmware-8eb674b257147efa4ba7829fb294254497aec7c6.zip
Keymap: Nojjan atreus (#3822)
* Add support for my Falbatech Atreus This is currently the default Atreus keyboard layout, but I will eventually customize it to match my Ergodox layout. * Address review comments * More review comments fixed * More review comments fixed
-rw-r--r--keyboards/atreus/keymaps/nojjan/config.h10
-rw-r--r--keyboards/atreus/keymaps/nojjan/keymap.c61
2 files changed, 71 insertions, 0 deletions
diff --git a/keyboards/atreus/keymaps/nojjan/config.h b/keyboards/atreus/keymaps/nojjan/config.h
new file mode 100644
index 000000000..90b7c4a6c
--- /dev/null
+++ b/keyboards/atreus/keymaps/nojjan/config.h
@@ -0,0 +1,10 @@
1#pragma once
2
3#undef MATRIX_ROW_PINS
4#undef MATRIX_COL_PINS
5#undef UNUSED_PINS
6
7// Pin configuration for falbatech atreus
8#define MATRIX_ROW_PINS { D0, D1, D3, D2 }
9#define MATRIX_COL_PINS { D7, C6, B5, B4, E6, D4, B6, F6, F7, D6, B7 }
10#define UNUSED_PINS
diff --git a/keyboards/atreus/keymaps/nojjan/keymap.c b/keyboards/atreus/keymaps/nojjan/keymap.c
new file mode 100644
index 000000000..8f56e5746
--- /dev/null
+++ b/keyboards/atreus/keymaps/nojjan/keymap.c
@@ -0,0 +1,61 @@
1// this is the style you want to emulate.
2// This is the canonical layout file for the Quantum project. If you want to add another keyboard,
3
4#include QMK_KEYBOARD_H
5
6// Each layer gets a name for readability, which is then used in the keymap matrix below.
7// The underscores don't mean anything - you can have a layer called STUFF or any other name.
8// Layer names don't all need to be of the same length, obviously, and you can also skip them
9// entirely and just use numbers.
10#define _QW 0
11#define _RS 1
12#define _LW 2
13
14const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
15[_QW] = LAYOUT( /* Qwerty */
16 KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P ,
17 KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN ,
18 KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH ,
19 KC_ESC, KC_TAB, KC_LGUI, KC_LSFT, KC_BSPC, KC_LCTL, KC_LALT, KC_SPC, MO(_RS), KC_MINS, KC_QUOT, KC_ENT ),
20/*
21 * ! @ up { } || pgup 7 8 9 *
22 * # left down right $ || pgdn 4 5 6 +
23 * [ ] ( ) & || ` 1 2 3 \
24 * lower insert super shift bksp ctrl || alt space fn . 0 =
25 */
26[_RS] = LAYOUT( /* [> RAISE <] */
27 KC_EXLM, KC_AT, KC_UP, KC_LCBR, KC_RCBR, KC_PGUP, KC_7, KC_8, KC_9, KC_ASTR ,
28 KC_HASH, KC_LEFT, KC_DOWN, KC_RGHT, KC_DLR, KC_PGDN, KC_4, KC_5, KC_6, KC_PLUS ,
29 KC_LBRC, KC_RBRC, KC_LPRN, KC_RPRN, KC_AMPR, KC_GRV, KC_1, KC_2, KC_3, KC_BSLS ,
30 TG(_LW), KC_INS, KC_LGUI, KC_LSFT, KC_BSPC, KC_LCTL, KC_LALT, KC_SPC, KC_TRNS, KC_DOT, KC_0, KC_EQL ),
31/*
32 * insert home up end pgup || up F7 F8 F9 F10
33 * del left down right pgdn || down F4 F5 F6 F11
34 * volup reset || F1 F2 F3 F12
35 * voldn super shift bksp ctrl || alt space L0 prtsc scroll pause
36 */
37[_LW] = LAYOUT( /* [> LOWER <] */
38 KC_INS, KC_HOME, KC_UP, KC_END, KC_PGUP, KC_UP, KC_F7, KC_F8, KC_F9, KC_F10 ,
39 KC_DELT, KC_LEFT, KC_DOWN, KC_RGHT, KC_DOWN, KC_DOWN, KC_F4, KC_F5, KC_F6, KC_F11 ,
40 KC_NO, KC_VOLU, KC_NO, KC_NO, RESET, KC_NO, KC_F1, KC_F2, KC_F3, KC_F12 ,
41 KC_NO, KC_VOLD, KC_LGUI, KC_LSFT, KC_BSPC, KC_LCTL, KC_LALT, KC_SPC, TO(_QW), KC_PSCR, KC_SLCK, KC_PAUS )
42};
43
44const uint16_t PROGMEM fn_actions[] = {
45
46};
47
48const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
49{
50 // MACRODOWN only works in this function
51 switch(id) {
52 case 0:
53 if (record->event.pressed) {
54 register_code(KC_RSFT);
55 } else {
56 unregister_code(KC_RSFT);
57 }
58 break;
59 }
60 return MACRO_NONE;
61};