diff options
107 files changed, 4038 insertions, 662 deletions
diff --git a/.travis.yml b/.travis.yml index b206d1451..18ecde7e3 100644 --- a/.travis.yml +++ b/.travis.yml | |||
| @@ -5,12 +5,10 @@ language: c | |||
| 5 | branches: | 5 | branches: |
| 6 | except: | 6 | except: |
| 7 | - /^.*-automated-build$/ | 7 | - /^.*-automated-build$/ |
| 8 | - /^[0-9]+\.[0-9]+\.[0-9]+/ | ||
| 8 | env: | 9 | env: |
| 9 | global: | 10 | global: |
| 10 | - secure: vBTSL34BDPxDilKUuTXqU4CJ26Pv5hogD2nghatkxSQkI1/jbdnLj/DQdPUrMJFDIY6TK3AltsBx72MaMsLQ1JO/Ou24IeHINHXzUC1FlS9yQa48cpxnhX5kzXNyGs3oa0qaFbvnr7RgYRWtmD52n4bIZuSuW+xpBv05x2OCizdT2ZonH33nATaHGFasxROm4qYZ241VfzcUv766V6RVHgL4x9V08warugs+RENVkfzxxwhk3NmkrISabze0gSVJLHBPHxroZC6EUcf/ocobcuDrCwFqtEt90i7pNIAFUE7gZsN2uE75LmpzAWin21G7lLPcPL2k4FJVd8an1HiP2WmscJU6U89fOfMb2viObnKcCzebozBCmKGtHEuXZo9FcReOx49AnQSpmESJGs+q2dL/FApkTjQiyT4J6O5dJpoww0/r57Wx0cmmqjETKBb5rSgXM51Etk3wO09mvcPHsEwrT7qH8r9XWdyCDoEn7FCLX3/LYnf/D4SmZ633YPl5gv3v9XEwxR5+04akjgnvWDSNIaDbWBdxHNb7l4pMc+WR1bwCyMyA7KXj0RrftEGOrm9ZRLe6BkbT4cycA+j77nbPOMcyZChliV9pPQos+4TOJoTzcK2L8yWVoY409aDNVuAjdP6Yum0R2maBGl/etLmIMpJC35C5/lZ+dUNjJAM= | 11 | - secure: vBTSL34BDPxDilKUuTXqU4CJ26Pv5hogD2nghatkxSQkI1/jbdnLj/DQdPUrMJFDIY6TK3AltsBx72MaMsLQ1JO/Ou24IeHINHXzUC1FlS9yQa48cpxnhX5kzXNyGs3oa0qaFbvnr7RgYRWtmD52n4bIZuSuW+xpBv05x2OCizdT2ZonH33nATaHGFasxROm4qYZ241VfzcUv766V6RVHgL4x9V08warugs+RENVkfzxxwhk3NmkrISabze0gSVJLHBPHxroZC6EUcf/ocobcuDrCwFqtEt90i7pNIAFUE7gZsN2uE75LmpzAWin21G7lLPcPL2k4FJVd8an1HiP2WmscJU6U89fOfMb2viObnKcCzebozBCmKGtHEuXZo9FcReOx49AnQSpmESJGs+q2dL/FApkTjQiyT4J6O5dJpoww0/r57Wx0cmmqjETKBb5rSgXM51Etk3wO09mvcPHsEwrT7qH8r9XWdyCDoEn7FCLX3/LYnf/D4SmZ633YPl5gv3v9XEwxR5+04akjgnvWDSNIaDbWBdxHNb7l4pMc+WR1bwCyMyA7KXj0RrftEGOrm9ZRLe6BkbT4cycA+j77nbPOMcyZChliV9pPQos+4TOJoTzcK2L8yWVoY409aDNVuAjdP6Yum0R2maBGl/etLmIMpJC35C5/lZ+dUNjJAM= |
| 11 | matrix: | ||
| 12 | - TARGET=all-keyboards AUTOGEN=true | ||
| 13 | - TARGET=test AUTOGEN=false | ||
| 14 | before_install: | 12 | before_install: |
| 15 | - wget http://www.atmel.com/images/avr8-gnu-toolchain-3.5.4.1709-linux.any.x86_64.tar.gz | 13 | - wget http://www.atmel.com/images/avr8-gnu-toolchain-3.5.4.1709-linux.any.x86_64.tar.gz |
| 16 | install: | 14 | install: |
| @@ -19,7 +17,8 @@ install: | |||
| 19 | before_script: | 17 | before_script: |
| 20 | - avr-gcc --version | 18 | - avr-gcc --version |
| 21 | script: | 19 | script: |
| 22 | - make $TARGET AUTOGEN=$AUTOGEN | 20 | - make test AUTOGEN=false |
| 21 | - bash util/travis_build.sh | ||
| 23 | addons: | 22 | addons: |
| 24 | apt: | 23 | apt: |
| 25 | packages: | 24 | packages: |
| @@ -30,6 +29,4 @@ addons: | |||
| 30 | - libnewlib-arm-none-eabi | 29 | - libnewlib-arm-none-eabi |
| 31 | - diffutils | 30 | - diffutils |
| 32 | after_success: | 31 | after_success: |
| 33 | if [ "$AUTOGEN" == "true" ]; then | 32 | bash util/travis_compiled_push.sh |
| 34 | bash util/travis_compiled_push.sh; | ||
| 35 | fi | ||
diff --git a/build_keyboard.mk b/build_keyboard.mk index b85557d4a..2c64e93a2 100644 --- a/build_keyboard.mk +++ b/build_keyboard.mk | |||
| @@ -144,6 +144,11 @@ ifeq ($(strip $(MIDI_ENABLE)), yes) | |||
| 144 | SRC += $(QUANTUM_DIR)/process_keycode/process_midi.c | 144 | SRC += $(QUANTUM_DIR)/process_keycode/process_midi.c |
| 145 | endif | 145 | endif |
| 146 | 146 | ||
| 147 | ifeq ($(strip $(COMBO_ENABLE)), yes) | ||
| 148 | OPT_DEFS += -DCOMBO_ENABLE | ||
| 149 | SRC += $(QUANTUM_DIR)/process_keycode/process_combo.c | ||
| 150 | endif | ||
| 151 | |||
| 147 | ifeq ($(strip $(VIRTSER_ENABLE)), yes) | 152 | ifeq ($(strip $(VIRTSER_ENABLE)), yes) |
| 148 | OPT_DEFS += -DVIRTSER_ENABLE | 153 | OPT_DEFS += -DVIRTSER_ENABLE |
| 149 | endif | 154 | endif |
diff --git a/keyboards/atreus62/keymaps/mneme/README.md b/keyboards/atreus62/keymaps/mneme/README.md index 04ab070be..7bb5da9fc 100644 --- a/keyboards/atreus62/keymaps/mneme/README.md +++ b/keyboards/atreus62/keymaps/mneme/README.md | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | <!-- -*- mode: markdown; fill-column: 8192 -*- --> | 1 | <!-- -*- mode: markdown; fill-column: 8192 -*- --> |
| 2 | 2 | ||
| 3 | Mnemes Swedish Bonaza | 3 | Mnemes Swedish Bonanza |
| 4 | ======================= | 4 | ======================= |
| 5 | 5 | ||
| 6 | My Layout in process, most of the code is shamelessly stolen from [algernons][algernon] excellent layout | 6 | My Layout in process, most of the code is shamelessly stolen from [algernons][algernon] excellent layout |
| @@ -33,6 +33,8 @@ It's for Windows (current work forces me to) and Swedish (matter of birth) so ym | |||
| 33 | - `LEAD s l` : `λ`. | 33 | - `LEAD s l` : `λ`. |
| 34 | - `LEAD s s` : `¯\_(ツ)_/¯` | 34 | - `LEAD s s` : `¯\_(ツ)_/¯` |
| 35 | - `LEAD s f` : `凸(ツ)凸` | 35 | - `LEAD s f` : `凸(ツ)凸` |
| 36 | - `LEAD u l` : Set unicode input mode to linux. | ||
| 37 | - `LEAD s w` : Set unicode input mode to windows. | ||
| 36 | - `LEAD a *` : Application switching based on position in start menu. Very specific to my computer. | 38 | - `LEAD a *` : Application switching based on position in start menu. Very specific to my computer. |
| 37 | 39 | ||
| 38 | 40 | ||
| @@ -42,7 +44,7 @@ It's for Windows (current work forces me to) and Swedish (matter of birth) so ym | |||
| 42 | 44 | ||
| 43 | Basic navigation on the right hand and modifiers close | 45 | Basic navigation on the right hand and modifiers close |
| 44 | by for the left. The latter because I tend to use `ctrl+arrows` quite a lot. | 46 | by for the left. The latter because I tend to use `ctrl+arrows` quite a lot. |
| 45 | 47 | ||
| 46 | ## Sym layer | 48 | ## Sym layer |
| 47 | 49 | ||
| 48 |  | 50 |  |
diff --git a/keyboards/atreus62/keymaps/mneme/config.h b/keyboards/atreus62/keymaps/mneme/config.h index 2c2a08c05..73eb0fa33 100644 --- a/keyboards/atreus62/keymaps/mneme/config.h +++ b/keyboards/atreus62/keymaps/mneme/config.h | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | #define ONESHOT_TIMEOUT 3000 | 1 | #define ONESHOT_TIMEOUT 3000 |
| 2 | #define TAPPING_TERM 200 | 2 | #define TAPPING_TERM 200 |
| 3 | #define PREVENT_STUCK_MODIFIERS | 3 | #define PREVENT_STUCK_MODIFIERS |
| 4 | 4 | #define FORCE_NKRO | |
| 5 | #define LEADER_TIMEOUT 1000 | 5 | #define LEADER_TIMEOUT 1000 |
| 6 | 6 | ||
| 7 | #include "../../config.h" | 7 | #include "../../config.h" |
diff --git a/keyboards/atreus62/keymaps/mneme/img/base.png b/keyboards/atreus62/keymaps/mneme/img/base.png index 86907d544..3e77a5183 100644 --- a/keyboards/atreus62/keymaps/mneme/img/base.png +++ b/keyboards/atreus62/keymaps/mneme/img/base.png | |||
| Binary files differ | |||
diff --git a/keyboards/atreus62/keymaps/mneme/img/fun.png b/keyboards/atreus62/keymaps/mneme/img/fun.png index ec5a478c6..961a19724 100644 --- a/keyboards/atreus62/keymaps/mneme/img/fun.png +++ b/keyboards/atreus62/keymaps/mneme/img/fun.png | |||
| Binary files differ | |||
diff --git a/keyboards/atreus62/keymaps/mneme/img/sym.png b/keyboards/atreus62/keymaps/mneme/img/sym.png index 11b5bd4b0..5e2c80335 100644 --- a/keyboards/atreus62/keymaps/mneme/img/sym.png +++ b/keyboards/atreus62/keymaps/mneme/img/sym.png | |||
| Binary files differ | |||
diff --git a/keyboards/atreus62/keymaps/mneme/keymap.c b/keyboards/atreus62/keymaps/mneme/keymap.c index 7c1879982..2627e024f 100644 --- a/keyboards/atreus62/keymaps/mneme/keymap.c +++ b/keyboards/atreus62/keymaps/mneme/keymap.c | |||
| @@ -7,43 +7,47 @@ | |||
| 7 | /* | 7 | /* |
| 8 | *WINDOWS SWEDISH | 8 | *WINDOWS SWEDISH |
| 9 | */ | 9 | */ |
| 10 | #define KN_HALF KC_GRV // 1/2 | 10 | /* |
| 11 | #define KN_PLUS KC_MINS // + | 11 | *WINDOWS SWEDISH |
| 12 | #define KN_ACUT KC_EQL // ´ | 12 | */ |
| 13 | #define KN_AO KC_LBRC // Ã… | 13 | #define KN_HALF KC_GRV // 1/2 |
| 14 | #define KN_UMLA KC_RBRC // ¨ | 14 | #define KN_PLUS KC_MINS // + |
| 15 | #define KN_OE KC_SCLN // Ö | 15 | #define KN_ACUT KC_EQL // ´ |
| 16 | #define KN_AE KC_QUOT // Ä | 16 | #define KN_AO KC_LBRC // Å |
| 17 | #define KN_QUOT KC_NUHS // ' | 17 | #define KN_UMLA KC_RBRC // ¨ |
| 18 | #define KN_LABK KC_NUBS // < | 18 | #define KN_OE KC_SCLN // Ö |
| 19 | #define KN_MINS KC_SLSH // - | 19 | #define KN_AE KC_QUOT // Ä |
| 20 | #define KN_EXLM LSFT(KC_1) // ! | 20 | #define KN_QUOT KC_NUHS // ' |
| 21 | #define KN_DQT LSFT(KC_2) // " | 21 | #define KN_LABK KC_NUBS // < |
| 22 | #define KN_AT RALT(KC_2) // @ | 22 | #define KN_MINS KC_SLSH // - |
| 23 | #define KN_HASH LSFT(KC_3) // # | 23 | #define KN_EXLM LSFT(KC_1) // ! |
| 24 | #define KN_DLR RALT(KC_4) // $ | 24 | #define KN_DQT LSFT(KC_2) // " |
| 25 | #define KN_PERC LSFT(KC_5) // % | 25 | #define KN_AT RALT(KC_2) // @ |
| 26 | #define KN_AMPR LSFT(KC_6) // & | 26 | #define KN_HASH LSFT(KC_3) // # |
| 27 | #define KN_SLSH LSFT(KC_7) // / | 27 | #define KN_EUR LSFT(KC_4) // € |
| 28 | #define KN_LPRN LSFT(KC_8) // ( | 28 | #define KN_DLR RALT(KC_4) // $ |
| 29 | #define KN_RPRN LSFT(KC_9) // ) | 29 | #define KN_PERC LSFT(KC_5) // % |
| 30 | #define KN_EQL LSFT(KC_0) // = | 30 | #define KN_AMPR LSFT(KC_6) // & |
| 31 | #define KN_UNDS LSFT(KN_MINS) // _ | 31 | #define KN_SLSH LSFT(KC_7) // / |
| 32 | #define KN_QUES LSFT(KN_PLUS) // ? | 32 | #define KN_LPRN LSFT(KC_8) // ( |
| 33 | #define KN_GRAV LSFT(KN_ACUT) // ` | 33 | #define KN_RPRN LSFT(KC_9) // ) |
| 34 | #define KN_LCBR RALT(KC_7) // { | 34 | #define KN_EQL LSFT(KC_0) // = |
| 35 | #define KN_RCBR RALT(KC_0) // } | 35 | #define KN_UNDS LSFT(KN_MINS) // _ |
| 36 | #define KN_LBRC RALT(KC_8) // [ | 36 | #define KN_QUES LSFT(KN_PLUS) // ? |
| 37 | #define KN_RBRC RALT(KC_9) // ] | 37 | #define KN_GRAV LSFT(KN_ACUT) // ` |
| 38 | #define KN_RABK LSFT(KN_LABK) // < | 38 | #define KN_LCBR RALT(KC_7) // { |
| 39 | #define KN_COLN LSFT(KC_DOT) // : | 39 | #define KN_RCBR RALT(KC_0) // } |
| 40 | #define KN_SCLN LSFT(KC_COMM) // : | 40 | #define KN_LBRC RALT(KC_8) // [ |
| 41 | #define KN_PIPE RALT(KN_LABK) // | | 41 | #define KN_RBRC RALT(KC_9) // ] |
| 42 | #define KN_QUES LSFT(KN_PLUS) // ? | 42 | #define KN_RABK LSFT(KN_LABK) // < |
| 43 | #define KN_CIRC LSFT(KN_UMLA) // ^ | 43 | #define KN_COLN LSFT(KC_DOT) // : |
| 44 | #define KN_ASTR LSFT(KN_QUOT) // * | 44 | #define KN_SCLN LSFT(KC_COMM) // : |
| 45 | #define KN_TILD RALT(KN_UMLA) // ~ | 45 | #define KN_PIPE RALT(KN_LABK) // | |
| 46 | #define KN_BSLS RALT(KN_PLUS) // | 46 | #define KN_QUES LSFT(KN_PLUS) // ? |
| 47 | #define KN_CIRC LSFT(KN_UMLA) // ^ | ||
| 48 | #define KN_ASTR LSFT(KN_QUOT) // * | ||
| 49 | #define KN_TILD RALT(KN_UMLA) // ~ | ||
| 50 | #define KN_BSLS RALT(KN_PLUS) // | ||
| 47 | 51 | ||
| 48 | #define OSM_LCTL OSM(MOD_LCTL) | 52 | #define OSM_LCTL OSM(MOD_LCTL) |
| 49 | #define OSM_LALT OSM(MOD_LALT) | 53 | #define OSM_LALT OSM(MOD_LALT) |
| @@ -85,32 +89,26 @@ enum { | |||
| 85 | TD_EQ | 89 | TD_EQ |
| 86 | }; | 90 | }; |
| 87 | 91 | ||
| 88 | //Custom keycodes | ||
| 89 | enum { | ||
| 90 | PLACEHOLDER = SAFE_RANGE | ||
| 91 | }; | ||
| 92 | |||
| 93 | //State and timers | 92 | //State and timers |
| 94 | uint16_t kf_timers[12]; | 93 | uint16_t kf_timers[12]; |
| 95 | 94 | ||
| 96 | 95 | ||
| 97 | |||
| 98 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 96 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
| 99 | 97 | ||
| 100 | [BASE] = { | 98 | [BASE] = { |
| 101 | 99 | ||
| 102 | { M(KF_11) ,M(KF_1) ,M(KF_2) ,M(KF_3) ,M(KF_4) ,M(KF_5) ,KC_NO ,M(KF_6) ,M(KF_7) ,M(KF_8) ,M(KF_9) ,M(KF_10) ,M(KF_12) }, | 100 | { M(KF_11) ,M(KF_1) ,M(KF_2) ,M(KF_3) ,M(KF_4) ,M(KF_5) ,KC_NO ,M(KF_6) ,M(KF_7) ,M(KF_8) ,M(KF_9) ,M(KF_10) ,M(KF_12) }, |
| 103 | { KC_TAB ,KC_Q ,KC_W ,KC_E ,KC_R ,KC_T ,KC_NO ,KC_Y ,KC_U ,KC_I ,KC_O ,KC_P ,KN_AO }, | 101 | { KC_TAB ,KC_Q ,KC_W ,KC_E ,KC_R ,KC_T ,KC_NO ,KC_Y ,KC_U ,KC_I ,KC_O ,KC_P ,KN_AO }, |
| 104 | { OSM_LCTL ,KC_A ,KC_S ,KC_D ,KC_F ,KC_G ,KC_NO ,KC_H ,KC_J ,KC_K ,KC_L ,KN_OE ,KN_AE }, | 102 | { OSM_LCTL ,KC_A ,KC_S ,KC_D ,KC_F ,KC_G ,KC_NO ,KC_H ,KC_J ,KC_K ,KC_L ,KN_OE ,KN_AE }, |
| 105 | { OSM_LSFT ,KC_Z ,KC_X ,KC_C ,KC_V ,KC_B ,KC_DELT ,KC_N ,KC_M ,KC_COMM ,KC_DOT ,KN_MINS ,OSM_LSFT }, | 103 | { OSM_LSFT ,KC_Z ,KC_X ,KC_C ,KC_V ,KC_B ,KC_DELT ,KC_N ,KC_M ,KC_COMM ,KC_DOT ,KN_MINS ,OSM_LSFT }, |
| 106 | { MO(NAV) ,OSM_LCTL ,OSM_LALT ,KC_LGUI ,KC_SPC ,LT(SYM,KC_BSPC) ,KC_HYP ,LT(SYM,KC_ENT) ,KC_SPC ,KC_LEAD ,KC_LALT ,KC_LCTRL ,MO(NAV) } | 104 | { MO(NAV) ,OSM_LCTL ,OSM_LALT ,KC_LGUI ,MO(SYM) ,KC_BSPC ,KC_ENT ,KC_SPC ,MO(SYM) ,KC_LEAD ,KC_LALT ,KC_LCTRL ,KC_HYP } |
| 107 | 105 | ||
| 108 | }, | 106 | }, |
| 109 | [NAV] = { | 107 | [NAV] = { |
| 110 | 108 | ||
| 111 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, | 109 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, |
| 112 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_NO ,KC_PGUP ,KC_HOME ,KC_UP ,KC_END ,KC_TRNS ,KC_TRNS }, | 110 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_NO ,KC_HOME ,KC_PGDN ,KC_PGUP ,KC_END ,KC_TRNS ,KC_TRNS }, |
| 113 | { KC_TRNS ,KC_LSFT ,KC_LCTL ,KC_LALT ,KC_L ,KC_TRNS ,KC_NO ,KC_PGDN ,KC_LEFT ,KC_DOWN ,KC_RIGHT ,KC_TRNS ,KC_TRNS }, | 111 | { KC_TRNS ,KC_LSFT ,KC_LCTL ,KC_LALT ,KC_L ,KC_TRNS ,KC_NO ,KC_LEFT ,KC_DOWN ,KC_UP ,KC_RIGHT ,KC_TRNS ,KC_TRNS }, |
| 114 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, | 112 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, |
| 115 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_VOLD ,KC_VOLU } | 113 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_VOLD ,KC_VOLU } |
| 116 | 114 | ||
| @@ -119,8 +117,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 119 | 117 | ||
| 120 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,TD(TD_EQ) ,KC_NO ,TD(TD_FUN) ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, | 118 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,TD(TD_EQ) ,KC_NO ,TD(TD_FUN) ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS }, |
| 121 | { KC_TRNS ,KN_LABK ,KN_RABK ,KN_LCBR ,KN_RCBR ,KN_PLUS ,KC_NO ,KN_AT ,KN_DQT ,KN_QUOT ,KN_GRAV ,KN_SLSH ,KC_TRNS }, | 119 | { KC_TRNS ,KN_LABK ,KN_RABK ,KN_LCBR ,KN_RCBR ,KN_PLUS ,KC_NO ,KN_AT ,KN_DQT ,KN_QUOT ,KN_GRAV ,KN_SLSH ,KC_TRNS }, |
| 122 | { KC_TRNS ,KN_EXLM ,KN_EQL ,KN_LPRN ,KN_RPRN ,KN_MINS ,KC_NO ,KN_UNDS ,KN_SCLN ,KN_COLN ,KN_AMPR ,KN_PIPE ,KC_TRNS }, | 120 | { KC_TRNS ,KN_EXLM ,KN_EQL ,KN_LPRN ,KN_RPRN ,KN_MINS ,KC_NO ,KN_UNDS ,KN_CIRC ,KN_DLR ,KN_AMPR ,KN_PIPE ,KC_TRNS }, |
| 123 | { KC_TRNS ,KN_DLR ,KN_PERC ,KN_LBRC ,KN_RBRC ,KN_ASTR ,KC_TRNS ,KN_HASH ,KC_COMM ,KC_DOT ,KN_QUES ,KN_BSLS ,KC_TRNS }, | 121 | { KC_TRNS ,KN_EUR ,KN_PERC ,KN_LBRC ,KN_RBRC ,KN_ASTR ,KC_TRNS ,KN_HASH ,KN_SCLN ,KN_COLN ,KN_QUES ,KN_BSLS ,KC_TRNS }, |
| 124 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS } | 122 | { KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS ,KC_TRNS } |
| 125 | 123 | ||
| 126 | } | 124 | } |
| @@ -302,6 +300,15 @@ void matrix_scan_user(void) { | |||
| 302 | register_code (KC_LGUI); TAP_ONCE (KC_7); unregister_code (KC_LGUI); | 300 | register_code (KC_LGUI); TAP_ONCE (KC_7); unregister_code (KC_LGUI); |
| 303 | } | 301 | } |
| 304 | 302 | ||
| 303 | SEQ_TWO_KEYS (KC_U, KC_L) { | ||
| 304 | set_unicode_input_mode(UC_LNX); | ||
| 305 | } | ||
| 306 | |||
| 307 | |||
| 308 | SEQ_TWO_KEYS (KC_U, KC_W) { | ||
| 309 | set_unicode_input_mode(UC_WINC); | ||
| 310 | } | ||
| 311 | |||
| 305 | 312 | ||
| 306 | SEQ_TWO_KEYS (KC_S, KC_S) { | 313 | SEQ_TWO_KEYS (KC_S, KC_S) { |
| 307 | // ¯\_(ツ)_/¯ | 314 | // ¯\_(ツ)_/¯ |
diff --git a/keyboards/ergodox/keymaps/ab/readme.md b/keyboards/ergodox/keymaps/ab/readme.md index 62e08e162..4ad80efe6 100644 --- a/keyboards/ergodox/keymaps/ab/readme.md +++ b/keyboards/ergodox/keymaps/ab/readme.md | |||
| @@ -8,7 +8,7 @@ Beginner's keymap emulates standard QWERTY keyboard for beginners. Once you get | |||
| 8 | * Easy on beginners. It has everything you need for your day to day usage. | 8 | * Easy on beginners. It has everything you need for your day to day usage. |
| 9 | 9 | ||
| 10 | #### Cons | 10 | #### Cons |
| 11 | * Keys are not ergonomically placed to take full advantage of Ergodox-EZ. Take a look at this [Default Keymap](https://github.com/qmk/qmk_firmware/blob/master/keyboards/ergodox_ez/keymaps/default/readme.md) | 11 | * Keys are not ergonomically placed to take full advantage of Ergodox-EZ. Take a look at this [Default Keymap](https://github.com/qmk/qmk_firmware/blob/master/keyboards/ergodox/keymaps/default/readme.md) |
| 12 | * While multiple layers are possible, beginner's keymap only uses one additional layer for mouse, function and volume keys. | 12 | * While multiple layers are possible, beginner's keymap only uses one additional layer for mouse, function and volume keys. |
| 13 | 13 | ||
| 14 | #### Notes | 14 | #### Notes |
diff --git a/keyboards/ergodox/keymaps/ordinary/keymap.c b/keyboards/ergodox/keymaps/ordinary/keymap.c index 302c41cc8..5c01d9678 100644 --- a/keyboards/ergodox/keymaps/ordinary/keymap.c +++ b/keyboards/ergodox/keymaps/ordinary/keymap.c | |||
| @@ -1,5 +1,6 @@ | |||
| 1 | #include "ergodox.h" | 1 | #include "ergodox.h" |
| 2 | #include "led.h" | 2 | #include "led.h" |
| 3 | #include "mousekey.h" | ||
| 3 | #include "debug.h" | 4 | #include "debug.h" |
| 4 | #include "action_layer.h" | 5 | #include "action_layer.h" |
| 5 | #include "action_util.h" | 6 | #include "action_util.h" |
diff --git a/keyboards/ergodox/keymaps/robot_test_layout/keymap.c b/keyboards/ergodox/keymaps/robot_test_layout/keymap.c index 480be177f..e9e2597d7 100644 --- a/keyboards/ergodox/keymaps/robot_test_layout/keymap.c +++ b/keyboards/ergodox/keymaps/robot_test_layout/keymap.c | |||
| @@ -68,7 +68,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 68 | case RGB_FF0000: | 68 | case RGB_FF0000: |
| 69 | if (record->event.pressed) { | 69 | if (record->event.pressed) { |
| 70 | #ifdef RGBLIGHT_ENABLE | 70 | #ifdef RGBLIGHT_ENABLE |
| 71 | EZ_RGB(0xff0000); | 71 | EZ_RGB(0xff0000UL); |
| 72 | register_code(KC_1); unregister_code(KC_1); | 72 | register_code(KC_1); unregister_code(KC_1); |
| 73 | #endif | 73 | #endif |
| 74 | } | 74 | } |
| @@ -77,7 +77,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 77 | case RGB_00FF00: | 77 | case RGB_00FF00: |
| 78 | if (record->event.pressed) { | 78 | if (record->event.pressed) { |
| 79 | #ifdef RGBLIGHT_ENABLE | 79 | #ifdef RGBLIGHT_ENABLE |
| 80 | EZ_RGB(0x00ff00); | 80 | EZ_RGB(0x00ff00UL); |
| 81 | register_code(KC_2); unregister_code(KC_2); | 81 | register_code(KC_2); unregister_code(KC_2); |
| 82 | #endif | 82 | #endif |
| 83 | } | 83 | } |
| @@ -86,7 +86,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 86 | case RGB_0000FF: | 86 | case RGB_0000FF: |
| 87 | if (record->event.pressed) { | 87 | if (record->event.pressed) { |
| 88 | #ifdef RGBLIGHT_ENABLE | 88 | #ifdef RGBLIGHT_ENABLE |
| 89 | EZ_RGB(0x0000ff); | 89 | EZ_RGB(0x0000ffUL); |
| 90 | register_code(KC_3); unregister_code(KC_3); | 90 | register_code(KC_3); unregister_code(KC_3); |
| 91 | #endif | 91 | #endif |
| 92 | } | 92 | } |
| @@ -95,7 +95,7 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 95 | case RGB_FFFFFF: | 95 | case RGB_FFFFFF: |
| 96 | if (record->event.pressed) { | 96 | if (record->event.pressed) { |
| 97 | #ifdef RGBLIGHT_ENABLE | 97 | #ifdef RGBLIGHT_ENABLE |
| 98 | EZ_RGB(0xffffff); | 98 | EZ_RGB(0xffffffUL); |
| 99 | register_code(KC_4); unregister_code(KC_4); | 99 | register_code(KC_4); unregister_code(KC_4); |
| 100 | #endif | 100 | #endif |
| 101 | } | 101 | } |
diff --git a/keyboards/gonnerd/Makefile b/keyboards/gonnerd/Makefile new file mode 100644 index 000000000..57b2ef62e --- /dev/null +++ b/keyboards/gonnerd/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef MAKEFILE_INCLUDED | ||
| 2 | include ../../Makefile | ||
| 3 | endif | ||
diff --git a/keyboards/gonnerd/config.h b/keyboards/gonnerd/config.h new file mode 100644 index 000000000..cad8fe586 --- /dev/null +++ b/keyboards/gonnerd/config.h | |||
| @@ -0,0 +1,43 @@ | |||
| 1 | #ifndef CONFIG_H | ||
| 2 | #define CONFIG_H | ||
| 3 | |||
| 4 | #include "config_common.h" | ||
| 5 | |||
| 6 | /* USB Device descriptor parameter */ | ||
| 7 | #define VENDOR_ID 0xFEED | ||
| 8 | #define PRODUCT_ID 0x6060 | ||
| 9 | #define DEVICE_VER 0x0001 | ||
| 10 | #define MANUFACTURER GON | ||
| 11 | #define PRODUCT NerD | ||
| 12 | #define DESCRIPTION QMK port for the GON Nerd PCB | ||
| 13 | |||
| 14 | /* key matrix size */ | ||
| 15 | #define MATRIX_ROWS 10 | ||
| 16 | #define MATRIX_COLS 9 | ||
| 17 | |||
| 18 | /* backlight */ | ||
| 19 | #define BACKLIGHT_PIN B7 | ||
| 20 | #define BACKLIGHT_LEVELS 3 | ||
| 21 | |||
| 22 | /* matrix pins */ | ||
| 23 | #define MATRIX_ROW_PINS { B4, E2, F4, F7, F1, F6, C6, F5, D7, C7 } | ||
| 24 | #define MATRIX_COL_PINS { E6, B0, B1, B2, B3, F0, D0, D5, D1 } | ||
| 25 | #define UNUSED_PINS | ||
| 26 | |||
| 27 | /* COL2ROW or ROW2COL */ | ||
| 28 | #define DIODE_DIRECTION COL2ROW | ||
| 29 | |||
| 30 | /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||
| 31 | #define DEBOUNCING_DELAY 5 | ||
| 32 | |||
| 33 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||
| 34 | #define LOCKING_SUPPORT_ENABLE | ||
| 35 | /* Locking resynchronize hack */ | ||
| 36 | #define LOCKING_RESYNC_ENABLE | ||
| 37 | |||
| 38 | /* key combination for magic key command */ | ||
| 39 | #define IS_COMMAND() ( \ | ||
| 40 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||
| 41 | ) | ||
| 42 | |||
| 43 | #endif | ||
diff --git a/keyboards/gonnerd/gonnerd.c b/keyboards/gonnerd/gonnerd.c new file mode 100644 index 000000000..f25d3a85f --- /dev/null +++ b/keyboards/gonnerd/gonnerd.c | |||
| @@ -0,0 +1 @@ | |||
| #include "gonnerd.h" | |||
diff --git a/keyboards/gonnerd/gonnerd.h b/keyboards/gonnerd/gonnerd.h new file mode 100644 index 000000000..e5070328e --- /dev/null +++ b/keyboards/gonnerd/gonnerd.h | |||
| @@ -0,0 +1,42 @@ | |||
| 1 | #ifndef GONNERD_H | ||
| 2 | #define GONNERD_H | ||
| 3 | |||
| 4 | #include "quantum.h" | ||
| 5 | |||
| 6 | #define KEYMAP_TKL( \ | ||
| 7 | K08, K09, K18, K19, K28, K29, K38, K39, K48, K49, K58, K59, K68, K69, K88, K89, \ | ||
| 8 | K00, K01, K10, K11, K20, K21, K30, K31, K40, K41, K50, K51, K60, K61, K80, K81, K84, \ | ||
| 9 | K02, K03, K12, K13, K22, K23, K32, K33, K42, K43, K52, K53, K62, K63, K82, K83, K85, \ | ||
| 10 | K04, K14, K15, K24, K25, K34, K35, K44, K45, K54, K55, K64, K71, K65, \ | ||
| 11 | K07, K79, K16, K17, K26, K27, K36, K37, K46, K47, K56, K57, K66, K67, K86, \ | ||
| 12 | K06, K05, K78, K70, K72, K73, K74, K75, K76, K77, K87 \ | ||
| 13 | ) \ | ||
| 14 | { \ | ||
| 15 | { K00, K10, K20, K30, K40, K50, K60, K70, K80 }, \ | ||
| 16 | { K01, K11, K21, K31, K41, K51, K61, K71, K81 }, \ | ||
| 17 | { K02, K12, K22, K32, K42, K52, K62, K72, K82 }, \ | ||
| 18 | { K03, K13, K23, K33, K43, K53, K63, K73, K83 }, \ | ||
| 19 | { K04, K14, K24, K34, K44, K54, K64, K74, K84 }, \ | ||
| 20 | { K05, K15, K25, K35, K45, K55, K65, K75, K85 }, \ | ||
| 21 | { K06, K16, K26, K36, K46, K56, K66, K76, K86 }, \ | ||
| 22 | { K07, K17, K27, K37, K47, K57, K67, K77, K87 }, \ | ||
| 23 | { K08, K18, K28, K38, K48, K58, K68, K78, K88 }, \ | ||
| 24 | { K09, K19, K29, K39, K49, K59, K69, K79, K89 } \ | ||
| 25 | } | ||
| 26 | |||
| 27 | #define KEYMAP_60( \ | ||
| 28 | K08, K01, K10, K11, K20, K21, K30, K31, K40, K41, K50, K51, K60, K61, \ | ||
| 29 | K02, K03, K12, K13, K22, K23, K32, K33, K42, K43, K52, K53, K62, K63, \ | ||
| 30 | K04, K14, K15, K24, K25, K34, K35, K44, K45, K54, K55, K64, K71, K65, \ | ||
| 31 | K07, K79, K16, K17, K26, K27, K36, K37, K46, K47, K56, K57, K66, K67, \ | ||
| 32 | K06, K05, K78, K70, K72, K73, K74, K75 \ | ||
| 33 | ) KEYMAP_TKL( \ | ||
| 34 | K08, 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_NO, KC_NO, KC_NO, \ | ||
| 35 | KC_NO, K01, K10, K11, K20, K21, K30, K31, K40, K41, K50, K51, K60, K61, KC_NO, KC_NO, KC_NO, \ | ||
| 36 | K02, K03, K12, K13, K22, K23, K32, K33, K42, K43, K52, K53, K62, K63, KC_NO, KC_NO, KC_NO, \ | ||
| 37 | K04, K14, K15, K24, K25, K34, K35, K44, K45, K54, K55, K64, K71, K65, \ | ||
| 38 | K07, K79, K16, K17, K26, K27, K36, K37, K46, K47, K56, K57, K66, K67, KC_NO, \ | ||
| 39 | K06, K05, K78, K70, K72, K73, K74, K75, KC_NO, KC_NO, KC_NO \ | ||
| 40 | ) | ||
| 41 | |||
| 42 | #endif | ||
diff --git a/keyboards/gonnerd/keymaps/default/Makefile b/keyboards/gonnerd/keymaps/default/Makefile new file mode 100644 index 000000000..772d7aee3 --- /dev/null +++ b/keyboards/gonnerd/keymaps/default/Makefile | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | # Build Options | ||
| 2 | # change to "no" to disable the options, or define them in the Makefile in | ||
| 3 | # the appropriate keymap folder that will get included automatically | ||
| 4 | # | ||
| 5 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 6 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 7 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 8 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 9 | COMMAND_ENABLE = yes # Commands for debug and configuration | ||
| 10 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 11 | BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality | ||
| 12 | MIDI_ENABLE = no # MIDI controls | ||
| 13 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 14 | UNICODE_ENABLE = no # Unicode | ||
| 15 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 16 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 17 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 18 | |||
| 19 | ifndef QUANTUM_DIR | ||
| 20 | include ../../../../Makefile | ||
| 21 | endif | ||
diff --git a/keyboards/gonnerd/keymaps/default/keymap.c b/keyboards/gonnerd/keymaps/default/keymap.c new file mode 100644 index 000000000..a37005939 --- /dev/null +++ b/keyboards/gonnerd/keymaps/default/keymap.c | |||
| @@ -0,0 +1,16 @@ | |||
| 1 | #include "gonnerd.h" | ||
| 2 | |||
| 3 | // Keymap layers | ||
| 4 | |||
| 5 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 6 | [0] = KEYMAP_60( /* Base */ | ||
| 7 | KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS,KC_EQL, KC_BSPC,\ | ||
| 8 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC,KC_RBRC,KC_BSLS,\ | ||
| 9 | KC_LCTL,KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN,KC_QUOT,KC_NO, KC_ENT, \ | ||
| 10 | KC_LSFT,KC_NO, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM,KC_DOT, KC_SLSH,KC_RSFT,KC_NO, \ | ||
| 11 | KC_LCTL,KC_LGUI,KC_LALT, KC_SPC, KC_RALT,KC_RGUI,MO(1), KC_RCTL), | ||
| 12 | }; | ||
| 13 | |||
| 14 | const uint16_t PROGMEM fn_actions[] = { | ||
| 15 | |||
| 16 | }; | ||
diff --git a/keyboards/gonnerd/keymaps/mauin/Makefile b/keyboards/gonnerd/keymaps/mauin/Makefile new file mode 100644 index 000000000..772d7aee3 --- /dev/null +++ b/keyboards/gonnerd/keymaps/mauin/Makefile | |||
| @@ -0,0 +1,21 @@ | |||
| 1 | # Build Options | ||
| 2 | # change to "no" to disable the options, or define them in the Makefile in | ||
| 3 | # the appropriate keymap folder that will get included automatically | ||
| 4 | # | ||
| 5 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 6 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 7 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 8 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 9 | COMMAND_ENABLE = yes # Commands for debug and configuration | ||
| 10 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 11 | BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality | ||
| 12 | MIDI_ENABLE = no # MIDI controls | ||
| 13 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 14 | UNICODE_ENABLE = no # Unicode | ||
| 15 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 16 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 17 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 18 | |||
| 19 | ifndef QUANTUM_DIR | ||
| 20 | include ../../../../Makefile | ||
| 21 | endif | ||
diff --git a/keyboards/gonnerd/keymaps/mauin/keymap.c b/keyboards/gonnerd/keymaps/mauin/keymap.c new file mode 100644 index 000000000..1a1d515a9 --- /dev/null +++ b/keyboards/gonnerd/keymaps/mauin/keymap.c | |||
| @@ -0,0 +1,78 @@ | |||
| 1 | #include "gonnerd.h" | ||
| 2 | |||
| 3 | // Keymap layers | ||
| 4 | #define BASE_LAYER 0 | ||
| 5 | #define FUNCTION_LAYER 1 | ||
| 6 | #define SYSTEM_LAYER 2 | ||
| 7 | |||
| 8 | // Key aliases | ||
| 9 | #define __x__ KC_NO | ||
| 10 | |||
| 11 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 12 | /* Layer 0: Default Layer | ||
| 13 | * ,-----------------------------------------------------------. | ||
| 14 | * |Esc| 1| 2| 3| 4| 5| 6| 7| 8| 9| 0| -| = | BSp | | ||
| 15 | * |-----------------------------------------------------------| | ||
| 16 | * |Tab | Q| W| E| R| T| Y| U| I| O| P| [| ]| \| | ||
| 17 | * |-----------------------------------------------------------| | ||
| 18 | * |Funct | A| S| D| F| G| H| J| K| L| ;| '|Enter | | ||
| 19 | * |-----------------------------------------------------------| | ||
| 20 | * |Shift | Z| X| C| V| B| N| M| ,| .| /| Shift | | ||
| 21 | * |-----------------------------------------------------------' | ||
| 22 | * | Ctl|Alt|Gui | Space |Gui |Alt| F2| Ctl | | ||
| 23 | * `-----------------------------------------------------------' | ||
| 24 | */ | ||
| 25 | [BASE_LAYER] = KEYMAP_60( | ||
| 26 | KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, \ | ||
| 27 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, \ | ||
| 28 | MO(1), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, __x__, KC_ENT, \ | ||
| 29 | KC_LSFT, __x__, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, __x__, \ | ||
| 30 | KC_LCTL, KC_LALT, KC_LGUI, KC_SPC, KC_RGUI, KC_RALT, MO(3), KC_RCTL \ | ||
| 31 | ), | ||
| 32 | |||
| 33 | /* Layer 1: Function Layer | ||
| 34 | * ,-----------------------------------------------------------. | ||
| 35 | * | | F1| F2| F3| F4| F5| F6| F7| F8| F9|F10|F11| F12| Del | | ||
| 36 | * |-----------------------------------------------------------| | ||
| 37 | * | |Prv|Ply|Nxt| | |Pg^|Hme|Up |End| |Br-|Br+| | | ||
| 38 | * |-----------------------------------------------------------| | ||
| 39 | * |Hold |Mte|Vl-|Vl+| | |Pgv|Lft|Dwn|Rgt| | | | | ||
| 40 | * |-----------------------------------------------------------| | ||
| 41 | * | | | | | | | | | | | | | | ||
| 42 | * |-----------------------------------------------------------' | ||
| 43 | * | | | | | | | | | | ||
| 44 | * `-----------------------------------------------------------' | ||
| 45 | */ | ||
| 46 | [FUNCTION_LAYER] = KEYMAP_60( | ||
| 47 | KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, \ | ||
| 48 | __x__, KC_MPRV, KC_MPLY, KC_MNXT, __x__, __x__, KC_PGUP, KC_HOME, KC_UP, KC_END, __x__, KC_SLCK, KC_PAUS, __x__, \ | ||
| 49 | KC_TRNS, KC_MUTE, KC_VOLD, KC_VOLU, __x__, __x__, KC_PGDN, KC_LEFT, KC_DOWN, KC_RGHT, __x__, __x__, __x__, __x__, \ | ||
| 50 | KC_LSFT, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, \ | ||
| 51 | KC_LCTL, KC_LALT, KC_LGUI, KC_SPC, __x__, __x__, __x__, __x__ \ | ||
| 52 | ), | ||
| 53 | |||
| 54 | /* Layer 2: System Layer | ||
| 55 | * ,-----------------------------------------------------------. | ||
| 56 | * |Reset| | | | | | | | | | | | | | | ||
| 57 | * |-----------------------------------------------------------| | ||
| 58 | * | | | | | | | | | | | | | | | | ||
| 59 | * |-----------------------------------------------------------| | ||
| 60 | * | | | | | | | | | | | | | | | ||
| 61 | * |-----------------------------------------------------------| | ||
| 62 | * | | | | | | | | | | | | | | ||
| 63 | * |-----------------------------------------------------------' | ||
| 64 | * | | | | | | | | | | ||
| 65 | * `-----------------------------------------------------------' | ||
| 66 | */ | ||
| 67 | [SYSTEM_LAYER] = KEYMAP_60( | ||
| 68 | RESET, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, \ | ||
| 69 | __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, \ | ||
| 70 | __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, \ | ||
| 71 | __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, __x__, \ | ||
| 72 | __x__, __x__, __x__, __x__, __x__, __x__, KC_TRNS, __x__ \ | ||
| 73 | ), | ||
| 74 | }; | ||
| 75 | |||
| 76 | const uint16_t PROGMEM fn_actions[] = { | ||
| 77 | |||
| 78 | }; | ||
diff --git a/keyboards/gonnerd/keymaps/mauin/readme.md b/keyboards/gonnerd/keymaps/mauin/readme.md new file mode 100644 index 000000000..63be7c392 --- /dev/null +++ b/keyboards/gonnerd/keymaps/mauin/readme.md | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | # Mauin's keymap for the GON NerD | ||
| 2 | |||
| 3 | This layout is based on a Pok3r style layout with a standard base layer. | ||
| 4 | |||
| 5 | Function layers provide access to navigation and media keys. | ||
diff --git a/keyboards/gonnerd/readme.md b/keyboards/gonnerd/readme.md new file mode 100644 index 000000000..1224ff6b0 --- /dev/null +++ b/keyboards/gonnerd/readme.md | |||
| @@ -0,0 +1,34 @@ | |||
| 1 | GON NerD keyboard firmware | ||
| 2 | ====================== | ||
| 3 | |||
| 4 | ## Changing Bootloader | ||
| 5 | |||
| 6 | It's not possible to simply flash this firmware on the GON NerD keyboard as the original bootloader does not support DFU connections. | ||
| 7 | |||
| 8 | It is possible to change the bootloader of the GON NerD with an ISP programmer. A guide on how to change the bootloader on your GON NerD can be found here: | ||
| 9 | [Converting NerD60 to TMK](https://deskthority.net/wiki/Converting_NerD60_to_TMK). After changing the bootloader you can flash your QMK keymap onto the keyboard. | ||
| 10 | |||
| 11 | _After changing the bootloader on your GON NerD PCB you will not be able to go back to the original firmware and the official configuration software will | ||
| 12 | not work anymore. You will lose your warranty and official support from GON!_ | ||
| 13 | |||
| 14 | ## Building | ||
| 15 | |||
| 16 | Download or clone the whole firmware and navigate to the keyboards/gonnerd folder. Once your dev env is setup, you'll be able to type `make` to generate your .hex - you can then use the Teensy Loader to program your .hex file. | ||
| 17 | |||
| 18 | Depending on which keymap you would like to use, you will have to compile slightly differently. | ||
| 19 | |||
| 20 | ### Default | ||
| 21 | |||
| 22 | To build with the default keymap, simply run `make default`. | ||
| 23 | |||
| 24 | ### Other Keymaps | ||
| 25 | |||
| 26 | Several version of keymap are available in advance but you are recommended to define your favorite layout yourself. To define your own keymap create a folder with the name of your keymap in the keymaps folder, and see keymap documentation (you can find in top readme.md) and existant keymap files. | ||
| 27 | |||
| 28 | To build the firmware binary hex file with a keymap just do `make` with a keymap like this: | ||
| 29 | |||
| 30 | ``` | ||
| 31 | $ make [default|jack|<name>] | ||
| 32 | ``` | ||
| 33 | |||
| 34 | Keymaps follow the format **__\<name\>.c__** and are stored in the `keymaps` folder. | ||
diff --git a/keyboards/gonnerd/rules.mk b/keyboards/gonnerd/rules.mk new file mode 100644 index 000000000..c9b584d54 --- /dev/null +++ b/keyboards/gonnerd/rules.mk | |||
| @@ -0,0 +1,66 @@ | |||
| 1 | # MCU name | ||
| 2 | MCU = atmega32u4 | ||
| 3 | |||
| 4 | # Processor frequency. | ||
| 5 | # This will define a symbol, F_CPU, in all source code files equal to the | ||
| 6 | # processor frequency in Hz. You can then use this symbol in your source code to | ||
| 7 | # calculate timings. Do NOT tack on a 'UL' at the end, this will be done | ||
| 8 | # automatically to create a 32-bit value in your source code. | ||
| 9 | # | ||
| 10 | # This will be an integer division of F_USB below, as it is sourced by | ||
| 11 | # F_USB after it has run through any CPU prescalers. Note that this value | ||
| 12 | # does not *change* the processor frequency - it should merely be updated to | ||
| 13 | # reflect the processor speed set externally so that the code can use accurate | ||
| 14 | # software delays. | ||
| 15 | F_CPU = 8000000 | ||
| 16 | |||
| 17 | |||
| 18 | # | ||
| 19 | # LUFA specific | ||
| 20 | # | ||
| 21 | # Target architecture (see library "Board Types" documentation). | ||
| 22 | ARCH = AVR8 | ||
| 23 | |||
| 24 | # Input clock frequency. | ||
| 25 | # This will define a symbol, F_USB, in all source code files equal to the | ||
| 26 | # input clock frequency (before any prescaling is performed) in Hz. This value may | ||
| 27 | # differ from F_CPU if prescaling is used on the latter, and is required as the | ||
| 28 | # raw input clock is fed directly to the PLL sections of the AVR for high speed | ||
| 29 | # clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL' | ||
| 30 | # at the end, this will be done automatically to create a 32-bit value in your | ||
| 31 | # source code. | ||
| 32 | # | ||
| 33 | # If no clock division is performed on the input clock inside the AVR (via the | ||
| 34 | # CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU. | ||
| 35 | F_USB = $(F_CPU) | ||
| 36 | |||
| 37 | # Interrupt driven control endpoint task(+60) | ||
| 38 | OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT | ||
| 39 | |||
| 40 | |||
| 41 | # Boot Section Size in *bytes* | ||
| 42 | # Teensy halfKay 512 | ||
| 43 | # Teensy++ halfKay 1024 | ||
| 44 | # Atmel DFU loader 4096 | ||
| 45 | # LUFA bootloader 4096 | ||
| 46 | # USBaspLoader 2048 | ||
| 47 | OPT_DEFS += -DBOOTLOADER_SIZE=4096 | ||
| 48 | |||
| 49 | |||
| 50 | # Build Options | ||
| 51 | # change yes to no to disable | ||
| 52 | # | ||
| 53 | BOOTMAGIC_ENABLE ?= no # Virtual DIP switch configuration(+1000) | ||
| 54 | MOUSEKEY_ENABLE ?= yes # Mouse keys(+4700) | ||
| 55 | EXTRAKEY_ENABLE ?= yes # Audio control and System control(+450) | ||
| 56 | CONSOLE_ENABLE ?= no # Console for debug(+400) | ||
| 57 | COMMAND_ENABLE ?= yes # Commands for debug and configuration | ||
| 58 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||
| 59 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend | ||
| 60 | # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 61 | NKRO_ENABLE ?= no # USB Nkey Rollover | ||
| 62 | BACKLIGHT_ENABLE ?= yes # Enable keyboard backlight functionality on B7 by default | ||
| 63 | MIDI_ENABLE ?= no # MIDI controls | ||
| 64 | UNICODE_ENABLE ?= no # Unicode | ||
| 65 | BLUETOOTH_ENABLE ?= no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 66 | AUDIO_ENABLE ?= no # Audio output on port C6 | ||
diff --git a/keyboards/handwired/onekey/keymaps/default/keymap.c b/keyboards/handwired/onekey/keymaps/default/keymap.c index 756c4f51e..10c486718 100644 --- a/keyboards/handwired/onekey/keymaps/default/keymap.c +++ b/keyboards/handwired/onekey/keymaps/default/keymap.c | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | #include "onekey.h" | 1 | #include "onekey.h" |
| 2 | 2 | ||
| 3 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 3 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
| 4 | { KC_A } | 4 | {{ KC_A }} |
| 5 | }; | 5 | }; |
diff --git a/keyboards/handwired/promethium/config.h b/keyboards/handwired/promethium/config.h index 23fbfd0b9..fd45c2bfe 100644 --- a/keyboards/handwired/promethium/config.h +++ b/keyboards/handwired/promethium/config.h | |||
| @@ -43,38 +43,107 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 43 | #define MATRIX_ROW_PINS { D7, C6, D0, D1, F5, F4, F1, F0 } | 43 | #define MATRIX_ROW_PINS { D7, C6, D0, D1, F5, F4, F1, F0 } |
| 44 | #define UNUSED_PINS | 44 | #define UNUSED_PINS |
| 45 | 45 | ||
| 46 | /* COL2ROW or ROW2COL */ | 46 | /* |
| 47 | * Keyboard Matrix Assignments | ||
| 48 | * | ||
| 49 | * Change this to how you wired your keyboard | ||
| 50 | * COLS: AVR pins used for columns, left to right | ||
| 51 | * ROWS: AVR pins used for rows, top to bottom | ||
| 52 | * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||
| 53 | * ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||
| 54 | * | ||
| 55 | */ | ||
| 47 | #define DIODE_DIRECTION COL2ROW | 56 | #define DIODE_DIRECTION COL2ROW |
| 48 | 57 | ||
| 49 | /* define if matrix has ghost */ | 58 | // #define BACKLIGHT_PIN B7 |
| 59 | // #define BACKLIGHT_BREATHING | ||
| 60 | // #define BACKLIGHT_LEVELS 3 | ||
| 61 | |||
| 62 | /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||
| 63 | #define DEBOUNCING_DELAY 5 | ||
| 64 | |||
| 65 | /* define if matrix has ghost (lacks anti-ghosting diodes) */ | ||
| 50 | //#define MATRIX_HAS_GHOST | 66 | //#define MATRIX_HAS_GHOST |
| 51 | 67 | ||
| 52 | /* number of backlight levels */ | 68 | /* number of backlight levels */ |
| 53 | #define BACKLIGHT_LEVELS 3 | ||
| 54 | |||
| 55 | /* Set 0 if debouncing isn't needed */ | ||
| 56 | #define DEBOUNCING_DELAY 5 | ||
| 57 | 69 | ||
| 58 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | 70 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ |
| 59 | #define LOCKING_SUPPORT_ENABLE | 71 | // #define LOCKING_SUPPORT_ENABLE |
| 60 | /* Locking resynchronize hack */ | 72 | /* Locking resynchronize hack */ |
| 61 | #define LOCKING_RESYNC_ENABLE | 73 | // #define LOCKING_RESYNC_ENABLE |
| 74 | |||
| 75 | /* | ||
| 76 | * Force NKRO | ||
| 77 | * | ||
| 78 | * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||
| 79 | * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||
| 80 | * makefile for this to work.) | ||
| 81 | * | ||
| 82 | * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||
| 83 | * until the next keyboard reset. | ||
| 84 | * | ||
| 85 | * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||
| 86 | * fully operational during normal computer usage. | ||
| 87 | * | ||
| 88 | * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||
| 89 | * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||
| 90 | * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||
| 91 | * power-up. | ||
| 92 | * | ||
| 93 | */ | ||
| 94 | //#define FORCE_NKRO | ||
| 62 | 95 | ||
| 63 | /* key combination for command */ | 96 | /* key combination for command */ |
| 64 | #define IS_COMMAND() ( \ | 97 | #define IS_COMMAND() ( \ |
| 65 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT) | MOD_BIT(KC_LCTRL) | MOD_BIT(KC_RCTRL)) \ | 98 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT) | MOD_BIT(KC_LCTRL) | MOD_BIT(KC_RCTRL)) \ |
| 66 | ) | 99 | ) |
| 67 | 100 | ||
| 101 | /* control how magic key switches layers */ | ||
| 102 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS true | ||
| 103 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS true | ||
| 104 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM false | ||
| 105 | |||
| 106 | /* override magic key keymap */ | ||
| 107 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS | ||
| 108 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS | ||
| 109 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM | ||
| 110 | //#define MAGIC_KEY_HELP1 H | ||
| 111 | //#define MAGIC_KEY_HELP2 SLASH | ||
| 112 | //#define MAGIC_KEY_DEBUG D | ||
| 113 | //#define MAGIC_KEY_DEBUG_MATRIX X | ||
| 114 | //#define MAGIC_KEY_DEBUG_KBD K | ||
| 115 | //#define MAGIC_KEY_DEBUG_MOUSE M | ||
| 116 | //#define MAGIC_KEY_VERSION V | ||
| 117 | //#define MAGIC_KEY_STATUS S | ||
| 118 | //#define MAGIC_KEY_CONSOLE C | ||
| 119 | //#define MAGIC_KEY_LAYER0_ALT1 ESC | ||
| 120 | //#define MAGIC_KEY_LAYER0_ALT2 GRAVE | ||
| 121 | //#define MAGIC_KEY_LAYER0 0 | ||
| 122 | //#define MAGIC_KEY_LAYER1 1 | ||
| 123 | //#define MAGIC_KEY_LAYER2 2 | ||
| 124 | //#define MAGIC_KEY_LAYER3 3 | ||
| 125 | //#define MAGIC_KEY_LAYER4 4 | ||
| 126 | //#define MAGIC_KEY_LAYER5 5 | ||
| 127 | //#define MAGIC_KEY_LAYER6 6 | ||
| 128 | //#define MAGIC_KEY_LAYER7 7 | ||
| 129 | //#define MAGIC_KEY_LAYER8 8 | ||
| 130 | //#define MAGIC_KEY_LAYER9 9 | ||
| 131 | //#define MAGIC_KEY_BOOTLOADER PAUSE | ||
| 132 | //#define MAGIC_KEY_LOCK CAPS | ||
| 133 | //#define MAGIC_KEY_EEPROM E | ||
| 134 | //#define MAGIC_KEY_NKRO N | ||
| 135 | //#define MAGIC_KEY_SLEEP_LED Z | ||
| 136 | |||
| 68 | /* | 137 | /* |
| 69 | * Feature disable options | 138 | * Feature disable options |
| 70 | * These options are also useful to firmware size reduction. | 139 | * These options are also useful to firmware size reduction. |
| 71 | */ | 140 | */ |
| 72 | 141 | ||
| 73 | /* disable debug print */ | 142 | /* disable debug print */ |
| 74 | //#define NO_DEBUG | 143 | // #define NO_DEBUG |
| 75 | 144 | ||
| 76 | /* disable print */ | 145 | /* disable print */ |
| 77 | //#define NO_PRINT | 146 | // #define NO_PRINT |
| 78 | 147 | ||
| 79 | /* disable action features */ | 148 | /* disable action features */ |
| 80 | //#define NO_ACTION_LAYER | 149 | //#define NO_ACTION_LAYER |
diff --git a/keyboards/handwired/promethium/keymaps/priyadi/config.h b/keyboards/handwired/promethium/keymaps/priyadi/config.h index 8b78c0dc4..53059ca7d 100644 --- a/keyboards/handwired/promethium/keymaps/priyadi/config.h +++ b/keyboards/handwired/promethium/keymaps/priyadi/config.h | |||
| @@ -14,4 +14,11 @@ | |||
| 14 | #define RGB_DI_PIN B5 | 14 | #define RGB_DI_PIN B5 |
| 15 | #define RGBSPS_NUM 57 | 15 | #define RGBSPS_NUM 57 |
| 16 | 16 | ||
| 17 | #define LAYOUT_DVORAK | ||
| 18 | #define LAYOUT_COLEMAK | ||
| 19 | #define LAYOUT_NORMAN | ||
| 20 | #define LAYOUT_WORKMAN | ||
| 21 | |||
| 22 | #define DOUBLESPACE_LAYER_ENABLE | ||
| 23 | |||
| 17 | #endif | 24 | #endif |
diff --git a/keyboards/handwired/promethium/keymaps/priyadi/keymap.c b/keyboards/handwired/promethium/keymaps/priyadi/keymap.c index 7ae269563..1ad34612e 100644 --- a/keyboards/handwired/promethium/keymaps/priyadi/keymap.c +++ b/keyboards/handwired/promethium/keymaps/priyadi/keymap.c | |||
| @@ -3,40 +3,75 @@ | |||
| 3 | 3 | ||
| 4 | #include "promethium.h" | 4 | #include "promethium.h" |
| 5 | #include "action_layer.h" | 5 | #include "action_layer.h" |
| 6 | #ifdef AUDIO_ENABLE | ||
| 7 | #include "audio.h" | ||
| 8 | #include "musical_notes.h" | ||
| 9 | #endif | ||
| 10 | #include "eeconfig.h" | 6 | #include "eeconfig.h" |
| 11 | #include "process_unicode.h" | 7 | #include "process_unicode.h" |
| 12 | #include "quantum.h" | 8 | #include "quantum.h" |
| 13 | #include "rgbsps.h" | 9 | #include "rgbsps.h" |
| 14 | #include "ps2_mouse.h" | 10 | #include "ps2_mouse.h" |
| 15 | #include "ps2.h" | 11 | #include "ps2.h" |
| 12 | #include "outputselect.h" | ||
| 13 | #include "led.h" | ||
| 16 | #define COUNT(x) (sizeof (x) / sizeof (*(x))) | 14 | #define COUNT(x) (sizeof (x) / sizeof (*(x))) |
| 17 | 15 | ||
| 18 | // #define RGBLED_NUM 5 | 16 | // Fillers to make layering clearer |
| 19 | // struct cRGB led[RGBLED_NUM]; | 17 | #define _______ KC_TRNS |
| 18 | #define XXXXXXX KC_NO | ||
| 19 | #define G(x) LGUI(x) | ||
| 20 | #define KC_WWWB KC_WWW_BACK | ||
| 21 | #define KC_WWWF KC_WWW_FORWARD | ||
| 22 | |||
| 23 | // hybrid right-alt & scroll lock (mapped to Compose in OS) | ||
| 24 | #undef KC_RALT | ||
| 25 | #define KC_RALT MT(MOD_RALT, KC_SLCK) | ||
| 26 | |||
| 27 | bool capslock = false; | ||
| 28 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 29 | bool lspace_active = false; | ||
| 30 | bool rspace_active = false; | ||
| 31 | bool lspace_emitted = false; | ||
| 32 | bool rspace_emitted = false; | ||
| 33 | bool space_layer_entered = false; | ||
| 34 | #endif | ||
| 20 | 35 | ||
| 36 | // glow | ||
| 37 | enum glow_modes { | ||
| 38 | GLOW_NONE, | ||
| 39 | GLOW_MIN, | ||
| 40 | GLOW_FULL | ||
| 41 | }; | ||
| 42 | uint8_t glow_mode = GLOW_MIN; | ||
| 21 | 43 | ||
| 22 | extern keymap_config_t keymap_config; | 44 | extern keymap_config_t keymap_config; |
| 23 | 45 | ||
| 24 | enum layers { | 46 | enum layers { |
| 25 | _QWERTY, | 47 | _QWERTY, |
| 48 | _DVORAK, | ||
| 26 | _COLEMAK, | 49 | _COLEMAK, |
| 27 | _WORKMAN, | 50 | _WORKMAN, |
| 51 | _NORMAN, | ||
| 52 | |||
| 28 | _PUNC, | 53 | _PUNC, |
| 29 | _NUM, | 54 | _NUM, |
| 30 | _FUNC, | 55 | _FUNC, |
| 56 | |||
| 57 | _GREEKU, | ||
| 58 | _GREEKL, | ||
| 59 | |||
| 31 | _EMOJI, | 60 | _EMOJI, |
| 32 | _GUI, | 61 | _GUI, |
| 62 | _SYS, | ||
| 33 | }; | 63 | }; |
| 34 | 64 | ||
| 65 | // double-space layer | ||
| 66 | #define _SPACE _GUI | ||
| 67 | |||
| 35 | enum planck_keycodes { | 68 | enum planck_keycodes { |
| 36 | // layouts | 69 | // layouts |
| 37 | QWERTY = SAFE_RANGE, | 70 | QWERTY = SAFE_RANGE, |
| 71 | DVORAK, | ||
| 38 | COLEMAK, | 72 | COLEMAK, |
| 39 | WORKMAN, | 73 | WORKMAN, |
| 74 | NORMAN, | ||
| 40 | 75 | ||
| 41 | // layer switchers | 76 | // layer switchers |
| 42 | PUNC, | 77 | PUNC, |
| @@ -44,17 +79,19 @@ enum planck_keycodes { | |||
| 44 | FUNC, | 79 | FUNC, |
| 45 | EMOJI, | 80 | EMOJI, |
| 46 | GUI, | 81 | GUI, |
| 82 | GREEK, | ||
| 47 | 83 | ||
| 48 | // os switchers | 84 | // os switchers |
| 49 | LINUX, | 85 | LINUX, |
| 50 | WIN, | 86 | WIN, |
| 51 | OSX, | 87 | OSX, |
| 52 | }; | ||
| 53 | 88 | ||
| 54 | // Fillers to make layering clearer | 89 | // others |
| 55 | 90 | LSPACE, | |
| 56 | #define _______ KC_TRNS | 91 | RSPACE, |
| 57 | #define XXXXXXX KC_NO | 92 | GLOW, |
| 93 | AUDIO | ||
| 94 | }; | ||
| 58 | 95 | ||
| 59 | // unicode map | 96 | // unicode map |
| 60 | 97 | ||
| @@ -106,6 +143,59 @@ enum unicode_name { | |||
| 106 | SUN, // sun | 143 | SUN, // sun |
| 107 | MOON, // moon | 144 | MOON, // moon |
| 108 | SKULL, // skull | 145 | SKULL, // skull |
| 146 | |||
| 147 | // greek letters | ||
| 148 | UALPH, | ||
| 149 | UBETA, | ||
| 150 | UGAMM, | ||
| 151 | UDELT, | ||
| 152 | UEPSI, | ||
| 153 | UZETA, | ||
| 154 | UETA, | ||
| 155 | UTHET, | ||
| 156 | UIOTA, | ||
| 157 | UKAPP, | ||
| 158 | ULAMB, | ||
| 159 | UMU, | ||
| 160 | UNU, | ||
| 161 | UXI, | ||
| 162 | UOMIC, | ||
| 163 | UPI, | ||
| 164 | URHO, | ||
| 165 | USIGM, | ||
| 166 | UTAU, | ||
| 167 | UUPSI, | ||
| 168 | UPHI, | ||
| 169 | UCHI, | ||
| 170 | UPSI, | ||
| 171 | UOMEG, | ||
| 172 | |||
| 173 | LALPH, | ||
| 174 | LBETA, | ||
| 175 | LGAMM, | ||
| 176 | LDELT, | ||
| 177 | LEPSI, | ||
| 178 | LZETA, | ||
| 179 | LETA, | ||
| 180 | LTHET, | ||
| 181 | LIOTA, | ||
| 182 | LKAPP, | ||
| 183 | LLAMB, | ||
| 184 | LMU, | ||
| 185 | LNU, | ||
| 186 | LXI, | ||
| 187 | LOMIC, | ||
| 188 | LPI, | ||
| 189 | LRHO, | ||
| 190 | LSIGM, | ||
| 191 | LTAU, | ||
| 192 | LUPSI, | ||
| 193 | LPHI, | ||
| 194 | LCHI, | ||
| 195 | LPSI, | ||
| 196 | LOMEG, | ||
| 197 | |||
| 198 | FSIGM, | ||
| 109 | }; | 199 | }; |
| 110 | 200 | ||
| 111 | const uint32_t PROGMEM unicode_map[] = { | 201 | const uint32_t PROGMEM unicode_map[] = { |
| @@ -156,19 +246,58 @@ const uint32_t PROGMEM unicode_map[] = { | |||
| 156 | [SUN] = 0x2600, | 246 | [SUN] = 0x2600, |
| 157 | [MOON] = 0x1F314, | 247 | [MOON] = 0x1F314, |
| 158 | [SKULL] = 0x1F480, | 248 | [SKULL] = 0x1F480, |
| 159 | }; | ||
| 160 | |||
| 161 | 249 | ||
| 162 | // hybrid shift - = | 250 | // greek letters |
| 163 | // #undef KC_LSFT | 251 | [UALPH] = 0x0391, |
| 164 | // #define KC_LSFT MT(MOD_LSFT, KC_MINS) | 252 | [UBETA] = 0x0392, |
| 165 | // #undef KC_RSFT | 253 | [UGAMM] = 0x0393, |
| 166 | // #define KC_RSFT MT(MOD_LSFT, KC_EQL) | 254 | [UDELT] = 0x0394, |
| 167 | 255 | [UEPSI] = 0x0395, | |
| 168 | 256 | [UZETA] = 0x0396, | |
| 169 | // hybrid right-gui & scroll lock (mapped to Compose in OS) | 257 | [UETA] = 0x0397, |
| 170 | #undef KC_RCTL | 258 | [UTHET] = 0x0398, |
| 171 | #define KC_RCTL MT(MOD_LCTL, KC_SLCK) | 259 | [UIOTA] = 0x0399, |
| 260 | [UKAPP] = 0x039A, | ||
| 261 | [ULAMB] = 0x039B, | ||
| 262 | [UMU] = 0x039C, | ||
| 263 | [UNU] = 0x039D, | ||
| 264 | [UXI] = 0x039E, | ||
| 265 | [UOMIC] = 0x039F, | ||
| 266 | [UPI] = 0x03A0, | ||
| 267 | [URHO] = 0x03A1, | ||
| 268 | [USIGM] = 0x03A3, | ||
| 269 | [UTAU] = 0x03A4, | ||
| 270 | [UUPSI] = 0x03A5, | ||
| 271 | [UPHI] = 0x03A6, | ||
| 272 | [UCHI] = 0x03A7, | ||
| 273 | [UPSI] = 0x03A8, | ||
| 274 | [UOMEG] = 0x03A9, | ||
| 275 | [LALPH] = 0x03B1, | ||
| 276 | [LBETA] = 0x03B2, | ||
| 277 | [LGAMM] = 0x03B3, | ||
| 278 | [LDELT] = 0x03B4, | ||
| 279 | [LEPSI] = 0x03B5, | ||
| 280 | [LZETA] = 0x03B6, | ||
| 281 | [LETA] = 0x03B7, | ||
| 282 | [LTHET] = 0x03B8, | ||
| 283 | [LIOTA] = 0x03B9, | ||
| 284 | [LKAPP] = 0x03BA, | ||
| 285 | [LLAMB] = 0x03BB, | ||
| 286 | [LMU] = 0x03BC, | ||
| 287 | [LNU] = 0x03BD, | ||
| 288 | [LXI] = 0x03BE, | ||
| 289 | [LOMIC] = 0x03BF, | ||
| 290 | [LPI] = 0x03C0, | ||
| 291 | [LRHO] = 0x03C1, | ||
| 292 | [LSIGM] = 0x03C3, | ||
| 293 | [LTAU] = 0x03C4, | ||
| 294 | [LUPSI] = 0x03C5, | ||
| 295 | [LPHI] = 0x03C6, | ||
| 296 | [LCHI] = 0x03C7, | ||
| 297 | [LPSI] = 0x03C8, | ||
| 298 | [LOMEG] = 0x03C9, | ||
| 299 | [FSIGM] = 0x03C2, | ||
| 300 | }; | ||
| 172 | 301 | ||
| 173 | // RGBSPS | 302 | // RGBSPS |
| 174 | 303 | ||
| @@ -207,6 +336,17 @@ const uint8_t PROGMEM LED_ALNUM[] = { | |||
| 207 | LED_RSPC | 336 | LED_RSPC |
| 208 | }; | 337 | }; |
| 209 | 338 | ||
| 339 | const uint8_t PROGMEM LED_HOMING[] = { | ||
| 340 | LED_A, | ||
| 341 | LED_S, | ||
| 342 | LED_D, | ||
| 343 | LED_F, | ||
| 344 | LED_J, | ||
| 345 | LED_K, | ||
| 346 | LED_L, | ||
| 347 | LED_SCLN | ||
| 348 | }; | ||
| 349 | |||
| 210 | const uint8_t PROGMEM LED_MODS[] = { | 350 | const uint8_t PROGMEM LED_MODS[] = { |
| 211 | LED_TAB, | 351 | LED_TAB, |
| 212 | LED_ESC, | 352 | LED_ESC, |
| @@ -244,149 +384,105 @@ const uint8_t PROGMEM LED_TRACKPOINT[] = { | |||
| 244 | LED_TRACKPOINT3, | 384 | LED_TRACKPOINT3, |
| 245 | }; | 385 | }; |
| 246 | 386 | ||
| 247 | void led_reset(void) { | 387 | void led_turnoff_keys(void) { |
| 248 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { | 388 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { |
| 249 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 15, 6, 0); | 389 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0); |
| 250 | } | 390 | } |
| 251 | |||
| 252 | for(uint8_t i = 0; i < COUNT(LED_MODS); i++) { | 391 | for(uint8_t i = 0; i < COUNT(LED_MODS); i++) { |
| 253 | rgbsps_set(pgm_read_byte(&LED_MODS[i]), 15, 0, 0); | 392 | rgbsps_set(pgm_read_byte(&LED_MODS[i]), 0, 0, 0); |
| 254 | } | 393 | } |
| 255 | |||
| 256 | for(uint8_t i = 0; i < COUNT(LED_FN); i++) { | 394 | for(uint8_t i = 0; i < COUNT(LED_FN); i++) { |
| 257 | rgbsps_set(pgm_read_byte(&LED_FN[i]), 15, 15, 15); | 395 | rgbsps_set(pgm_read_byte(&LED_FN[i]), 0, 0, 0); |
| 258 | } | 396 | } |
| 259 | } | 397 | } |
| 260 | 398 | ||
| 261 | void led_layer_normal(void) { | 399 | void led_reset(void) { |
| 262 | rgbsps_set(LED_IND_FUNC, 0, 0, 0); | 400 | switch (glow_mode) { |
| 263 | rgbsps_set(LED_IND_NUM, 0, 0, 0); | 401 | case GLOW_NONE: |
| 264 | rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | 402 | led_turnoff_keys(); |
| 265 | 403 | break; | |
| 266 | led_reset(); | 404 | case GLOW_MIN: |
| 267 | 405 | led_turnoff_keys(); | |
| 268 | rgbsps_send(); | 406 | for(uint8_t i = 0; i < COUNT(LED_HOMING); i++) { |
| 269 | } | 407 | rgbsps_set(pgm_read_byte(&LED_HOMING[i]), 8, 8, 8); |
| 270 | 408 | } | |
| 271 | void led_layer_func(void) { | 409 | rgbsps_set(LED_F, 15, 0, 0); |
| 272 | rgbsps_set(LED_IND_FUNC, 0, 15, 0); | 410 | rgbsps_set(LED_J, 15, 0, 0); |
| 273 | rgbsps_set(LED_IND_NUM, 0, 0, 0); | 411 | break; |
| 274 | rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | 412 | case GLOW_FULL: |
| 275 | 413 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { | |
| 276 | led_reset(); | 414 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 8, 8, 8); |
| 277 | 415 | } | |
| 278 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { | 416 | for(uint8_t i = 0; i < COUNT(LED_MODS); i++) { |
| 279 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0); | 417 | rgbsps_set(pgm_read_byte(&LED_MODS[i]), 0, 15, 0); |
| 418 | } | ||
| 419 | for(uint8_t i = 0; i < COUNT(LED_FN); i++) { | ||
| 420 | rgbsps_set(pgm_read_byte(&LED_FN[i]), 0, 0, 15); | ||
| 421 | } | ||
| 422 | for(uint8_t i = 0; i < COUNT(LED_HOMING); i++) { | ||
| 423 | rgbsps_set(pgm_read_byte(&LED_HOMING[i]), 15, 0, 0); | ||
| 424 | } | ||
| 425 | rgbsps_set(LED_F, 15, 15, 0); | ||
| 426 | rgbsps_set(LED_J, 15, 15, 0); | ||
| 427 | break; | ||
| 280 | } | 428 | } |
| 281 | |||
| 282 | rgbsps_set(LED_I, 15, 0, 15); | ||
| 283 | rgbsps_set(LED_J, 15, 0, 15); | ||
| 284 | rgbsps_set(LED_K, 15, 0, 15); | ||
| 285 | rgbsps_set(LED_L, 15, 0, 15); | ||
| 286 | |||
| 287 | rgbsps_set(LED_U, 15, 0, 0); | ||
| 288 | rgbsps_set(LED_O, 15, 0, 0); | ||
| 289 | rgbsps_set(LED_COMM, 15, 0, 0); | ||
| 290 | rgbsps_set(LED_DOT, 15, 0, 0); | ||
| 291 | rgbsps_set(LED_SCLN, 15, 0, 0); | ||
| 292 | rgbsps_set(LED_P, 15, 0, 0); | ||
| 293 | |||
| 294 | rgbsps_set(LED_Q, 0, 15, 0); | ||
| 295 | rgbsps_set(LED_W, 0, 15, 0); | ||
| 296 | rgbsps_set(LED_E, 0, 15, 0); | ||
| 297 | rgbsps_set(LED_R, 0, 15, 0); | ||
| 298 | rgbsps_set(LED_A, 0, 15, 0); | ||
| 299 | rgbsps_set(LED_S, 0, 15, 0); | ||
| 300 | rgbsps_set(LED_D, 0, 15, 0); | ||
| 301 | rgbsps_set(LED_F, 0, 15, 0); | ||
| 302 | rgbsps_set(LED_Z, 0, 15, 0); | ||
| 303 | rgbsps_set(LED_X, 0, 15, 0); | ||
| 304 | rgbsps_set(LED_C, 0, 15, 0); | ||
| 305 | rgbsps_set(LED_V, 0, 15, 0); | ||
| 306 | |||
| 307 | rgbsps_send(); | ||
| 308 | } | 429 | } |
| 309 | 430 | ||
| 310 | void led_layer_punc(void) { | 431 | void led_set_layer_indicator(void) { |
| 311 | rgbsps_set(LED_IND_FUNC, 0, 15, 0); | 432 | static uint8_t oldlayer = 255; |
| 312 | rgbsps_set(LED_IND_NUM, 0, 0, 15); | ||
| 313 | rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | ||
| 314 | |||
| 315 | led_reset(); | ||
| 316 | |||
| 317 | rgbsps_send(); | ||
| 318 | } | ||
| 319 | 433 | ||
| 320 | void led_layer_num(void) { | ||
| 321 | rgbsps_set(LED_IND_FUNC, 0, 0, 0); | 434 | rgbsps_set(LED_IND_FUNC, 0, 0, 0); |
| 322 | rgbsps_set(LED_IND_NUM, 0, 0, 15); | 435 | // rgbsps_set(LED_IND_NUM, 0, 0, 0); |
| 323 | rgbsps_set(LED_IND_EMOJI, 0, 0, 0); | 436 | rgbsps_set(LED_IND_EMOJI, 0, 0, 0); |
| 324 | 437 | ||
| 325 | led_reset(); | 438 | led_reset(); |
| 326 | 439 | ||
| 327 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { | 440 | uint8_t layer = biton32(layer_state); |
| 328 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 0, 0, 0); | 441 | if (oldlayer == layer) { |
| 442 | return; | ||
| 329 | } | 443 | } |
| 330 | 444 | ||
| 331 | rgbsps_set(LED_U, 0, 5, 15); | 445 | oldlayer = layer; |
| 332 | rgbsps_set(LED_I, 0, 5, 15); | ||
| 333 | rgbsps_set(LED_O, 0, 5, 15); | ||
| 334 | rgbsps_set(LED_J, 0, 5, 15); | ||
| 335 | rgbsps_set(LED_K, 0, 5, 15); | ||
| 336 | rgbsps_set(LED_L, 0, 5, 15); | ||
| 337 | rgbsps_set(LED_M, 0, 5, 15); | ||
| 338 | rgbsps_set(LED_COMM, 0, 5, 15); | ||
| 339 | rgbsps_set(LED_DOT, 0, 5, 15); | ||
| 340 | rgbsps_set(LED_FUNC, 0, 5, 15); | ||
| 341 | |||
| 342 | rgbsps_set(LED_EMOJI, 0, 10, 15); | ||
| 343 | rgbsps_set(LED_RALT, 0, 10, 15); | ||
| 344 | |||
| 345 | rgbsps_set(LED_Q, 0, 10, 15); | ||
| 346 | rgbsps_set(LED_W, 0, 10, 15); | ||
| 347 | rgbsps_set(LED_E, 0, 10, 15); | ||
| 348 | rgbsps_set(LED_R, 0, 10, 15); | ||
| 349 | rgbsps_set(LED_T, 0, 10, 15); | ||
| 350 | rgbsps_set(LED_Y, 0, 10, 15); | ||
| 351 | rgbsps_set(LED_P, 0, 10, 15); | ||
| 352 | |||
| 353 | rgbsps_set(LED_A, 0, 15, 15); | ||
| 354 | rgbsps_set(LED_S, 0, 15, 15); | ||
| 355 | rgbsps_set(LED_D, 0, 15, 15); | ||
| 356 | rgbsps_set(LED_F, 0, 15, 15); | ||
| 357 | rgbsps_set(LED_Z, 0, 15, 15); | ||
| 358 | rgbsps_set(LED_X, 0, 15, 15); | ||
| 359 | rgbsps_set(LED_C, 0, 15, 15); | ||
| 360 | rgbsps_set(LED_V, 0, 15, 15); | ||
| 361 | |||
| 362 | rgbsps_send(); | ||
| 363 | } | ||
| 364 | 446 | ||
| 365 | void led_layer_emoji(void) { | 447 | if (layer <= _NORMAN) { |
| 366 | for(uint8_t i = 0; i < COUNT(LED_ALNUM); i++) { | 448 | rgbsps_send(); |
| 367 | rgbsps_set(pgm_read_byte(&LED_ALNUM[i]), 15, 15, 0); | 449 | return; |
| 368 | } | ||
| 369 | for(uint8_t i = 0; i < COUNT(LED_MODS); i++) { | ||
| 370 | rgbsps_set(pgm_read_byte(&LED_MODS[i]), 15, 15, 0); | ||
| 371 | } | 450 | } |
| 372 | for(uint8_t i = 0; i < COUNT(LED_FN); i++) { | 451 | |
| 373 | rgbsps_set(pgm_read_byte(&LED_FN[i]), 15, 15, 0); | 452 | switch(layer) { |
| 453 | case _FUNC: | ||
| 454 | rgbsps_set(LED_IND_FUNC, 15, 0, 0); | ||
| 455 | break; | ||
| 456 | // case _NUM: | ||
| 457 | // rgbsps_set(LED_IND_NUM, 0, 0, 15); | ||
| 458 | // break; | ||
| 459 | case _EMOJI: | ||
| 460 | rgbsps_set(LED_IND_EMOJI, 15, 15, 0); | ||
| 461 | break; | ||
| 462 | default: | ||
| 463 | rgbsps_set(LED_IND_FUNC, 3, 3, 3); | ||
| 464 | rgbsps_set(LED_IND_NUM, 3, 3, 3); | ||
| 465 | rgbsps_set(LED_IND_EMOJI, 3, 3, 3); | ||
| 374 | } | 466 | } |
| 375 | 467 | ||
| 376 | rgbsps_set(LED_IND_FUNC, 0, 0, 0); | 468 | rgbsps_send(); |
| 377 | rgbsps_set(LED_IND_NUM, 0, 0, 0); | 469 | } |
| 378 | rgbsps_set(LED_IND_EMOJI, 15, 15, 0); | ||
| 379 | 470 | ||
| 380 | rgbsps_set(LED_PUNC, 15, 15, 15); | 471 | void led_set_output_ble(void) { |
| 381 | rgbsps_set(LED_EMOJI, 15, 15, 15); | 472 | rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 15); |
| 473 | rgbsps_set(LED_IND_USB, 0, 0, 0); | ||
| 474 | rgbsps_send(); | ||
| 475 | } | ||
| 382 | 476 | ||
| 477 | void led_set_output_usb(void) { | ||
| 478 | rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 0); | ||
| 479 | rgbsps_set(LED_IND_USB, 15, 15, 15); | ||
| 383 | rgbsps_send(); | 480 | rgbsps_send(); |
| 384 | } | 481 | } |
| 385 | 482 | ||
| 386 | void led_layer_gui(void) { | 483 | void led_set_output_none(void) { |
| 387 | rgbsps_set(LED_IND_FUNC, 15, 10, 15); | 484 | rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 0); |
| 388 | rgbsps_set(LED_IND_NUM, 15, 10, 15); | 485 | rgbsps_set(LED_IND_USB, 0, 0, 0); |
| 389 | rgbsps_set(LED_IND_EMOJI, 15, 10, 15); | ||
| 390 | rgbsps_send(); | 486 | rgbsps_send(); |
| 391 | } | 487 | } |
| 392 | 488 | ||
| @@ -398,13 +494,6 @@ void led_init(void) { | |||
| 398 | rgbsps_set(LED_TRACKPOINT1, 15, 0, 0); | 494 | rgbsps_set(LED_TRACKPOINT1, 15, 0, 0); |
| 399 | rgbsps_set(LED_TRACKPOINT2, 0, 0, 15); | 495 | rgbsps_set(LED_TRACKPOINT2, 0, 0, 15); |
| 400 | rgbsps_set(LED_TRACKPOINT3, 15, 0, 0); | 496 | rgbsps_set(LED_TRACKPOINT3, 15, 0, 0); |
| 401 | |||
| 402 | // // hardcode indicator for now | ||
| 403 | rgbsps_set(LED_IND_BLUETOOTH, 0, 0, 15); | ||
| 404 | rgbsps_set(LED_IND_USB, 15, 15, 15); | ||
| 405 | rgbsps_set(LED_IND_BATTERY, 0, 15, 0); | ||
| 406 | |||
| 407 | led_layer_normal(); | ||
| 408 | } | 497 | } |
| 409 | 498 | ||
| 410 | 499 | ||
| @@ -416,20 +505,40 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 416 | * ,-----------------------------------------------------------------------------------. | 505 | * ,-----------------------------------------------------------------------------------. |
| 417 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | | 506 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | |
| 418 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 507 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 419 | * | Esc | A | S | D | F | G | H | J | K | L | ; |Enter | | 508 | * | Esc | A | S | D | F | G | H | J | K | L | ' |Enter | |
| 420 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 509 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 421 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Shift | | 510 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Shift | |
| 422 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 511 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 423 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |AltGr | GUI | Ctrl | | 512 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 424 | * `-----------------------------------------------------------------------------------' | 513 | * `-----------------------------------------------------------------------------------' |
| 425 | */ | 514 | */ |
| 426 | [_QWERTY] = KEYMAP( | 515 | [_QWERTY] = KEYMAP( |
| 427 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC, | 516 | KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC, |
| 428 | KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_QUOT, KC_ENT , | 517 | KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_QUOT, KC_ENT , |
| 429 | KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, | 518 | KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, |
| 430 | KC_LCTL, KC_LGUI, KC_LALT, PUNC, NUM, KC_SPC, KC_SPC, FUNC, EMOJI, KC_RALT, KC_RGUI, KC_RCTL | 519 | KC_LCTL, KC_LALT, KC_LGUI, PUNC, NUM, LSPACE, RSPACE, FUNC, GREEK, KC_RGUI, KC_RALT, KC_RCTL |
| 431 | ), | 520 | ), |
| 432 | 521 | ||
| 522 | /* Dvorak | ||
| 523 | * ,-----------------------------------------------------------------------------------. | ||
| 524 | * | Tab | ' | , | . | P | Y | F | G | C | R | L | Bksp | | ||
| 525 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 526 | * | Esc | A | O | E | U | I | D | H | T | N | S |Enter | | ||
| 527 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 528 | * | Shift| / | Q | J | K | X | B | M | W | V | Z |Shift | | ||
| 529 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 530 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | | ||
| 531 | * `-----------------------------------------------------------------------------------' | ||
| 532 | */ | ||
| 533 | #ifdef LAYOUT_DVORAK | ||
| 534 | [_DVORAK] = KEYMAP( | ||
| 535 | _______, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, _______, | ||
| 536 | _______, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, _______, | ||
| 537 | _______, KC_SLSH, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, _______, | ||
| 538 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 539 | ), | ||
| 540 | #endif | ||
| 541 | |||
| 433 | /* Colemak | 542 | /* Colemak |
| 434 | * ,-----------------------------------------------------------------------------------. | 543 | * ,-----------------------------------------------------------------------------------. |
| 435 | * | Tab | Q | W | F | P | G | J | L | U | Y | ; | Bksp | | 544 | * | Tab | Q | W | F | P | G | J | L | U | Y | ; | Bksp | |
| @@ -438,15 +547,39 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 438 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 547 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 439 | * | Shift| Z | X | C | V | B | K | M | , | . | / |Shift | | 548 | * | Shift| Z | X | C | V | B | K | M | , | . | / |Shift | |
| 440 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 549 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 441 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |AltGr | GUI | Ctrl | | 550 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 442 | * `-----------------------------------------------------------------------------------' | 551 | * `-----------------------------------------------------------------------------------' |
| 443 | */ | 552 | */ |
| 553 | |||
| 554 | #ifdef LAYOUT_COLEMAK | ||
| 444 | [_COLEMAK] = KEYMAP( | 555 | [_COLEMAK] = KEYMAP( |
| 445 | _______, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_QUOT, _______, | 556 | _______, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_QUOT, _______, |
| 446 | _______, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, _______, | 557 | _______, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, _______, |
| 447 | _______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, | 558 | _______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, |
| 448 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | 559 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 449 | ), | 560 | ), |
| 561 | #endif | ||
| 562 | |||
| 563 | /* Norman | ||
| 564 | * ,-----------------------------------------------------------------------------------. | ||
| 565 | * | Tab | Q | W | D | F | K | J | U | R | L | ; | Bksp | | ||
| 566 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 567 | * | Esc | A | S | E | T | G | Y | N | I | O | H |Enter | | ||
| 568 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 569 | * | Shift| Z | X | C | V | B | P | M | , | . | / |Shift | | ||
| 570 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 571 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | | ||
| 572 | * `-----------------------------------------------------------------------------------' | ||
| 573 | */ | ||
| 574 | |||
| 575 | #ifdef LAYOUT_NORMAN | ||
| 576 | [_NORMAN] = KEYMAP( | ||
| 577 | _______, KC_Q, KC_W, KC_D, KC_F, KC_K, KC_J, KC_U, KC_R, KC_L, KC_QUOT, _______, | ||
| 578 | _______, KC_A, KC_S, KC_E, KC_T, KC_G, KC_Y, KC_N, KC_I, KC_O, KC_H, _______, | ||
| 579 | _______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_P, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______, | ||
| 580 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 581 | ), | ||
| 582 | #endif | ||
| 450 | 583 | ||
| 451 | /* Workman | 584 | /* Workman |
| 452 | * ,-----------------------------------------------------------------------------------. | 585 | * ,-----------------------------------------------------------------------------------. |
| @@ -456,50 +589,53 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 456 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 589 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 457 | * | Shift| Z | X | M | C | V | K | K | , | . | / |Shift | | 590 | * | Shift| Z | X | M | C | V | K | K | , | . | / |Shift | |
| 458 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 591 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 459 | * | Ctrl | GUI | Alt | Punc | Num | Space | Func |Emoji |AltGr | GUI | Ctrl | | 592 | * | Ctrl | Alt | GUI | Punc | Num | Space | Func |Greek | GUI |AltGr | Ctrl | |
| 460 | * `-----------------------------------------------------------------------------------' | 593 | * `-----------------------------------------------------------------------------------' |
| 461 | */ | 594 | */ |
| 595 | |||
| 596 | #ifdef LAYOUT_WORKMAN | ||
| 462 | [_WORKMAN] = KEYMAP( | 597 | [_WORKMAN] = KEYMAP( |
| 463 | _______, KC_Q, KC_D, KC_R, KC_W, KC_B, KC_J, KC_F, KC_U, KC_P, KC_QUOT, _______, | 598 | _______, KC_Q, KC_D, KC_R, KC_W, KC_B, KC_J, KC_F, KC_U, KC_P, KC_QUOT, _______, |
| 464 | _______, KC_A, KC_S, KC_H, KC_T, KC_G, KC_Y, KC_N, KC_E, KC_O, KC_I, _______, | 599 | _______, KC_A, KC_S, KC_H, KC_T, KC_G, KC_Y, KC_N, KC_E, KC_O, KC_I, _______, |
| 465 | _______, KC_Z, KC_X, KC_M, KC_C, KC_V, KC_K, KC_L, KC_COMM, KC_DOT, KC_SLSH, _______, | 600 | _______, KC_Z, KC_X, KC_M, KC_C, KC_V, KC_K, KC_L, KC_COMM, KC_DOT, KC_SLSH, _______, |
| 466 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | 601 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 467 | ), | 602 | ), |
| 603 | #endif | ||
| 468 | 604 | ||
| 469 | /* Punc | 605 | /* Punc |
| 470 | * ,-----------------------------------------------------------------------------------. | 606 | * ,-----------------------------------------------------------------------------------. |
| 471 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | ` | | 607 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | ` | |
| 472 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 608 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 473 | * | | | \ | - | = | < | > | ( | ) | ' | | | | 609 | * | | * | \ | - | = | / | | ( | ) | < | > | | |
| 474 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 610 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 475 | * | | | | | _ | + | { | } | [ | ] | " | | | | 611 | * | & | ^ | | | _ | + | ? | | [ | ] | { | } | : | |
| 476 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 612 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 477 | * | | | | | | | | | | | | | 613 | * | | | | | | | | | | | | |
| 478 | * `-----------------------------------------------------------------------------------' | 614 | * `-----------------------------------------------------------------------------------' |
| 479 | */ | 615 | */ |
| 480 | [_PUNC] = KEYMAP( | 616 | [_PUNC] = KEYMAP( |
| 481 | KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_GRV , | 617 | KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_GRV , |
| 482 | XXXXXXX, XXXXXXX, KC_BSLS, KC_MINS, KC_EQL, KC_LABK, KC_RABK, KC_LPRN, KC_RPRN, KC_QUOT, XXXXXXX, XXXXXXX, | 618 | XXXXXXX, KC_ASTR, KC_BSLS, KC_MINS, KC_EQL, KC_SLSH, XXXXXXX, KC_LPRN, KC_RPRN, KC_LABK, KC_RABK, XXXXXXX, |
| 483 | XXXXXXX, XXXXXXX, KC_PIPE, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_LBRC, KC_RBRC, KC_DQUO, XXXXXXX, XXXXXXX, | 619 | KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, XXXXXXX, KC_LBRC, KC_RBRC, KC_LCBR, KC_RCBR, KC_COLN, |
| 484 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | 620 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 485 | ), | 621 | ), |
| 486 | 622 | ||
| 487 | /* Num | 623 | /* Num |
| 488 | * ,-----------------------------------------------------------------------------------. | 624 | * ,-----------------------------------------------------------------------------------. |
| 489 | * | ^ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 625 | * | ~ | ! | @ | # | $ | % | A | 7 | 8 | 9 | D | ` | |
| 490 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 626 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 491 | * | Esc | @ | A | B | C | ( | ) | 4 | 5 | 6 | : |Enter | | 627 | * | | * | \ | - | = | / | B | 4 | 5 | 6 | E | | |
| 492 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 628 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 493 | * | & | # | D | E | F | [ | ] | 1 | 2 | 3 | / | * | | 629 | * | & | ^ | | | _ | + | ? | C | 1 | 2 | 3 | F | : | |
| 494 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 630 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 495 | * | | | | x | | | 0 | , | . | + | - | | 631 | * | | | | | | | x | 0 | , | . | | | |
| 496 | * `-----------------------------------------------------------------------------------' | 632 | * `-----------------------------------------------------------------------------------' |
| 497 | */ | 633 | */ |
| 498 | [_NUM] = KEYMAP( | 634 | [_NUM] = KEYMAP( |
| 499 | KC_CIRC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC, | 635 | KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, S(KC_A), KC_7, KC_8, KC_9, S(KC_D), KC_GRV, |
| 500 | KC_ESC, KC_AT, S(KC_A), S(KC_B), S(KC_C), KC_LPRN, KC_RPRN, KC_4, KC_5, KC_6, KC_COLN, KC_ENT, | 636 | XXXXXXX, KC_ASTR, KC_BSLS, KC_MINS, KC_EQL, KC_SLSH, S(KC_B), KC_4, KC_5, KC_6, S(KC_E), _______, |
| 501 | KC_AMPR, KC_HASH, S(KC_D), S(KC_E), S(KC_F), KC_LBRC, KC_RBRC, KC_1, KC_2, KC_3, KC_SLSH, KC_ASTR, | 637 | KC_AMPR, KC_CIRC, KC_PIPE, KC_UNDS, KC_PLUS, KC_QUES, S(KC_C), KC_1, KC_2, KC_3, S(KC_F), KC_COLN, |
| 502 | _______, _______, _______, KC_X, _______, KC_SPC, KC_SPC, KC_0, KC_COMM, KC_DOT, KC_PLUS, KC_MINS | 638 | _______, _______, _______, _______, _______, _______, _______, KC_0, KC_COMM, KC_DOT, KC_X, _______ |
| 503 | ), | 639 | ), |
| 504 | 640 | ||
| 505 | /* Func | 641 | /* Func |
| @@ -520,6 +656,42 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 520 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | 656 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ |
| 521 | ), | 657 | ), |
| 522 | 658 | ||
| 659 | /* Uppercase Greek | ||
| 660 | * ,-----------------------------------------------------------------------------------. | ||
| 661 | * | | | | | | | | | | | | | | ||
| 662 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 663 | * | | | | | | | | | | | | | | ||
| 664 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 665 | * | | | | | | | | | | | | | | ||
| 666 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 667 | * | | | | | | | | | | | | | | ||
| 668 | * `-----------------------------------------------------------------------------------' | ||
| 669 | */ | ||
| 670 | [_GREEKU] = KEYMAP( | ||
| 671 | _______, _______, _______,X(UEPSI), X(URHO), X(UTAU),X(UUPSI),X(UTHET),X(UIOTA),X(UOMIC), X(UPI), _______, | ||
| 672 | _______,X(UALPH),X(USIGM),X(UDELT), X(UPHI),X(UGAMM), X(UETA), X(UXI),X(UKAPP),X(ULAMB), _______, _______, | ||
| 673 | _______,X(UZETA), X(UCHI), X(UPSI),X(UOMEG),X(UBETA), X(UNU), X(UMU), _______, _______, _______, _______, | ||
| 674 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 675 | ), | ||
| 676 | |||
| 677 | /* Lowercase Greek | ||
| 678 | * ,-----------------------------------------------------------------------------------. | ||
| 679 | * | | | | | | | | | | | | | | ||
| 680 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 681 | * | | | | | | | | | | | | | | ||
| 682 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 683 | * | | | | | | | | | | | | | | ||
| 684 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 685 | * | | | | | | | | | | | | | | ||
| 686 | * `-----------------------------------------------------------------------------------' | ||
| 687 | */ | ||
| 688 | [_GREEKL] = KEYMAP( | ||
| 689 | _______, _______,X(FSIGM),X(LEPSI), X(LRHO), X(LTAU),X(LUPSI),X(LTHET),X(LIOTA),X(LOMIC), X(LPI), _______, | ||
| 690 | _______,X(LALPH),X(LSIGM),X(LDELT), X(LPHI),X(LGAMM), X(LETA), X(LXI),X(LKAPP),X(LLAMB), _______, _______, | ||
| 691 | _______,X(LZETA), X(LCHI), X(LPSI),X(LOMEG),X(LBETA), X(LNU), X(LMU), _______, _______, _______, _______, | ||
| 692 | _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||
| 693 | ), | ||
| 694 | |||
| 523 | /* Emoji | 695 | /* Emoji |
| 524 | * ,-----------------------------------------------------------------------------------. | 696 | * ,-----------------------------------------------------------------------------------. |
| 525 | * | | | | | | | | | | | | | | 697 | * | | | | | | | | | | | | | |
| @@ -535,40 +707,46 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 535 | X(HART2), X(CRY2),X(WEARY),X(EYERT),X(SMIRK), X(TJOY),X(RECYC),X(UNAMU),X(MUSIC),X(OKHND),X(PENSV), X(PHEW), | 707 | X(HART2), X(CRY2),X(WEARY),X(EYERT),X(SMIRK), X(TJOY),X(RECYC),X(UNAMU),X(MUSIC),X(OKHND),X(PENSV), X(PHEW), |
| 536 | X(THMUP), X(PRAY),X(SMILE),X(SMIL2),X(FLUSH), X(GRIN),X(HEART), X(BYE), X(KISS),X(CELEB), X(COOL),X(NOEVS), | 708 | X(THMUP), X(PRAY),X(SMILE),X(SMIL2),X(FLUSH), X(GRIN),X(HEART), X(BYE), X(KISS),X(CELEB), X(COOL),X(NOEVS), |
| 537 | X(THMDN),X(SLEEP), X(CLAP), X(CRY), X(VIC),X(BHART), X(SUN),X(SMEYE), X(WINK), X(MOON),X(CONFU),X(NOEVH), | 709 | X(THMDN),X(SLEEP), X(CLAP), X(CRY), X(VIC),X(BHART), X(SUN),X(SMEYE), X(WINK), X(MOON),X(CONFU),X(NOEVH), |
| 538 | X(POO), X(EYES),X(HUNRD), _______,X(SKULL),X(HORNS), X(HALO), X(FEAR), _______,X(YUMMY),X(DISAP),X(NOEVK) | 710 | X(POO), X(EYES), _______,X(HUNRD), X(SKULL),X(HORNS), X(HALO), X(FEAR),X(YUMMY),_______,X(DISAP),X(NOEVK) |
| 539 | ), | 711 | ), |
| 540 | 712 | ||
| 541 | /* GUI | 713 | /* GUI |
| 542 | * ,-----------------------------------------------------------------------------------. | 714 | * ,-----------------------------------------------------------------------------------. |
| 543 | * | | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | | | 715 | * | | D1 | D2 | D3 | D4 | D5 | D6 | D7 | D8 | D9 | D10 | | |
| 544 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 716 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 545 | * |Linux | | Vol- | Mute | Vol+ | | | D- | | D+ | |Qwerty| | 717 | * | | | Vol- | Mute | Vol+ | | | Prev | | Next | | | |
| 546 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 718 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 547 | * | Win | | Prev | Play | Next | | | | | | |Colmak| | 719 | * | | | Prev | Play | Next | | | | | | | | |
| 548 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 720 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 549 | * | OSX | | | | | BL- | BL+ | | | | |Workmn| | 721 | * | | | | | | | | | | | | | |
| 550 | * `-----------------------------------------------------------------------------------' | 722 | * `-----------------------------------------------------------------------------------' |
| 551 | */ | 723 | */ |
| 552 | [_GUI] = KEYMAP( | 724 | [_GUI] = KEYMAP( |
| 553 | _______, LGUI(KC_1),LGUI(KC_2),LGUI(KC_3),LGUI(KC_4),LGUI(KC_5),LGUI(KC_6),LGUI(KC_7),LGUI(KC_8),LGUI(KC_9),LGUI(KC_0), _______, | 725 | XXXXXXX, G(KC_1), G(KC_2), G(KC_3), G(KC_4), G(KC_5), G(KC_6), G(KC_7), G(KC_8), G(KC_9), G(KC_0), XXXXXXX, |
| 554 | LINUX, _______, KC_VOLD, KC_MUTE, KC_VOLU,_______,_______,KC_WWW_BACK,_______,KC_WWW_FORWARD,KC_PAUS, QWERTY, | 726 | XXXXXXX, XXXXXXX, KC_VOLD, KC_MUTE, KC_VOLU, XXXXXXX, XXXXXXX, KC_WWWB, XXXXXXX, KC_WWWF, XXXXXXX, XXXXXXX, |
| 555 | WIN, _______, KC_MPRV, KC_MPLY, KC_MNXT, RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, COLEMAK, | 727 | XXXXXXX, XXXXXXX, KC_MPRV, KC_MPLY, KC_MNXT, KC_SPC, KC_SPC, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, |
| 556 | OSX, _______, _______, _______, _______, BL_DEC, BL_INC, _______, _______, RGB_VAI, RGB_VAD, WORKMAN | 728 | XXXXXXX, XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX, XXXXXXX |
| 557 | ), | 729 | ), |
| 558 | 730 | ||
| 559 | }; | 731 | /* Sys |
| 732 | * ,-----------------------------------------------------------------------------------. | ||
| 733 | * | |Qwerty| Win | |Reset | | | USB | | | | | | ||
| 734 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 735 | * | |Audio | |Dvorak| | Glow | | |WorkMn|Linux | | | | ||
| 736 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 737 | * | | | |Colmak| | BLE |Norman|MacOS | | | | | | ||
| 738 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 739 | * | | | | | | | | | | | | | | ||
| 740 | * `-----------------------------------------------------------------------------------' | ||
| 741 | */ | ||
| 742 | [_SYS] = KEYMAP( | ||
| 743 | XXXXXXX, QWERTY, WIN, XXXXXXX, RESET, XXXXXXX, XXXXXXX, OUT_USB, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, | ||
| 744 | XXXXXXX, AUDIO, XXXXXXX, DVORAK, XXXXXXX, GLOW, XXXXXXX, XXXXXXX, WORKMAN, LINUX, XXXXXXX, XXXXXXX, | ||
| 745 | XXXXXXX, XXXXXXX, XXXXXXX, COLEMAK, XXXXXXX, OUT_BLE, NORMAN, OSX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, | ||
| 746 | _______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______ | ||
| 747 | ), | ||
| 560 | 748 | ||
| 561 | #ifdef AUDIO_ENABLE | 749 | }; |
| 562 | float tone_startup[][2] = SONG(STARTUP_SOUND); | ||
| 563 | float tone_qwerty[][2] = SONG(QWERTY_SOUND); | ||
| 564 | float tone_colemak[][2] = SONG(COLEMAK_SOUND); | ||
| 565 | float tone_workman[][2] = SONG(DVORAK_SOUND); | ||
| 566 | float tone_goodbye[][2] = SONG(GOODBYE_SOUND); | ||
| 567 | float tone_linux[][2] = SONG(CAPS_LOCK_ON_SOUND); | ||
| 568 | float tone_windows[][2] = SONG(SCROLL_LOCK_ON_SOUND); | ||
| 569 | float tone_osx[][2] = SONG(NUM_LOCK_ON_SOUND); | ||
| 570 | float tone_click[][2] = SONG(MUSICAL_NOTE(_F3, 2)); | ||
| 571 | #endif | ||
| 572 | 750 | ||
| 573 | void persistant_default_layer_set(uint16_t default_layer) { | 751 | void persistant_default_layer_set(uint16_t default_layer) { |
| 574 | eeconfig_update_default_layer(default_layer); | 752 | eeconfig_update_default_layer(default_layer); |
| @@ -576,24 +754,140 @@ void persistant_default_layer_set(uint16_t default_layer) { | |||
| 576 | } | 754 | } |
| 577 | 755 | ||
| 578 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | 756 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { |
| 579 | #ifdef AUDIO_ENABLE | 757 | bool lshift = keyboard_report->mods & MOD_BIT(KC_LSFT); |
| 580 | // faux clicky | 758 | bool rshift = keyboard_report->mods & MOD_BIT(KC_RSFT); |
| 581 | if (record->event.pressed) PLAY_NOTE_ARRAY(tone_click, false, 0); | 759 | |
| 582 | #endif | 760 | #ifdef DOUBLESPACE_LAYER_ENABLE |
| 761 | // double-space: send space immediately if any other key depressed before space is released | ||
| 762 | if ((lspace_active ^ rspace_active) | ||
| 763 | && keycode != LSPACE | ||
| 764 | && keycode != RSPACE | ||
| 765 | && record->event.pressed) | ||
| 766 | { | ||
| 767 | if (lspace_active) { | ||
| 768 | if (!lspace_emitted) { | ||
| 769 | register_code(KC_SPC); | ||
| 770 | unregister_code(KC_SPC); | ||
| 771 | } | ||
| 772 | lspace_emitted = true; | ||
| 773 | } | ||
| 774 | if (rspace_active) { | ||
| 775 | if (!rspace_emitted) { | ||
| 776 | register_code(KC_SPC); | ||
| 777 | unregister_code(KC_SPC); | ||
| 778 | } | ||
| 779 | rspace_emitted = true; | ||
| 780 | } | ||
| 781 | } | ||
| 782 | #endif | ||
| 583 | 783 | ||
| 584 | switch (keycode) { | 784 | switch (keycode) { |
| 785 | |||
| 786 | #ifdef DOUBLESPACE_LAYER_ENABLE | ||
| 787 | // double-space enter space layer | ||
| 788 | case LSPACE: | ||
| 789 | if (record->event.pressed) { | ||
| 790 | lspace_active = true; | ||
| 791 | if (rspace_active) { | ||
| 792 | layer_on(_SPACE); | ||
| 793 | space_layer_entered = true; | ||
| 794 | } | ||
| 795 | } else { | ||
| 796 | lspace_active = false; | ||
| 797 | if (space_layer_entered) { | ||
| 798 | layer_off(_SPACE); | ||
| 799 | if (!rspace_active) { | ||
| 800 | space_layer_entered = false; | ||
| 801 | } | ||
| 802 | } else { | ||
| 803 | if (!lspace_emitted) { | ||
| 804 | register_code(KC_SPC); | ||
| 805 | unregister_code(KC_SPC); | ||
| 806 | } | ||
| 807 | lspace_emitted = false; | ||
| 808 | } | ||
| 809 | } | ||
| 810 | return false; | ||
| 811 | break; | ||
| 812 | case RSPACE: | ||
| 813 | if (record->event.pressed) { | ||
| 814 | rspace_active = true; | ||
| 815 | if (lspace_active) { | ||
| 816 | layer_on(_SPACE); | ||
| 817 | space_layer_entered = true; | ||
| 818 | } | ||
| 819 | } else { | ||
| 820 | rspace_active = false; | ||
| 821 | if (space_layer_entered) { | ||
| 822 | layer_off(_SPACE); | ||
| 823 | if (!lspace_active) { | ||
| 824 | space_layer_entered = false; | ||
| 825 | } | ||
| 826 | } else { | ||
| 827 | if (!rspace_emitted) { | ||
| 828 | register_code(KC_SPC); | ||
| 829 | unregister_code(KC_SPC); | ||
| 830 | } | ||
| 831 | rspace_emitted = false; | ||
| 832 | } | ||
| 833 | } | ||
| 834 | return false; | ||
| 835 | break; | ||
| 836 | #endif | ||
| 837 | |||
| 838 | // handle greek layer shift | ||
| 839 | // handle both shift = capslock | ||
| 840 | case KC_LSFT: | ||
| 841 | case KC_RSFT: | ||
| 842 | ; | ||
| 843 | uint8_t layer = biton32(layer_state); | ||
| 844 | if (layer == _GREEKU || layer == _GREEKL) { | ||
| 845 | if (record->event.pressed) { | ||
| 846 | layer_on(_GREEKU); | ||
| 847 | layer_off(_GREEKL); | ||
| 848 | } else { | ||
| 849 | if (lshift ^ rshift) { // if only one shift was pressed | ||
| 850 | layer_on(_GREEKL); | ||
| 851 | layer_off(_GREEKU); | ||
| 852 | } | ||
| 853 | } | ||
| 854 | } else { | ||
| 855 | if (record->event.pressed) { | ||
| 856 | if (lshift ^ rshift) { // if only one shift was pressed | ||
| 857 | register_code(KC_CAPS); | ||
| 858 | unregister_code(KC_CAPS); | ||
| 859 | } | ||
| 860 | } | ||
| 861 | } | ||
| 862 | return true; | ||
| 863 | break; | ||
| 864 | |||
| 865 | // press both ctrls to activate SYS layer | ||
| 866 | case KC_LCTL: | ||
| 867 | case KC_RCTL: | ||
| 868 | ; | ||
| 869 | bool lctrl = keyboard_report->mods & MOD_BIT(KC_LCTL); | ||
| 870 | bool rctrl = keyboard_report->mods & MOD_BIT(KC_RCTL); | ||
| 871 | if (record->event.pressed) { | ||
| 872 | if (lctrl ^ rctrl) { // if only one ctrl was pressed | ||
| 873 | layer_on(_SYS); | ||
| 874 | } | ||
| 875 | } else { | ||
| 876 | layer_off(_SYS); | ||
| 877 | } | ||
| 878 | return true; | ||
| 879 | break; | ||
| 880 | |||
| 585 | // QWERTZ style comma and dot: semicolon and colon when shifted | 881 | // QWERTZ style comma and dot: semicolon and colon when shifted |
| 586 | case KC_COMM: | 882 | case KC_COMM: |
| 587 | if (record->event.pressed) { | 883 | if (record->event.pressed) { |
| 588 | bool lshifted = keyboard_report->mods & MOD_BIT(KC_LSFT); | 884 | if (lshift || rshift) { |
| 589 | bool rshifted = keyboard_report->mods & MOD_BIT(KC_RSFT); | 885 | if (lshift) unregister_code(KC_LSFT); |
| 590 | if (lshifted || rshifted) { | 886 | if (rshift) unregister_code(KC_RSFT); |
| 591 | if (lshifted) unregister_code(KC_LSFT); | ||
| 592 | if (rshifted) unregister_code(KC_RSFT); | ||
| 593 | register_code(KC_SCLN); | 887 | register_code(KC_SCLN); |
| 594 | unregister_code(KC_SCLN); | 888 | unregister_code(KC_SCLN); |
| 595 | if (lshifted) register_code(KC_LSFT); | 889 | if (lshift) register_code(KC_LSFT); |
| 596 | if (rshifted) register_code(KC_RSFT); | 890 | if (rshift) register_code(KC_RSFT); |
| 597 | } else { | 891 | } else { |
| 598 | register_code(KC_COMM); | 892 | register_code(KC_COMM); |
| 599 | unregister_code(KC_COMM); | 893 | unregister_code(KC_COMM); |
| @@ -617,90 +911,88 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 617 | // layout switchers | 911 | // layout switchers |
| 618 | case QWERTY: | 912 | case QWERTY: |
| 619 | if (record->event.pressed) { | 913 | if (record->event.pressed) { |
| 620 | #ifdef AUDIO_ENABLE | ||
| 621 | PLAY_NOTE_ARRAY(tone_qwerty, false, 0); | ||
| 622 | #endif | ||
| 623 | persistant_default_layer_set(1UL<<_QWERTY); | 914 | persistant_default_layer_set(1UL<<_QWERTY); |
| 624 | } | 915 | } |
| 625 | return false; | 916 | return false; |
| 626 | break; | 917 | break; |
| 918 | #ifdef LAYOUT_DVORAK | ||
| 919 | case DVORAK: | ||
| 920 | if (record->event.pressed) { | ||
| 921 | persistant_default_layer_set(1UL<<_DVORAK); | ||
| 922 | } | ||
| 923 | return false; | ||
| 924 | break; | ||
| 925 | #endif | ||
| 926 | #ifdef LAYOUT_COLEMAK | ||
| 627 | case COLEMAK: | 927 | case COLEMAK: |
| 628 | if (record->event.pressed) { | 928 | if (record->event.pressed) { |
| 629 | #ifdef AUDIO_ENABLE | ||
| 630 | PLAY_NOTE_ARRAY(tone_colemak, false, 0); | ||
| 631 | #endif | ||
| 632 | persistant_default_layer_set(1UL<<_COLEMAK); | 929 | persistant_default_layer_set(1UL<<_COLEMAK); |
| 633 | } | 930 | } |
| 634 | return false; | 931 | return false; |
| 635 | break; | 932 | break; |
| 933 | #endif | ||
| 934 | #ifdef LAYOUT_WORKMAN | ||
| 636 | case WORKMAN: | 935 | case WORKMAN: |
| 637 | if (record->event.pressed) { | 936 | if (record->event.pressed) { |
| 638 | #ifdef AUDIO_ENABLE | ||
| 639 | PLAY_NOTE_ARRAY(tone_workman, false, 0); | ||
| 640 | #endif | ||
| 641 | persistant_default_layer_set(1UL<<_WORKMAN); | 937 | persistant_default_layer_set(1UL<<_WORKMAN); |
| 642 | } | 938 | } |
| 643 | return false; | 939 | return false; |
| 644 | break; | 940 | break; |
| 941 | #endif | ||
| 942 | #ifdef LAYOUT_NORMAN | ||
| 943 | case NORMAN: | ||
| 944 | if (record->event.pressed) { | ||
| 945 | persistant_default_layer_set(1UL<<_NORMAN); | ||
| 946 | } | ||
| 947 | return false; | ||
| 948 | break; | ||
| 949 | #endif | ||
| 645 | 950 | ||
| 646 | // layer switcher | 951 | // layer switcher |
| 647 | case PUNC: | 952 | case PUNC: |
| 648 | if (record->event.pressed) { | 953 | if (record->event.pressed) { |
| 649 | layer_on(_PUNC); | 954 | layer_on(_PUNC); |
| 650 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 955 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); |
| 651 | if (IS_LAYER_ON(_GUI)) { | ||
| 652 | led_layer_gui(); | ||
| 653 | } else { | ||
| 654 | led_layer_punc();; | ||
| 655 | } | ||
| 656 | } else { | 956 | } else { |
| 657 | layer_off(_PUNC); | 957 | layer_off(_PUNC); |
| 658 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 958 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); |
| 659 | if (IS_LAYER_ON(_EMOJI)) { | ||
| 660 | led_layer_emoji(); | ||
| 661 | } else { | ||
| 662 | led_layer_normal();; | ||
| 663 | } | ||
| 664 | } | 959 | } |
| 665 | return false; | 960 | return false; |
| 666 | break; | 961 | break; |
| 667 | case EMOJI: | 962 | |
| 963 | case GREEK: | ||
| 668 | if (record->event.pressed) { | 964 | if (record->event.pressed) { |
| 669 | layer_on(_EMOJI); | 965 | if (lshift || rshift) { |
| 670 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 966 | layer_on(_GREEKU); |
| 671 | if (IS_LAYER_ON(_GUI)) { | 967 | layer_off(_GREEKL); |
| 672 | led_layer_gui(); | ||
| 673 | } else { | 968 | } else { |
| 674 | led_layer_emoji();; | 969 | layer_on(_GREEKL); |
| 970 | layer_off(_GREEKU); | ||
| 971 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); | ||
| 675 | } | 972 | } |
| 676 | } else { | 973 | } else { |
| 677 | layer_off(_EMOJI); | 974 | layer_off(_GREEKU); |
| 678 | update_tri_layer(_PUNC, _EMOJI, _GUI); | 975 | layer_off(_GREEKL); |
| 679 | if (IS_LAYER_ON(_PUNC)) { | 976 | update_tri_layer(_PUNC, _GREEKL, _EMOJI); |
| 680 | led_layer_punc(); | ||
| 681 | } else { | ||
| 682 | led_layer_normal();; | ||
| 683 | } | ||
| 684 | } | 977 | } |
| 685 | return false; | 978 | return false; |
| 686 | break; | 979 | break; |
| 980 | |||
| 687 | case NUM: | 981 | case NUM: |
| 688 | if (record->event.pressed) { | 982 | if (record->event.pressed) { |
| 983 | turn_off_capslock(); | ||
| 689 | layer_on(_NUM); | 984 | layer_on(_NUM); |
| 690 | led_layer_num(); | ||
| 691 | } else { | 985 | } else { |
| 692 | layer_off(_NUM); | 986 | layer_off(_NUM); |
| 693 | led_layer_normal(); | ||
| 694 | } | 987 | } |
| 695 | return false; | 988 | return false; |
| 696 | break; | 989 | break; |
| 990 | |||
| 697 | case FUNC: | 991 | case FUNC: |
| 698 | if (record->event.pressed) { | 992 | if (record->event.pressed) { |
| 699 | layer_on(_FUNC); | 993 | layer_on(_FUNC); |
| 700 | led_layer_func(); | ||
| 701 | } else { | 994 | } else { |
| 702 | layer_off(_FUNC); | 995 | layer_off(_FUNC); |
| 703 | led_layer_normal(); | ||
| 704 | } | 996 | } |
| 705 | return false; | 997 | return false; |
| 706 | break; | 998 | break; |
| @@ -708,86 +1000,115 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | |||
| 708 | // OS switchers | 1000 | // OS switchers |
| 709 | case LINUX: | 1001 | case LINUX: |
| 710 | set_unicode_input_mode(UC_LNX); | 1002 | set_unicode_input_mode(UC_LNX); |
| 711 | #ifdef AUDIO_ENABLE | ||
| 712 | PLAY_NOTE_ARRAY(tone_linux, false, 0); | ||
| 713 | #endif | ||
| 714 | return false; | 1003 | return false; |
| 715 | break; | 1004 | break; |
| 716 | case WIN: | 1005 | case WIN: |
| 717 | set_unicode_input_mode(UC_WINC); | 1006 | set_unicode_input_mode(UC_WINC); |
| 718 | #ifdef AUDIO_ENABLE | ||
| 719 | PLAY_NOTE_ARRAY(tone_windows, false, 0); | ||
| 720 | #endif | ||
| 721 | return false; | 1007 | return false; |
| 722 | break; | 1008 | break; |
| 723 | case OSX: | 1009 | case OSX: |
| 724 | set_unicode_input_mode(UC_OSX); | 1010 | set_unicode_input_mode(UC_OSX); |
| 725 | #ifdef AUDIO_ENABLE | 1011 | return false; |
| 726 | PLAY_NOTE_ARRAY(tone_osx, false, 0); | 1012 | break; |
| 727 | #endif | 1013 | |
| 1014 | // glow mode changer | ||
| 1015 | case GLOW: | ||
| 1016 | if (record->event.pressed) { | ||
| 1017 | glow_mode++; | ||
| 1018 | if (glow_mode > GLOW_FULL) { | ||
| 1019 | glow_mode = GLOW_NONE; | ||
| 1020 | } | ||
| 1021 | led_reset(); | ||
| 1022 | rgbsps_send(); | ||
| 1023 | } | ||
| 1024 | return false; | ||
| 1025 | break; | ||
| 1026 | |||
| 1027 | // faux clicky toggle, TBD | ||
| 1028 | case AUDIO: | ||
| 728 | return false; | 1029 | return false; |
| 729 | break; | 1030 | break; |
| 730 | } | 1031 | } |
| 731 | return true; | 1032 | return true; |
| 732 | } | 1033 | } |
| 733 | 1034 | ||
| 734 | void matrix_init_user(void) { | 1035 | void set_output_user(uint8_t output) { |
| 735 | #ifdef AUDIO_ENABLE | 1036 | switch(output) { |
| 736 | startup_user(); | 1037 | case OUTPUT_USB: |
| 737 | #endif | 1038 | led_set_output_usb(); |
| 738 | set_unicode_input_mode(UC_LNX); | 1039 | break; |
| 739 | led_init(); | 1040 | case OUTPUT_ADAFRUIT_BLE: |
| 1041 | led_set_output_ble(); | ||
| 1042 | break; | ||
| 1043 | default: | ||
| 1044 | led_set_output_none(); | ||
| 1045 | } | ||
| 740 | } | 1046 | } |
| 741 | 1047 | ||
| 742 | // void init_rgblight(void) { | 1048 | void matrix_init_user(void) { |
| 743 | // for (uint8_t i = 0; i < RGBLED_NUM; i++) { | 1049 | _delay_ms(500); // give time for usb to initialize |
| 744 | // led[i].r = 255; | ||
| 745 | // led[i].g = 85; | ||
| 746 | // led[i].b = 0; | ||
| 747 | // } | ||
| 748 | // ws2812_setleds(led, RGBLED_NUM); | ||
| 749 | // } | ||
| 750 | 1050 | ||
| 1051 | set_unicode_input_mode(UC_LNX); | ||
| 1052 | led_init(); | ||
| 751 | 1053 | ||
| 752 | #ifdef AUDIO_ENABLE | 1054 | // auto detect output on init |
| 1055 | uint8_t output = auto_detect_output(); | ||
| 1056 | if (output == OUTPUT_USB) { | ||
| 1057 | set_output(OUTPUT_USB); | ||
| 1058 | } else { | ||
| 1059 | set_output(OUTPUT_ADAFRUIT_BLE); | ||
| 1060 | } | ||
| 1061 | } | ||
| 753 | 1062 | ||
| 754 | void startup_user() | 1063 | void matrix_scan_user(void) { |
| 755 | { | 1064 | led_set_layer_indicator(); |
| 756 | _delay_ms(20); // gets rid of tick | ||
| 757 | PLAY_NOTE_ARRAY(tone_startup, false, 0); | ||
| 758 | } | 1065 | } |
| 759 | 1066 | ||
| 760 | void shutdown_user() | 1067 | void battery_poll(uint8_t level) { |
| 761 | { | 1068 | rgbsps_sethsv(LED_IND_BATTERY, level * 120/255, 255, 15); |
| 762 | PLAY_NOTE_ARRAY(tone_goodbye, false, 0); | 1069 | rgbsps_send(); |
| 763 | _delay_ms(150); | ||
| 764 | stop_all_notes(); | ||
| 765 | } | 1070 | } |
| 766 | 1071 | ||
| 767 | #endif | 1072 | void led_set_user(uint8_t usb_led) { |
| 1073 | bool new_capslock = usb_led & (1<<USB_LED_CAPS_LOCK); | ||
| 1074 | if (new_capslock ^ capslock) { // capslock state is different | ||
| 1075 | if (capslock = new_capslock) { | ||
| 1076 | rgbsps_set(LED_IND_NUM, 15, 0, 0); | ||
| 1077 | } else { | ||
| 1078 | rgbsps_set(LED_IND_NUM, 0, 0, 0); | ||
| 1079 | } | ||
| 1080 | rgbsps_send(); | ||
| 1081 | } | ||
| 1082 | } | ||
| 768 | 1083 | ||
| 1084 | void turn_off_capslock() { | ||
| 1085 | if (capslock) { | ||
| 1086 | register_code(KC_CAPS); | ||
| 1087 | unregister_code(KC_CAPS); | ||
| 1088 | } | ||
| 1089 | } | ||
| 769 | 1090 | ||
| 770 | void ps2_mouse_init_user() { | 1091 | void ps2_mouse_init_user() { |
| 771 | uint8_t rcv; | 1092 | uint8_t rcv; |
| 772 | 1093 | ||
| 773 | // set TrackPoint sensitivity | 1094 | // set TrackPoint sensitivity |
| 774 | PS2_MOUSE_SEND(0xE2, "set trackpoint sensitivity: 0xE2"); | 1095 | PS2_MOUSE_SEND(0xE2, "tpsens: 0xE2"); |
| 775 | PS2_MOUSE_SEND(0x81, "set trackpoint sensitivity: 0x81"); | 1096 | PS2_MOUSE_SEND(0x81, "tpsens: 0x81"); |
| 776 | PS2_MOUSE_SEND(0x4A, "set trackpoint sensitivity: 0x4A"); | 1097 | PS2_MOUSE_SEND(0x4A, "tpsens: 0x4A"); |
| 777 | PS2_MOUSE_SEND(0x49, "set trackpoint sensitivity: 0x59"); | 1098 | PS2_MOUSE_SEND(0x49, "tpsens: 0x59"); |
| 778 | 1099 | ||
| 779 | // set TrackPoint Negative Inertia factor | 1100 | // set TrackPoint Negative Inertia factor |
| 780 | PS2_MOUSE_SEND(0xE2, "set negative inertia factor: 0xE2"); | 1101 | PS2_MOUSE_SEND(0xE2, "tpnegin: 0xE2"); |
| 781 | PS2_MOUSE_SEND(0x81, "set negative inertia factor: 0x81"); | 1102 | PS2_MOUSE_SEND(0x81, "tpnegin: 0x81"); |
| 782 | PS2_MOUSE_SEND(0x4D, "set negative inertia factor: 0x4D"); | 1103 | PS2_MOUSE_SEND(0x4D, "tpnegin: 0x4D"); |
| 783 | PS2_MOUSE_SEND(0x06, "set negative inertia factor: 0x06"); | 1104 | PS2_MOUSE_SEND(0x06, "tpnegin: 0x06"); |
| 784 | 1105 | ||
| 785 | // set TrackPoint speed | 1106 | // set TrackPoint speed |
| 786 | // (transfer function upper plateau speed) | 1107 | // (transfer function upper plateau speed) |
| 787 | PS2_MOUSE_SEND(0xE2, "set trackpoint speed: 0xE2"); | 1108 | PS2_MOUSE_SEND(0xE2, "tpsp: 0xE2"); |
| 788 | PS2_MOUSE_SEND(0x81, "set trackpoint speed: 0x81"); | 1109 | PS2_MOUSE_SEND(0x81, "tpsp: 0x81"); |
| 789 | PS2_MOUSE_SEND(0x60, "set trackpoint speed: 0x60"); | 1110 | PS2_MOUSE_SEND(0x60, "tpsp: 0x60"); |
| 790 | PS2_MOUSE_SEND(0x61, "set trackpoint speed: 0x61"); | 1111 | PS2_MOUSE_SEND(0x61, "tpsp: 0x61"); |
| 791 | 1112 | ||
| 792 | // inquire pts status | 1113 | // inquire pts status |
| 793 | rcv = ps2_host_send(0xE2); | 1114 | rcv = ps2_host_send(0xE2); |
diff --git a/keyboards/handwired/promethium/promethium.c b/keyboards/handwired/promethium/promethium.c index a0035cce1..62e2281fa 100644 --- a/keyboards/handwired/promethium/promethium.c +++ b/keyboards/handwired/promethium/promethium.c | |||
| @@ -1,6 +1,38 @@ | |||
| 1 | #include "promethium.h" | 1 | #include "promethium.h" |
| 2 | #include "analog.h" | ||
| 3 | #include "timer.h" | ||
| 4 | #include "matrix.h" | ||
| 2 | 5 | ||
| 3 | void matrix_init_kb(void) { | 6 | // cubic fit {3.3, 0}, {3.5, 2.9}, {3.6, 5}, {3.7, 8.6}, {3.8, 36}, {3.9, 62}, {4.0, 73}, {4.05, 83}, {4.1, 89}, {4.15, 94}, {4.2, 100} |
| 7 | |||
| 8 | uint8_t battery_level(void) { | ||
| 9 | float voltage = analogRead(BATTERY_PIN) * 2 * 3.3 / 1024; | ||
| 10 | if (voltage < MIN_VOLTAGE) return 0; | ||
| 11 | if (voltage > MAX_VOLTAGE) return 255; | ||
| 12 | return (voltage - MIN_VOLTAGE) / (MAX_VOLTAGE - MIN_VOLTAGE) * 255; | ||
| 13 | } | ||
| 14 | |||
| 15 | __attribute__ ((weak)) | ||
| 16 | void battery_poll(uint8_t level) { | ||
| 17 | } | ||
| 4 | 18 | ||
| 19 | void matrix_init_kb(void) { | ||
| 5 | matrix_init_user(); | 20 | matrix_init_user(); |
| 6 | } \ No newline at end of file | 21 | } |
| 22 | |||
| 23 | void matrix_scan_kb(void) { | ||
| 24 | static uint16_t counter = BATTERY_POLL; | ||
| 25 | counter++; | ||
| 26 | |||
| 27 | if (counter > BATTERY_POLL) { | ||
| 28 | counter = 0; | ||
| 29 | battery_poll(battery_level()); | ||
| 30 | } | ||
| 31 | |||
| 32 | matrix_scan_user(); | ||
| 33 | } | ||
| 34 | |||
| 35 | void led_set_kb(uint8_t usb_led) { | ||
| 36 | led_set_user(usb_led); | ||
| 37 | } | ||
| 38 | |||
diff --git a/keyboards/handwired/promethium/promethium.h b/keyboards/handwired/promethium/promethium.h index 662eeab99..da37e5c56 100644 --- a/keyboards/handwired/promethium/promethium.h +++ b/keyboards/handwired/promethium/promethium.h | |||
| @@ -4,6 +4,11 @@ | |||
| 4 | #include "quantum.h" | 4 | #include "quantum.h" |
| 5 | 5 | ||
| 6 | #define PS2_INIT_DELAY 2000 | 6 | #define PS2_INIT_DELAY 2000 |
| 7 | #define UNICODE_TYPE_DELAY 0 | ||
| 8 | #define BATTERY_PIN 9 | ||
| 9 | #define BATTERY_POLL 30000 | ||
| 10 | #define MAX_VOLTAGE 4.2 | ||
| 11 | #define MIN_VOLTAGE 3.2 | ||
| 7 | 12 | ||
| 8 | #define KEYMAP( \ | 13 | #define KEYMAP( \ |
| 9 | k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c, \ | 14 | k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, k1c, \ |
| @@ -22,6 +27,8 @@ | |||
| 22 | {k47, k48, k49, k4a, k4b, k4c} \ | 27 | {k47, k48, k49, k4a, k4b, k4c} \ |
| 23 | } | 28 | } |
| 24 | 29 | ||
| 30 | |||
| 31 | |||
| 25 | enum led_sequence { | 32 | enum led_sequence { |
| 26 | LED_IND_BLUETOOTH, | 33 | LED_IND_BLUETOOTH, |
| 27 | LED_IND_USB, | 34 | LED_IND_USB, |
| @@ -98,4 +105,4 @@ enum led_sequence { | |||
| 98 | 105 | ||
| 99 | #endif | 106 | #endif |
| 100 | 107 | ||
| 101 | 108 | void battery_poll(uint8_t level); \ No newline at end of file | |
diff --git a/keyboards/handwired/promethium/rgbsps.c b/keyboards/handwired/promethium/rgbsps.c index ea922ec3f..f30badd35 100644 --- a/keyboards/handwired/promethium/rgbsps.c +++ b/keyboards/handwired/promethium/rgbsps.c | |||
| @@ -21,4 +21,53 @@ void rgbsps_turnoff(void) { | |||
| 21 | 21 | ||
| 22 | void rgbsps_send(void) { | 22 | void rgbsps_send(void) { |
| 23 | ws2812_setleds(led, RGBSPS_NUM); | 23 | ws2812_setleds(led, RGBSPS_NUM); |
| 24 | } \ No newline at end of file | 24 | } |
| 25 | |||
| 26 | void rgbsps_sethsv(uint8_t index, uint16_t hue, uint8_t sat, uint8_t val) { | ||
| 27 | uint8_t r = 0, g = 0, b = 0, base, color; | ||
| 28 | |||
| 29 | if (sat == 0) { // Acromatic color (gray). Hue doesn't mind. | ||
| 30 | r = val; | ||
| 31 | g = val; | ||
| 32 | b = val; | ||
| 33 | } else { | ||
| 34 | base = ((255 - sat) * val) >> 8; | ||
| 35 | color = (val - base) * (hue % 60) / 60; | ||
| 36 | |||
| 37 | switch (hue / 60) { | ||
| 38 | case 0: | ||
| 39 | r = val; | ||
| 40 | g = base + color; | ||
| 41 | b = base; | ||
| 42 | break; | ||
| 43 | case 1: | ||
| 44 | r = val - color; | ||
| 45 | g = val; | ||
| 46 | b = base; | ||
| 47 | break; | ||
| 48 | case 2: | ||
| 49 | r = base; | ||
| 50 | g = val; | ||
| 51 | b = base + color; | ||
| 52 | break; | ||
| 53 | case 3: | ||
| 54 | r = base; | ||
| 55 | g = val - color; | ||
| 56 | b = val; | ||
| 57 | break; | ||
| 58 | case 4: | ||
| 59 | r = base + color; | ||
| 60 | g = base; | ||
| 61 | b = val; | ||
| 62 | break; | ||
| 63 | case 5: | ||
| 64 | r = val; | ||
| 65 | g = base; | ||
| 66 | b = val - color; | ||
| 67 | break; | ||
| 68 | } | ||
| 69 | } | ||
| 70 | |||
| 71 | rgbsps_set(index, r, g, b); | ||
| 72 | } | ||
| 73 | |||
diff --git a/keyboards/handwired/promethium/rgbsps.h b/keyboards/handwired/promethium/rgbsps.h index 6da197f75..72612a7a8 100644 --- a/keyboards/handwired/promethium/rgbsps.h +++ b/keyboards/handwired/promethium/rgbsps.h | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | void rgbsps_set(uint8_t index, uint8_t r, uint8_t g, uint8_t b); | 1 | void rgbsps_set(uint8_t index, uint8_t r, uint8_t g, uint8_t b); |
| 2 | void rgbsps_setall(uint8_t r, uint8_t g, uint8_t b); | 2 | void rgbsps_setall(uint8_t r, uint8_t g, uint8_t b); |
| 3 | void rgbsps_turnoff(void); | 3 | void rgbsps_turnoff(void); |
| 4 | void rgbsps_send(void); \ No newline at end of file | 4 | void rgbsps_send(void); |
| 5 | void rgbsps_sethsv(uint8_t index, uint16_t hue, uint8_t sat, uint8_t val); \ No newline at end of file | ||
diff --git a/keyboards/handwired/promethium/rules.mk b/keyboards/handwired/promethium/rules.mk index 465ef3359..e75cf4dde 100644 --- a/keyboards/handwired/promethium/rules.mk +++ b/keyboards/handwired/promethium/rules.mk | |||
| @@ -72,4 +72,5 @@ API_SYSEX_ENABLE ?= no | |||
| 72 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend | 72 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend |
| 73 | 73 | ||
| 74 | SRC += $(QUANTUM_DIR)/light_ws2812.c | 74 | SRC += $(QUANTUM_DIR)/light_ws2812.c |
| 75 | SRC += rgbsps.c \ No newline at end of file | 75 | SRC += rgbsps.c |
| 76 | SRC += $(QUANTUM_DIR)/analog.c \ No newline at end of file | ||
diff --git a/keyboards/handwired/reddot/Makefile b/keyboards/handwired/reddot/Makefile new file mode 100755 index 000000000..191c6bb66 --- /dev/null +++ b/keyboards/handwired/reddot/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef MAKEFILE_INCLUDED | ||
| 2 | include ../../../Makefile | ||
| 3 | endif \ No newline at end of file | ||
diff --git a/keyboards/handwired/reddot/config.h b/keyboards/handwired/reddot/config.h new file mode 100755 index 000000000..15f114297 --- /dev/null +++ b/keyboards/handwired/reddot/config.h | |||
| @@ -0,0 +1,162 @@ | |||
| 1 | /* | ||
| 2 | Copyright 2012 Jun Wako <wakojun@gmail.com> | ||
| 3 | |||
| 4 | This program is free software: you can redistribute it and/or modify | ||
| 5 | it under the terms of the GNU General Public License as published by | ||
| 6 | the Free Software Foundation, either version 2 of the License, or | ||
| 7 | (at your option) any later version. | ||
| 8 | |||
| 9 | This program is distributed in the hope that it will be useful, | ||
| 10 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | GNU General Public License for more details. | ||
| 13 | |||
| 14 | You should have received a copy of the GNU General Public License | ||
| 15 | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #ifndef CONFIG_H | ||
| 19 | #define CONFIG_H | ||
| 20 | |||
| 21 | #include "config_common.h" | ||
| 22 | |||
| 23 | /* USB Device descriptor parameter */ | ||
| 24 | #define VENDOR_ID 0xFEED | ||
| 25 | #define PRODUCT_ID 0x6060 | ||
| 26 | #define DEVICE_VER 0x0001 | ||
| 27 | #define MANUFACTURER upils | ||
| 28 | #define PRODUCT reddot | ||
| 29 | #define DESCRIPTION A custom keyboard | ||
| 30 | |||
| 31 | /* key matrix size */ | ||
| 32 | #define MATRIX_ROWS 5 | ||
| 33 | #define MATRIX_COLS 19 | ||
| 34 | |||
| 35 | /* | ||
| 36 | * Keyboard Matrix Assignments | ||
| 37 | * | ||
| 38 | * Change this to how you wired your keyboard | ||
| 39 | * COLS: AVR pins used for columns, left to right | ||
| 40 | * ROWS: AVR pins used for rows, top to bottom | ||
| 41 | * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||
| 42 | * ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||
| 43 | * | ||
| 44 | */ | ||
| 45 | #define MATRIX_ROW_PINS { B0, B1, B2, B3, E6 } | ||
| 46 | #define MATRIX_COL_PINS { B7, D0, D1, D2, D3, C6, C7, D5, D4, D7, B4, B5, B6, F7, F6, F5, F4, F1, F0 } | ||
| 47 | #define UNUSED_PINS | ||
| 48 | |||
| 49 | |||
| 50 | /* COL2ROW or ROW2COL */ | ||
| 51 | #define DIODE_DIRECTION COL2ROW | ||
| 52 | |||
| 53 | // #define BACKLIGHT_PIN B7 | ||
| 54 | // #define BACKLIGHT_BREATHING | ||
| 55 | // #define BACKLIGHT_LEVELS 3 | ||
| 56 | |||
| 57 | |||
| 58 | /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||
| 59 | #define DEBOUNCING_DELAY 5 | ||
| 60 | |||
| 61 | /* define if matrix has ghost (lacks anti-ghosting diodes) */ | ||
| 62 | //#define MATRIX_HAS_GHOST | ||
| 63 | |||
| 64 | |||
| 65 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||
| 66 | //#define LOCKING_SUPPORT_ENABLE | ||
| 67 | /* Locking resynchronize hack */ | ||
| 68 | #define LOCKING_RESYNC_ENABLE | ||
| 69 | |||
| 70 | /* | ||
| 71 | * Force NKRO | ||
| 72 | * | ||
| 73 | * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||
| 74 | * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||
| 75 | * makefile for this to work.) | ||
| 76 | * | ||
| 77 | * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||
| 78 | * until the next keyboard reset. | ||
| 79 | * | ||
| 80 | * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||
| 81 | * fully operational during normal computer usage. | ||
| 82 | * | ||
| 83 | * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||
| 84 | * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||
| 85 | * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||
| 86 | * power-up. | ||
| 87 | * | ||
| 88 | */ | ||
| 89 | //#define FORCE_NKRO | ||
| 90 | |||
| 91 | /* | ||
| 92 | * Magic Key Options | ||
| 93 | * | ||
| 94 | * Magic keys are hotkey commands that allow control over firmware functions of | ||
| 95 | * the keyboard. They are best used in combination with the HID Listen program, | ||
| 96 | * found here: https://www.pjrc.com/teensy/hid_listen.html | ||
| 97 | * | ||
| 98 | * The options below allow the magic key functionality to be changed. This is | ||
| 99 | * useful if your keyboard/keypad is missing keys and you want magic key support. | ||
| 100 | * | ||
| 101 | */ | ||
| 102 | |||
| 103 | /* key combination for magic key command */ | ||
| 104 | #define IS_COMMAND() ( \ | ||
| 105 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||
| 106 | ) | ||
| 107 | |||
| 108 | /* control how magic key switches layers */ | ||
| 109 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS true | ||
| 110 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS true | ||
| 111 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM false | ||
| 112 | |||
| 113 | /* override magic key keymap */ | ||
| 114 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS | ||
| 115 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS | ||
| 116 | //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM | ||
| 117 | //#define MAGIC_KEY_HELP1 H | ||
| 118 | //#define MAGIC_KEY_HELP2 SLASH | ||
| 119 | //#define MAGIC_KEY_DEBUG D | ||
| 120 | //#define MAGIC_KEY_DEBUG_MATRIX X | ||
| 121 | //#define MAGIC_KEY_DEBUG_KBD K | ||
| 122 | //#define MAGIC_KEY_DEBUG_MOUSE M | ||
| 123 | //#define MAGIC_KEY_VERSION V | ||
| 124 | //#define MAGIC_KEY_STATUS S | ||
| 125 | //#define MAGIC_KEY_CONSOLE C | ||
| 126 | //#define MAGIC_KEY_LAYER0_ALT1 ESC | ||
| 127 | //#define MAGIC_KEY_LAYER0_ALT2 GRAVE | ||
| 128 | //#define MAGIC_KEY_LAYER0 0 | ||
| 129 | //#define MAGIC_KEY_LAYER1 1 | ||
| 130 | //#define MAGIC_KEY_LAYER2 2 | ||
| 131 | //#define MAGIC_KEY_LAYER3 3 | ||
| 132 | //#define MAGIC_KEY_LAYER4 4 | ||
| 133 | //#define MAGIC_KEY_LAYER5 5 | ||
| 134 | //#define MAGIC_KEY_LAYER6 6 | ||
| 135 | //#define MAGIC_KEY_LAYER7 7 | ||
| 136 | //#define MAGIC_KEY_LAYER8 8 | ||
| 137 | //#define MAGIC_KEY_LAYER9 9 | ||
| 138 | //#define MAGIC_KEY_BOOTLOADER PAUSE | ||
| 139 | //#define MAGIC_KEY_LOCK CAPS | ||
| 140 | //#define MAGIC_KEY_EEPROM E | ||
| 141 | //#define MAGIC_KEY_NKRO N | ||
| 142 | //#define MAGIC_KEY_SLEEP_LED Z | ||
| 143 | |||
| 144 | /* | ||
| 145 | * Feature disable options | ||
| 146 | * These options are also useful to firmware size reduction. | ||
| 147 | */ | ||
| 148 | |||
| 149 | /* disable debug print */ | ||
| 150 | //#define NO_DEBUG | ||
| 151 | |||
| 152 | /* disable print */ | ||
| 153 | //#define NO_PRINT | ||
| 154 | |||
| 155 | /* disable action features */ | ||
| 156 | //#define NO_ACTION_LAYER | ||
| 157 | //#define NO_ACTION_TAPPING | ||
| 158 | //#define NO_ACTION_ONESHOT | ||
| 159 | //#define NO_ACTION_MACRO | ||
| 160 | //#define NO_ACTION_FUNCTION | ||
| 161 | |||
| 162 | #endif | ||
diff --git a/keyboards/handwired/reddot/keymaps/default/keymap.c b/keyboards/handwired/reddot/keymaps/default/keymap.c new file mode 100755 index 000000000..44ee2ce51 --- /dev/null +++ b/keyboards/handwired/reddot/keymaps/default/keymap.c | |||
| @@ -0,0 +1,29 @@ | |||
| 1 | #include "reddot.h" | ||
| 2 | #include "../../../../../quantum/keymap_extras/keymap_french.h" | ||
| 3 | |||
| 4 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 5 | |||
| 6 | [0] = KEYMAP( | ||
| 7 | KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_TAB, KC_CAPS, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_FN0, KC_KP_SLASH, KC_KP_ASTERISK, KC_KP_MINUS,\ | ||
| 8 | KC_LALT, FR_AMP, FR_EACU, FR_QUOT, FR_APOS, FR_LPRN, KC_BSPACE, KC_DELETE, FR_MINS, FR_EGRV, FR_UNDS, FR_CCED, FR_AGRV, FR_RPRN, FR_EQL, KC_INSERT, KC_HOME, KC_PGUP,\ | ||
| 9 | KC_LGUI, FR_A, FR_Z, KC_E, KC_R, KC_T, KC_LSFT, KC_ENT, KC_Y, KC_U, KC_I, KC_O, KC_P, FR_CIRC, FR_DLR, KC_DELETE, KC_END, KC_PGDOWN, KC_KP_PLUS,\ | ||
| 10 | KC_LCTL, FR_Q, KC_S, KC_D, KC_F, KC_G, KC_ENT, KC_H, KC_J, KC_K, KC_L, FR_M, FR_UGRV, FR_ASTR, KC_KP_1, KC_UP, KC_KP_3,\ | ||
| 11 | FR_LESS, FR_W, KC_X, KC_C, KC_V, KC_B, KC_SPACE, KC_SPACE, KC_N, FR_COMM, FR_SCLN, FR_COLN, FR_EXLM, NO_ALGR, KC_LEFT, KC_DOWN, KC_RIGHT, KC_KP_ENTER), | ||
| 12 | |||
| 13 | [1] = KEYMAP( | ||
| 14 | KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_TAB, KC_CAPS, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_FN0, KC_KP_SLASH, KC_KP_ASTERISK, KC_KP_MINUS,\ | ||
| 15 | KC_LALT, FR_AMP, FR_EACU, FR_QUOT, FR_APOS, FR_LPRN, KC_BSPACE, KC_DELETE, FR_MINS, FR_EGRV, FR_UNDS, FR_CCED, FR_AGRV, FR_RPRN, FR_EQL, KC_7, KC_8, KC_9,\ | ||
| 16 | KC_LGUI, FR_A, FR_Z, KC_E, KC_R, KC_T, KC_LSFT, KC_ENT, KC_Y, KC_U, KC_I, KC_O, KC_P, FR_CIRC, FR_DLR, KC_4, KC_5, KC_6, KC_KP_PLUS,\ | ||
| 17 | KC_LCTL, FR_Q, KC_S, KC_D, KC_F, KC_G, KC_ENT, KC_H, KC_J, KC_K, KC_L, FR_M, FR_UGRV, FR_ASTR, KC_1, KC_2, KC_3,\ | ||
| 18 | FR_LESS, FR_W, KC_X, KC_C, KC_V, KC_B, KC_SPACE, KC_SPACE, KC_N, FR_COMM, FR_SCLN, FR_COLN, FR_EXLM, NO_ALGR, KC_LEFT, KC_DOWN, KC_RIGHT, KC_KP_ENTER), | ||
| 19 | }; | ||
| 20 | |||
| 21 | |||
| 22 | const uint16_t PROGMEM fn_actions[] = { | ||
| 23 | ACTION_LAYER_TOGGLE(1), | ||
| 24 | }; | ||
| 25 | |||
| 26 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) { | ||
| 27 | return MACRO_NONE; | ||
| 28 | }; | ||
| 29 | |||
diff --git a/keyboards/handwired/reddot/keymaps/default/readme.md b/keyboards/handwired/reddot/keymaps/default/readme.md new file mode 100755 index 000000000..f04833c3e --- /dev/null +++ b/keyboards/handwired/reddot/keymaps/default/readme.md | |||
| @@ -0,0 +1 @@ | |||
| # The default keymap for handwired/reddot | |||
diff --git a/keyboards/handwired/reddot/readme.md b/keyboards/handwired/reddot/readme.md new file mode 100755 index 000000000..11bcba54a --- /dev/null +++ b/keyboards/handwired/reddot/readme.md | |||
| @@ -0,0 +1,24 @@ | |||
| 1 | ## RedDot Specific Info ## | ||
| 2 | |||
| 3 | |||
| 4 | ## Quantum MK Firmware | ||
| 5 | |||
| 6 | For the full Quantum feature list, see [the parent README.md](/README.md). | ||
| 7 | |||
| 8 | ## Building | ||
| 9 | |||
| 10 | Download or clone the whole firmware and navigate to the keyboard/reddot folder. Once your dev env is setup, you'll be able to type `make` to generate your .hex - you can then use the Teensy Loader to program your .hex file. | ||
| 11 | |||
| 12 | Depending on which keymap you would like to use, you will have to compile slightly differently. | ||
| 13 | |||
| 14 | ### Default | ||
| 15 | To build with the default keymap, simply run `make`. | ||
| 16 | |||
| 17 | ### Other Keymaps | ||
| 18 | Several version of keymap are available in advance but you are recommended to define your favorite layout yourself. To define your own keymap create file named `<name>.c` and see keymap document (you can find in top README.md) and existent keymap files. | ||
| 19 | |||
| 20 | To build the firmware binary hex file with a keymap just do `make` with `KEYMAP` option like: | ||
| 21 | ``` | ||
| 22 | $ make KEYMAP=[default|jack|<name>] | ||
| 23 | ``` | ||
| 24 | Keymaps follow the format **__\<name\>.c__** and are stored in the `keymaps` folder. | ||
diff --git a/keyboards/handwired/reddot/reddot.c b/keyboards/handwired/reddot/reddot.c new file mode 100755 index 000000000..4e1efc06c --- /dev/null +++ b/keyboards/handwired/reddot/reddot.c | |||
| @@ -0,0 +1,7 @@ | |||
| 1 | #include "reddot.h" | ||
| 2 | |||
| 3 | void matrix_init_kb(void) { | ||
| 4 | |||
| 5 | matrix_init_user(); | ||
| 6 | } | ||
| 7 | |||
diff --git a/keyboards/handwired/reddot/reddot.h b/keyboards/handwired/reddot/reddot.h new file mode 100755 index 000000000..f0c4be557 --- /dev/null +++ b/keyboards/handwired/reddot/reddot.h | |||
| @@ -0,0 +1,20 @@ | |||
| 1 | #ifndef REDDOT_H | ||
| 2 | #define REDDOT_H | ||
| 3 | |||
| 4 | #include "quantum.h" | ||
| 5 | |||
| 6 | #define KEYMAP( \ | ||
| 7 | k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k10, k11, k12, k13, \ | ||
| 8 | k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, k2C, k2D, k2E, k30, k31, k32, \ | ||
| 9 | k40, k41, k42, k43, k44, k45, k46, k47, k48, k49, k4A, k4B, k4C, k4D, k4E, k50, k51, k52, k53, \ | ||
| 10 | k60, k61, k62, k63, k64, k65, k66, k68, k69, k6A, k6B, k6C, k6D, k6E, k70, k71, k72, \ | ||
| 11 | k80, k81, k82, k83, k84, k85, k86, k88, k89, k8A, k8B, k8C, k8D, k8E, k90, k91, k92, k93\ | ||
| 12 | ) { \ | ||
| 13 | { k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k10, k11, k12, k13 }, \ | ||
| 14 | { k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, k2C, k2D, k2E, k30, k31, k32, KC_NO }, \ | ||
| 15 | { k40, k41, k42, k43, k44, k45, k46, k47, k48, k49, k4A, k4B, k4C, k4D, k4E, k50, k51, k52, k53 }, \ | ||
| 16 | { k60, k61, k62, k63, k64, k65, k66, KC_NO, k68, k69, k6A, k6B, k6C, k6D, k6E, k70, k71, k72, KC_NO }, \ | ||
| 17 | { k80, k81, k82, k83, k84, k85, k86, KC_NO, k88, k89, k8A, k8B, k8C, k8D, k8E, k90, k91, k92, k93 } \ | ||
| 18 | } | ||
| 19 | |||
| 20 | #endif | ||
diff --git a/keyboards/handwired/reddot/rules.mk b/keyboards/handwired/reddot/rules.mk new file mode 100755 index 000000000..9a4409fe6 --- /dev/null +++ b/keyboards/handwired/reddot/rules.mk | |||
| @@ -0,0 +1,88 @@ | |||
| 1 | |||
| 2 | #MCU = at90usb1287 | ||
| 3 | MCU = atmega32u4 | ||
| 4 | |||
| 5 | # Processor frequency. | ||
| 6 | # This will define a symbol, F_CPU, in all source code files equal to the | ||
| 7 | # processor frequency in Hz. You can then use this symbol in your source code to | ||
| 8 | # calculate timings. Do NOT tack on a 'UL' at the end, this will be done | ||
| 9 | # automatically to create a 32-bit value in your source code. | ||
| 10 | # | ||
| 11 | # This will be an integer division of F_USB below, as it is sourced by | ||
| 12 | # F_USB after it has run through any CPU prescalers. Note that this value | ||
| 13 | # does not *change* the processor frequency - it should merely be updated to | ||
| 14 | # reflect the processor speed set externally so that the code can use accurate | ||
| 15 | # software delays. | ||
| 16 | F_CPU = 16000000 | ||
| 17 | |||
| 18 | # for avr upload | ||
| 19 | USB ?= /dev/cu.usbmodem1421 | ||
| 20 | # | ||
| 21 | # LUFA specific | ||
| 22 | # | ||
| 23 | # Target architecture (see library "Board Types" documentation). | ||
| 24 | ARCH = AVR8 | ||
| 25 | |||
| 26 | # Input clock frequency. | ||
| 27 | # This will define a symbol, F_USB, in all source code files equal to the | ||
| 28 | # input clock frequency (before any prescaling is performed) in Hz. This value may | ||
| 29 | # differ from F_CPU if prescaling is used on the latter, and is required as the | ||
| 30 | # raw input clock is fed directly to the PLL sections of the AVR for high speed | ||
| 31 | # clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL' | ||
| 32 | # at the end, this will be done automatically to create a 32-bit value in your | ||
| 33 | # source code. | ||
| 34 | # | ||
| 35 | # If no clock division is performed on the input clock inside the AVR (via the | ||
| 36 | # CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU. | ||
| 37 | F_USB = $(F_CPU) | ||
| 38 | |||
| 39 | |||
| 40 | ifdef TEENSY2 | ||
| 41 | OPT_DEFS += -DATREUS_TEENSY2 | ||
| 42 | ATREUS_UPLOAD_COMMAND = teensy_loader_cli -w -mmcu=$(MCU) $(TARGET).hex | ||
| 43 | else | ||
| 44 | OPT_DEFS += -DATREUS_ASTAR | ||
| 45 | OPT_DEFS += -DCATERINA_BOOTLOADER | ||
| 46 | ATREUS_UPLOAD_COMMAND = while [ ! -r $(USB) ]; do sleep 1; done; \ | ||
| 47 | avrdude -p $(MCU) -c avr109 -U flash:w:$(TARGET).hex -P $(USB) | ||
| 48 | endif | ||
| 49 | # Interrupt driven control endpoint task(+60) | ||
| 50 | OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT | ||
| 51 | |||
| 52 | |||
| 53 | # MCU name | ||
| 54 | |||
| 55 | # Boot Section Size in *bytes* | ||
| 56 | # Teensy halfKay 512 | ||
| 57 | # Teensy++ halfKay 1024 | ||
| 58 | # Atmel DFU loader 4096 | ||
| 59 | # LUFA bootloader 4096 | ||
| 60 | # USBaspLoader 2048 | ||
| 61 | OPT_DEFS += -DBOOTLOADER_SIZE=4096 | ||
| 62 | |||
| 63 | |||
| 64 | # Build Options | ||
| 65 | # change yes to no to disable | ||
| 66 | # | ||
| 67 | BOOTMAGIC_ENABLE ?= no # Virtual DIP switch configuration(+1000) | ||
| 68 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 69 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 70 | CONSOLE_ENABLE ?= no # Console for debug(+400) | ||
| 71 | COMMAND_ENABLE ?= no # Commands for debug and configuration | ||
| 72 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||
| 73 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend | ||
| 74 | # if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 75 | NKRO_ENABLE ?= no # USB Nkey Rollover | ||
| 76 | BACKLIGHT_ENABLE ?= no # Enable keyboard backlight functionality on B7 by default | ||
| 77 | MIDI_ENABLE ?= no # MIDI controls | ||
| 78 | UNICODE_ENABLE ?= no # Unicode | ||
| 79 | BLUETOOTH_ENABLE ?= no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 80 | AUDIO_ENABLE ?= no # Audio output on port C6 | ||
| 81 | |||
| 82 | ifndef QUANTUM_DIR | ||
| 83 | include ../../../Makefile | ||
| 84 | endif | ||
| 85 | |||
| 86 | upload: build | ||
| 87 | $(ATREUS_UPLOAD_COMMAND) | ||
| 88 | |||
diff --git a/keyboards/kc60/kc60.c b/keyboards/kc60/kc60.c index 746ac634a..09b924b28 100644 --- a/keyboards/kc60/kc60.c +++ b/keyboards/kc60/kc60.c | |||
| @@ -1 +1,16 @@ | |||
| 1 | #include "kc60.h" | 1 | #include "kc60.h" |
| 2 | |||
| 3 | void led_set_kb(uint8_t usb_led) | ||
| 4 | { | ||
| 5 | if (usb_led & (1<<USB_LED_CAPS_LOCK)) { | ||
| 6 | // output low | ||
| 7 | DDRB |= (1<<2); | ||
| 8 | PORTB &= ~(1<<2); | ||
| 9 | } else { | ||
| 10 | // Hi-Z | ||
| 11 | DDRB &= ~(1<<2); | ||
| 12 | PORTB &= ~(1<<2); | ||
| 13 | } | ||
| 14 | |||
| 15 | led_set_user(usb_led); | ||
| 16 | } \ No newline at end of file | ||
diff --git a/keyboards/kc60/rules.mk b/keyboards/kc60/rules.mk index a935ed19e..06bd5dc92 100644 --- a/keyboards/kc60/rules.mk +++ b/keyboards/kc60/rules.mk | |||
| @@ -1,6 +1,3 @@ | |||
| 1 | # project specific files | ||
| 2 | SRC = led.c | ||
| 3 | |||
| 4 | # MCU name | 1 | # MCU name |
| 5 | #MCU = at90usb1287 | 2 | #MCU = at90usb1287 |
| 6 | MCU = atmega32u4 | 3 | MCU = atmega32u4 |
diff --git a/keyboards/lets_split/Makefile b/keyboards/lets_split/Makefile index 4e2a6f00f..f5c87d4d6 100644 --- a/keyboards/lets_split/Makefile +++ b/keyboards/lets_split/Makefile | |||
| @@ -1,3 +1,5 @@ | |||
| 1 | SUBPROJECT_DEFAULT = rev2 | ||
| 2 | |||
| 1 | ifndef MAKEFILE_INCLUDED | 3 | ifndef MAKEFILE_INCLUDED |
| 2 | include ../../Makefile | 4 | include ../../Makefile |
| 3 | endif \ No newline at end of file | 5 | endif |
diff --git a/keyboards/lets_split/config.h b/keyboards/lets_split/config.h index 7df0c5752..008fb0978 100644 --- a/keyboards/lets_split/config.h +++ b/keyboards/lets_split/config.h | |||
| @@ -26,4 +26,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 26 | #ifdef SUBPROJECT_rev2 | 26 | #ifdef SUBPROJECT_rev2 |
| 27 | #include "rev2/config.h" | 27 | #include "rev2/config.h" |
| 28 | #endif | 28 | #endif |
| 29 | #ifdef SUBPROJECT_rev2fliphalf | ||
| 30 | #include "../../rev2fliphalf/config.h" | ||
| 31 | #endif | ||
| 29 | #endif | 32 | #endif |
diff --git a/keyboards/lets_split/eeprom-lefthand.eep b/keyboards/lets_split/eeprom-lefthand.eep index a92200b12..b9666a74c 100644 --- a/keyboards/lets_split/eeprom-lefthand.eep +++ b/keyboards/lets_split/eeprom-lefthand.eep | |||
| @@ -1,2 +1,2 @@ | |||
| 1 | :080000000000000000000001F7 | 1 | :0B0000000000000000000000000001F4 |
| 2 | :00000001FF | 2 | :00000001FF |
diff --git a/keyboards/lets_split/eeprom-righthand.eep b/keyboards/lets_split/eeprom-righthand.eep index 91a683170..94cc5be7f 100644 --- a/keyboards/lets_split/eeprom-righthand.eep +++ b/keyboards/lets_split/eeprom-righthand.eep | |||
| @@ -1,2 +1,2 @@ | |||
| 1 | :080000000000000000000000F8 | 1 | :0B0000000000000000000000000000F5 |
| 2 | :00000001FF | 2 | :00000001FF |
diff --git a/keyboards/lets_split/keymaps/i2c/config.h b/keyboards/lets_split/keymaps/i2c/config.h index efe8bb0f2..013542731 100644 --- a/keyboards/lets_split/keymaps/i2c/config.h +++ b/keyboards/lets_split/keymaps/i2c/config.h | |||
| @@ -16,12 +16,16 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 16 | */ | 16 | */ |
| 17 | #define USE_I2C | 17 | #define USE_I2C |
| 18 | 18 | ||
| 19 | #define I2C_MASTER_LEFT | 19 | #define MASTER_LEFT |
| 20 | // #define I2C_MASTER_RIGHT | 20 | // #define _MASTER_RIGHT |
| 21 | // #define EE_HANDS | ||
| 21 | 22 | ||
| 22 | #ifdef SUBPROJECT_rev1 | 23 | #ifdef SUBPROJECT_rev1 |
| 23 | #include "../../rev1/config.h" | 24 | #include "../../rev1/config.h" |
| 24 | #endif | 25 | #endif |
| 25 | #ifdef SUBPROJECT_rev2 | 26 | #ifdef SUBPROJECT_rev2 |
| 26 | #include "../../rev2/config.h" | 27 | #include "../../rev2/config.h" |
| 27 | #endif \ No newline at end of file | 28 | #endif |
| 29 | #ifdef SUBPROJECT_rev2fliphalf | ||
| 30 | #include "../../rev2fliphalf/config.h" | ||
| 31 | #endif | ||
diff --git a/keyboards/lets_split/keymaps/serial/config.h b/keyboards/lets_split/keymaps/serial/config.h index cd766cc4f..ba271d1ac 100644 --- a/keyboards/lets_split/keymaps/serial/config.h +++ b/keyboards/lets_split/keymaps/serial/config.h | |||
| @@ -18,7 +18,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 18 | 18 | ||
| 19 | #define USE_SERIAL | 19 | #define USE_SERIAL |
| 20 | 20 | ||
| 21 | #define EE_HANDS | 21 | #define MASTER_LEFT |
| 22 | // #define _MASTER_RIGHT | ||
| 23 | // #define EE_HANDS | ||
| 22 | 24 | ||
| 23 | 25 | ||
| 24 | #ifdef SUBPROJECT_rev1 | 26 | #ifdef SUBPROJECT_rev1 |
| @@ -26,4 +28,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 26 | #endif | 28 | #endif |
| 27 | #ifdef SUBPROJECT_rev2 | 29 | #ifdef SUBPROJECT_rev2 |
| 28 | #include "../../rev2/config.h" | 30 | #include "../../rev2/config.h" |
| 29 | #endif \ No newline at end of file | 31 | #endif |
| 32 | #ifdef SUBPROJECT_rev2fliphalf | ||
| 33 | #include "../../rev2fliphalf/config.h" | ||
| 34 | #endif | ||
diff --git a/keyboards/lets_split/lets_split.h b/keyboards/lets_split/lets_split.h index 2cdfb061f..0de308c7a 100644 --- a/keyboards/lets_split/lets_split.h +++ b/keyboards/lets_split/lets_split.h | |||
| @@ -7,6 +7,9 @@ | |||
| 7 | #ifdef SUBPROJECT_rev2 | 7 | #ifdef SUBPROJECT_rev2 |
| 8 | #include "rev2.h" | 8 | #include "rev2.h" |
| 9 | #endif | 9 | #endif |
| 10 | #ifdef SUBPROJECT_rev2fliphalf | ||
| 11 | #include "rev2fliphalf.h" | ||
| 12 | #endif | ||
| 10 | 13 | ||
| 11 | #include "quantum.h" | 14 | #include "quantum.h" |
| 12 | 15 | ||
diff --git a/keyboards/lets_split/readme.md b/keyboards/lets_split/readme.md index 6e296737a..ecce3f415 100644 --- a/keyboards/lets_split/readme.md +++ b/keyboards/lets_split/readme.md | |||
| @@ -6,9 +6,45 @@ This readme and most of the code are from https://github.com/ahtn/tmk_keyboard/ | |||
| 6 | Split keyboard firmware for Arduino Pro Micro or other ATmega32u4 | 6 | Split keyboard firmware for Arduino Pro Micro or other ATmega32u4 |
| 7 | based boards. | 7 | based boards. |
| 8 | 8 | ||
| 9 | |||
| 10 | ## First Time Setup | ||
| 11 | |||
| 12 | Download or clone the whole firmware and navigate to the keyboards/lets_split directory. Once your dev env is setup, you'll be able to generate the default .hex using: | ||
| 13 | |||
| 14 | ``` | ||
| 15 | $ make rev2 | ||
| 16 | ``` | ||
| 17 | |||
| 18 | You will see a lot of output and if everything worked correctly you will see the built hex files: | ||
| 19 | |||
| 20 | ``` | ||
| 21 | lets_split_rev2_serial.hex | ||
| 22 | lets_split_rev2_i2c.hex | ||
| 23 | ``` | ||
| 24 | |||
| 25 | If you would like to use one of the alternative keymaps, or create your own, copy one of the existing [keymaps](keymaps/) and run make like so: | ||
| 26 | |||
| 27 | |||
| 28 | ``` | ||
| 29 | $ make rev2-YOUR_KEYMAP_NAME | ||
| 30 | ``` | ||
| 31 | |||
| 32 | If everything worked correctly you will see a file: | ||
| 33 | |||
| 34 | ``` | ||
| 35 | lets_split_rev2_YOUR_KEYMAP_NAME.hex | ||
| 36 | ``` | ||
| 37 | |||
| 38 | For more information on customizing keymaps, take a look at the primary documentation for [Customizing Your Keymap](/readme.md##customizing-your-keymap) in the main readme.md. | ||
| 39 | |||
| 40 | ### Let's split 1.0 | ||
| 41 | If you have a first generation Let's Split you will need to use the revision 1 code. To do so, use `rev1` in all your commands instead. | ||
| 42 | |||
| 9 | Features | 43 | Features |
| 10 | -------- | 44 | -------- |
| 11 | 45 | ||
| 46 | For the full Quantum Mechanical Keyboard feature list, see [the parent readme.md](/readme.md). | ||
| 47 | |||
| 12 | Some features supported by the firmware: | 48 | Some features supported by the firmware: |
| 13 | 49 | ||
| 14 | * Either half can connect to the computer via USB, or both halves can be used | 50 | * Either half can connect to the computer via USB, or both halves can be used |
| @@ -62,7 +98,7 @@ unnecessary in simple use cases. | |||
| 62 | Notes on Software Configuration | 98 | Notes on Software Configuration |
| 63 | ------------------------------- | 99 | ------------------------------- |
| 64 | 100 | ||
| 65 | Configuring the firmware is similar to any other TMK project. One thing | 101 | Configuring the firmware is similar to any other QMK project. One thing |
| 66 | to note is that `MATIX_ROWS` in `config.h` is the total number of rows between | 102 | to note is that `MATIX_ROWS` in `config.h` is the total number of rows between |
| 67 | the two halves, i.e. if your split keyboard has 4 rows in each half, then | 103 | the two halves, i.e. if your split keyboard has 4 rows in each half, then |
| 68 | `MATRIX_ROWS=8`. | 104 | `MATRIX_ROWS=8`. |
| @@ -70,33 +106,59 @@ the two halves, i.e. if your split keyboard has 4 rows in each half, then | |||
| 70 | Also the current implementation assumes a maximum of 8 columns, but it would | 106 | Also the current implementation assumes a maximum of 8 columns, but it would |
| 71 | not be very difficult to adapt it to support more if required. | 107 | not be very difficult to adapt it to support more if required. |
| 72 | 108 | ||
| 73 | |||
| 74 | Flashing | 109 | Flashing |
| 110 | ------- | ||
| 111 | From the keymap directory run `make SUBPROJECT-KEYMAP-avrdude` for automatic serial port resolution and flashing. | ||
| 112 | Example: `make rev2-serial-avrdude` | ||
| 113 | |||
| 114 | |||
| 115 | Choosing which board to plug the USB cable into (choosing Master) | ||
| 75 | -------- | 116 | -------- |
| 117 | Because the two boards are identical, the firmware has logic to differentiate the left and right board. | ||
| 118 | |||
| 119 | It uses two strategies to figure things out: look at the EEPROM (memory on the chip) or looks if the current board has the usb cable. | ||
| 120 | |||
| 121 | The EEPROM approach requires additional setup (flashing the eeeprom) but allows you to swap the usb cable to either side. | ||
| 122 | |||
| 123 | The USB cable approach is easier to setup and if you just want the usb cable on the left board, you do not need to do anything extra. | ||
| 124 | |||
| 125 | ### Setting the left hand as master | ||
| 126 | If you always plug the usb cable into the left board, nothing extra is needed as this is the default. Comment out `EE_HANDS` and comment out `I2C_MASTER_RIGHT` or `MASTER_RIGHT` if for some reason it was set. | ||
| 76 | 127 | ||
| 128 | ### Setting the right hand as master | ||
| 129 | If you always plug the usb cable into the right board, add an extra flag to your `config.h` | ||
| 130 | ``` | ||
| 131 | #define MASTER_RIGHT | ||
| 132 | ``` | ||
| 133 | |||
| 134 | ### Setting EE_hands to use either hands as master | ||
| 77 | If you define `EE_HANDS` in your `config.h`, you will need to set the | 135 | If you define `EE_HANDS` in your `config.h`, you will need to set the |
| 78 | EEPROM for the left and right halves. The EEPROM is used to store whether the | 136 | EEPROM for the left and right halves. |
| 137 | |||
| 138 | The EEPROM is used to store whether the | ||
| 79 | half is left handed or right handed. This makes it so that the same firmware | 139 | half is left handed or right handed. This makes it so that the same firmware |
| 80 | file will run on both hands instead of having to flash left and right handed | 140 | file will run on both hands instead of having to flash left and right handed |
| 81 | versions of the firmware to each half. To flash the EEPROM file for the left | 141 | versions of the firmware to each half. To flash the EEPROM file for the left |
| 82 | half run: | 142 | half run: |
| 83 | ``` | 143 | ``` |
| 84 | make eeprom-left | 144 | avrdude -p atmega32u4 -P $(COM_PORT) -c avr109 -U eeprom:w:eeprom-lefthand.eep |
| 145 | // or the equivalent in dfu-programmer | ||
| 146 | |||
| 85 | ``` | 147 | ``` |
| 86 | and similarly for right half | 148 | and similarly for right half |
| 87 | ``` | 149 | ``` |
| 88 | make eeprom-right | 150 | avrdude -p atmega32u4 -P $(COM_PORT) -c avr109 -U eeprom:w:eeprom-righhand.eep |
| 151 | // or the equivalent in dfu-programmer | ||
| 89 | ``` | 152 | ``` |
| 90 | 153 | ||
| 91 | After you have flashed the EEPROM for the first time, you then need to program | 154 | NOTE: replace `$(COM_PORT)` with the port of your device (e.g. `/dev/ttyACM0`) |
| 92 | the flash memory: | 155 | |
| 93 | ``` | 156 | After you have flashed the EEPROM, you then need to set `EE_HANDS` in your config.h, rebuild the hex files and reflash. |
| 94 | make program | 157 | |
| 95 | ``` | ||
| 96 | Note that you need to program both halves, but you have the option of using | 158 | Note that you need to program both halves, but you have the option of using |
| 97 | different keymaps for each half. You could program the left half with a QWERTY | 159 | different keymaps for each half. You could program the left half with a QWERTY |
| 98 | layout and the right half with a Colemak layout. Then if you connect the left | 160 | layout and the right half with a Colemak layout using bootmagic's default layout option. |
| 99 | half to a computer by USB the keyboard will use QWERTY and Colemak when the | 161 | Then if you connect the left half to a computer by USB the keyboard will use QWERTY and Colemak when the |
| 100 | right half is connected. | 162 | right half is connected. |
| 101 | 163 | ||
| 102 | 164 | ||
diff --git a/keyboards/lets_split/rev2/rev2.h b/keyboards/lets_split/rev2/rev2.h index 7c397912f..990976de2 100644 --- a/keyboards/lets_split/rev2/rev2.h +++ b/keyboards/lets_split/rev2/rev2.h | |||
| @@ -9,10 +9,10 @@ | |||
| 9 | //void promicro_bootloader_jmp(bool program); | 9 | //void promicro_bootloader_jmp(bool program); |
| 10 | 10 | ||
| 11 | #define KEYMAP( \ | 11 | #define KEYMAP( \ |
| 12 | k00, k01, k02, k03, k04, k05, k40, k41, k42, k43, k44, k45, \ | 12 | k00, k01, k02, k03, k04, k05, k45, k44, k43, k42, k41, k40, \ |
| 13 | k10, k11, k12, k13, k14, k15, k50, k51, k52, k53, k54, k55, \ | 13 | k10, k11, k12, k13, k14, k15, k55, k54, k53, k52, k51, k50, \ |
| 14 | k20, k21, k22, k23, k24, k25, k60, k61, k62, k63, k64, k65, \ | 14 | k20, k21, k22, k23, k24, k25, k65, k64, k63, k62, k61, k60, \ |
| 15 | k30, k31, k32, k33, k34, k35, k70, k71, k72, k73, k74, k75 \ | 15 | k30, k31, k32, k33, k34, k35, k75, k74, k73, k72, k71, k70 \ |
| 16 | ) \ | 16 | ) \ |
| 17 | { \ | 17 | { \ |
| 18 | { k00, k01, k02, k03, k04, k05 }, \ | 18 | { k00, k01, k02, k03, k04, k05 }, \ |
diff --git a/keyboards/lets_split/rev2fliphalf/Makefile b/keyboards/lets_split/rev2fliphalf/Makefile new file mode 100644 index 000000000..4e2a6f00f --- /dev/null +++ b/keyboards/lets_split/rev2fliphalf/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef MAKEFILE_INCLUDED | ||
| 2 | include ../../Makefile | ||
| 3 | endif \ No newline at end of file | ||
diff --git a/keyboards/lets_split/rev2fliphalf/config.h b/keyboards/lets_split/rev2fliphalf/config.h new file mode 100644 index 000000000..1c45cf136 --- /dev/null +++ b/keyboards/lets_split/rev2fliphalf/config.h | |||
| @@ -0,0 +1,91 @@ | |||
| 1 | /* | ||
| 2 | Copyright 2012 Jun Wako <wakojun@gmail.com> | ||
| 3 | |||
| 4 | This program is free software: you can redistribute it and/or modify | ||
| 5 | it under the terms of the GNU General Public License as published by | ||
| 6 | the Free Software Foundation, either version 2 of the License, or | ||
| 7 | (at your option) any later version. | ||
| 8 | |||
| 9 | This program is distributed in the hope that it will be useful, | ||
| 10 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | GNU General Public License for more details. | ||
| 13 | |||
| 14 | You should have received a copy of the GNU General Public License | ||
| 15 | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 16 | */ | ||
| 17 | |||
| 18 | #ifndef CONFIG_H | ||
| 19 | #define CONFIG_H | ||
| 20 | |||
| 21 | #include "config_common.h" | ||
| 22 | |||
| 23 | /* USB Device descriptor parameter */ | ||
| 24 | #define VENDOR_ID 0xFEED | ||
| 25 | #define PRODUCT_ID 0x3060 | ||
| 26 | #define DEVICE_VER 0x0001 | ||
| 27 | #define MANUFACTURER Wootpatoot | ||
| 28 | #define PRODUCT Lets Split v2 | ||
| 29 | #define DESCRIPTION A split keyboard for the cheap makers | ||
| 30 | |||
| 31 | /* key matrix size */ | ||
| 32 | // Rows are doubled-up | ||
| 33 | #define MATRIX_ROWS 8 | ||
| 34 | #define MATRIX_COLS 6 | ||
| 35 | |||
| 36 | // wiring of each half | ||
| 37 | #define MATRIX_ROW_PINS { D7, E6, B4, B5 } | ||
| 38 | //#define MATRIX_COL_PINS { F6, F7, B1, B3, B2, B6 } | ||
| 39 | #define MATRIX_COL_PINS { B6, B2, B3, B1, F7, F6 } //uncomment this line and comment line above if you need to reverse left-to-right key order | ||
| 40 | |||
| 41 | //#define CATERINA_BOOTLOADER | ||
| 42 | |||
| 43 | /* COL2ROW or ROW2COL */ | ||
| 44 | #define DIODE_DIRECTION COL2ROW | ||
| 45 | |||
| 46 | /* define if matrix has ghost */ | ||
| 47 | //#define MATRIX_HAS_GHOST | ||
| 48 | |||
| 49 | /* number of backlight levels */ | ||
| 50 | // #define BACKLIGHT_LEVELS 3 | ||
| 51 | |||
| 52 | /* Set 0 if debouncing isn't needed */ | ||
| 53 | #define DEBOUNCING_DELAY 5 | ||
| 54 | |||
| 55 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||
| 56 | #define LOCKING_SUPPORT_ENABLE | ||
| 57 | /* Locking resynchronize hack */ | ||
| 58 | #define LOCKING_RESYNC_ENABLE | ||
| 59 | |||
| 60 | /* key combination for command */ | ||
| 61 | #define IS_COMMAND() ( \ | ||
| 62 | keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||
| 63 | ) | ||
| 64 | |||
| 65 | /* ws2812 RGB LED */ | ||
| 66 | #define RGB_DI_PIN D3 | ||
| 67 | #define RGBLIGHT_TIMER | ||
| 68 | #define RGBLED_NUM 12 // Number of LEDs | ||
| 69 | #define ws2812_PORTREG PORTD | ||
| 70 | #define ws2812_DDRREG DDRD | ||
| 71 | |||
| 72 | /* | ||
| 73 | * Feature disable options | ||
| 74 | * These options are also useful to firmware size reduction. | ||
| 75 | */ | ||
| 76 | |||
| 77 | /* disable debug print */ | ||
| 78 | // #define NO_DEBUG | ||
| 79 | |||
| 80 | /* disable print */ | ||
| 81 | // #define NO_PRINT | ||
| 82 | |||
| 83 | /* disable action features */ | ||
| 84 | //#define NO_ACTION_LAYER | ||
| 85 | //#define NO_ACTION_TAPPING | ||
| 86 | //#define NO_ACTION_ONESHOT | ||
| 87 | //#define NO_ACTION_MACRO | ||
| 88 | //#define NO_ACTION_FUNCTION | ||
| 89 | |||
| 90 | |||
| 91 | #endif \ No newline at end of file | ||
diff --git a/keyboards/lets_split/rev2fliphalf/rev2fliphalf.c b/keyboards/lets_split/rev2fliphalf/rev2fliphalf.c new file mode 100644 index 000000000..c505d3a6e --- /dev/null +++ b/keyboards/lets_split/rev2fliphalf/rev2fliphalf.c | |||
| @@ -0,0 +1,32 @@ | |||
| 1 | #include "lets_split.h" | ||
| 2 | |||
| 3 | #ifdef AUDIO_ENABLE | ||
| 4 | float tone_startup[][2] = SONG(STARTUP_SOUND); | ||
| 5 | float tone_goodbye[][2] = SONG(GOODBYE_SOUND); | ||
| 6 | #endif | ||
| 7 | |||
| 8 | void matrix_init_kb(void) { | ||
| 9 | |||
| 10 | #ifdef AUDIO_ENABLE | ||
| 11 | _delay_ms(20); // gets rid of tick | ||
| 12 | PLAY_NOTE_ARRAY(tone_startup, false, 0); | ||
| 13 | #endif | ||
| 14 | |||
| 15 | // // green led on | ||
| 16 | // DDRD |= (1<<5); | ||
| 17 | // PORTD &= ~(1<<5); | ||
| 18 | |||
| 19 | // // orange led on | ||
| 20 | // DDRB |= (1<<0); | ||
| 21 | // PORTB &= ~(1<<0); | ||
| 22 | |||
| 23 | matrix_init_user(); | ||
| 24 | }; | ||
| 25 | |||
| 26 | void shutdown_user(void) { | ||
| 27 | #ifdef AUDIO_ENABLE | ||
| 28 | PLAY_NOTE_ARRAY(tone_goodbye, false, 0); | ||
| 29 | _delay_ms(150); | ||
| 30 | stop_all_notes(); | ||
| 31 | #endif | ||
| 32 | } | ||
diff --git a/keyboards/lets_split/rev2fliphalf/rev2fliphalf.h b/keyboards/lets_split/rev2fliphalf/rev2fliphalf.h new file mode 100644 index 000000000..7dc8e5ba8 --- /dev/null +++ b/keyboards/lets_split/rev2fliphalf/rev2fliphalf.h | |||
| @@ -0,0 +1,28 @@ | |||
| 1 | #ifndef REV2FLIPHALF_H | ||
| 2 | #define REV2FLIPHALF_H | ||
| 3 | |||
| 4 | #include "../lets_split.h" | ||
| 5 | |||
| 6 | //void promicro_bootloader_jmp(bool program); | ||
| 7 | #include "quantum.h" | ||
| 8 | |||
| 9 | //void promicro_bootloader_jmp(bool program); | ||
| 10 | |||
| 11 | #define KEYMAP( \ | ||
| 12 | k00, k01, k02, k03, k04, k05, k40, k41, k42, k43, k44, k45, \ | ||
| 13 | k10, k11, k12, k13, k14, k15, k50, k51, k52, k53, k54, k55, \ | ||
| 14 | k20, k21, k22, k23, k24, k25, k60, k61, k62, k63, k64, k65, \ | ||
| 15 | k30, k31, k32, k33, k34, k35, k70, k71, k72, k73, k74, k75 \ | ||
| 16 | ) \ | ||
| 17 | { \ | ||
| 18 | { k00, k01, k02, k03, k04, k05 }, \ | ||
| 19 | { k10, k11, k12, k13, k14, k15 }, \ | ||
| 20 | { k20, k21, k22, k23, k24, k25 }, \ | ||
| 21 | { k30, k31, k32, k33, k34, k35 }, \ | ||
| 22 | { k40, k41, k42, k43, k44, k45 }, \ | ||
| 23 | { k50, k51, k52, k53, k54, k55 }, \ | ||
| 24 | { k60, k61, k62, k63, k64, k65 }, \ | ||
| 25 | { k70, k71, k72, k73, k74, k75 } \ | ||
| 26 | } | ||
| 27 | |||
| 28 | #endif \ No newline at end of file | ||
diff --git a/keyboards/lets_split/rev2fliphalf/rules.mk b/keyboards/lets_split/rev2fliphalf/rules.mk new file mode 100644 index 000000000..80a942d06 --- /dev/null +++ b/keyboards/lets_split/rev2fliphalf/rules.mk | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | BACKLIGHT_ENABLE = no | ||
| 2 | |||
| 3 | ifndef QUANTUM_DIR | ||
| 4 | include ../../../Makefile | ||
| 5 | endif | ||
diff --git a/keyboards/lets_split/rules.mk b/keyboards/lets_split/rules.mk index 1aee5313c..0efa78550 100644 --- a/keyboards/lets_split/rules.mk +++ b/keyboards/lets_split/rules.mk | |||
| @@ -73,3 +73,15 @@ USE_I2C ?= yes | |||
| 73 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend | 73 | SLEEP_LED_ENABLE ?= no # Breathing sleep LED during USB suspend |
| 74 | 74 | ||
| 75 | CUSTOM_MATRIX = yes | 75 | CUSTOM_MATRIX = yes |
| 76 | |||
| 77 | avrdude: build | ||
| 78 | ls /dev/tty* > /tmp/1; \ | ||
| 79 | echo "Reset your Pro Micro now"; \ | ||
| 80 | while [[ -z $$USB ]]; do \ | ||
| 81 | sleep 1; \ | ||
| 82 | ls /dev/tty* > /tmp/2; \ | ||
| 83 | USB=`diff /tmp/1 /tmp/2 | grep -o '/dev/tty.*'`; \ | ||
| 84 | done; \ | ||
| 85 | avrdude -p $(MCU) -c avr109 -P $$USB -U flash:w:$(BUILD_DIR)/$(TARGET).hex | ||
| 86 | |||
| 87 | .PHONY: avrdude | ||
diff --git a/keyboards/lets_split/split_util.c b/keyboards/lets_split/split_util.c index 461921798..226dc1881 100644 --- a/keyboards/lets_split/split_util.c +++ b/keyboards/lets_split/split_util.c | |||
| @@ -21,7 +21,8 @@ static void setup_handedness(void) { | |||
| 21 | #ifdef EE_HANDS | 21 | #ifdef EE_HANDS |
| 22 | isLeftHand = eeprom_read_byte(EECONFIG_HANDEDNESS); | 22 | isLeftHand = eeprom_read_byte(EECONFIG_HANDEDNESS); |
| 23 | #else | 23 | #else |
| 24 | #ifdef I2C_MASTER_RIGHT | 24 | // I2C_MASTER_RIGHT is deprecated use MASTER_RIGHT instead since this works for both serial and i2c |
| 25 | #if defined(I2C_MASTER_RIGHT) || defined(MASTER_RIGHT) | ||
| 25 | isLeftHand = !has_usb(); | 26 | isLeftHand = !has_usb(); |
| 26 | #else | 27 | #else |
| 27 | isLeftHand = has_usb(); | 28 | isLeftHand = has_usb(); |
diff --git a/keyboards/planck/keymaps/bone2planck/Makefile b/keyboards/planck/keymaps/bone2planck/Makefile index cf2c31f0f..39635192e 100644 --- a/keyboards/planck/keymaps/bone2planck/Makefile +++ b/keyboards/planck/keymaps/bone2planck/Makefile | |||
| @@ -1,20 +1,16 @@ | |||
| 1 | # Please remove if no longer applicable | ||
| 2 | $(warning THIS FILE MAY BE TOO LARGE FOR YOUR KEYBOARD) | ||
| 3 | $(warning Please disable some options in the Makefile to resolve) | ||
| 4 | |||
| 5 | # Build Options | 1 | # Build Options |
| 6 | # change to "no" to disable the options, or define them in the Makefile in | 2 | # change to "no" to disable the options, or define them in the Makefile in |
| 7 | # the appropriate keymap folder that will get included automatically | 3 | # the appropriate keymap folder that will get included automatically |
| 8 | # | 4 | # |
| 9 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | 5 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) |
| 10 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | 6 | MOUSEKEY_ENABLE = no # Mouse keys(+4700) |
| 11 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | 7 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) |
| 12 | CONSOLE_ENABLE = no # Console for debug(+400) | 8 | CONSOLE_ENABLE = no # Console for debug(+400) |
| 13 | COMMAND_ENABLE = yes # Commands for debug and configuration | 9 | COMMAND_ENABLE = no # Commands for debug and configuration |
| 14 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | 10 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work |
| 15 | BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality | 11 | BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality |
| 16 | MIDI_ENABLE = no # MIDI controls | 12 | MIDI_ENABLE = no # MIDI controls |
| 17 | AUDIO_ENABLE = yes # Audio output on port C6 | 13 | AUDIO_ENABLE = no # Audio output on port C6 |
| 18 | UNICODE_ENABLE = no # Unicode | 14 | UNICODE_ENABLE = no # Unicode |
| 19 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | 15 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID |
| 20 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | 16 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. |
diff --git a/keyboards/planck/keymaps/bone2planck/config.h b/keyboards/planck/keymaps/bone2planck/config.h index 60aff6db0..3e9e692d3 100644 --- a/keyboards/planck/keymaps/bone2planck/config.h +++ b/keyboards/planck/keymaps/bone2planck/config.h | |||
| @@ -1,7 +1,8 @@ | |||
| 1 | #ifndef CONFIG_USER_H | 1 | #ifndef CONFIG_USER_H |
| 2 | #define CONFIG_USER_H | 2 | #define CONFIG_USER_H |
| 3 | #endif | ||
| 4 | 3 | ||
| 5 | #include "../../config.h" | 4 | #include "../../config.h" |
| 6 | 5 | ||
| 7 | #define PREVENT_STUCK_MODIFIERS \ No newline at end of file | 6 | #define PREVENT_STUCK_MODIFIERS |
| 7 | |||
| 8 | #endif \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/bone2planck/keymap.c b/keyboards/planck/keymaps/bone2planck/keymap.c index 69d164b8c..5f77acf91 100644 --- a/keyboards/planck/keymaps/bone2planck/keymap.c +++ b/keyboards/planck/keymaps/bone2planck/keymap.c | |||
| @@ -7,11 +7,12 @@ | |||
| 7 | // for intellisense, has to be commented for building | 7 | // for intellisense, has to be commented for building |
| 8 | /* | 8 | /* |
| 9 | #include "..\..\..\..\quantum\keymap_extras\keymap_german.h" | 9 | #include "..\..\..\..\quantum\keymap_extras\keymap_german.h" |
| 10 | #include "..\..\..\..\quantum\keymap_common.h" | ||
| 11 | #include "..\..\..\..\tmk_core\common\keycode.h" | 10 | #include "..\..\..\..\tmk_core\common\keycode.h" |
| 12 | */ | 11 | */ |
| 13 | 12 | ||
| 13 | |||
| 14 | #define _______ KC_TRNS | 14 | #define _______ KC_TRNS |
| 15 | #define XXXXXXX KC_NO | ||
| 15 | 16 | ||
| 16 | /* This Layout tries to emulate the Bone2 Variant of Neo2, and is intended to be used with a German QWERTZ Softwarelayout. | 17 | /* This Layout tries to emulate the Bone2 Variant of Neo2, and is intended to be used with a German QWERTZ Softwarelayout. |
| 17 | It has "üäöß" as it is optimized for a mix of German & English. | 18 | It has "üäöß" as it is optimized for a mix of German & English. |
| @@ -23,11 +24,11 @@ Bone2 wiki page: http://wiki.neo-layout.org/wiki/Bone | |||
| 23 | 24 | ||
| 24 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | 25 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { |
| 25 | 26 | ||
| 26 | /* Bone2 | 27 | /* Bone2 (adapted) |
| 27 | * ,-----------------------------------------------------------------------------------. | 28 | * ,-----------------------------------------------------------------------------------. |
| 28 | * | Q | J | D | U | A | X | P | H | L | M | W | ẞ | | 29 | * | ß | J | D | U | A | X | P | H | L | M | W | Q | |
| 29 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 30 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 30 | * |M1/Tab| C | T | I | E | O | B | N | R | S | G |M1/Ent| //hold for M1, tap for Tab/Enter | 31 | * | M1 | C | T | I | E | O | B | N | R | S | G |M1/Ent| //hold for M1, tap for Enter |
| 31 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 32 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 32 | * | Shift| F | V | Ü | Ä | Ö | Y | Z | , | . | K |Shift | | 33 | * | Shift| F | V | Ü | Ä | Ö | Y | Z | , | . | K |Shift | |
| 33 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 34 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| @@ -35,20 +36,21 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 35 | * `-----------------------------------------------------------------------------------' | 36 | * `-----------------------------------------------------------------------------------' |
| 36 | */ | 37 | */ |
| 37 | [0] = { | 38 | [0] = { |
| 38 | { DE_Q, DE_J, DE_D, DE_U, DE_A, DE_X, DE_P, DE_H, DE_L, DE_M, DE_W, DE_SS }, | 39 | { DE_SS, DE_J, DE_D, DE_U, DE_A, DE_X, DE_P, DE_H, DE_L, DE_M, DE_W, DE_Q }, |
| 39 | { LT(1,KC_TAB), DE_C, DE_T, DE_I, DE_E, DE_O, DE_B, DE_N, DE_R, DE_S, DE_G, LT(1,KC_ENT) }, | 40 | //{ LT(1,KC_TAB), DE_C, DE_T, DE_I, DE_E, DE_O, DE_B, DE_N, DE_R, DE_S, DE_G, LT(1,KC_ENT) }, |
| 41 | { MO(1), DE_C, DE_T, DE_I, DE_E, DE_O, DE_B, DE_N, DE_R, DE_S, DE_G, LT(1,KC_ENT) }, | ||
| 40 | { KC_LSFT, DE_F, DE_V, DE_UE, DE_AE, DE_OE, DE_Y, DE_Z, DE_COMM, DE_DOT, DE_K, KC_LSFT }, | 42 | { KC_LSFT, DE_F, DE_V, DE_UE, DE_AE, DE_OE, DE_Y, DE_Z, DE_COMM, DE_DOT, DE_K, KC_LSFT }, |
| 41 | { KC_LCTL, KC_RGUI, KC_LALT, MO(4), MO(2), KC_SPC, KC_SPC, MO(2), MO(4), KC_RALT, KC_ESC, KC_RCTL } | 43 | { KC_LCTL, KC_RGUI, KC_LALT, MO(4), MO(2), KC_SPC, KC_SPC, MO(2), MO(4), KC_RALT, KC_ESC, KC_RCTL } |
| 42 | }, | 44 | }, |
| 43 | 45 | ||
| 44 | /* M1 Special Characters | 46 | /* M1 Special Characters |
| 45 | very ergonomic placement for coding | 47 | * very ergonomic placement for coding |
| 46 | * ,-----------------------------------------------------------------------------------. | 48 | * ,-----------------------------------------------------------------------------------. |
| 47 | * | ° | @ | _ | [ | ] | ^ | ! | < | > | = | & | ´ | | 49 | * | ° | @ | _ | [ | ] | ^ | ! | < | > | = | & | ´ | |
| 48 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 50 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 49 | * |M1/Tab| \ | / | { | } | * | ? | ( | ) | - | : |M1/Ent| //hold for M1, tap for Tab/Enter | 51 | * | M1 | \ | / | { | } | * | ? | ( | ) | - | : |M1/Ent| //hold for M1, tap for Enter |
| 50 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 52 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 51 | * | Shift| # | $ | | | ~ | € | + | % | " | ' | ; |Shift | | 53 | * | Shift| # | ~ | | | $ | € | + | % | " | ' | ; |Shift | |
| 52 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 54 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 53 | * | Ctrl | GUI | Alt | M4 | M2 | Space | M2 | M4 | Alt | Esc | Ctrl | | 55 | * | Ctrl | GUI | Alt | M4 | M2 | Space | M2 | M4 | Alt | Esc | Ctrl | |
| 54 | * `-----------------------------------------------------------------------------------' | 56 | * `-----------------------------------------------------------------------------------' |
| @@ -56,56 +58,55 @@ very ergonomic placement for coding | |||
| 56 | [1] = { | 58 | [1] = { |
| 57 | { DE_RING, DE_AT, DE_UNDS, DE_LBRC, DE_RBRC, DE_CIRC, DE_EXLM, DE_LESS, DE_MORE, DE_EQL, DE_AMPR, DE_ACUT }, | 59 | { DE_RING, DE_AT, DE_UNDS, DE_LBRC, DE_RBRC, DE_CIRC, DE_EXLM, DE_LESS, DE_MORE, DE_EQL, DE_AMPR, DE_ACUT }, |
| 58 | { _______, DE_BSLS, DE_SLSH, DE_LCBR, DE_RCBR, DE_ASTR, DE_QST, DE_LPRN, DE_RPRN, DE_MINS, DE_COLN, _______ }, | 60 | { _______, DE_BSLS, DE_SLSH, DE_LCBR, DE_RCBR, DE_ASTR, DE_QST, DE_LPRN, DE_RPRN, DE_MINS, DE_COLN, _______ }, |
| 59 | { _______, DE_HASH, DE_DLR, DE_PIPE, DE_TILD, DE_EURO, DE_PLUS, DE_PERC, DE_DQOT, DE_QUOT, DE_SCLN, _______ }, | 61 | { _______, DE_HASH, DE_TILD, DE_PIPE, DE_DLR, DE_EURO, DE_PLUS, DE_PERC, DE_DQOT, DE_QUOT, DE_SCLN, _______ }, |
| 60 | { _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ } | 62 | { _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ } |
| 61 | }, | 63 | }, |
| 62 | 64 | ||
| 63 | /* Navigation & Number Blocks | 65 | /* M2 Navigation & Number Blocks |
| 64 | very easy to get used to & intuituve placement | 66 | * very easy to get used to & intuituve placement |
| 65 | * ,-----------------------------------------------------------------------------------. | 67 | * ,-----------------------------------------------------------------------------------. |
| 66 | * | | PgUp | Bksp | Up | DEL | PgDn | | 7 | 8 | 9 | | Ins | | 68 | * | | PgUp | Bksp | Up | DEL | PgDn | | 7 | 8 | 9 | | Ins | |
| 67 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 69 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 68 | * | Tab | Home | Lft | Down | Right| End | . | 4 | 5 | 6 | , | Enter| | 70 | * | Tab | Home | Lft | Down | Right| End | | 4 | 5 | 6 | . | Enter| |
| 69 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 71 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 70 | * | Shift| | Tab | | Enter| | 0 | 1 | 2 | 3 | ; |Shift | | 72 | * | Shift| | Tab | | Enter| | 0 | 1 | 2 | 3 | , |Shift | |
| 71 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 73 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 72 | * | Ctrl | GUI | Alt | M3 | M2 | Space | M2 | M3 | Alt | Esc | Ctrl | | 74 | * | Ctrl | GUI | Alt | M3 | M2 | Space | M2 | M3 | Alt | Esc | Ctrl | |
| 73 | * `-----------------------------------------------------------------------------------' | 75 | * `-----------------------------------------------------------------------------------' |
| 74 | */ | 76 | */ |
| 75 | [2] = { | 77 | [2] = { |
| 76 | { KC_NO, KC_PGUP, KC_BSPC, KC_UP, KC_DEL, KC_PGDN, KC_NO, DE_7, DE_8, DE_9, KC_NO, KC_INS }, | 78 | { XXXXXXX, KC_PGUP, KC_BSPC, KC_UP, KC_DEL, KC_PGDN, XXXXXXX, DE_7, DE_8, DE_9, XXXXXXX, KC_INS }, |
| 77 | { KC_TAB, KC_HOME, KC_LEFT, KC_DOWN, KC_RGHT, KC_END, DE_DOT, DE_4, DE_5, DE_6, DE_COMM, KC_ENT }, | 79 | { KC_TAB, KC_HOME, KC_LEFT, KC_DOWN, KC_RGHT, KC_END, XXXXXXX, DE_4, DE_5, DE_6, DE_DOT, KC_ENT }, |
| 78 | { _______, KC_NO, KC_TAB, KC_NO, KC_ENT, KC_NO, DE_0, DE_1, DE_2, DE_3, DE_SCLN, _______ }, | 80 | { _______, XXXXXXX, KC_TAB, XXXXXXX, KC_ENT, XXXXXXX, DE_0, DE_1, DE_2, DE_3, DE_COMM, _______ }, |
| 79 | { _______, _______, _______, MO(3), _______, _______, _______, _______, MO(3), _______, _______, _______ } | 81 | { _______, _______, _______, MO(3), _______, _______, _______, _______, MO(3), _______, _______, _______ } |
| 80 | }, | 82 | }, |
| 81 | 83 | ||
| 82 | /* Flipped Navigation & Number Blocks for one handed use | 84 | /* M3 Switched Navigation & Number Blocks for one handed use |
| 83 | accessed by sliding from M2 to M3 with thumb | 85 | * accessed by sliding from M2 to M3 with thumb |
| 84 | * ,-----------------------------------------------------------------------------------. | 86 | * ,-----------------------------------------------------------------------------------. |
| 85 | * | Ins | | 7 | 8 | 9 | | PgUp | Bksp | Up | DEL | PgDn | | | 87 | * | Ins | | 7 | 8 | 9 | | PgUp | Bksp | Up | DEL | PgDn | | |
| 86 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 88 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 87 | * | Tab | . | 4 | 5 | 6 | , | Home | Left | Down | Right| End | Enter| | 89 | * | Tab | | 4 | 5 | 6 | . | Home | Left | Down | Right| End | Enter| |
| 88 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 90 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 89 | * | Shift| 0 | 1 | 2 | 3 | ; | | Tab | Ins | Enter| |Shift | | 91 | * | Shift| 0 | 1 | 2 | 3 | , | | Tab | | Enter| |Shift | |
| 90 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 92 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 91 | * | Ctrl | GUI | Alt | M3 | | Space | | M3 | Alt | Esc | Ctrl | | 93 | * | Ctrl | GUI | Alt | M3 | | Space | | M3 | Alt | Esc | Ctrl | |
| 92 | * `-----------------------------------------------------------------------------------' | 94 | * `-----------------------------------------------------------------------------------' |
| 93 | */ | 95 | */ |
| 94 | 96 | ||
| 95 | [3] = { | 97 | [3] = { |
| 96 | { KC_INS, KC_NO, DE_7, DE_8, DE_9, KC_NO, KC_PGUP, KC_BSPC, KC_UP, KC_DEL, KC_PGDN, KC_NO }, | 98 | { KC_INS, XXXXXXX, DE_7, DE_8, DE_9, XXXXXXX, KC_PGUP, KC_BSPC, KC_UP, KC_DEL, KC_PGDN, XXXXXXX }, |
| 97 | { _______, DE_DOT, DE_4, DE_5, DE_6, DE_COMM, KC_HOME, KC_LEFT, KC_DOWN, KC_RGHT, KC_END, _______ }, | 99 | { _______, XXXXXXX, DE_4, DE_5, DE_6, DE_DOT, KC_HOME, KC_LEFT, KC_DOWN, KC_RGHT, KC_END, _______ }, |
| 98 | { _______, DE_0, DE_1, DE_2, DE_3, DE_SCLN, KC_NO, KC_TAB, KC_INS, KC_ENT, KC_NO, _______ }, | 100 | { _______, DE_0, DE_1, DE_2, DE_3, DE_COMM, XXXXXXX, KC_TAB, XXXXXXX, KC_ENT, XXXXXXX, _______ }, |
| 99 | { _______, _______, _______, _______, KC_NO, _______, _______, KC_NO, _______, _______, _______, _______ } | 101 | { _______, _______, _______, _______, XXXXXXX, _______, _______, XXXXXXX, _______, _______, _______, _______ } |
| 100 | }, | 102 | }, |
| 101 | 103 | ||
| 102 | 104 | ||
| 103 | /* Function & Media Keys | 105 | /* M4 Function & Media Keys |
| 104 | slide from m4 to m5 to access flipped version | ||
| 105 | * ,-----------------------------------------------------------------------------------. | 106 | * ,-----------------------------------------------------------------------------------. |
| 106 | * | | | Print|Scroll|Pause | | | F7 | F8 | F9 | F12 | | | 107 | * | | | Print|Scroll|Pause | | | F7 | F8 | F9 | F12 | | |
| 107 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 108 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 108 | * | | | Mute | Vol- | Vol+ | | ³ | F4 | F5 | F6 | F11 | | | 109 | * | Tab | | Mute | Vol- | Vol+ | | ³ | F4 | F5 | F6 | F11 | Enter| |
| 109 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 110 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 110 | * | Shift| | Prev | Play | Next | | ² | F1 | F2 | F3 | F10 |Shift | | 111 | * | Shift| | Prev | Play | Next | | ² | F1 | F2 | F3 | F10 |Shift | |
| 111 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 112 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| @@ -113,18 +114,19 @@ slide from m4 to m5 to access flipped version | |||
| 113 | * `-----------------------------------------------------------------------------------' | 114 | * `-----------------------------------------------------------------------------------' |
| 114 | */ | 115 | */ |
| 115 | [4] = { | 116 | [4] = { |
| 116 | { KC_NO, KC_NO, KC_PSCR, KC_SLCK, KC_PAUS, KC_NO, KC_NO, KC_F7, KC_F8, KC_F9, KC_F12, KC_NO }, | 117 | { XXXXXXX, XXXXXXX, KC_PSCR, KC_SLCK, KC_PAUS, XXXXXXX, XXXXXXX, KC_F7, KC_F8, KC_F9, KC_F12, XXXXXXX }, |
| 117 | { KC_NO, KC_NO, KC_MUTE, KC_VOLD, KC_VOLU, KC_NO, DE_SQ3, KC_F4, KC_F5, KC_F6, KC_F11, KC_NO }, | 118 | { KC_TAB, XXXXXXX, KC_MUTE, KC_VOLD, KC_VOLU, XXXXXXX, DE_SQ3, KC_F4, KC_F5, KC_F6, KC_F11, KC_ENT }, |
| 118 | { _______, KC_NO, KC_MPRV, KC_MPLY, KC_MNXT, KC_NO, DE_SQ2, KC_F1, KC_F2, KC_F3, KC_F10, _______ }, | 119 | { _______, XXXXXXX, KC_MPRV, KC_MPLY, KC_MNXT, XXXXXXX, DE_SQ2, KC_F1, KC_F2, KC_F3, KC_F10, _______ }, |
| 119 | { _______, _______, _______, _______, MO(5), _______, _______, MO(5), _______, _______, _______, _______ } | 120 | { _______, _______, _______, _______, MO(5), _______, _______, MO(5), _______, _______, _______, _______ } |
| 120 | }, | 121 | }, |
| 121 | 122 | ||
| 122 | 123 | ||
| 123 | /* flipped Function & Media Keys | 124 | /* M5 Switched Function & Media Keys| |
| 125 | * accessed by sliding from M4 to M5 with thumb | ||
| 124 | * ,-----------------------------------------------------------------------------------. | 126 | * ,-----------------------------------------------------------------------------------. |
| 125 | * | | | F7 | F8 | F9 | F12 | | Print|Scroll| Pause| | | | 127 | * | | | F7 | F8 | F9 | F12 | | Print|Scroll| Pause| | | |
| 126 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 128 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 127 | * | | ³ | F4 | F5 | F6 | F11 | | Mute | Vol- | Vol+ | | | | 129 | * | Tab | ³ | F4 | F5 | F6 | F11 | | Mute | Vol- | Vol+ | | Enter| |
| 128 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 130 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 129 | * | Shift| ² | F1 | F2 | F3 | F10 | | Prev | Play | Next | |Shift | | 131 | * | Shift| ² | F1 | F2 | F3 | F10 | | Prev | Play | Next | |Shift | |
| 130 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 132 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| @@ -132,13 +134,14 @@ slide from m4 to m5 to access flipped version | |||
| 132 | * `-----------------------------------------------------------------------------------' | 134 | * `-----------------------------------------------------------------------------------' |
| 133 | */ | 135 | */ |
| 134 | [5] = { | 136 | [5] = { |
| 135 | { KC_NO, KC_NO, KC_F7, KC_F8, KC_F9, KC_F12, KC_NO, KC_PSCR, KC_SLCK, KC_PAUS, KC_NO, KC_NO }, | 137 | { XXXXXXX, XXXXXXX, KC_F7, KC_F8, KC_F9, KC_F12, XXXXXXX, KC_PSCR, KC_SLCK, KC_PAUS, XXXXXXX, XXXXXXX }, |
| 136 | { KC_NO, DE_SQ3, KC_F4, KC_F5, KC_F6, KC_F11, KC_NO, KC_MUTE, KC_VOLD, KC_VOLU, KC_NO, KC_NO }, | 138 | { _______, DE_SQ3, KC_F4, KC_F5, KC_F6, KC_F11, XXXXXXX, KC_MUTE, KC_VOLD, KC_VOLU, XXXXXXX, _______ }, |
| 137 | { _______, DE_SQ2, KC_F1, KC_F2, KC_F3, KC_F10, KC_NO, KC_MPRV, KC_MPLY, KC_MNXT, KC_NO, _______ }, | 139 | { _______, DE_SQ2, KC_F1, KC_F2, KC_F3, KC_F10, XXXXXXX, KC_MPRV, KC_MPLY, KC_MNXT, XXXXXXX, _______ }, |
| 138 | { _______, _______, _______, KC_NO, _______, _______, _______, _______, KC_NO, _______, _______, _______ } | 140 | { _______, _______, _______, XXXXXXX, _______, _______, _______, _______, XXXXXXX, _______, _______, _______ } |
| 139 | } | 141 | } |
| 140 | }; | 142 | }; |
| 141 | 143 | ||
| 144 | |||
| 142 | const uint16_t PROGMEM fn_actions[] = { | 145 | const uint16_t PROGMEM fn_actions[] = { |
| 143 | 146 | ||
| 144 | }; | 147 | }; |
diff --git a/keyboards/planck/keymaps/bone2planck/readme.md b/keyboards/planck/keymaps/bone2planck/readme.md index 3c425efdd..be22eabdb 100644 --- a/keyboards/planck/keymaps/bone2planck/readme.md +++ b/keyboards/planck/keymaps/bone2planck/readme.md | |||
| @@ -1,8 +1,96 @@ | |||
| 1 | check keymap.c to the layers | 1 | Bone2Planck |
| 2 | ===================================== | ||
| 2 | 3 | ||
| 3 | This Layout tries to emulate the Bone2 Variant of Neo2, and is intended to be used with a German QWERTZ Softwarelayout. | 4 | This layout tries to emulate the Bone2 variant of Neo2, and is intended to be used with a German QWERTZ softwarelayout. |
| 4 | It has "üäöß" as it is optimized for a mix of German & English. | 5 | It has "üäöß" as it is optimized for a mix of German & English. |
| 5 | My favourite features are the placement of the special characters often used for programming right on the home row | 6 | The special character layer and the navigation & number block layer are inspired by the Neo2 layers, |
| 6 | and the number & navigation block combo, so you never have to move your hands from their home position. | 7 | designed to keep the fingers near the home row. |
| 7 | 8 | ||
| 8 | Bone2 wiki page: http://wiki.neo-layout.org/wiki/Bone \ No newline at end of file | 9 | Bone2 wiki page: http://wiki.neo-layout.org/wiki/Bone |
| 10 | |||
| 11 | To build, run "make" from within the \bone2planck folder. | ||
| 12 | |||
| 13 | ## Bone2 (adapted) Base Layer | ||
| 14 | ``` | ||
| 15 | ,-----------------------------------------------------------------------------------. | ||
| 16 | | ß | J | D | U | A | X | P | H | L | M | W | Q | | ||
| 17 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 18 | | M1 | C | T | I | E | O | B | N | R | S | G |M1/Ent| hold: M1, tap: Enter | ||
| 19 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 20 | | Shift| F | V | Ü | Ä | Ö | Y | Z | , | . | K |Shift | | ||
| 21 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 22 | | Ctrl | GUI | Alt | M4 | M2 | Space | M2 | M4 | Alt | Esc | Ctrl | | ||
| 23 | `-----------------------------------------------------------------------------------' | ||
| 24 | ``` | ||
| 25 | |||
| 26 | ## M1 Special Characters | ||
| 27 | very ergonomic placement for coding | ||
| 28 | ``` | ||
| 29 | ,-----------------------------------------------------------------------------------. | ||
| 30 | | ° | @ | _ | [ | ] | ^ | ! | < | > | = | & | ´ | | ||
| 31 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 32 | | M1 | \ | / | { | } | * | ? | ( | ) | - | : |M1/Ent| hold: M1, tap: Enter | ||
| 33 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 34 | | Shift| # | ~ | | | $ | € | + | % | " | ' | ; |Shift | | ||
| 35 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 36 | | Ctrl | GUI | Alt | M4 | M2 | Space | M2 | M4 | Alt | Esc | Ctrl | | ||
| 37 | `-----------------------------------------------------------------------------------' | ||
| 38 | ``` | ||
| 39 | |||
| 40 | ## M2 Navigation & Number Blocks | ||
| 41 | very easy to get used to & intuituve placement | ||
| 42 | ``` | ||
| 43 | ,-----------------------------------------------------------------------------------. | ||
| 44 | | | PgUp | Bksp | Up | DEL | PgDn | | 7 | 8 | 9 | | Ins | | ||
| 45 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 46 | | Tab | Home | Lft | Down | Right| End | | 4 | 5 | 6 | . | Enter| | ||
| 47 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 48 | | Shift| | Tab | | Enter| | 0 | 1 | 2 | 3 | , |Shift | | ||
| 49 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 50 | | Ctrl | GUI | Alt | M3 | M2 | Space | M2 | M3 | Alt | Esc | Ctrl | | ||
| 51 | `-----------------------------------------------------------------------------------' | ||
| 52 | ``` | ||
| 53 | |||
| 54 | ## M4 Function & Media Keys | ||
| 55 | ``` | ||
| 56 | ,-----------------------------------------------------------------------------------. | ||
| 57 | | | | Print|Scroll|Pause | | | F7 | F8 | F9 | F12 | | | ||
| 58 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 59 | | Tab | | Mute | Vol- | Vol+ | | ³ | F4 | F5 | F6 | F11 | Enter| | ||
| 60 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 61 | | Shift| | Prev | Play | Next | | ² | F1 | F2 | F3 | F10 |Shift | | ||
| 62 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 63 | | Ctrl | GUI | Alt | M4 | M5 | Space | M5 | M4 | Alt | Esc | Ctrl | | ||
| 64 | `-----------------------------------------------------------------------------------' | ||
| 65 | ``` | ||
| 66 | |||
| 67 | |||
| 68 | ##Switched layers for one handed access: | ||
| 69 | |||
| 70 | ### M3 Switched Navigation & Number Blocks | ||
| 71 | accessed by sliding from M2 to M3 with thumb | ||
| 72 | ``` | ||
| 73 | ,-----------------------------------------------------------------------------------. | ||
| 74 | | Ins | | 7 | 8 | 9 | | PgUp | Bksp | Up | DEL | PgDn | | | ||
| 75 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 76 | | Tab | | 4 | 5 | 6 | . | Home | Left | Down | Right| End | Enter| | ||
| 77 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 78 | | Shift| 0 | 1 | 2 | 3 | , | | Tab | | Enter| |Shift | | ||
| 79 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 80 | | Ctrl | GUI | Alt | M3 | | Space | | M3 | Alt | Esc | Ctrl | | ||
| 81 | `-----------------------------------------------------------------------------------' | ||
| 82 | ``` | ||
| 83 | |||
| 84 | ### M5 Switched Function & Media Keys | ||
| 85 | accessed by sliding from M4 to M5 with thumb | ||
| 86 | ``` | ||
| 87 | ,-----------------------------------------------------------------------------------. | ||
| 88 | | | | F7 | F8 | F9 | F12 | | Print|Scroll| Pause| | | | ||
| 89 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 90 | | Tab | ³ | F4 | F5 | F6 | F11 | | Mute | Vol- | Vol+ | | Enter| | ||
| 91 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 92 | | Shift| ² | F1 | F2 | F3 | F10 | | Prev | Play | Next | |Shift | | ||
| 93 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 94 | | Ctrl | GUI | Alt | | M5 | Space | M5 | | Alt | Esc | Ctrl | | ||
| 95 | `-----------------------------------------------------------------------------------' | ||
| 96 | ``` \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/callum/keymap.c b/keyboards/planck/keymaps/callum/keymap.c index a1254d975..2acd988ea 100644 --- a/keyboards/planck/keymaps/callum/keymap.c +++ b/keyboards/planck/keymaps/callum/keymap.c | |||
| @@ -12,8 +12,6 @@ extern keymap_config_t keymap_config; | |||
| 12 | #define _SYMB 2 | 12 | #define _SYMB 2 |
| 13 | #define _MOUSE 3 | 13 | #define _MOUSE 3 |
| 14 | #define _FUNC 4 | 14 | #define _FUNC 4 |
| 15 | #define CMDLEFT LGUI(KC_LEFT) | ||
| 16 | #define CMDRGHT LGUI(KC_RGHT) | ||
| 17 | #define ENDASH LALT(KC_MINS) | 15 | #define ENDASH LALT(KC_MINS) |
| 18 | #define POUND LALT(KC_3) | 16 | #define POUND LALT(KC_3) |
| 19 | 17 | ||
| @@ -50,7 +48,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 50 | 48 | ||
| 51 | /* MOVE | 49 | /* MOVE |
| 52 | * ,-----------------------------------------------------------------------------------. | 50 | * ,-----------------------------------------------------------------------------------. |
| 53 | * | Esc | | Cmd-L| Up | Cmd-R| | | Cmd-L| Up | Cmd-R| | Esc | | 51 | * | Esc | | Home | Up | End | | | Home | Up | End | | Esc | |
| 54 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 52 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 55 | * | Del | Caps | Left | Down | Right| | | Left | Down | Right| Caps | Del | | 53 | * | Del | Caps | Left | Down | Right| | | Left | Down | Right| Caps | Del | |
| 56 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 54 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| @@ -60,7 +58,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 60 | * `-----------------------------------------------------------------------------------' | 58 | * `-----------------------------------------------------------------------------------' |
| 61 | */ | 59 | */ |
| 62 | [_MOVE] = { | 60 | [_MOVE] = { |
| 63 | {KC_ESC, XXXXXXX, CMDLEFT, KC_UP, CMDRGHT, XXXXXXX, XXXXXXX, CMDLEFT, KC_UP, CMDRGHT, XXXXXXX, KC_ESC }, | 61 | {KC_ESC, XXXXXXX, KC_HOME, KC_UP, KC_END, XXXXXXX, XXXXXXX, KC_HOME, KC_UP, KC_END, XXXXXXX, KC_ESC }, |
| 64 | {KC_DEL, KC_CAPS, KC_LEFT, KC_DOWN, KC_RGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_CAPS, KC_DEL }, | 62 | {KC_DEL, KC_CAPS, KC_LEFT, KC_DOWN, KC_RGHT, XXXXXXX, XXXXXXX, KC_LEFT, KC_DOWN, KC_RGHT, KC_CAPS, KC_DEL }, |
| 65 | {_______, XXXXXXX, XXXXXXX, KC_PGUP, KC_PGDN, XXXXXXX, XXXXXXX, KC_PGDN, KC_PGUP, XXXXXXX, XXXXXXX, _______}, | 63 | {_______, XXXXXXX, XXXXXXX, KC_PGUP, KC_PGDN, XXXXXXX, XXXXXXX, KC_PGDN, KC_PGUP, XXXXXXX, XXXXXXX, _______}, |
| 66 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 64 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} |
diff --git a/keyboards/planck/keymaps/callum/readme.md b/keyboards/planck/keymaps/callum/readme.md index f970cd974..71e200b9d 100644 --- a/keyboards/planck/keymaps/callum/readme.md +++ b/keyboards/planck/keymaps/callum/readme.md | |||
| @@ -23,7 +23,7 @@ We have five layers. A `BASE` layer, in colemak; a `MOVE` layer, with an arrow c | |||
| 23 | 23 | ||
| 24 | /* MOVE | 24 | /* MOVE |
| 25 | * ,-----------------------------------------------------------------------------------. | 25 | * ,-----------------------------------------------------------------------------------. |
| 26 | * | Esc | | Cmd-L| Up | Cmd-R| | | Cmd-L| Up | Cmd-R| | Esc | | 26 | * | Esc | | Home | Up | End | | | Home | Up | End | | Esc | |
| 27 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 27 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 28 | * | Del | Caps | Left | Down | Right| | | Left | Down | Right| Caps | Del | | 28 | * | Del | Caps | Left | Down | Right| | | Left | Down | Right| Caps | Del | |
| 29 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 29 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
diff --git a/keyboards/planck/keymaps/espynn/Makefile b/keyboards/planck/keymaps/espynn/Makefile new file mode 100644 index 000000000..44a030ba3 --- /dev/null +++ b/keyboards/planck/keymaps/espynn/Makefile | |||
| @@ -0,0 +1,63 @@ | |||
| 1 | #---------------------------------------------------------------------------- | ||
| 2 | # On command line: | ||
| 3 | # | ||
| 4 | # make all = Make software. | ||
| 5 | # | ||
| 6 | # make clean = Clean out built project files. | ||
| 7 | # | ||
| 8 | # make coff = Convert ELF to AVR COFF. | ||
| 9 | # | ||
| 10 | # make extcoff = Convert ELF to AVR Extended COFF. | ||
| 11 | # | ||
| 12 | # make program = Download the hex file to the device. | ||
| 13 | # Please customize your programmer settings(PROGRAM_CMD) | ||
| 14 | # | ||
| 15 | # make teensy = Download the hex file to the device, using teensy_loader_cli. | ||
| 16 | # (must have teensy_loader_cli installed). | ||
| 17 | # | ||
| 18 | # make dfu = Download the hex file to the device, using dfu-programmer (must | ||
| 19 | # have dfu-programmer installed). | ||
| 20 | # | ||
| 21 | # make flip = Download the hex file to the device, using Atmel FLIP (must | ||
| 22 | # have Atmel FLIP installed). | ||
| 23 | # | ||
| 24 | # make dfu-ee = Download the eeprom file to the device, using dfu-programmer | ||
| 25 | # (must have dfu-programmer installed). | ||
| 26 | # | ||
| 27 | # make flip-ee = Download the eeprom file to the device, using Atmel FLIP | ||
| 28 | # (must have Atmel FLIP installed). | ||
| 29 | # | ||
| 30 | # make debug = Start either simulavr or avarice as specified for debugging, | ||
| 31 | # with avr-gdb or avr-insight as the front end for debugging. | ||
| 32 | # | ||
| 33 | # make filename.s = Just compile filename.c into the assembler code only. | ||
| 34 | # | ||
| 35 | # make filename.i = Create a preprocessed source file for use in submitting | ||
| 36 | # bug reports to the GCC project. | ||
| 37 | # | ||
| 38 | # To rebuild project do "make clean" then "make all". | ||
| 39 | #---------------------------------------------------------------------------- | ||
| 40 | |||
| 41 | # Build Options | ||
| 42 | # change to "no" to disable the options, or define them in the makefile.mk in | ||
| 43 | # the appropriate keymap folder that will get included automatically | ||
| 44 | # | ||
| 45 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 46 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 47 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 48 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 49 | COMMAND_ENABLE = yes # Commands for debug and configuration | ||
| 50 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 51 | BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality | ||
| 52 | MIDI_ENABLE = no # MIDI controls | ||
| 53 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 54 | UNICODE_ENABLE = no # Unicode | ||
| 55 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 56 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 57 | |||
| 58 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||
| 59 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 60 | |||
| 61 | ifndef QUANTUM_DIR | ||
| 62 | include ../../../../Makefile | ||
| 63 | endif | ||
diff --git a/keyboards/planck/keymaps/espynn/keyboard-layout.jpg b/keyboards/planck/keymaps/espynn/keyboard-layout.jpg new file mode 100644 index 000000000..55e5396bf --- /dev/null +++ b/keyboards/planck/keymaps/espynn/keyboard-layout.jpg | |||
| Binary files differ | |||
diff --git a/keyboards/planck/keymaps/espynn/keymap.c b/keyboards/planck/keymaps/espynn/keymap.c new file mode 100644 index 000000000..4a3fe32b8 --- /dev/null +++ b/keyboards/planck/keymaps/espynn/keymap.c | |||
| @@ -0,0 +1,151 @@ | |||
| 1 | #include "planck.h" | ||
| 2 | #include "action_layer.h" | ||
| 3 | #include "eeconfig.h" | ||
| 4 | #ifdef BACKLIGHT_ENABLE | ||
| 5 | #include "backlight.h" | ||
| 6 | #endif | ||
| 7 | #define PREVENT_STUCK_MODIFIERS | ||
| 8 | extern keymap_config_t keymap_config; | ||
| 9 | |||
| 10 | // Symbolic names for macro IDs. | ||
| 11 | #define _QWERTY 0 // QUERTY layer | ||
| 12 | #define _LOWER 1 // Lower layer | ||
| 13 | #define _RAISE 2 // Raise layer | ||
| 14 | #define _CUSTOM 3 // Custom layer (LOWER + RAISE) | ||
| 15 | #define _BL 4 // Backlight | ||
| 16 | #define _CUS0 5 // Mobile# | ||
| 17 | #define _CUS1 6 // signature | ||
| 18 | #define _CUS2 7 // macro 2 | ||
| 19 | #define _CUS3 8 // macro 3 | ||
| 20 | #define _CUS4 9 // macro 4 | ||
| 21 | #define _CUS5 10 // email | ||
| 22 | #define _COPY 11 // copy | ||
| 23 | #define _PASTE 12 // paste | ||
| 24 | #define _CUT 13 // cut | ||
| 25 | |||
| 26 | // Macro shortcuts. | ||
| 27 | #define QWERTY M(_LOWER) | ||
| 28 | #define LOWER M(_LOWER) | ||
| 29 | #define RAISE M(_RAISE) | ||
| 30 | #define CUSTOM M(_CUSTOM) | ||
| 31 | #define BL M(_BL) | ||
| 32 | #define CUS0 M(_CUS0) | ||
| 33 | #define CUS1 M(_CUS1) | ||
| 34 | #define CUS2 M(_CUS2) | ||
| 35 | #define CUS3 M(_CUS3) | ||
| 36 | #define CUS4 M(_CUS4) | ||
| 37 | #define CUS5 M(_CUS5) | ||
| 38 | #define COPY M(_COPY) | ||
| 39 | #define PASTE M(_PASTE) | ||
| 40 | #define CUT M(_CUT) | ||
| 41 | |||
| 42 | // Func macro definitions. | ||
| 43 | #define LWR_PGDN FUNC(0) // Tap for PgDn, hold for LOWER | ||
| 44 | #define RSE_PGUP FUNC(1) // Tap for PgUp, hold for RAISE | ||
| 45 | #define CTL_CAPS FUNC(2) // Tap for Caps, hold for Ctrl (DOESN'T SEEM TO WORK) | ||
| 46 | #define SFT_ENT FUNC(3) // Tap for Enter, hold for Shift | ||
| 47 | #define ZM_NRM FUNC(4) // Zoom normal | ||
| 48 | #define ZM_IN FUNC(5) // Zoom out | ||
| 49 | #define ZM_OUT FUNC(6) // Zoom in | ||
| 50 | |||
| 51 | // Enable these functions using FUNC(n) macro. | ||
| 52 | const uint16_t PROGMEM fn_actions[] = { | ||
| 53 | [0] = ACTION_LAYER_TAP_KEY(_LOWER, KC_PGDN), | ||
| 54 | [1] = ACTION_LAYER_TAP_KEY(_RAISE, KC_PGUP), | ||
| 55 | [2] = ACTION_MODS_TAP_KEY(MOD_LCTL, KC_CAPS), | ||
| 56 | [3] = ACTION_MODS_TAP_KEY(MOD_RSFT, KC_ENT), | ||
| 57 | [4] = ACTION_MODS_KEY(MOD_LCTL, KC_0), | ||
| 58 | [5] = ACTION_MODS_KEY(MOD_LCTL, KC_MINS), | ||
| 59 | [6] = ACTION_MODS_KEY(MOD_LCTL, KC_PLUS), | ||
| 60 | [7] = ACTION_MODS_KEY(MOD_LCTL, KC_UNDS), | ||
| 61 | }; | ||
| 62 | |||
| 63 | // This config can be found at Keyboard layout editor site: http://goo.gl/zjXL2l | ||
| 64 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 65 | [_QWERTY] = { /* QWERTY */ | ||
| 66 | {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC}, | ||
| 67 | {KC_DEL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT}, | ||
| 68 | {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_ENT}, | ||
| 69 | {KC_LCTL, KC_ESC, KC_LGUI, KC_LALT, LOWER, KC_SPC, KC_SPC, RAISE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} | ||
| 70 | }, | ||
| 71 | [_LOWER] = { /* LOWER */ | ||
| 72 | {KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL}, | ||
| 73 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LPRN, KC_RPRN, KC_LCBR, KC_RCBR, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}, | ||
| 74 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LBRC, KC_RBRC, KC_QUOT, KC_DQT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}, | ||
| 75 | {KC_TRNS, ZM_NRM, ZM_IN, ZM_OUT, KC_TRNS, KC_PGDN, KC_PGDN, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS} | ||
| 76 | }, | ||
| 77 | [_RAISE] = { /* RAISE */ | ||
| 78 | {KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12}, | ||
| 79 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LCBR, KC_LCBR, KC_BSLS, KC_TRNS}, | ||
| 80 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_BSLS, KC_PIPE, KC_GRV, KC_TILD, KC_LBRC, KC_LBRC, KC_TRNS, KC_TRNS}, | ||
| 81 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGUP, KC_TRNS, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} | ||
| 82 | }, | ||
| 83 | [_CUSTOM] = { /* CUSTOM */ | ||
| 84 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, CUS4, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}, | ||
| 85 | {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, CUS0, CUS3, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}, | ||
| 86 | {KC_TRNS, KC_TRNS, CUT, COPY, PASTE, CUS1, CUS5, CUS2, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}, | ||
| 87 | {BL, RESET, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS} | ||
| 88 | } | ||
| 89 | }; | ||
| 90 | |||
| 91 | // Set a layer persistantly. | ||
| 92 | void persistant_default_layer_set(uint16_t default_layer) { | ||
| 93 | eeconfig_update_default_layer(default_layer); | ||
| 94 | default_layer_set(default_layer); | ||
| 95 | } | ||
| 96 | |||
| 97 | // Macro actions for each corresponding ID. | ||
| 98 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | ||
| 99 | { | ||
| 100 | switch(id) { | ||
| 101 | case _RAISE: // Raised layer. | ||
| 102 | if (record->event.pressed) { | ||
| 103 | layer_on(_RAISE); | ||
| 104 | update_tri_layer(_LOWER, _RAISE, _CUSTOM); | ||
| 105 | } else { | ||
| 106 | layer_off(_RAISE); | ||
| 107 | update_tri_layer(_LOWER, _RAISE, _CUSTOM); | ||
| 108 | } | ||
| 109 | break; | ||
| 110 | case _LOWER: // Lowered layer. | ||
| 111 | if (record->event.pressed) { | ||
| 112 | layer_on(_LOWER); | ||
| 113 | update_tri_layer(_LOWER, _RAISE, _CUSTOM); | ||
| 114 | } else { | ||
| 115 | layer_off(_LOWER); | ||
| 116 | update_tri_layer(_LOWER, _RAISE, _CUSTOM); | ||
| 117 | } | ||
| 118 | break; | ||
| 119 | case _BL: // Backlight | ||
| 120 | if (record->event.pressed) { | ||
| 121 | register_code(KC_RSFT); | ||
| 122 | #ifdef BACKLIGHT_ENABLE | ||
| 123 | backlight_step(); | ||
| 124 | #endif | ||
| 125 | } else { | ||
| 126 | unregister_code(KC_RSFT); | ||
| 127 | } | ||
| 128 | break; | ||
| 129 | case _CUS0: // enter your mobile# here | ||
| 130 | return MACRODOWN(T(9), T(9), T(9), T(MINS),T(9), T(9), T(9), T(MINS),T(9), T(9), T(9), T(9),END); | ||
| 131 | case _CUS1: // signature line for email | ||
| 132 | return MACRODOWN(T(ENT), T(ENT), T(MINS), T(J), T(W), END); | ||
| 133 | case _CUS2: // Custom macro 2 | ||
| 134 | return MACRODOWN( DOWN(KC_LSFT), TYPE(KC_L), UP(KC_LSFT), END ); | ||
| 135 | case _CUS3: // custom macro 3 | ||
| 136 | return MACRODOWN( DOWN(KC_LSFT), TYPE(KC_F), UP(KC_LSFT), END ); | ||
| 137 | case _CUS4: // custom macro 4 | ||
| 138 | return MACRODOWN( DOWN(KC_LSFT), TYPE(KC_I), UP(KC_LSFT), END ); | ||
| 139 | case _CUS5: // Enter your email here | ||
| 140 | return MACRODOWN( TYPE(KC_F), | ||
| 141 | DOWN(KC_LSFT), TYPE(KC_2), UP(KC_LSFT), | ||
| 142 | TYPE(KC_G), TYPE(KC_M), TYPE(KC_A), TYPE(KC_I), TYPE(KC_L), TYPE(KC_DOT), TYPE(KC_C), TYPE(KC_O), TYPE(KC_M), END ); | ||
| 143 | case _CUT: //cut macro | ||
| 144 | return MACRODOWN( DOWN(KC_LCTL), TYPE(KC_X), UP(KC_LCTL), END ); | ||
| 145 | case _COPY: // copy macro | ||
| 146 | return MACRODOWN( DOWN(KC_LCTL), TYPE(KC_C), UP(KC_LCTL), END ); | ||
| 147 | case _PASTE: // paste macro | ||
| 148 | return MACRODOWN( DOWN(KC_LCTL), TYPE(KC_V), UP(KC_LCTL), END ); | ||
| 149 | }; | ||
| 150 | return MACRO_NONE; | ||
| 151 | } \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/espynn/layout.json b/keyboards/planck/keymaps/espynn/layout.json new file mode 100644 index 000000000..38ccc3452 --- /dev/null +++ b/keyboards/planck/keymaps/espynn/layout.json | |||
| @@ -0,0 +1,271 @@ | |||
| 1 | [ | ||
| 2 | { | ||
| 3 | "backcolor": "#858585", | ||
| 4 | "name": "Planck 40%", | ||
| 5 | "author": "James Folkert", | ||
| 6 | "background": { | ||
| 7 | "name": "Aluminium brushed", | ||
| 8 | "style": "background-image: url('/bg/metal/aluminum_texture1642.jpg');" | ||
| 9 | }, | ||
| 10 | "switchMount": "cherry", | ||
| 11 | "switchBrand": "cherry", | ||
| 12 | "switchType": "MX1A-A1xx", | ||
| 13 | "pcb": true, | ||
| 14 | "plate": true | ||
| 15 | }, | ||
| 16 | [ | ||
| 17 | { | ||
| 18 | "fa": [ | ||
| 19 | 2, | ||
| 20 | 2, | ||
| 21 | 0, | ||
| 22 | 2 | ||
| 23 | ] | ||
| 24 | }, | ||
| 25 | "F1\n1\n\n!\n\n\n\n\n\n<i class='kb kb-Tab-2'></i>", | ||
| 26 | "F2\n2\n\n@\n\n\n\n\n\nQ", | ||
| 27 | "F3\n3\n\n#\n\n\n\n\n\nW", | ||
| 28 | "F4\n4\n\n$\n\n\n\n\n\nE", | ||
| 29 | "F5\n5\n\n%\n\n\n\n\n\nR", | ||
| 30 | "F6\n6\n\n^\n\n\n\n\n\nT", | ||
| 31 | "F7\n6\n\n&\n\n\n\n\n\nY", | ||
| 32 | "F8\n8\n\n*\nMacro4\n\n\n\n\nU", | ||
| 33 | "F9\n9\n\n(\n\n\n\n\n\nI", | ||
| 34 | { | ||
| 35 | "fa": [ | ||
| 36 | 0, | ||
| 37 | 0, | ||
| 38 | 0, | ||
| 39 | 2 | ||
| 40 | ] | ||
| 41 | }, | ||
| 42 | "F10\n0\n\n)\n\n\n\n\n\nO", | ||
| 43 | { | ||
| 44 | "fa": [ | ||
| 45 | 2, | ||
| 46 | 2, | ||
| 47 | 0, | ||
| 48 | 2 | ||
| 49 | ] | ||
| 50 | }, | ||
| 51 | "F11\n-\n\n_\n\n\n\n\n\nP", | ||
| 52 | "F12\n=\n\n+\n\n\n\n\n\n<i class='kb kb-Unicode-BackSpace-DeleteLeft-Big'></i>" | ||
| 53 | ], | ||
| 54 | [ | ||
| 55 | { | ||
| 56 | "a": 7, | ||
| 57 | "f": 3 | ||
| 58 | }, | ||
| 59 | "<i class='mss mss-Unicode-DeleteRight-Big-2'></i>", | ||
| 60 | { | ||
| 61 | "f": 3 | ||
| 62 | }, | ||
| 63 | "A", | ||
| 64 | { | ||
| 65 | "f": 3 | ||
| 66 | }, | ||
| 67 | "S", | ||
| 68 | { | ||
| 69 | "f": 3 | ||
| 70 | }, | ||
| 71 | "D", | ||
| 72 | { | ||
| 73 | "t": "#ff0000", | ||
| 74 | "a": 4, | ||
| 75 | "f": 3 | ||
| 76 | }, | ||
| 77 | "\n(\n\n\n\n\n\n\n\nF", | ||
| 78 | { | ||
| 79 | "t": "#000000", | ||
| 80 | "f": 3 | ||
| 81 | }, | ||
| 82 | "\n)\n\n\n\n\n\n\n\nG", | ||
| 83 | { | ||
| 84 | "f": 3 | ||
| 85 | }, | ||
| 86 | "\n{\n\n\nMacro0\n\n\n\n\nH", | ||
| 87 | { | ||
| 88 | "t": "#ff0000", | ||
| 89 | "f": 3 | ||
| 90 | }, | ||
| 91 | "\n}\n\n\nMacro3\n\n\n\n\nJ", | ||
| 92 | { | ||
| 93 | "t": "#000000", | ||
| 94 | "f": 3 | ||
| 95 | }, | ||
| 96 | "{\n\n\n\n\n\n\n\n\nK", | ||
| 97 | { | ||
| 98 | "f": 3 | ||
| 99 | }, | ||
| 100 | "{\n\n\n\n\n\n\n\n\nL", | ||
| 101 | { | ||
| 102 | "fa": [ | ||
| 103 | 2, | ||
| 104 | 2, | ||
| 105 | 2, | ||
| 106 | 2, | ||
| 107 | 0, | ||
| 108 | 0, | ||
| 109 | 0, | ||
| 110 | 2 | ||
| 111 | ] | ||
| 112 | }, | ||
| 113 | "\\\n\n|\n\n\n\n\n:\n\n;", | ||
| 114 | { | ||
| 115 | "a": 7, | ||
| 116 | "fa": [ | ||
| 117 | 9 | ||
| 118 | ] | ||
| 119 | }, | ||
| 120 | "<i class='mss mss-Unicode-Enter-3'></i>" | ||
| 121 | ], | ||
| 122 | [ | ||
| 123 | { | ||
| 124 | "f": 3 | ||
| 125 | }, | ||
| 126 | "Shift", | ||
| 127 | { | ||
| 128 | "f": 3 | ||
| 129 | }, | ||
| 130 | "Z", | ||
| 131 | { | ||
| 132 | "f": 3 | ||
| 133 | }, | ||
| 134 | "X\n\n\n\nCut", | ||
| 135 | { | ||
| 136 | "f": 3 | ||
| 137 | }, | ||
| 138 | "C\n\n\n\nCopy", | ||
| 139 | { | ||
| 140 | "a": 4, | ||
| 141 | "fa": [ | ||
| 142 | 2, | ||
| 143 | 2, | ||
| 144 | 2, | ||
| 145 | 2 | ||
| 146 | ] | ||
| 147 | }, | ||
| 148 | "\\\n[\n|\n{\nPaste\n\n\n\n\nV", | ||
| 149 | "|\n]\n\n}\nMacro1\n\n\n\n\nB", | ||
| 150 | "`\n'\n~\n\"\nMacro5\n\n\n\n\nN", | ||
| 151 | "~\n\"\n\n\nMacro2\n\n\n\n\nM", | ||
| 152 | { | ||
| 153 | "fa": [ | ||
| 154 | 2, | ||
| 155 | 2, | ||
| 156 | 2, | ||
| 157 | 2, | ||
| 158 | 0, | ||
| 159 | 0, | ||
| 160 | 0, | ||
| 161 | 1 | ||
| 162 | ] | ||
| 163 | }, | ||
| 164 | "[\n\n{\n\n\n\n\n<\n\n,", | ||
| 165 | "[\n\n{\n\n\n\n\n\n\n.", | ||
| 166 | { | ||
| 167 | "a": 6 | ||
| 168 | }, | ||
| 169 | "\n\n?\n\n\n\n\n\n/", | ||
| 170 | { | ||
| 171 | "a": 4, | ||
| 172 | "fa": [ | ||
| 173 | 2, | ||
| 174 | 2, | ||
| 175 | 2, | ||
| 176 | 0, | ||
| 177 | 0, | ||
| 178 | 0, | ||
| 179 | 0, | ||
| 180 | 1, | ||
| 181 | 9, | ||
| 182 | 0 | ||
| 183 | ] | ||
| 184 | }, | ||
| 185 | "\n\n\n<i class='kb kb-Arrows-Bottom-4'></i>Shift\n\n\n\n\n<i class='mss mss-Unicode-Enter-3'></i>\n\n<i class='kb kb-Arrows-Bottom-4'></i>Shift" | ||
| 186 | ], | ||
| 187 | [ | ||
| 188 | { | ||
| 189 | "a": 7, | ||
| 190 | "f": 3 | ||
| 191 | }, | ||
| 192 | "Ctrl\n\n\n\nBLight", | ||
| 193 | { | ||
| 194 | "a": 4, | ||
| 195 | "fa": [ | ||
| 196 | 2, | ||
| 197 | 1, | ||
| 198 | 2, | ||
| 199 | 0, | ||
| 200 | 0, | ||
| 201 | 0, | ||
| 202 | 0, | ||
| 203 | 1, | ||
| 204 | 9, | ||
| 205 | 9 | ||
| 206 | ] | ||
| 207 | }, | ||
| 208 | "\nZNorm\n\n\nRESET\n\n\n\n\n<i class='mss mss-Unicode-Escape-3'></i>", | ||
| 209 | { | ||
| 210 | "fa": [ | ||
| 211 | 2, | ||
| 212 | 1, | ||
| 213 | 2, | ||
| 214 | 0, | ||
| 215 | 0, | ||
| 216 | 0, | ||
| 217 | 0, | ||
| 218 | 1, | ||
| 219 | 9, | ||
| 220 | 6 | ||
| 221 | ] | ||
| 222 | }, | ||
| 223 | "\nZIn\n\n\n\n\n\n\n\n<i class='kb kb-logo-windows-8'></i>", | ||
| 224 | { | ||
| 225 | "fa": [ | ||
| 226 | 2, | ||
| 227 | 1, | ||
| 228 | 2, | ||
| 229 | 0, | ||
| 230 | 0, | ||
| 231 | 0, | ||
| 232 | 0, | ||
| 233 | 1, | ||
| 234 | 9, | ||
| 235 | 9 | ||
| 236 | ] | ||
| 237 | }, | ||
| 238 | "\nZOut\n\n\n\n\n\n\n\n<i class='kb kb-Unicode-Alternate-1'></i>", | ||
| 239 | { | ||
| 240 | "a": 7, | ||
| 241 | "fa": [ | ||
| 242 | 9 | ||
| 243 | ] | ||
| 244 | }, | ||
| 245 | "⇓", | ||
| 246 | { | ||
| 247 | "a": 4, | ||
| 248 | "fa": [ | ||
| 249 | 9, | ||
| 250 | 5, | ||
| 251 | 5 | ||
| 252 | ], | ||
| 253 | "w": 2 | ||
| 254 | }, | ||
| 255 | "\n<i class='kb kb-Unicode-Page-Down-3'></i>\n<i class='kb kb-Unicode-Page-Up-3'></i>", | ||
| 256 | { | ||
| 257 | "a": 7 | ||
| 258 | }, | ||
| 259 | "⇑", | ||
| 260 | { | ||
| 261 | "a": 4, | ||
| 262 | "fa": [ | ||
| 263 | 2 | ||
| 264 | ] | ||
| 265 | }, | ||
| 266 | "<i class='kb kb-Multimedia-FastForward-End'></i>\n\n\n\n\n\n\n\n\n←", | ||
| 267 | "<i class='kb kb-Multimedia-Volume-Down-1'></i>\n\n\n\n\n\n\n\n\n↓", | ||
| 268 | "<i class='kb kb-Multimedia-Volume-Up-1'></i>\n\n\n\n\n\n\n\n\n↑", | ||
| 269 | "<i class='kb kb-Multimedia-Play-Pause'></i>\n\n\n\n\n\n\n\n\n→" | ||
| 270 | ] | ||
| 271 | ] \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/espynn/readme.md b/keyboards/planck/keymaps/espynn/readme.md new file mode 100644 index 000000000..8882f4601 --- /dev/null +++ b/keyboards/planck/keymaps/espynn/readme.md | |||
| @@ -0,0 +1,18 @@ | |||
| 1 | # Espynn's keymap for Planck Ortholinear 40% Mechanical Keyboard | ||
| 2 | Created by James Folkert: https://twitter.com/trekloFsemaJ | ||
| 3 | Added several custom functions to the keymap from the "ab" map. Special thanks to "mollat" for demonstration of macros in their keymap.c | ||
| 4 | |||
| 5 | |||
| 6 |  | ||
| 7 | |||
| 8 | |||
| 9 | * Online keyboard layout editor: http://www.keyboard-layout-editor.com/ | ||
| 10 | * [JSON of raw layout] (layout.json "JSON of raw layout") | ||
| 11 | |||
| 12 | # Notes | ||
| 13 | * Simultaneous RAISE+LOWER enters CUSTOM layer. Several custom keymaps are here | ||
| 14 | * I disregarded the advice of Jack and used macros for passwords. I accept my fate. These have been abstracted to macros 2, 3, and 4 | ||
| 15 | * add your mobile and email to the keymap before make | ||
| 16 | * RAISE and LOWER also acts as PgUp and PgDn when tapped. | ||
| 17 | * [CapsLock] also acts as [Ctrl] key when you press and hold. It is convenient for GNU Emacs users. (not sure if this works) | ||
| 18 | * Bracket/ paran/ brace keys are placed in the center of the keyboard for programmer's convenience. \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/luke/Makefile b/keyboards/planck/keymaps/luke/Makefile new file mode 100644 index 000000000..847686873 --- /dev/null +++ b/keyboards/planck/keymaps/luke/Makefile | |||
| @@ -0,0 +1,25 @@ | |||
| 1 | |||
| 2 | |||
| 3 | # Build Options | ||
| 4 | # change to "no" to disable the options, or define them in the Makefile in | ||
| 5 | # the appropriate keymap folder that will get included automatically | ||
| 6 | # | ||
| 7 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 8 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 9 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 10 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 11 | COMMAND_ENABLE = no # Commands for debug and configuration | ||
| 12 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 13 | BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality | ||
| 14 | MIDI_ENABLE = no # MIDI controls | ||
| 15 | AUDIO_ENABLE = no # Audio output on port C6 | ||
| 16 | UNICODE_ENABLE = yes # Unicode | ||
| 17 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 18 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 19 | |||
| 20 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||
| 21 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 22 | |||
| 23 | ifndef QUANTUM_DIR | ||
| 24 | include ../../../../Makefile | ||
| 25 | endif | ||
diff --git a/keyboards/planck/keymaps/luke/keymap.c b/keyboards/planck/keymaps/luke/keymap.c new file mode 100644 index 000000000..26dcb451b --- /dev/null +++ b/keyboards/planck/keymaps/luke/keymap.c | |||
| @@ -0,0 +1,355 @@ | |||
| 1 | /* | ||
| 2 | * A keyboard layout for the gridded planck. | ||
| 3 | * | ||
| 4 | * Copyright (C) 2017 Luke Silva | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or | ||
| 7 | * modify it under the terms of the GNU General Public License | ||
| 8 | * as published by the Free Software Foundation; either version 2 | ||
| 9 | * of the License, or (at your option) any later version. | ||
| 10 | * | ||
| 11 | * This program is distributed in the hope that it will be useful, | ||
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 14 | * GNU General Public License for more details. | ||
| 15 | * | ||
| 16 | * You should have received a copy of the GNU General Public License | ||
| 17 | * along with this program; if not, write to the Free Software | ||
| 18 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||
| 19 | * | ||
| 20 | * ,-----------------------------------------------------------------------------------. | ||
| 21 | * | | | | | | | | | | | | | | ||
| 22 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 23 | * | | | | | | | | | | | | | | ||
| 24 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 25 | * | | | | | | | | | | | | | | ||
| 26 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 27 | * | | | | | | | | | | | | | | ||
| 28 | * `-----------------------------------------------------------------------------------' | ||
| 29 | * | ||
| 30 | * This layout uses colemak by default, and is designed for programming, with easy access to symbols | ||
| 31 | * through either double purpose modifiers or colemak style rolling for commonly used symbol clusters | ||
| 32 | * Eg: compare colemak 'this' to '(){\n}' on the symbol layer. | ||
| 33 | * | ||
| 34 | * The layout also supports a range of multilingual characters, covering those | ||
| 35 | * needed for French, German, Swedish and likely some other European Languages. | ||
| 36 | * In the future full support for Colemak's multilingual deadkeys may be introduced. | ||
| 37 | * | ||
| 38 | * The multilingual characters are inputted through QMK's unicode engine, using | ||
| 39 | * the Linux input method by default, however this can be changed at runtime. | ||
| 40 | * | ||
| 41 | */ | ||
| 42 | |||
| 43 | |||
| 44 | #include "planck.h" | ||
| 45 | |||
| 46 | #define _______ KC_TRNS | ||
| 47 | #define XXXXXXX KC_NO | ||
| 48 | |||
| 49 | |||
| 50 | // Layers | ||
| 51 | #define _COLEMAK 0 | ||
| 52 | #define _QWERTY 1 | ||
| 53 | #define _SYM 2 | ||
| 54 | #define _NUM 3 | ||
| 55 | #define _GR 4 | ||
| 56 | #define _GR_S 5 | ||
| 57 | #define _ADJ 6 | ||
| 58 | #define _NAV 7 | ||
| 59 | #define _PLOVER 8 | ||
| 60 | |||
| 61 | // Macro ID numbers | ||
| 62 | #define M_ALT_HASH 1 | ||
| 63 | #define M_GR_DASH 2 | ||
| 64 | #define M_SYM_LPRN 3 | ||
| 65 | #define M_NAV_UNDS 4 | ||
| 66 | #define M_NUM_RPRN 5 | ||
| 67 | #define M_CTRL_DLR 6 | ||
| 68 | #define M_LCBR_ENT 7 | ||
| 69 | #define M_PLOVER 8 | ||
| 70 | #define M_EXT_PLV 9 | ||
| 71 | #define M_WINDOWS 10 | ||
| 72 | #define M_LINUX 11 | ||
| 73 | #define M_OSX 12 | ||
| 74 | #define M_FUNCTION 13 | ||
| 75 | #define M_THEN 14 | ||
| 76 | #define M_CATCH 15 | ||
| 77 | |||
| 78 | // Macro keys | ||
| 79 | #define ALT_HASH MACROTAP(M_ALT_HASH) // tap for #, hold for Alt | ||
| 80 | #define GR_DASH MACROTAP(M_GR_DASH) // tap for -, hold for GR layer a-class-name | ||
| 81 | #define SYM_LPRN MACROTAP(M_SYM_LPRN) // tap for (, hold for symbols layer if() | ||
| 82 | #define NAV_UNDS MACROTAP(M_NAV_UNDS) // tap for _, hold for navigation layer snake_case_variable | ||
| 83 | #define NUM_RPRN MACROTAP(M_NUM_RPRN) // tap for ), hold for numbers layer else if() | ||
| 84 | #define CTRL_DLR MACROTAP(M_CTRL_DLR) // tap for $, hold for ctrl $php_is_really_weird | ||
| 85 | #define LCBR_ENT M(M_LCBR_ENT) // {\n easier code formatting | ||
| 86 | #define PLOVER M(M_PLOVER) // PHROPB (plover) or ERFVIK(qwerty) starts plover | ||
| 87 | #define EXT_PLV M(M_EXT_PLV) // PHRO*F (plover) or ERFVYU(qwerty) stops plover | ||
| 88 | #define WINDOWS M(M_WINDOWS) // Sets Unicode handler to windows | ||
| 89 | #define LINUX M(M_LINUX) // Sets Unicode handler to linux | ||
| 90 | #define OSX M(M_OSX) // Sets Unicode handler to OSX | ||
| 91 | #define FUNCTION M(M_FUNCTION) | ||
| 92 | #define THEN M(M_THEN) | ||
| 93 | #define CATCH M(M_CATCH) | ||
| 94 | |||
| 95 | |||
| 96 | // Renames of QMK keys... (would have otherwise been a macro) | ||
| 97 | #define QWERTY DF(_QWERTY) | ||
| 98 | #define COLEMAK DF(_COLEMAK) | ||
| 99 | |||
| 100 | |||
| 101 | |||
| 102 | |||
| 103 | |||
| 104 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 105 | |||
| 106 | /* Colemak | ||
| 107 | * ,-----------------------------------------------------------------------------------. | ||
| 108 | * | Tab | Q | W | F | P | G | J | L | U | Y | ;: | Bksp | | ||
| 109 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 110 | * | Bksp | A | R | S | T | D | H | N | E | I | O | '" | | ||
| 111 | * |------+------+------+------+------+------+------+------+------+------+------+------`---. | ||
| 112 | * |Shift=| Z | X | C | V | B | K | M | ,< | .> | /? |Shift/Ent | | ||
| 113 | * |------+------+------+------+------+------+------+------+------+------+------+----------| | ||
| 114 | * |CtCaps|GUIF4 | Alt# | Gr- | Sym( | Nav_ |Space | Num) |Ctrl$ | F11 | F12 |Nav toggle| | ||
| 115 | * `---------------------------------------------------------------------------------------' | ||
| 116 | */ | ||
| 117 | |||
| 118 | [_COLEMAK] = { | ||
| 119 | {KC_TAB, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_BSPC}, | ||
| 120 | {KC_BSPC, KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, KC_QUOT}, | ||
| 121 | {SFT_T(KC_EQL), KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_T(KC_ENT) }, | ||
| 122 | {CTL_T(KC_CAPS), KC_LGUI, ALT_HASH, GR_DASH, SYM_LPRN, NAV_UNDS, KC_SPC, NUM_RPRN, CTRL_DLR, KC_F11, KC_F12, TG(_NAV)} | ||
| 123 | }, | ||
| 124 | |||
| 125 | |||
| 126 | |||
| 127 | /* QWERTY | ||
| 128 | * ,-----------------------------------------------------------------------------------. | ||
| 129 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 130 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 131 | * | Bksp | A | S | D | F | G | H | J | K | L | ;: | '" | | ||
| 132 | * |------+------+------+------+------+------+------+------+------+------+------+------`---. | ||
| 133 | * |Shift=| Z | X | C | V | B | N | M | ,< | .> | /? |Shift/Ent | | ||
| 134 | * |------+------+------+------+------+------+------+------+------+------+------+----------| | ||
| 135 | * |CtCaps|GUIF4 | Alt# | Gr- | Sym( | Nav_ |Space | Num) |Ctrl$ | F11 | F12 |Nav toggle| | ||
| 136 | * `---------------------------------------------------------------------------------------' | ||
| 137 | */ | ||
| 138 | |||
| 139 | [_QWERTY] = { | ||
| 140 | {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC}, | ||
| 141 | {KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, | ||
| 142 | {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, SFT_T(KC_ENT) }, | ||
| 143 | {CTL_T(KC_CAPS), KC_LGUI, KC_LALT, GR_DASH, SYM_LPRN,KC_SPC, KC_SPC, NUM_RPRN, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT} | ||
| 144 | }, | ||
| 145 | |||
| 146 | |||
| 147 | /* Symbols | ||
| 148 | * ,-----------------------------------------------------------------------------------. | ||
| 149 | * | Tab | ` | @ | / | * | ^ | % | : | + | - | Del | Bksp | | ||
| 150 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 151 | * | | [ | ; | } | ( | " | ' | ) | {\n | ! | ] | \ | | ||
| 152 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 153 | * |Shift | . | { | < | > | ~ | X2 | = | & | | | ? |Enter | | ||
| 154 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 155 | * | | | | | Sym | _ |Space | NUM | X2 | | | | | ||
| 156 | * `-----------------------------------------------------------------------------------' | ||
| 157 | */ | ||
| 158 | |||
| 159 | [_SYM] = { | ||
| 160 | {KC_TAB, KC_GRV, KC_AT, KC_SLSH, KC_ASTR, KC_CIRC, KC_PERC, KC_COLN, KC_PLUS, KC_MINS, KC_DEL, KC_BSPC}, | ||
| 161 | {FUNCTION,KC_LBRC, KC_SCLN, KC_RCBR, KC_LPRN, KC_DQT, KC_QUOT, KC_RPRN, LCBR_ENT,KC_EXLM, KC_RBRC, KC_BSLS}, | ||
| 162 | {KC_LSFT, KC_DOT, KC_LCBR, KC_LABK, KC_RABK, KC_TILD, _______, KC_EQL, KC_AMPR, KC_PIPE, KC_QUES, KC_ENT }, | ||
| 163 | {THEN, CATCH, XXXXXXX, XXXXXXX, _______, _______, _______, _______, _______, XXXXXXX, XXXXXXX, _______} | ||
| 164 | }, | ||
| 165 | |||
| 166 | |||
| 167 | /* Numbers | ||
| 168 | * ,-----------------------------------------------------------------------------------. | ||
| 169 | * | Tab | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | ||
| 170 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 171 | * | Bksp | x | D | E | F | + | - | 4 | 5 | 6 | 0 |Enter | | ||
| 172 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 173 | * |Shift | ( | A | B | C | * | / | 1 | 2 | 3 | ) |Enter | | ||
| 174 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 175 | * | | | | GR | SYM | _ |Space | NUM | 0 | . | f | | | ||
| 176 | * `-----------------------------------------------------------------------------------' | ||
| 177 | */ | ||
| 178 | |||
| 179 | [_NUM] = { | ||
| 180 | {KC_TAB, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC}, | ||
| 181 | {KC_BSPC, KC_X, S(KC_D), S(KC_E), S(KC_F), KC_PLUS, KC_MINS, KC_4, KC_5, KC_6, KC_0, KC_ENT }, | ||
| 182 | {KC_LSFT, KC_LPRN, S(KC_A), S(KC_B), S(KC_C), KC_ASTR, KC_SLSH, KC_1, KC_2, KC_3, KC_RPRN, KC_ENT }, | ||
| 183 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_0, KC_DOT, KC_F, _______} | ||
| 184 | }, | ||
| 185 | |||
| 186 | |||
| 187 | /* Gr layer / international keys | ||
| 188 | * ,-----------------------------------------------------------------------------------. | ||
| 189 | * | | ä | å | | ¢£ | €¥ | | ë | ê | ü | ù | | | ||
| 190 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 191 | * | | â | à | ß | | | | è | é | ï | ö | | | ||
| 192 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 193 | * | | æ | ô | ç | œ | | | û | « | » | î | | | ||
| 194 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 195 | * | | | | | | | | | | | | | | ||
| 196 | * `-----------------------------------------------------------------------------------' | ||
| 197 | */ | ||
| 198 | |||
| 199 | [_GR] = { | ||
| 200 | {_______, UC(0xE4),UC(0xE5), _______,UC(0xA2), UC(0x20AC),_______,UC(0xEB),UC(0xEA),UC(0xFC),UC(0xF9), _______}, | ||
| 201 | {_______, UC(0xE2),UC(0xE0),UC(0xDF), _______, _______, _______,UC(0xE8),UC(0xE9),UC(0xEF),UC(0xF6), _______}, | ||
| 202 | {MO(_GR_S),UC(0xE6),UC(0xF4),UC(0xE7),UC(0x153),_______, _______,UC(0xFB),UC(0xAB),UC(0xBB),UC(0xEE), MO(_GR_S)}, | ||
| 203 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 204 | }, | ||
| 205 | |||
| 206 | // Shifted layer of the above | ||
| 207 | [_GR_S] = { | ||
| 208 | {_______, UC(0xC4),UC(0xC5), _______, UC(0xA3), UC(0xA5),_______, UC(0xCB),UC(0xCA),UC(0xDC),UC(0xD9),_______}, | ||
| 209 | {_______, UC(0xC2),UC(0xC0), UC(0xDF),_______, _______, _______, UC(0xC8),UC(0xC9),UC(0xCF),UC(0xD6),_______}, | ||
| 210 | {MO(_GR_S),UC(0xC6),UC(0xD4), UC(0xC7),UC(0x152),_______, _______, UC(0xDB),UC(0xAB),UC(0xBB),UC(0xCE),MO(_GR_S)}, | ||
| 211 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 212 | }, | ||
| 213 | |||
| 214 | |||
| 215 | /* Adjust Layer (Gr + Num) | ||
| 216 | * ,-----------------------------------------------------------------------------------. | ||
| 217 | * | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | | ||
| 218 | * |------+-------------+------+------+------+------+------+------+------+------+------| | ||
| 219 | * | | |Prntscr| ESC |VOLUP | PLAY | PREV |QWERTY|COLEMAK|PLOVER| | | | ||
| 220 | * |------+-------------+------+------+------+------+------+------+------+------+------| | ||
| 221 | * | | |BACKLIT| INS |VOLDWN| MUTE | NEXT | WIND |LINUX | OSX | | | | ||
| 222 | * |------+-------------+------+------+------+------+------+------+------+------+------| | ||
| 223 | * | | | | | | | | | | | | | | ||
| 224 | * `-----------------------------------------------------------------------------------' | ||
| 225 | */ | ||
| 226 | |||
| 227 | [_ADJ] = { | ||
| 228 | {KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12 }, | ||
| 229 | {XXXXXXX, XXXXXXX, KC_PSCR, KC_ESC, KC_VOLU, KC_MPLY, KC_MPRV, QWERTY, COLEMAK, PLOVER, XXXXXXX, XXXXXXX}, | ||
| 230 | {XXXXXXX, XXXXXXX, BL_STEP, KC_INS, KC_VOLD, KC_MUTE, KC_MNXT, WINDOWS, LINUX, OSX, XXXXXXX, XXXXXXX}, | ||
| 231 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 232 | }, | ||
| 233 | |||
| 234 | |||
| 235 | /* Navigation | ||
| 236 | * ,-----------------------------------------------------------------------------------. | ||
| 237 | * | | | BTN3 | BTN2 | BTN1 | | ACL0 | HOME | PGDN | PGUP | END | Bksp | | ||
| 238 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 239 | * | |MSLEFT| MSDN | MSUP |MSRGHT| | ACL1 | LEFT | DOWN | UP | RGHT |Enter | | ||
| 240 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 241 | * | |WHLEFT| WHDN | WHUP |WHRGHT| | ACL2 |C-LEFT|C-PGDN|C-PGUP|C-RGHT|Enter | | ||
| 242 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 243 | * | | | | | | _ |Space | ACL0 | ACL1 | ACL2 | |TGLNAV| | ||
| 244 | * `-----------------------------------------------------------------------------------' | ||
| 245 | */ | ||
| 246 | |||
| 247 | [_NAV] = { | ||
| 248 | {XXXXXXX, XXXXXXX, KC_BTN3, KC_BTN2, KC_BTN1, XXXXXXX, KC_ACL0, KC_HOME, KC_PGDN, KC_PGUP, KC_END, KC_BSPC}, | ||
| 249 | {XXXXXXX, KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R, XXXXXXX, KC_ACL1, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT,KC_ENT }, | ||
| 250 | {XXXXXXX, KC_WH_L, KC_WH_D, KC_WH_U, KC_WH_R, XXXXXXX, KC_ACL2, LCTL(KC_LEFT), LCTL(KC_PGDN), LCTL(KC_PGUP), LCTL(KC_RIGHT), KC_ENT }, | ||
| 251 | {_______, _______, _______, _______, _______, _______, _______, KC_ACL0, KC_ACL1, KC_ACL2, _______, _______} | ||
| 252 | }, | ||
| 253 | |||
| 254 | /* Plover Layer | ||
| 255 | * ,-----------------------------------------------------------------------------------. | ||
| 256 | * | | S | T | P | H | * | * | F | P | L | T | D | | ||
| 257 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 258 | * |TogOut| S | K | W | R | * | * | R | B | G | S | Z | | ||
| 259 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 260 | * | # | # | # | # | # | # | # | # | # | # | # | # | | ||
| 261 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 262 | * | Exit | | | # | A | O | E | U | | | | | | ||
| 263 | * `-----------------------------------------------------------------------------------' | ||
| 264 | */ | ||
| 265 | |||
| 266 | [_PLOVER] = { | ||
| 267 | {XXXXXXX, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC}, | ||
| 268 | {XXXXXXX, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, | ||
| 269 | {KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1 }, | ||
| 270 | {EXT_PLV, XXXXXXX, XXXXXXX, KC_1, KC_C, KC_V, KC_N, KC_M, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX} | ||
| 271 | } | ||
| 272 | |||
| 273 | |||
| 274 | }; | ||
| 275 | |||
| 276 | const uint16_t PROGMEM fn_actions[] = { | ||
| 277 | }; | ||
| 278 | |||
| 279 | |||
| 280 | void matrix_init_user(){ | ||
| 281 | set_unicode_input_mode(UC_LNX); | ||
| 282 | } | ||
| 283 | |||
| 284 | |||
| 285 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | ||
| 286 | { | ||
| 287 | switch(id) { | ||
| 288 | case M_ALT_HASH: | ||
| 289 | return MACRO_TAP_SHFT_KEY_HOLD_MOD(record, 3, LALT); | ||
| 290 | case M_GR_DASH: | ||
| 291 | { | ||
| 292 | const macro_t* macro = MACRO_TAP_HOLD_LAYER(record, MACRO(T(MINS)), _GR); | ||
| 293 | update_tri_layer(_NUM, _GR, _ADJ); | ||
| 294 | return macro; | ||
| 295 | } | ||
| 296 | case M_SYM_LPRN: | ||
| 297 | return MACRO_TAP_SHFT_KEY_HOLD_LAYER(record, 9, _SYM); | ||
| 298 | case M_NAV_UNDS: | ||
| 299 | return MACRO_TAP_SHFT_KEY_HOLD_LAYER(record, MINS, _NAV); | ||
| 300 | case M_NUM_RPRN: | ||
| 301 | { | ||
| 302 | const macro_t* macro = MACRO_TAP_SHFT_KEY_HOLD_LAYER(record, 0, _NUM); | ||
| 303 | update_tri_layer(_NUM, _GR, _ADJ); | ||
| 304 | return macro; | ||
| 305 | } | ||
| 306 | case M_CTRL_DLR: | ||
| 307 | return MACRO_TAP_SHFT_KEY_HOLD_MOD(record, 4, LCTL); | ||
| 308 | case M_LCBR_ENT: | ||
| 309 | return MACRODOWN(I(10), D(LSFT), T(LBRC), U(LSFT), T(ENT), END); | ||
| 310 | case M_PLOVER: | ||
| 311 | if (record->event.pressed) { | ||
| 312 | layer_and(0); | ||
| 313 | layer_on(_PLOVER); | ||
| 314 | default_layer_set(_PLOVER); | ||
| 315 | |||
| 316 | // Starts plover | ||
| 317 | return MACRO(I(10), D(E), D(R), D(F), D(V), D(I), D(K), U(E), U(R), U(F), U(V), U(I), U(K), END); | ||
| 318 | } | ||
| 319 | break; | ||
| 320 | case M_EXT_PLV: | ||
| 321 | if (!record->event.pressed) { | ||
| 322 | layer_off(_PLOVER); | ||
| 323 | default_layer_set(_COLEMAK); | ||
| 324 | |||
| 325 | //Pauses plover | ||
| 326 | return MACRO(I(10), D(E), D(R), D(F), D(V), D(Y), D(U), U(E), U(R), U(F), U(V), U(Y), U(U), END); | ||
| 327 | } | ||
| 328 | break; | ||
| 329 | case M_WINDOWS: | ||
| 330 | set_unicode_input_mode(UC_WIN); | ||
| 331 | break; | ||
| 332 | case M_LINUX: | ||
| 333 | set_unicode_input_mode(UC_LNX); | ||
| 334 | break; | ||
| 335 | case M_OSX: | ||
| 336 | set_unicode_input_mode(UC_OSX); | ||
| 337 | break; | ||
| 338 | case M_FUNCTION: | ||
| 339 | if (record->event.pressed) { | ||
| 340 | SEND_STRING("function"); | ||
| 341 | } | ||
| 342 | break; | ||
| 343 | case M_THEN: | ||
| 344 | if (record->event.pressed) { | ||
| 345 | SEND_STRING("then"); | ||
| 346 | } | ||
| 347 | break; | ||
| 348 | case M_CATCH: | ||
| 349 | if (record->event.pressed) { | ||
| 350 | SEND_STRING("catch"); | ||
| 351 | } | ||
| 352 | break; | ||
| 353 | } | ||
| 354 | return MACRO_NONE; | ||
| 355 | }; | ||
diff --git a/keyboards/planck/keymaps/luke/readme.md b/keyboards/planck/keymaps/luke/readme.md new file mode 100644 index 000000000..3a4824b5b --- /dev/null +++ b/keyboards/planck/keymaps/luke/readme.md | |||
| @@ -0,0 +1,2 @@ | |||
| 1 | # A more basic Planck Layout for copying | ||
| 2 | |||
diff --git a/keyboards/planck/keymaps/smt/Makefile b/keyboards/planck/keymaps/smt/Makefile new file mode 100644 index 000000000..457a3d01d --- /dev/null +++ b/keyboards/planck/keymaps/smt/Makefile | |||
| @@ -0,0 +1,3 @@ | |||
| 1 | ifndef QUANTUM_DIR | ||
| 2 | include ../../../../Makefile | ||
| 3 | endif | ||
diff --git a/keyboards/planck/keymaps/smt/keymap.c b/keyboards/planck/keymaps/smt/keymap.c new file mode 100644 index 000000000..51e5a40bf --- /dev/null +++ b/keyboards/planck/keymaps/smt/keymap.c | |||
| @@ -0,0 +1,229 @@ | |||
| 1 | #include "planck.h" | ||
| 2 | #include "action_layer.h" | ||
| 3 | #ifdef AUDIO_ENABLE | ||
| 4 | #include "audio.h" | ||
| 5 | #endif | ||
| 6 | #include "eeconfig.h" | ||
| 7 | |||
| 8 | extern keymap_config_t keymap_config; | ||
| 9 | |||
| 10 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | ||
| 11 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. | ||
| 12 | // Layer names don't all need to be of the same length, obviously, and you can also skip them | ||
| 13 | // entirely and just use numbers. | ||
| 14 | #define _DVORAK 0 | ||
| 15 | #define _QWERTY 1 | ||
| 16 | #define _LOWER 2 | ||
| 17 | #define _RAISE 3 | ||
| 18 | #define _ADJUST 16 | ||
| 19 | |||
| 20 | enum planck_keycodes { | ||
| 21 | DVORAK = SAFE_RANGE, | ||
| 22 | QWERTY, | ||
| 23 | LOWER, | ||
| 24 | RAISE, | ||
| 25 | BACKLIT | ||
| 26 | }; | ||
| 27 | |||
| 28 | // Fillers to make layering more clear | ||
| 29 | #define _______ KC_TRNS | ||
| 30 | #define XXXXXXX KC_NO | ||
| 31 | |||
| 32 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 33 | |||
| 34 | /* Dvorak | ||
| 35 | * ,-----------------------------------------------------------------------------------. | ||
| 36 | * | Tab | " | , | . | P | Y | F | G | C | R | L | Bksp | | ||
| 37 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 38 | * | Esc | A | O | E | U | I | D | H | T | N | S | - | | ||
| 39 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 40 | * | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | | ||
| 41 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 42 | * | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | ||
| 43 | * `-----------------------------------------------------------------------------------' | ||
| 44 | */ | ||
| 45 | [_DVORAK] = { | ||
| 46 | {KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_BSPC}, | ||
| 47 | {KC_ESC, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS}, | ||
| 48 | {SFT_T(KC_ESC), KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_T(KC_ENT)}, | ||
| 49 | {ALL_T(KC_GRV), KC_LCTL, KC_LALT, KC_LGUI, LOWER, KC_SPC, KC_SPC, RAISE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} | ||
| 50 | }, | ||
| 51 | |||
| 52 | /* Qwerty | ||
| 53 | * ,-----------------------------------------------------------------------------------. | ||
| 54 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 55 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 56 | * | Esc | A | S | D | F | G | H | J | K | L | ; | " | | ||
| 57 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 58 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | | ||
| 59 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 60 | * | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | ||
| 61 | * `-----------------------------------------------------------------------------------' | ||
| 62 | */ | ||
| 63 | [_QWERTY] = { | ||
| 64 | {_______, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC}, | ||
| 65 | {_______, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, | ||
| 66 | {_______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______}, | ||
| 67 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 68 | }, | ||
| 69 | |||
| 70 | /* Lower | ||
| 71 | * ,-----------------------------------------------------------------------------------. | ||
| 72 | * | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Del | | ||
| 73 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 74 | * | | F1 | F2 | F3 | F4 | F5 | F6 | 4 | 5 | 6 | Home |PageUp| | ||
| 75 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 76 | * | | F7 | F8 | F9 | F10 | F11 | F12 | 1 | 2 | 3 | End |PageDn| | ||
| 77 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 78 | * | | | | | | | | Next | Vol- | Vol+ | Play | | ||
| 79 | * `-----------------------------------------------------------------------------------' | ||
| 80 | */ | ||
| 81 | [_LOWER] = { | ||
| 82 | {KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_DEL}, | ||
| 83 | {_______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_4, KC_5, KC_6, KC_HOME, KC_PGUP}, | ||
| 84 | {_______, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_1, KC_2, KC_3, KC_END, KC_PGDN}, | ||
| 85 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} | ||
| 86 | }, | ||
| 87 | |||
| 88 | /* Raise | ||
| 89 | * ,-----------------------------------------------------------------------------------. | ||
| 90 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | ||
| 91 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 92 | * | | | | | | | _ | ? | + | { | } | | | | ||
| 93 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 94 | * | | | | | | | - | / | = | [ | ] | \ | | ||
| 95 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 96 | * | | | | | | | | Next | Vol- | Vol+ | Play | | ||
| 97 | * `-----------------------------------------------------------------------------------' | ||
| 98 | */ | ||
| 99 | [_RAISE] = { | ||
| 100 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL}, | ||
| 101 | {_______, _______, _______, _______, _______, _______, KC_UNDS, KC_QUES, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE}, | ||
| 102 | {_______, _______, _______, _______, _______, _______, KC_MINS, KC_SLSH, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS}, | ||
| 103 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} | ||
| 104 | }, | ||
| 105 | |||
| 106 | /* Adjust (Lower + Raise) | ||
| 107 | * ,-----------------------------------------------------------------------------------. | ||
| 108 | * | | Reset| | | | | | | | | | Del | | ||
| 109 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 110 | * | | | |Aud on|Audoff|AGnorm|AGswap|Dvorak|Qwerty| | | | | ||
| 111 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 112 | * | |Voice-|Voice+|Mus on|Musoff|MIDIon|MIDIof| | | | | | | ||
| 113 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 114 | * | | | | | | | | | | | | | ||
| 115 | * `-----------------------------------------------------------------------------------' | ||
| 116 | */ | ||
| 117 | [_ADJUST] = { | ||
| 118 | {_______, RESET, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_DEL}, | ||
| 119 | {_______, _______, _______, AU_ON, AU_OFF, AG_NORM, AG_SWAP, DVORAK, QWERTY, _______, _______, _______}, | ||
| 120 | {_______, MUV_DE, MUV_IN, MU_ON, MU_OFF, MI_ON, MI_OFF, _______, _______, _______, _______, _______}, | ||
| 121 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||
| 122 | } | ||
| 123 | |||
| 124 | |||
| 125 | }; | ||
| 126 | |||
| 127 | #ifdef AUDIO_ENABLE | ||
| 128 | |||
| 129 | float tone_startup[][2] = SONG(STARTUP_SOUND); | ||
| 130 | float tone_qwerty[][2] = SONG(QWERTY_SOUND); | ||
| 131 | float tone_dvorak[][2] = SONG(DVORAK_SOUND); | ||
| 132 | float music_scale[][2] = SONG(MUSIC_SCALE_SOUND); | ||
| 133 | |||
| 134 | float tone_goodbye[][2] = SONG(GOODBYE_SOUND); | ||
| 135 | #endif | ||
| 136 | |||
| 137 | |||
| 138 | void persistant_default_layer_set(uint16_t default_layer) { | ||
| 139 | eeconfig_update_default_layer(default_layer); | ||
| 140 | default_layer_set(default_layer); | ||
| 141 | } | ||
| 142 | |||
| 143 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||
| 144 | switch (keycode) { | ||
| 145 | case DVORAK: | ||
| 146 | if (record->event.pressed) { | ||
| 147 | #ifdef AUDIO_ENABLE | ||
| 148 | PLAY_NOTE_ARRAY(tone_dvorak, false, 0); | ||
| 149 | #endif | ||
| 150 | persistant_default_layer_set(1UL<<_DVORAK); | ||
| 151 | } | ||
| 152 | return false; | ||
| 153 | break; | ||
| 154 | case QWERTY: | ||
| 155 | if (record->event.pressed) { | ||
| 156 | #ifdef AUDIO_ENABLE | ||
| 157 | PLAY_NOTE_ARRAY(tone_qwerty, false, 0); | ||
| 158 | #endif | ||
| 159 | persistant_default_layer_set(1UL<<_QWERTY); | ||
| 160 | } | ||
| 161 | return false; | ||
| 162 | break; | ||
| 163 | case LOWER: | ||
| 164 | if (record->event.pressed) { | ||
| 165 | layer_on(_LOWER); | ||
| 166 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 167 | } else { | ||
| 168 | layer_off(_LOWER); | ||
| 169 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 170 | } | ||
| 171 | return false; | ||
| 172 | break; | ||
| 173 | case RAISE: | ||
| 174 | if (record->event.pressed) { | ||
| 175 | layer_on(_RAISE); | ||
| 176 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 177 | } else { | ||
| 178 | layer_off(_RAISE); | ||
| 179 | update_tri_layer(_LOWER, _RAISE, _ADJUST); | ||
| 180 | } | ||
| 181 | return false; | ||
| 182 | break; | ||
| 183 | case BACKLIT: | ||
| 184 | if (record->event.pressed) { | ||
| 185 | register_code(KC_RSFT); | ||
| 186 | #ifdef BACKLIGHT_ENABLE | ||
| 187 | backlight_step(); | ||
| 188 | #endif | ||
| 189 | } else { | ||
| 190 | unregister_code(KC_RSFT); | ||
| 191 | } | ||
| 192 | return false; | ||
| 193 | break; | ||
| 194 | } | ||
| 195 | return true; | ||
| 196 | } | ||
| 197 | |||
| 198 | void matrix_init_user(void) { | ||
| 199 | #ifdef AUDIO_ENABLE | ||
| 200 | startup_user(); | ||
| 201 | #endif | ||
| 202 | } | ||
| 203 | |||
| 204 | #ifdef AUDIO_ENABLE | ||
| 205 | |||
| 206 | void startup_user() | ||
| 207 | { | ||
| 208 | _delay_ms(20); // gets rid of tick | ||
| 209 | PLAY_NOTE_ARRAY(tone_startup, false, 0); | ||
| 210 | } | ||
| 211 | |||
| 212 | void shutdown_user() | ||
| 213 | { | ||
| 214 | PLAY_NOTE_ARRAY(tone_goodbye, false, 0); | ||
| 215 | _delay_ms(150); | ||
| 216 | stop_all_notes(); | ||
| 217 | } | ||
| 218 | |||
| 219 | void music_on_user(void) | ||
| 220 | { | ||
| 221 | music_scale_user(); | ||
| 222 | } | ||
| 223 | |||
| 224 | void music_scale_user(void) | ||
| 225 | { | ||
| 226 | PLAY_NOTE_ARRAY(music_scale, false, 0); | ||
| 227 | } | ||
| 228 | |||
| 229 | #endif | ||
diff --git a/keyboards/planck/keymaps/smt/readme.md b/keyboards/planck/keymaps/smt/readme.md new file mode 100644 index 000000000..0e955a574 --- /dev/null +++ b/keyboards/planck/keymaps/smt/readme.md | |||
| @@ -0,0 +1,103 @@ | |||
| 1 | # smt's Planck keymap | ||
| 2 | |||
| 3 | This keymap is primarily based on the default Planck keymap. | ||
| 4 | |||
| 5 | Notable differences from the default are: | ||
| 6 | |||
| 7 | 1. **Dvorak by default** | ||
| 8 | |||
| 9 | I happen to type in Dvorak, and prefer that layer to be the default on my keyboard. This is easy enough to switch around with Qwerty, Colemak, or whatever. | ||
| 10 | |||
| 11 | 2. **Right Shift** | ||
| 12 | |||
| 13 | I use both the left and right shift keys when I type. When I want to modify a key with shift, I hold shift with the hand opposite the one typing the key. In the default keymap, Enter is where shift would be on a standard keyboard layout. Oh, muscle memory. | ||
| 14 | |||
| 15 | Thankfully, QMK supports [mod-tap](https://github.com/jackhumbert/qmk_firmware/wiki#fun-with-modifier-keys) keys, and this allows me to set the Enter key to send a modifier (MOD_LSFT) when held, and KC_ENT when tapped. Awesome! | ||
| 16 | |||
| 17 | 3. Escape | ||
| 18 | |||
| 19 | I am experimenting with using Left Shift as a mod-tap key for Escape, similar to how I use the Enter key. It's set up like this on my Minivan, so in the interest of consistency... | ||
| 20 | |||
| 21 | 4. Backtick | ||
| 22 | |||
| 23 | I don't currently have LEDs on any of my keyboards, and even if I did, I don't think I would want their controls on a base layer. | ||
| 24 | |||
| 25 | So, why use backtick in the lower left corner? I use it as my tmux prefix key, so I need to type it more frequently than most people. Putting it on the base layer works well for me. | ||
| 26 | |||
| 27 | ## Dvorak (default) | ||
| 28 | |||
| 29 | ``` | ||
| 30 | ,-----------------------------------------------------------------------------------. | ||
| 31 | | Tab | " | , | . | P | Y | F | G | C | R | L | Bksp | | ||
| 32 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 33 | | Esc | A | O | E | U | I | D | H | T | N | S | - | | ||
| 34 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 35 | | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | | ||
| 36 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 37 | | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | ||
| 38 | `-----------------------------------------------------------------------------------' | ||
| 39 | ``` | ||
| 40 | |||
| 41 | ## Qwerty (same as default) | ||
| 42 | |||
| 43 | ``` | ||
| 44 | ,-----------------------------------------------------------------------------------. | ||
| 45 | | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 46 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 47 | | Esc | A | S | D | F | G | H | J | K | L | ; | " | | ||
| 48 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 49 | | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | | ||
| 50 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 51 | | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | ||
| 52 | `-----------------------------------------------------------------------------------' | ||
| 53 | ``` | ||
| 54 | |||
| 55 | ## Lower | ||
| 56 | |||
| 57 | This is where I put the number row, a numpad cluster, function keys, and some light navigation via Home/End/PageUp/PageDn. Like the "Raise" layer, the top row is redundant to help with Planck compatibility. | ||
| 58 | |||
| 59 | ``` | ||
| 60 | ,-----------------------------------------------------------------------------------. | ||
| 61 | | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Del | | ||
| 62 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 63 | | | F1 | F2 | F3 | F4 | F5 | F6 | 4 | 5 | 6 | Home |PageUp| | ||
| 64 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 65 | | | F7 | F8 | F9 | F10 | F11 | F12 | 1 | 2 | 3 | End |PageDn| | ||
| 66 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 67 | | | | | | | | | Next | Vol- | Vol+ | Play | | ||
| 68 | `-----------------------------------------------------------------------------------' | ||
| 69 | ``` | ||
| 70 | |||
| 71 | ## Raise | ||
| 72 | |||
| 73 | As a developer, it makes the most sense for me to group all the commonly-used symbols that don't fit on the main layer. In particular, having the dual-column of parens-braces-brackets really helps a lot. | ||
| 74 | |||
| 75 | I haven't completely filled this layer, which leaves room for future mappings and macros. | ||
| 76 | |||
| 77 | ``` | ||
| 78 | ,-----------------------------------------------------------------------------------. | ||
| 79 | | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | ||
| 80 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 81 | | | | | | | | _ | ? | + | { | } | | | | ||
| 82 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 83 | | | | | | | | - | / | = | [ | ] | \ | | ||
| 84 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 85 | | | | | | | | | Next | Vol- | Vol+ | Play | | ||
| 86 | `-----------------------------------------------------------------------------------' | ||
| 87 | ``` | ||
| 88 | |||
| 89 | ## Adjust (Lower + Raise) | ||
| 90 | |||
| 91 | Utility layer. This is where I'd switch to Qwerty, or ~~fool around with~~ adjust the audio/music settings. | ||
| 92 | |||
| 93 | ``` | ||
| 94 | ,-----------------------------------------------------------------------------------. | ||
| 95 | | | Reset| | | | | | | | | | Del | | ||
| 96 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 97 | | | | |Aud on|AudOff|AGnorm|AGswap|Dvorak|Qwerty| | | | | ||
| 98 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 99 | | |Voice-|Voice+|Mus on|MusOff|MidiOn|MidOff| | | | | | | ||
| 100 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 101 | | | | | | | | | | | | | | ||
| 102 | `-----------------------------------------------------------------------------------' | ||
| 103 | ``` | ||
diff --git a/keyboards/planck/keymaps/yale/Makefile b/keyboards/planck/keymaps/yale/Makefile new file mode 100644 index 000000000..581e08cd0 --- /dev/null +++ b/keyboards/planck/keymaps/yale/Makefile | |||
| @@ -0,0 +1,25 @@ | |||
| 1 | |||
| 2 | |||
| 3 | # Build Options | ||
| 4 | # change to "no" to disable the options, or define them in the Makefile in | ||
| 5 | # the appropriate keymap folder that will get included automatically | ||
| 6 | # | ||
| 7 | BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000) | ||
| 8 | MOUSEKEY_ENABLE = yes # Mouse keys(+4700) | ||
| 9 | EXTRAKEY_ENABLE = yes # Audio control and System control(+450) | ||
| 10 | CONSOLE_ENABLE = no # Console for debug(+400) | ||
| 11 | COMMAND_ENABLE = yes # Commands for debug and configuration | ||
| 12 | NKRO_ENABLE = yes # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work | ||
| 13 | BACKLIGHT_ENABLE = yes # Enable keyboard backlight functionality | ||
| 14 | MIDI_ENABLE = no # MIDI controls | ||
| 15 | AUDIO_ENABLE = yes # Audio output on port C6 | ||
| 16 | UNICODE_ENABLE = no # Unicode | ||
| 17 | BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID | ||
| 18 | RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. Do not enable this with audio at the same time. | ||
| 19 | |||
| 20 | # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||
| 21 | SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend | ||
| 22 | |||
| 23 | ifndef QUANTUM_DIR | ||
| 24 | include ../../../../Makefile | ||
| 25 | endif \ No newline at end of file | ||
diff --git a/keyboards/planck/keymaps/yale/config.h b/keyboards/planck/keymaps/yale/config.h new file mode 100644 index 000000000..8a916bbd0 --- /dev/null +++ b/keyboards/planck/keymaps/yale/config.h | |||
| @@ -0,0 +1,11 @@ | |||
| 1 | #ifndef CONFIG_USER_H | ||
| 2 | #define CONFIG_USER_H | ||
| 3 | |||
| 4 | #include "../../config.h" | ||
| 5 | |||
| 6 | #define PREVENT_STUCK_MODIFIERS | ||
| 7 | |||
| 8 | #endif | ||
| 9 | |||
| 10 | |||
| 11 | |||
diff --git a/keyboards/planck/keymaps/yale/keymap.c b/keyboards/planck/keymaps/yale/keymap.c new file mode 100644 index 000000000..f2280778a --- /dev/null +++ b/keyboards/planck/keymaps/yale/keymap.c | |||
| @@ -0,0 +1,108 @@ | |||
| 1 | // This is the canonical layout file for the Quantum project. If you want to add another keyboard, | ||
| 2 | // this is the style you want to emulate. | ||
| 3 | // | ||
| 4 | |||
| 5 | #include "planck.h" | ||
| 6 | #ifdef BACKLIGHT_ENABLE | ||
| 7 | #include "backlight.h" | ||
| 8 | #endif | ||
| 9 | |||
| 10 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | ||
| 11 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. | ||
| 12 | // Layer names don't all need to be of the same length, obviously, and you can also skip them | ||
| 13 | // entirely and just use numbers. | ||
| 14 | #define _QWERTY 0 | ||
| 15 | #define _NUM 5 | ||
| 16 | #define _FUNC 6 | ||
| 17 | #define _NAV 7 | ||
| 18 | |||
| 19 | // Fillers to make layering more clear | ||
| 20 | #define _______ KC_TRNS | ||
| 21 | #define XXXXXXX KC_NO | ||
| 22 | |||
| 23 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
| 24 | |||
| 25 | /* _QWERTY | ||
| 26 | * ,-----------------------------------------------------------------------------------. | ||
| 27 | * | Esc | Q | W | E | R | T | Y | U | I | O | P | Bksp | | ||
| 28 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 29 | * |Ctrl/Tab| A | S | D | F | G | H | J | K | L | ; | " | | ||
| 30 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 31 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Shift | | ||
| 32 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 33 | * | Ctrl | Alt | GUI | GUI | Num | Space | FN | GUI | Alt | Ctrl | Enter| | ||
| 34 | * `-----------------------------------------------------------------------------------' | ||
| 35 | */ | ||
| 36 | [_QWERTY] = { | ||
| 37 | {KC_ESC, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC}, | ||
| 38 | {CTL_T(KC_TAB), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, | ||
| 39 | {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT}, | ||
| 40 | {KC_LCTL, KC_LALT, KC_LGUI, KC_LGUI, MO(_NUM), KC_SPC, KC_SPC, MO(_FUNC), KC_RGUI, KC_RALT, KC_RCTL, KC_ENT} | ||
| 41 | }, | ||
| 42 | |||
| 43 | /* _NUM | ||
| 44 | * ,-----------------------------------------------------------------------------------. | ||
| 45 | * | ___ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | ____ | | ||
| 46 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 47 | * | Ctrl | ` | [ | { | ( | / | \ | ) | } | ] | - | = | | ||
| 48 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 49 | * | ____ | ! | @ | # | $ | % | ^ | & | * | _ | + | ____ | | ||
| 50 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 51 | * | ____ | ___ | ___ | ___ | XXXX | ______ | ____ | ____ | ____ | __ | ____ | | ||
| 52 | * `-----------------------------------------------------------------------------------' | ||
| 53 | */ | ||
| 54 | [_NUM] = { | ||
| 55 | {_______, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, _______}, | ||
| 56 | {KC_LCTL, KC_GRV, KC_LBRC, KC_LCBR, KC_LPRN, KC_SLSH, KC_BSLS, KC_RPRN, KC_RCBR, KC_RBRC, KC_MINS, KC_EQL}, | ||
| 57 | {_______, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_UNDS, KC_PLUS, _______}, | ||
| 58 | {_______, _______, _______, _______, _______, _______, _______, MO(_NAV), _______, _______, _______, _______} | ||
| 59 | }, | ||
| 60 | |||
| 61 | /* _FUNC | ||
| 62 | * ,-----------------------------------------------------------------------------------. | ||
| 63 | * | ____ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | ____ | | ||
| 64 | * |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 65 | * | ____ |Shift | Ctrl | Alt | GUI | ____ | Left | Down | Up |Right | Del | ____ | | ||
| 66 | * |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 67 | * | ____ |Light | ____ | Vol- | Prev | Play | Mute | Next | Vol+ | ____ | ____ | ____ | | ||
| 68 | * |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 69 | * | ____ | ____ | ____ | ____ | ____ | _____ | XXXX | ____ | ____ | ____ | ____ | | ||
| 70 | * `-----------------------------------------------------------------------------------' | ||
| 71 | */ | ||
| 72 | [_FUNC] = { | ||
| 73 | {_______, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, _______}, | ||
| 74 | {_______, KC_LSFT, KC_LCTL, KC_LALT, KC_LGUI, _______, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_DEL, _______}, | ||
| 75 | {_______, M(0), _______, KC_VOLD, KC_MPRV, KC_MPLY, KC_MUTE, KC_MNXT, KC_VOLU, _______, _______, _______}, | ||
| 76 | {_______, _______, _______, _______, MO(_NAV), _______, _______, _______, _______, _______, _______, _______} | ||
| 77 | }, | ||
| 78 | |||
| 79 | [_NAV] = { | ||
| 80 | {KC_MS_ACCEL2, KC_FN1, KC_FN2, KC_FN3, KC_FN4, XXXXXXX, XXXXXXX, KC_WH_D, KC_WH_U, XXXXXXX, XXXXXXX, XXXXXXX}, | ||
| 81 | {KC_MS_ACCEL1, KC_MS_BTN4, KC_MS_BTN3, KC_MS_BTN2, KC_MS_BTN1, XXXXXXX, KC_MS_LEFT, KC_MS_DOWN, KC_MS_UP, KC_MS_RIGHT, XXXXXXX, XXXXXXX}, | ||
| 82 | {KC_MS_ACCEL0, KC_FN9, KC_FN10, KC_FN11, KC_FN12, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX}, | ||
| 83 | {XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX} | ||
| 84 | }, | ||
| 85 | |||
| 86 | }; | ||
| 87 | |||
| 88 | const uint16_t PROGMEM fn_actions[] = { | ||
| 89 | |||
| 90 | }; | ||
| 91 | |||
| 92 | const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) | ||
| 93 | { | ||
| 94 | // MACRODOWN only works in this function | ||
| 95 | switch(id) { | ||
| 96 | case 0: | ||
| 97 | if (record->event.pressed) { | ||
| 98 | register_code(KC_RSFT); | ||
| 99 | #ifdef BACKLIGHT_ENABLE | ||
| 100 | backlight_step(); | ||
| 101 | #endif | ||
| 102 | } else { | ||
| 103 | unregister_code(KC_RSFT); | ||
| 104 | } | ||
| 105 | break; | ||
| 106 | } | ||
| 107 | return MACRO_NONE; | ||
| 108 | }; | ||
diff --git a/keyboards/planck/keymaps/yale/yale_layout_picture.jpg b/keyboards/planck/keymaps/yale/yale_layout_picture.jpg new file mode 100644 index 000000000..ab9c6b4eb --- /dev/null +++ b/keyboards/planck/keymaps/yale/yale_layout_picture.jpg | |||
| Binary files differ | |||
diff --git a/keyboards/preonic/keymaps/smt/keymap.c b/keyboards/preonic/keymaps/smt/keymap.c index 5465d543a..ba05d9ad5 100644 --- a/keyboards/preonic/keymaps/smt/keymap.c +++ b/keyboards/preonic/keymaps/smt/keymap.c | |||
| @@ -1,9 +1,9 @@ | |||
| 1 | #include "preonic.h" | 1 | #include "preonic.h" |
| 2 | #include "action_layer.h" | 2 | #include "action_layer.h" |
| 3 | #include "eeconfig.h" | ||
| 4 | #ifdef AUDIO_ENABLE | 3 | #ifdef AUDIO_ENABLE |
| 5 | #include "audio.h" | 4 | #include "audio.h" |
| 6 | #endif | 5 | #endif |
| 6 | #include "eeconfig.h" | ||
| 7 | 7 | ||
| 8 | // Each layer gets a name for readability, which is then used in the keymap matrix below. | 8 | // Each layer gets a name for readability, which is then used in the keymap matrix below. |
| 9 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. | 9 | // The underscores don't mean anything - you can have a layer called STUFF or any other name. |
| @@ -33,39 +33,39 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 33 | * ,-----------------------------------------------------------------------------------. | 33 | * ,-----------------------------------------------------------------------------------. |
| 34 | * | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 34 | * | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | |
| 35 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 35 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 36 | * | Tab | " | , | . | P | Y | F | G | C | R | L | / | | 36 | * | Tab | " | , | . | P | Y | F | G | C | R | L | Bksp | |
| 37 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 37 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 38 | * | Esc | A | O | E | U | I | D | H | T | N | S | - | | 38 | * | Esc | A | O | E | U | I | D | H | T | N | S | - | |
| 39 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 39 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 40 | * | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | | 40 | * | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | |
| 41 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 41 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 42 | * | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | 42 | * | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | |
| 43 | * `-----------------------------------------------------------------------------------' | 43 | * `-----------------------------------------------------------------------------------' |
| 44 | */ | 44 | */ |
| 45 | [_DVORAK] = { | 45 | [_DVORAK] = { |
| 46 | {KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC}, | 46 | {KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC}, |
| 47 | {KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_SLSH}, | 47 | {KC_TAB, KC_QUOT, KC_COMM, KC_DOT, KC_P, KC_Y, KC_F, KC_G, KC_C, KC_R, KC_L, KC_BSPC}, |
| 48 | {KC_ESC, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS}, | 48 | {KC_ESC, KC_A, KC_O, KC_E, KC_U, KC_I, KC_D, KC_H, KC_T, KC_N, KC_S, KC_MINS}, |
| 49 | {KC_LSFT, KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_T(KC_ENT)}, | 49 | {SFT_T(KC_ESC), KC_SCLN, KC_Q, KC_J, KC_K, KC_X, KC_B, KC_M, KC_W, KC_V, KC_Z, SFT_T(KC_ENT)}, |
| 50 | {BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER, KC_SPC, KC_SPC, RAISE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} | 50 | {ALL_T(KC_GRV), KC_LCTL, KC_LALT, KC_LGUI, LOWER, KC_SPC, KC_SPC, RAISE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} |
| 51 | }, | 51 | }, |
| 52 | 52 | ||
| 53 | /* Qwerty | 53 | /* Qwerty |
| 54 | * ,-----------------------------------------------------------------------------------. | 54 | * ,-----------------------------------------------------------------------------------. |
| 55 | * | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 55 | * | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | |
| 56 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 56 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 57 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Del | | 57 | * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | |
| 58 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 58 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 59 | * | Esc | A | S | D | F | G | H | J | K | L | ; | " | | 59 | * | Esc | A | S | D | F | G | H | J | K | L | ; | " | |
| 60 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 60 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 61 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | | 61 | * | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | |
| 62 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 62 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 63 | * | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | 63 | * | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | |
| 64 | * `-----------------------------------------------------------------------------------' | 64 | * `-----------------------------------------------------------------------------------' |
| 65 | */ | 65 | */ |
| 66 | [_QWERTY] = { | 66 | [_QWERTY] = { |
| 67 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}, | 67 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}, |
| 68 | {_______, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_DEL}, | 68 | {_______, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, _______}, |
| 69 | {_______, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, | 69 | {_______, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT}, |
| 70 | {_______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______}, | 70 | {_______, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, _______}, |
| 71 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | 71 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} |
| @@ -98,9 +98,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 98 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 98 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 99 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | 99 | * | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | |
| 100 | * |------+------+------+------+------+-------------+------+------+------+------+------| | 100 | * |------+------+------+------+------+-------------+------+------+------+------+------| |
| 101 | * | | | | | | | | _ | + | { | } | | | | 101 | * | | | | | | | _ | ? | + | { | } | | | |
| 102 | * |------+------+------+------+------+------|------+------+------+------+------+------| | 102 | * |------+------+------+------+------+------|------+------+------+------+------+------| |
| 103 | * | | | | | | | | - | = | [ | ] | \ | | 103 | * | | | | | | | - | / | = | [ | ] | \ | |
| 104 | * |------+------+------+------+------+------+------+------+------+------+------+------| | 104 | * |------+------+------+------+------+------+------+------+------+------+------+------| |
| 105 | * | | | | | | | | Next | Vol- | Vol+ | Play | | 105 | * | | | | | | | | Next | Vol- | Vol+ | Play | |
| 106 | * `-----------------------------------------------------------------------------------' | 106 | * `-----------------------------------------------------------------------------------' |
| @@ -108,8 +108,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 108 | [_RAISE] = { | 108 | [_RAISE] = { |
| 109 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL}, | 109 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL}, |
| 110 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL}, | 110 | {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_DEL}, |
| 111 | {_______, _______, _______, _______, _______, _______, _______, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE}, | 111 | {_______, _______, _______, _______, _______, _______, KC_UNDS, KC_QUES, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE}, |
| 112 | {_______, _______, _______, _______, _______, _______, _______, KC_MINS, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS}, | 112 | {_______, _______, _______, _______, _______, _______, KC_MINS, KC_SLSH, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS}, |
| 113 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} | 113 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} |
| 114 | }, | 114 | }, |
| 115 | 115 | ||
diff --git a/keyboards/preonic/keymaps/smt/readme.md b/keyboards/preonic/keymaps/smt/readme.md index 2dcc1927f..016da7b01 100644 --- a/keyboards/preonic/keymaps/smt/readme.md +++ b/keyboards/preonic/keymaps/smt/readme.md | |||
| @@ -12,7 +12,17 @@ Notable differences from the default are: | |||
| 12 | 12 | ||
| 13 | I use both the left and right shift keys when I type. When I want to modify a key with shift, I hold shift with the hand opposite the one typing the key. In the default keymap, Enter is where shift would be on a standard keyboard layout. Oh, muscle memory. | 13 | I use both the left and right shift keys when I type. When I want to modify a key with shift, I hold shift with the hand opposite the one typing the key. In the default keymap, Enter is where shift would be on a standard keyboard layout. Oh, muscle memory. |
| 14 | 14 | ||
| 15 | Thankfully, QMK supports [mod-tap](https://github.com/qmk/qmk_firmware/wiki#fun-with-modifier-keys) keys, and this allows me to set the Enter key to send a modifier (MOD_LSFT) when held, and KC_ENT when tapped. Awesome! | 15 | Thankfully, QMK supports [mod-tap](https://github.com/jackhumbert/qmk_firmware/wiki#fun-with-modifier-keys) keys, and this allows me to set the Enter key to send a modifier (MOD_LSFT) when held, and KC_ENT when tapped. Awesome! |
| 16 | |||
| 17 | 3. Escape | ||
| 18 | |||
| 19 | I am experimenting with using Left Shift as a mod-tap key for Escape, similar to how I use the Enter key. It's set up like this on my Minivan, so in the interest of consistency... | ||
| 20 | |||
| 21 | 4. Backtick | ||
| 22 | |||
| 23 | I don't currently have LEDs on any of my keyboards, and even if I did, I don't think I would want their controls on a base layer. | ||
| 24 | |||
| 25 | So, why use backtick in the lower left corner? I use it as my tmux prefix key, so I need to type it more frequently than most people. Putting it on the base layer works well for me. | ||
| 16 | 26 | ||
| 17 | ## Dvorak (default) | 27 | ## Dvorak (default) |
| 18 | 28 | ||
| @@ -20,13 +30,13 @@ Notable differences from the default are: | |||
| 20 | ,-----------------------------------------------------------------------------------. | 30 | ,-----------------------------------------------------------------------------------. |
| 21 | | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 31 | | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | |
| 22 | |------+------+------+------+------+------+------+------+------+------+------+------| | 32 | |------+------+------+------+------+------+------+------+------+------+------+------| |
| 23 | | Tab | " | , | . | P | Y | F | G | C | R | L | / | | 33 | | Tab | " | , | . | P | Y | F | G | C | R | L | Bksp | |
| 24 | |------+------+------+------+------+-------------+------+------+------+------+------| | 34 | |------+------+------+------+------+-------------+------+------+------+------+------| |
| 25 | | Esc | A | O | E | U | I | D | H | T | N | S | - | | 35 | | Esc | A | O | E | U | I | D | H | T | N | S | - | |
| 26 | |------+------+------+------+------+------|------+------+------+------+------+------| | 36 | |------+------+------+------+------+------|------+------+------+------+------+------| |
| 27 | | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | | 37 | | Shift| ; | Q | J | K | X | B | M | W | V | Z |Enter | |
| 28 | |------+------+------+------+------+------+------+------+------+------+------+------| | 38 | |------+------+------+------+------+------+------+------+------+------+------+------| |
| 29 | | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | 39 | | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | |
| 30 | `-----------------------------------------------------------------------------------' | 40 | `-----------------------------------------------------------------------------------' |
| 31 | ``` | 41 | ``` |
| 32 | 42 | ||
| @@ -36,13 +46,13 @@ Notable differences from the default are: | |||
| 36 | ,-----------------------------------------------------------------------------------. | 46 | ,-----------------------------------------------------------------------------------. |
| 37 | | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | | 47 | | ` | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | Bksp | |
| 38 | |------+------+------+------+------+------+------+------+------+------+------+------| | 48 | |------+------+------+------+------+------+------+------+------+------+------+------| |
| 39 | | Tab | Q | W | E | R | T | Y | U | I | O | P | Del | | 49 | | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | |
| 40 | |------+------+------+------+------+-------------+------+------+------+------+------| | 50 | |------+------+------+------+------+-------------+------+------+------+------+------| |
| 41 | | Esc | A | S | D | F | G | H | J | K | L | ; | " | | 51 | | Esc | A | S | D | F | G | H | J | K | L | ; | " | |
| 42 | |------+------+------+------+------+------|------+------+------+------+------+------| | 52 | |------+------+------+------+------+------|------+------+------+------+------+------| |
| 43 | | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | | 53 | | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | |
| 44 | |------+------+------+------+------+------+------+------+------+------+------+------| | 54 | |------+------+------+------+------+------+------+------+------+------+------+------| |
| 45 | | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | | 55 | | ` | Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | |
| 46 | `-----------------------------------------------------------------------------------' | 56 | `-----------------------------------------------------------------------------------' |
| 47 | ``` | 57 | ``` |
| 48 | 58 | ||
| @@ -76,10 +86,28 @@ I haven't completely filled this layer, which leaves room for future mappings an | |||
| 76 | |------+------+------+------+------+-------------+------+------+------+------+------| | 86 | |------+------+------+------+------+-------------+------+------+------+------+------| |
| 77 | | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | | 87 | | ~ | ! | @ | # | $ | % | ^ | & | * | ( | ) | Del | |
| 78 | |------+------+------+------+------+-------------+------+------+------+------+------| | 88 | |------+------+------+------+------+-------------+------+------+------+------+------| |
| 79 | | | | | | | | | _ | + | { | } | | | | 89 | | | | | | | | _ | ? | + | { | } | | | |
| 80 | |------+------+------+------+------+------|------+------+------+------+------+------| | 90 | |------+------+------+------+------+------|------+------+------+------+------+------| |
| 81 | | | | | | | | | - | = | [ | ] | \ | | 91 | | | | | | | | - | / | = | [ | ] | \ | |
| 82 | |------+------+------+------+------+------+------+------+------+------+------+------| | 92 | |------+------+------+------+------+------+------+------+------+------+------+------| |
| 83 | | | | | | | | | Next | Vol- | Vol+ | Play | | 93 | | | | | | | | | Next | Vol- | Vol+ | Play | |
| 84 | `-----------------------------------------------------------------------------------' | 94 | `-----------------------------------------------------------------------------------' |
| 85 | ``` | 95 | ``` |
| 96 | |||
| 97 | ## Adjust (Lower + Raise) | ||
| 98 | |||
| 99 | Utility layer. This is where I'd switch to Qwerty, or ~~fool around with~~ adjust the audio/music settings. | ||
| 100 | |||
| 101 | ``` | ||
| 102 | ,-----------------------------------------------------------------------------------. | ||
| 103 | | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | | ||
| 104 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 105 | | | Reset| | | | | | | | | | Del | | ||
| 106 | |------+------+------+------+------+-------------+------+------+------+------+------| | ||
| 107 | | | | |Aud on|AudOff|AGnorm|AGswap|Dvorak|Qwerty| | | | | ||
| 108 | |------+------+------+------+------+------|------+------+------+------+------+------| | ||
| 109 | | |Voice-|Voice+|Mus on|MusOff|MidiOn|MidOff| | | | | | | ||
| 110 | |------+------+------+------+------+------+------+------+------+------+------+------| | ||
| 111 | | | | | | | | | | | | | | ||
| 112 | `-----------------------------------------------------------------------------------' | ||
| 113 | ``` | ||
diff --git a/keyboards/readme.md b/keyboards/readme.md index d2f41ad7e..5b7b28207 100644 --- a/keyboards/readme.md +++ b/keyboards/readme.md | |||
| @@ -39,6 +39,7 @@ These keyboards are part of the QMK repository, but their manufacturers are not | |||
| 39 | * [Bantam44](/keyboards/bantam44) — It is a 44-key 40% staggered keyboard. | 39 | * [Bantam44](/keyboards/bantam44) — It is a 44-key 40% staggered keyboard. |
| 40 | * [Ergodox Infinity](/keyboards/ergodox) - Ergonomic Split Keyboard by Input Club. | 40 | * [Ergodox Infinity](/keyboards/ergodox) - Ergonomic Split Keyboard by Input Club. |
| 41 | * [GH60](/keyboards/gh60) — A 60% Geekhack community-driven project. | 41 | * [GH60](/keyboards/gh60) — A 60% Geekhack community-driven project. |
| 42 | * [GON NerD](/keyboards/gonnerd) — Korean custom 60% PCB | ||
| 42 | * [Happy Hacking Keyboard](/keyboards/hhkb) — The Happy Hacking keyboard can be hacked with a custom controller to run QMK. | 43 | * [Happy Hacking Keyboard](/keyboards/hhkb) — The Happy Hacking keyboard can be hacked with a custom controller to run QMK. |
| 43 | * [Infinity 60%](/keyboards/infinity60) - — Compact community keyboard by Input Club. | 44 | * [Infinity 60%](/keyboards/infinity60) - — Compact community keyboard by Input Club. |
| 44 | * [JD45](/keyboards/jd45) — Another Geekhack community project, designed by jdcarpe. | 45 | * [JD45](/keyboards/jd45) — Another Geekhack community project, designed by jdcarpe. |
diff --git a/quantum/config_common.h b/quantum/config_common.h index 4bdb2065d..28f68b9c7 100644 --- a/quantum/config_common.h +++ b/quantum/config_common.h | |||
| @@ -2,8 +2,10 @@ | |||
| 2 | #define CONFIG_DEFINITIONS_H | 2 | #define CONFIG_DEFINITIONS_H |
| 3 | 3 | ||
| 4 | /* diode directions */ | 4 | /* diode directions */ |
| 5 | #define COL2ROW 0 | 5 | #define COL2ROW 0 |
| 6 | #define ROW2COL 1 | 6 | #define ROW2COL 1 |
| 7 | #define CUSTOM_MATRIX 2 /* Disables built-in matrix scanning code */ | ||
| 8 | |||
| 7 | /* I/O pins */ | 9 | /* I/O pins */ |
| 8 | #ifndef F0 | 10 | #ifndef F0 |
| 9 | #define B0 0x30 | 11 | #define B0 0x30 |
diff --git a/quantum/keymap_common.c b/quantum/keymap_common.c index eced3d2bb..54b872d49 100644 --- a/quantum/keymap_common.c +++ b/quantum/keymap_common.c | |||
| @@ -80,7 +80,10 @@ action_t action_for_key(uint8_t layer, keypos_t key) | |||
| 80 | action.code = keymap_function_id_to_action( (int)keycode & 0xFFF ); | 80 | action.code = keymap_function_id_to_action( (int)keycode & 0xFFF ); |
| 81 | break; | 81 | break; |
| 82 | case QK_MACRO ... QK_MACRO_MAX: | 82 | case QK_MACRO ... QK_MACRO_MAX: |
| 83 | action.code = ACTION_MACRO(keycode & 0xFF); | 83 | if (keycode & 0x800) // tap macros have upper bit set |
| 84 | action.code = ACTION_MACRO_TAP(keycode & 0xFF); | ||
| 85 | else | ||
| 86 | action.code = ACTION_MACRO(keycode & 0xFF); | ||
| 84 | break; | 87 | break; |
| 85 | case QK_LAYER_TAP ... QK_LAYER_TAP_MAX: | 88 | case QK_LAYER_TAP ... QK_LAYER_TAP_MAX: |
| 86 | action.code = ACTION_LAYER_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF); | 89 | action.code = ACTION_LAYER_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF); |
| @@ -117,7 +120,7 @@ action_t action_for_key(uint8_t layer, keypos_t key) | |||
| 117 | action.code = ACTION_MODS_ONESHOT(mod); | 120 | action.code = ACTION_MODS_ONESHOT(mod); |
| 118 | break; | 121 | break; |
| 119 | case QK_MOD_TAP ... QK_MOD_TAP_MAX: | 122 | case QK_MOD_TAP ... QK_MOD_TAP_MAX: |
| 120 | action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0xF, keycode & 0xFF); | 123 | action.code = ACTION_MODS_TAP_KEY((keycode >> 0x8) & 0x1F, keycode & 0xFF); |
| 121 | break; | 124 | break; |
| 122 | #ifdef BACKLIGHT_ENABLE | 125 | #ifdef BACKLIGHT_ENABLE |
| 123 | case BL_0 ... BL_15: | 126 | case BL_0 ... BL_15: |
diff --git a/quantum/light_ws2812.c b/quantum/light_ws2812.c index a883b1388..55bdd9cd8 100755 --- a/quantum/light_ws2812.c +++ b/quantum/light_ws2812.c | |||
| @@ -70,7 +70,7 @@ void I2C_WriteBit(unsigned char c) | |||
| 70 | 70 | ||
| 71 | // Inits bitbanging port, must be called before using the functions below | 71 | // Inits bitbanging port, must be called before using the functions below |
| 72 | // | 72 | // |
| 73 | void I2C_Init() | 73 | void I2C_Init(void) |
| 74 | { | 74 | { |
| 75 | I2C_PORT &= ~ ((1 << I2C_DAT) | (1 << I2C_CLK)); | 75 | I2C_PORT &= ~ ((1 << I2C_DAT) | (1 << I2C_CLK)); |
| 76 | 76 | ||
| @@ -82,7 +82,7 @@ void I2C_Init() | |||
| 82 | 82 | ||
| 83 | // Send a START Condition | 83 | // Send a START Condition |
| 84 | // | 84 | // |
| 85 | void I2C_Start() | 85 | void I2C_Start(void) |
| 86 | { | 86 | { |
| 87 | // set both to high at the same time | 87 | // set both to high at the same time |
| 88 | I2C_DDR &= ~ ((1 << I2C_DAT) | (1 << I2C_CLK)); | 88 | I2C_DDR &= ~ ((1 << I2C_DAT) | (1 << I2C_CLK)); |
| @@ -97,7 +97,7 @@ void I2C_Start() | |||
| 97 | 97 | ||
| 98 | // Send a STOP Condition | 98 | // Send a STOP Condition |
| 99 | // | 99 | // |
| 100 | void I2C_Stop() | 100 | void I2C_Stop(void) |
| 101 | { | 101 | { |
| 102 | I2C_CLOCK_HI(); | 102 | I2C_CLOCK_HI(); |
| 103 | _delay_us(I2C_DELAY); | 103 | _delay_us(I2C_DELAY); |
diff --git a/quantum/matrix.c b/quantum/matrix.c index 07eb87bc3..ac523482a 100644 --- a/quantum/matrix.c +++ b/quantum/matrix.c | |||
| @@ -60,13 +60,14 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 60 | extern const matrix_row_t matrix_mask[]; | 60 | extern const matrix_row_t matrix_mask[]; |
| 61 | #endif | 61 | #endif |
| 62 | 62 | ||
| 63 | #if (DIODE_DIRECTION == ROW2COL) || (DIODE_DIRECTION == COL2ROW) | ||
| 63 | static const uint8_t row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS; | 64 | static const uint8_t row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS; |
| 64 | static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; | 65 | static const uint8_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS; |
| 66 | #endif | ||
| 65 | 67 | ||
| 66 | /* matrix state(1:on, 0:off) */ | 68 | /* matrix state(1:on, 0:off) */ |
| 67 | static matrix_row_t matrix[MATRIX_ROWS]; | 69 | static matrix_row_t matrix[MATRIX_ROWS]; |
| 68 | 70 | ||
| 69 | static matrix_row_t matrix_raw[MATRIX_ROWS]; | ||
| 70 | static matrix_row_t matrix_debouncing[MATRIX_ROWS]; | 71 | static matrix_row_t matrix_debouncing[MATRIX_ROWS]; |
| 71 | 72 | ||
| 72 | 73 | ||
| @@ -76,7 +77,7 @@ static matrix_row_t matrix_debouncing[MATRIX_ROWS]; | |||
| 76 | static void unselect_rows(void); | 77 | static void unselect_rows(void); |
| 77 | static void select_row(uint8_t row); | 78 | static void select_row(uint8_t row); |
| 78 | static void unselect_row(uint8_t row); | 79 | static void unselect_row(uint8_t row); |
| 79 | #else // ROW2COL | 80 | #elif (DIODE_DIRECTION == ROW2COL) |
| 80 | static void init_rows(void); | 81 | static void init_rows(void); |
| 81 | static bool read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col); | 82 | static bool read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col); |
| 82 | static void unselect_cols(void); | 83 | static void unselect_cols(void); |
| @@ -133,7 +134,7 @@ uint8_t matrix_cols(void) { | |||
| 133 | // /* PORTxn */ | 134 | // /* PORTxn */ |
| 134 | // _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF); | 135 | // _SFR_IO8((col_pins[c] >> 4) + 2) |= _BV(col_pins[c] & 0xF); |
| 135 | // } | 136 | // } |
| 136 | // #else | 137 | // #elif (DIODE_DIRECTION == ROW2COL) |
| 137 | // for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) { | 138 | // for (int8_t c = MATRIX_COLS - 1; c >= 0; --c) { |
| 138 | // /* DDRxn */ | 139 | // /* DDRxn */ |
| 139 | // _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF); | 140 | // _SFR_IO8((col_pins[c] >> 4) + 1) |= _BV(col_pins[c] & 0xF); |
| @@ -158,7 +159,7 @@ void matrix_init(void) { | |||
| 158 | #if (DIODE_DIRECTION == COL2ROW) | 159 | #if (DIODE_DIRECTION == COL2ROW) |
| 159 | unselect_rows(); | 160 | unselect_rows(); |
| 160 | init_cols(); | 161 | init_cols(); |
| 161 | #else // ROW2COL | 162 | #elif (DIODE_DIRECTION == ROW2COL) |
| 162 | unselect_cols(); | 163 | unselect_cols(); |
| 163 | init_rows(); | 164 | init_rows(); |
| 164 | #endif | 165 | #endif |
| @@ -166,7 +167,6 @@ void matrix_init(void) { | |||
| 166 | // initialize matrix state: all keys off | 167 | // initialize matrix state: all keys off |
| 167 | for (uint8_t i=0; i < MATRIX_ROWS; i++) { | 168 | for (uint8_t i=0; i < MATRIX_ROWS; i++) { |
| 168 | matrix[i] = 0; | 169 | matrix[i] = 0; |
| 169 | matrix_raw[i] = 0; | ||
| 170 | matrix_debouncing[i] = 0; | 170 | matrix_debouncing[i] = 0; |
| 171 | } | 171 | } |
| 172 | 172 | ||
| @@ -194,7 +194,7 @@ uint8_t matrix_scan(void) | |||
| 194 | 194 | ||
| 195 | } | 195 | } |
| 196 | 196 | ||
| 197 | #else // ROW2COL | 197 | #elif (DIODE_DIRECTION == ROW2COL) |
| 198 | 198 | ||
| 199 | // Set col, read rows | 199 | // Set col, read rows |
| 200 | for (uint8_t current_col = 0; current_col < MATRIX_COLS; current_col++) { | 200 | for (uint8_t current_col = 0; current_col < MATRIX_COLS; current_col++) { |
| @@ -336,7 +336,7 @@ static void unselect_rows(void) | |||
| 336 | } | 336 | } |
| 337 | } | 337 | } |
| 338 | 338 | ||
| 339 | #else // ROW2COL | 339 | #elif (DIODE_DIRECTION == ROW2COL) |
| 340 | 340 | ||
| 341 | static void init_rows(void) | 341 | static void init_rows(void) |
| 342 | { | 342 | { |
diff --git a/quantum/process_keycode/process_combo.c b/quantum/process_keycode/process_combo.c new file mode 100644 index 000000000..e2189ad98 --- /dev/null +++ b/quantum/process_keycode/process_combo.c | |||
| @@ -0,0 +1,134 @@ | |||
| 1 | #include "process_combo.h" | ||
| 2 | #include "print.h" | ||
| 3 | |||
| 4 | |||
| 5 | #define COMBO_TIMER_ELAPSED -1 | ||
| 6 | |||
| 7 | |||
| 8 | __attribute__ ((weak)) | ||
| 9 | combo_t key_combos[] = { | ||
| 10 | |||
| 11 | }; | ||
| 12 | |||
| 13 | __attribute__ ((weak)) | ||
| 14 | void process_combo_event(uint8_t combo_index, bool pressed) { | ||
| 15 | |||
| 16 | } | ||
| 17 | |||
| 18 | static uint8_t current_combo_index = 0; | ||
| 19 | |||
| 20 | static inline void send_combo(uint16_t action, bool pressed) | ||
| 21 | { | ||
| 22 | if (action) { | ||
| 23 | if (pressed) { | ||
| 24 | register_code16(action); | ||
| 25 | } else { | ||
| 26 | unregister_code16(action); | ||
| 27 | } | ||
| 28 | } else { | ||
| 29 | process_combo_event(current_combo_index, pressed); | ||
| 30 | } | ||
| 31 | } | ||
| 32 | |||
| 33 | #define ALL_COMBO_KEYS_ARE_DOWN (((1<<count)-1) == combo->state) | ||
| 34 | #define NO_COMBO_KEYS_ARE_DOWN (0 == combo->state) | ||
| 35 | #define KEY_STATE_DOWN(key) do{ combo->state |= (1<<key); } while(0) | ||
| 36 | #define KEY_STATE_UP(key) do{ combo->state &= ~(1<<key); } while(0) | ||
| 37 | static bool process_single_combo(combo_t *combo, uint16_t keycode, keyrecord_t *record) | ||
| 38 | { | ||
| 39 | uint8_t count = 0; | ||
| 40 | uint8_t index = -1; | ||
| 41 | /* Find index of keycode and number of combo keys */ | ||
| 42 | for (const uint16_t *keys = combo->keys; ;++count) { | ||
| 43 | uint16_t key = pgm_read_word(&keys[count]); | ||
| 44 | if (keycode == key) index = count; | ||
| 45 | if (COMBO_END == key) break; | ||
| 46 | } | ||
| 47 | |||
| 48 | /* Return if not a combo key */ | ||
| 49 | if (-1 == (int8_t)index) return false; | ||
| 50 | |||
| 51 | /* The combos timer is used to signal whether the combo is active */ | ||
| 52 | bool is_combo_active = COMBO_TIMER_ELAPSED == combo->timer ? false : true; | ||
| 53 | |||
| 54 | if (record->event.pressed) { | ||
| 55 | KEY_STATE_DOWN(index); | ||
| 56 | |||
| 57 | if (is_combo_active) { | ||
| 58 | if (ALL_COMBO_KEYS_ARE_DOWN) { /* Combo was pressed */ | ||
| 59 | send_combo(combo->keycode, true); | ||
| 60 | combo->timer = COMBO_TIMER_ELAPSED; | ||
| 61 | } else { /* Combo key was pressed */ | ||
| 62 | combo->timer = timer_read(); | ||
| 63 | #ifdef COMBO_ALLOW_ACTION_KEYS | ||
| 64 | combo->prev_record = *record; | ||
| 65 | #else | ||
| 66 | combo->prev_key = keycode; | ||
| 67 | #endif | ||
| 68 | } | ||
| 69 | } | ||
| 70 | } else { | ||
| 71 | if (ALL_COMBO_KEYS_ARE_DOWN) { /* Combo was released */ | ||
| 72 | send_combo(combo->keycode, false); | ||
| 73 | } | ||
| 74 | |||
| 75 | if (is_combo_active) { /* Combo key was tapped */ | ||
| 76 | #ifdef COMBO_ALLOW_ACTION_KEYS | ||
| 77 | record->event.pressed = true; | ||
| 78 | process_action(record, store_or_get_action(record->event.pressed, record->event.key)); | ||
| 79 | record->event.pressed = false; | ||
| 80 | process_action(record, store_or_get_action(record->event.pressed, record->event.key)); | ||
| 81 | #else | ||
| 82 | register_code16(keycode); | ||
| 83 | send_keyboard_report(); | ||
| 84 | unregister_code16(keycode); | ||
| 85 | #endif | ||
| 86 | combo->timer = 0; | ||
| 87 | } | ||
| 88 | |||
| 89 | KEY_STATE_UP(index); | ||
| 90 | } | ||
| 91 | |||
| 92 | if (NO_COMBO_KEYS_ARE_DOWN) { | ||
| 93 | combo->timer = 0; | ||
| 94 | } | ||
| 95 | |||
| 96 | return is_combo_active; | ||
| 97 | } | ||
| 98 | |||
| 99 | bool process_combo(uint16_t keycode, keyrecord_t *record) | ||
| 100 | { | ||
| 101 | bool is_combo_key = false; | ||
| 102 | |||
| 103 | for (current_combo_index = 0; current_combo_index < COMBO_COUNT; ++current_combo_index) { | ||
| 104 | combo_t *combo = &key_combos[current_combo_index]; | ||
| 105 | is_combo_key |= process_single_combo(combo, keycode, record); | ||
| 106 | } | ||
| 107 | |||
| 108 | return !is_combo_key; | ||
| 109 | } | ||
| 110 | |||
| 111 | void matrix_scan_combo(void) | ||
| 112 | { | ||
| 113 | for (int i = 0; i < COMBO_COUNT; ++i) { | ||
| 114 | combo_t *combo = &key_combos[i]; | ||
| 115 | if (combo->timer && | ||
| 116 | combo->timer != COMBO_TIMER_ELAPSED && | ||
| 117 | timer_elapsed(combo->timer) > COMBO_TERM) { | ||
| 118 | |||
| 119 | /* This disables the combo, meaning key events for this | ||
| 120 | * combo will be handled by the next processors in the chain | ||
| 121 | */ | ||
| 122 | combo->timer = COMBO_TIMER_ELAPSED; | ||
| 123 | |||
| 124 | #ifdef COMBO_ALLOW_ACTION_KEYS | ||
| 125 | process_action(&combo->prev_record, | ||
| 126 | store_or_get_action(combo->prev_record.event.pressed, | ||
| 127 | combo->prev_record.event.key)); | ||
| 128 | #else | ||
| 129 | unregister_code16(combo->prev_key); | ||
| 130 | register_code16(combo->prev_key); | ||
| 131 | #endif | ||
| 132 | } | ||
| 133 | } | ||
| 134 | } | ||
diff --git a/quantum/process_keycode/process_combo.h b/quantum/process_keycode/process_combo.h new file mode 100644 index 000000000..847f2b737 --- /dev/null +++ b/quantum/process_keycode/process_combo.h | |||
| @@ -0,0 +1,43 @@ | |||
| 1 | #ifndef PROCESS_COMBO_H | ||
| 2 | #define PROCESS_COMBO_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | #include "progmem.h" | ||
| 6 | #include "quantum.h" | ||
| 7 | |||
| 8 | typedef struct | ||
| 9 | { | ||
| 10 | const uint16_t *keys; | ||
| 11 | uint16_t keycode; | ||
| 12 | #ifdef EXTRA_EXTRA_LONG_COMBOS | ||
| 13 | uint32_t state; | ||
| 14 | #elif EXTRA_LONG_COMBOS | ||
| 15 | uint16_t state; | ||
| 16 | #else | ||
| 17 | uint8_t state; | ||
| 18 | #endif | ||
| 19 | uint16_t timer; | ||
| 20 | #ifdef COMBO_ALLOW_ACTION_KEYS | ||
| 21 | keyrecord_t prev_record; | ||
| 22 | #else | ||
| 23 | uint16_t prev_key; | ||
| 24 | #endif | ||
| 25 | } combo_t; | ||
| 26 | |||
| 27 | |||
| 28 | #define COMBO(ck, ca) {.keys = &(ck)[0], .keycode = (ca)} | ||
| 29 | #define COMBO_ACTION(ck) {.keys = &(ck)[0]} | ||
| 30 | |||
| 31 | #define COMBO_END 0 | ||
| 32 | #ifndef COMBO_COUNT | ||
| 33 | #define COMBO_COUNT 0 | ||
| 34 | #endif | ||
| 35 | #ifndef COMBO_TERM | ||
| 36 | #define COMBO_TERM TAPPING_TERM | ||
| 37 | #endif | ||
| 38 | |||
| 39 | bool process_combo(uint16_t keycode, keyrecord_t *record); | ||
| 40 | void matrix_scan_combo(void); | ||
| 41 | void process_combo_event(uint8_t combo_index, bool pressed); | ||
| 42 | |||
| 43 | #endif | ||
diff --git a/quantum/process_keycode/process_unicode.c b/quantum/process_keycode/process_unicode.c index a30e93ae3..9d01a592d 100644 --- a/quantum/process_keycode/process_unicode.c +++ b/quantum/process_keycode/process_unicode.c | |||
| @@ -139,9 +139,18 @@ void unicode_map_input_error() {} | |||
| 139 | bool process_unicode_map(uint16_t keycode, keyrecord_t *record) { | 139 | bool process_unicode_map(uint16_t keycode, keyrecord_t *record) { |
| 140 | if ((keycode & QK_UNICODE_MAP) == QK_UNICODE_MAP && record->event.pressed) { | 140 | if ((keycode & QK_UNICODE_MAP) == QK_UNICODE_MAP && record->event.pressed) { |
| 141 | const uint32_t* map = unicode_map; | 141 | const uint32_t* map = unicode_map; |
| 142 | uint16_t index = keycode & 0x7FF; | 142 | uint16_t index = keycode - QK_UNICODE_MAP; |
| 143 | uint32_t code = pgm_read_dword_far(&map[index]); | 143 | uint32_t code = pgm_read_dword_far(&map[index]); |
| 144 | if ((code > 0xFFFF && input_mode == UC_OSX) || (code > 0xFFFFF && input_mode == UC_LNX)) { | 144 | if (code > 0xFFFF && code <= 0x10ffff && input_mode == UC_OSX) { |
| 145 | // Convert to UTF-16 surrogate pair | ||
| 146 | code -= 0x10000; | ||
| 147 | uint32_t lo = code & 0x3ff; | ||
| 148 | uint32_t hi = (code & 0xffc00) >> 10; | ||
| 149 | unicode_input_start(); | ||
| 150 | register_hex32(hi + 0xd800); | ||
| 151 | register_hex32(lo + 0xdc00); | ||
| 152 | unicode_input_finish(); | ||
| 153 | } else if ((code > 0x10ffff && input_mode == UC_OSX) || (code > 0xFFFFF && input_mode == UC_LNX)) { | ||
| 145 | // when character is out of range supported by the OS | 154 | // when character is out of range supported by the OS |
| 146 | unicode_map_input_error(); | 155 | unicode_map_input_error(); |
| 147 | } else { | 156 | } else { |
diff --git a/quantum/quantum.c b/quantum/quantum.c index 63ffe2074..45ea8cb73 100644 --- a/quantum/quantum.c +++ b/quantum/quantum.c | |||
| @@ -1,4 +1,7 @@ | |||
| 1 | #include "quantum.h" | 1 | #include "quantum.h" |
| 2 | #ifdef PROTOCOL_LUFA | ||
| 3 | #include "outputselect.h" | ||
| 4 | #endif | ||
| 2 | 5 | ||
| 3 | #ifndef TAPPING_TERM | 6 | #ifndef TAPPING_TERM |
| 4 | #define TAPPING_TERM 200 | 7 | #define TAPPING_TERM 200 |
| @@ -33,14 +36,42 @@ static void do_code16 (uint16_t code, void (*f) (uint8_t)) { | |||
| 33 | f(KC_RGUI); | 36 | f(KC_RGUI); |
| 34 | } | 37 | } |
| 35 | 38 | ||
| 39 | static inline void qk_register_weak_mods(uint8_t kc) { | ||
| 40 | add_weak_mods(MOD_BIT(kc)); | ||
| 41 | send_keyboard_report(); | ||
| 42 | } | ||
| 43 | |||
| 44 | static inline void qk_unregister_weak_mods(uint8_t kc) { | ||
| 45 | del_weak_mods(MOD_BIT(kc)); | ||
| 46 | send_keyboard_report(); | ||
| 47 | } | ||
| 48 | |||
| 49 | static inline void qk_register_mods(uint8_t kc) { | ||
| 50 | add_weak_mods(MOD_BIT(kc)); | ||
| 51 | send_keyboard_report(); | ||
| 52 | } | ||
| 53 | |||
| 54 | static inline void qk_unregister_mods(uint8_t kc) { | ||
| 55 | del_weak_mods(MOD_BIT(kc)); | ||
| 56 | send_keyboard_report(); | ||
| 57 | } | ||
| 58 | |||
| 36 | void register_code16 (uint16_t code) { | 59 | void register_code16 (uint16_t code) { |
| 37 | do_code16 (code, register_code); | 60 | if (IS_MOD(code) || code == KC_NO) { |
| 61 | do_code16 (code, qk_register_mods); | ||
| 62 | } else { | ||
| 63 | do_code16 (code, qk_register_weak_mods); | ||
| 64 | } | ||
| 38 | register_code (code); | 65 | register_code (code); |
| 39 | } | 66 | } |
| 40 | 67 | ||
| 41 | void unregister_code16 (uint16_t code) { | 68 | void unregister_code16 (uint16_t code) { |
| 42 | unregister_code (code); | 69 | unregister_code (code); |
| 43 | do_code16 (code, unregister_code); | 70 | if (IS_MOD(code) || code == KC_NO) { |
| 71 | do_code16 (code, qk_unregister_mods); | ||
| 72 | } else { | ||
| 73 | do_code16 (code, qk_unregister_weak_mods); | ||
| 74 | } | ||
| 44 | } | 75 | } |
| 45 | 76 | ||
| 46 | __attribute__ ((weak)) | 77 | __attribute__ ((weak)) |
| @@ -130,6 +161,9 @@ bool process_record_quantum(keyrecord_t *record) { | |||
| 130 | #ifndef DISABLE_CHORDING | 161 | #ifndef DISABLE_CHORDING |
| 131 | process_chording(keycode, record) && | 162 | process_chording(keycode, record) && |
| 132 | #endif | 163 | #endif |
| 164 | #ifdef COMBO_ENABLE | ||
| 165 | process_combo(keycode, record) && | ||
| 166 | #endif | ||
| 133 | #ifdef UNICODE_ENABLE | 167 | #ifdef UNICODE_ENABLE |
| 134 | process_unicode(keycode, record) && | 168 | process_unicode(keycode, record) && |
| 135 | #endif | 169 | #endif |
| @@ -212,6 +246,36 @@ bool process_record_quantum(keyrecord_t *record) { | |||
| 212 | return false; | 246 | return false; |
| 213 | break; | 247 | break; |
| 214 | #endif | 248 | #endif |
| 249 | #ifdef PROTOCOL_LUFA | ||
| 250 | case OUT_AUTO: | ||
| 251 | if (record->event.pressed) { | ||
| 252 | set_output(OUTPUT_AUTO); | ||
| 253 | } | ||
| 254 | return false; | ||
| 255 | break; | ||
| 256 | case OUT_USB: | ||
| 257 | if (record->event.pressed) { | ||
| 258 | set_output(OUTPUT_USB); | ||
| 259 | } | ||
| 260 | return false; | ||
| 261 | break; | ||
| 262 | #ifdef BLUETOOTH_ENABLE | ||
| 263 | case OUT_BT: | ||
| 264 | if (record->event.pressed) { | ||
| 265 | set_output(OUTPUT_BLUETOOTH); | ||
| 266 | } | ||
| 267 | return false; | ||
| 268 | break; | ||
| 269 | #endif | ||
| 270 | #ifdef ADAFRUIT_BLE_ENABLE | ||
| 271 | case OUT_BLE: | ||
| 272 | if (record->event.pressed) { | ||
| 273 | set_output(OUTPUT_ADAFRUIT_BLE); | ||
| 274 | } | ||
| 275 | return false; | ||
| 276 | break; | ||
| 277 | #endif | ||
| 278 | #endif | ||
| 215 | case MAGIC_SWAP_CONTROL_CAPSLOCK ... MAGIC_TOGGLE_NKRO: | 279 | case MAGIC_SWAP_CONTROL_CAPSLOCK ... MAGIC_TOGGLE_NKRO: |
| 216 | if (record->event.pressed) { | 280 | if (record->event.pressed) { |
| 217 | // MAGIC actions (BOOTMAGIC without the boot) | 281 | // MAGIC actions (BOOTMAGIC without the boot) |
| @@ -508,6 +572,11 @@ void matrix_scan_quantum() { | |||
| 508 | #ifdef TAP_DANCE_ENABLE | 572 | #ifdef TAP_DANCE_ENABLE |
| 509 | matrix_scan_tap_dance(); | 573 | matrix_scan_tap_dance(); |
| 510 | #endif | 574 | #endif |
| 575 | |||
| 576 | #ifdef COMBO_ENABLE | ||
| 577 | matrix_scan_combo(); | ||
| 578 | #endif | ||
| 579 | |||
| 511 | matrix_scan_kb(); | 580 | matrix_scan_kb(); |
| 512 | } | 581 | } |
| 513 | 582 | ||
| @@ -525,34 +594,45 @@ static const uint8_t backlight_pin = BACKLIGHT_PIN; | |||
| 525 | # define COM1x1 COM1A1 | 594 | # define COM1x1 COM1A1 |
| 526 | # define OCR1x OCR1A | 595 | # define OCR1x OCR1A |
| 527 | #else | 596 | #else |
| 528 | # error "Backlight pin not supported - use B5, B6, or B7" | 597 | # define NO_BACKLIGHT_CLOCK |
| 598 | #endif | ||
| 599 | |||
| 600 | #ifndef BACKLIGHT_ON_STATE | ||
| 601 | #define BACKLIGHT_ON_STATE 0 | ||
| 529 | #endif | 602 | #endif |
| 530 | 603 | ||
| 531 | __attribute__ ((weak)) | 604 | __attribute__ ((weak)) |
| 532 | void backlight_init_ports(void) | 605 | void backlight_init_ports(void) |
| 533 | { | 606 | { |
| 534 | 607 | ||
| 535 | // Setup backlight pin as output and output low. | 608 | // Setup backlight pin as output and output to on state. |
| 536 | // DDRx |= n | 609 | // DDRx |= n |
| 537 | _SFR_IO8((backlight_pin >> 4) + 1) |= _BV(backlight_pin & 0xF); | 610 | _SFR_IO8((backlight_pin >> 4) + 1) |= _BV(backlight_pin & 0xF); |
| 538 | // PORTx &= ~n | 611 | #if BACKLIGHT_ON_STATE == 0 |
| 539 | _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF); | 612 | // PORTx &= ~n |
| 613 | _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF); | ||
| 614 | #else | ||
| 615 | // PORTx |= n | ||
| 616 | _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF); | ||
| 617 | #endif | ||
| 540 | 618 | ||
| 541 | // Use full 16-bit resolution. | 619 | #ifndef NO_BACKLIGHT_CLOCK |
| 542 | ICR1 = 0xFFFF; | 620 | // Use full 16-bit resolution. |
| 621 | ICR1 = 0xFFFF; | ||
| 543 | 622 | ||
| 544 | // I could write a wall of text here to explain... but TL;DW | 623 | // I could write a wall of text here to explain... but TL;DW |
| 545 | // Go read the ATmega32u4 datasheet. | 624 | // Go read the ATmega32u4 datasheet. |
| 546 | // And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on | 625 | // And this: http://blog.saikoled.com/post/43165849837/secret-konami-cheat-code-to-high-resolution-pwm-on |
| 547 | 626 | ||
| 548 | // Pin PB7 = OCR1C (Timer 1, Channel C) | 627 | // Pin PB7 = OCR1C (Timer 1, Channel C) |
| 549 | // Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0 | 628 | // Compare Output Mode = Clear on compare match, Channel C = COM1C1=1 COM1C0=0 |
| 550 | // (i.e. start high, go low when counter matches.) | 629 | // (i.e. start high, go low when counter matches.) |
| 551 | // WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0 | 630 | // WGM Mode 14 (Fast PWM) = WGM13=1 WGM12=1 WGM11=1 WGM10=0 |
| 552 | // Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1 | 631 | // Clock Select = clk/1 (no prescaling) = CS12=0 CS11=0 CS10=1 |
| 553 | 632 | ||
| 554 | TCCR1A = _BV(COM1x1) | _BV(WGM11); // = 0b00001010; | 633 | TCCR1A = _BV(COM1x1) | _BV(WGM11); // = 0b00001010; |
| 555 | TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001; | 634 | TCCR1B = _BV(WGM13) | _BV(WGM12) | _BV(CS10); // = 0b00011001; |
| 635 | #endif | ||
| 556 | 636 | ||
| 557 | backlight_init(); | 637 | backlight_init(); |
| 558 | #ifdef BACKLIGHT_BREATHING | 638 | #ifdef BACKLIGHT_BREATHING |
| @@ -564,24 +644,43 @@ __attribute__ ((weak)) | |||
| 564 | void backlight_set(uint8_t level) | 644 | void backlight_set(uint8_t level) |
| 565 | { | 645 | { |
| 566 | // Prevent backlight blink on lowest level | 646 | // Prevent backlight blink on lowest level |
| 567 | // PORTx &= ~n | 647 | #if BACKLIGHT_ON_STATE == 0 |
| 568 | _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF); | 648 | // PORTx &= ~n |
| 649 | _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF); | ||
| 650 | #else | ||
| 651 | // PORTx |= n | ||
| 652 | _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF); | ||
| 653 | #endif | ||
| 569 | 654 | ||
| 570 | if ( level == 0 ) { | 655 | if ( level == 0 ) { |
| 571 | // Turn off PWM control on backlight pin, revert to output low. | 656 | #ifndef NO_BACKLIGHT_CLOCK |
| 572 | TCCR1A &= ~(_BV(COM1x1)); | 657 | // Turn off PWM control on backlight pin, revert to output low. |
| 573 | OCR1x = 0x0; | 658 | TCCR1A &= ~(_BV(COM1x1)); |
| 574 | } else if ( level == BACKLIGHT_LEVELS ) { | 659 | OCR1x = 0x0; |
| 575 | // Turn on PWM control of backlight pin | 660 | #else |
| 576 | TCCR1A |= _BV(COM1x1); | 661 | #if BACKLIGHT_ON_STATE == 0 |
| 577 | // Set the brightness | 662 | // PORTx |= n |
| 578 | OCR1x = 0xFFFF; | 663 | _SFR_IO8((backlight_pin >> 4) + 2) |= _BV(backlight_pin & 0xF); |
| 579 | } else { | 664 | #else |
| 580 | // Turn on PWM control of backlight pin | 665 | // PORTx &= ~n |
| 581 | TCCR1A |= _BV(COM1x1); | 666 | _SFR_IO8((backlight_pin >> 4) + 2) &= ~_BV(backlight_pin & 0xF); |
| 582 | // Set the brightness | 667 | #endif |
| 583 | OCR1x = 0xFFFF >> ((BACKLIGHT_LEVELS - level) * ((BACKLIGHT_LEVELS + 1) / 2)); | 668 | #endif |
| 584 | } | 669 | } |
| 670 | #ifndef NO_BACKLIGHT_CLOCK | ||
| 671 | else if ( level == BACKLIGHT_LEVELS ) { | ||
| 672 | // Turn on PWM control of backlight pin | ||
| 673 | TCCR1A |= _BV(COM1x1); | ||
| 674 | // Set the brightness | ||
| 675 | OCR1x = 0xFFFF; | ||
| 676 | } | ||
| 677 | else { | ||
| 678 | // Turn on PWM control of backlight pin | ||
| 679 | TCCR1A |= _BV(COM1x1); | ||
| 680 | // Set the brightness | ||
| 681 | OCR1x = 0xFFFF >> ((BACKLIGHT_LEVELS - level) * ((BACKLIGHT_LEVELS + 1) / 2)); | ||
| 682 | } | ||
| 683 | #endif | ||
| 585 | 684 | ||
| 586 | #ifdef BACKLIGHT_BREATHING | 685 | #ifdef BACKLIGHT_BREATHING |
| 587 | breathing_intensity_default(); | 686 | breathing_intensity_default(); |
diff --git a/quantum/quantum.h b/quantum/quantum.h index e6adf974a..18f072189 100644 --- a/quantum/quantum.h +++ b/quantum/quantum.h | |||
| @@ -15,7 +15,6 @@ | |||
| 15 | #ifdef RGBLIGHT_ENABLE | 15 | #ifdef RGBLIGHT_ENABLE |
| 16 | #include "rgblight.h" | 16 | #include "rgblight.h" |
| 17 | #endif | 17 | #endif |
| 18 | |||
| 19 | #include "action_layer.h" | 18 | #include "action_layer.h" |
| 20 | #include "eeconfig.h" | 19 | #include "eeconfig.h" |
| 21 | #include <stddef.h> | 20 | #include <stddef.h> |
| @@ -63,6 +62,10 @@ extern uint32_t default_layer_state; | |||
| 63 | #include "process_printer.h" | 62 | #include "process_printer.h" |
| 64 | #endif | 63 | #endif |
| 65 | 64 | ||
| 65 | #ifdef COMBO_ENABLE | ||
| 66 | #include "process_combo.h" | ||
| 67 | #endif | ||
| 68 | |||
| 66 | #define SEND_STRING(str) send_string(PSTR(str)) | 69 | #define SEND_STRING(str) send_string(PSTR(str)) |
| 67 | void send_string(const char *str); | 70 | void send_string(const char *str); |
| 68 | 71 | ||
diff --git a/quantum/quantum_keycodes.h b/quantum/quantum_keycodes.h index 4853655f9..ab2e79026 100644 --- a/quantum/quantum_keycodes.h +++ b/quantum/quantum_keycodes.h | |||
| @@ -39,14 +39,14 @@ enum quantum_keycodes { | |||
| 39 | QK_CHORDING = 0x5600, | 39 | QK_CHORDING = 0x5600, |
| 40 | QK_CHORDING_MAX = 0x56FF, | 40 | QK_CHORDING_MAX = 0x56FF, |
| 41 | #endif | 41 | #endif |
| 42 | QK_MOD_TAP = 0x6000, | 42 | QK_TAP_DANCE = 0x5700, |
| 43 | QK_MOD_TAP_MAX = 0x6FFF, | 43 | QK_TAP_DANCE_MAX = 0x57FF, |
| 44 | QK_TAP_DANCE = 0x7100, | ||
| 45 | QK_TAP_DANCE_MAX = 0x71FF, | ||
| 46 | #ifdef UNICODEMAP_ENABLE | 44 | #ifdef UNICODEMAP_ENABLE |
| 47 | QK_UNICODE_MAP = 0x7800, | 45 | QK_UNICODE_MAP = 0x5800, |
| 48 | QK_UNICODE_MAP_MAX = 0x7FFF, | 46 | QK_UNICODE_MAP_MAX = 0x5BFF, |
| 49 | #endif | 47 | #endif |
| 48 | QK_MOD_TAP = 0x6000, | ||
| 49 | QK_MOD_TAP_MAX = 0x7FFF, | ||
| 50 | #ifdef UNICODE_ENABLE | 50 | #ifdef UNICODE_ENABLE |
| 51 | QK_UNICODE = 0x8000, | 51 | QK_UNICODE = 0x8000, |
| 52 | QK_UNICODE_MAX = 0xFFFF, | 52 | QK_UNICODE_MAX = 0xFFFF, |
| @@ -54,7 +54,7 @@ enum quantum_keycodes { | |||
| 54 | 54 | ||
| 55 | // Loose keycodes - to be used directly | 55 | // Loose keycodes - to be used directly |
| 56 | 56 | ||
| 57 | RESET = 0x7000, | 57 | RESET = 0x5C00, |
| 58 | DEBUG, | 58 | DEBUG, |
| 59 | MAGIC_SWAP_CONTROL_CAPSLOCK, | 59 | MAGIC_SWAP_CONTROL_CAPSLOCK, |
| 60 | MAGIC_CAPSLOCK_TO_CONTROL, | 60 | MAGIC_CAPSLOCK_TO_CONTROL, |
| @@ -141,6 +141,16 @@ enum quantum_keycodes { | |||
| 141 | PRINT_ON, | 141 | PRINT_ON, |
| 142 | PRINT_OFF, | 142 | PRINT_OFF, |
| 143 | 143 | ||
| 144 | // output selection | ||
| 145 | OUT_AUTO, | ||
| 146 | OUT_USB, | ||
| 147 | #ifdef BLUETOOTH_ENABLE | ||
| 148 | OUT_BT, | ||
| 149 | #endif | ||
| 150 | #ifdef ADAFRUIT_BLE_ENABLE | ||
| 151 | OUT_BLE, | ||
| 152 | #endif | ||
| 153 | |||
| 144 | // always leave at the end | 154 | // always leave at the end |
| 145 | SAFE_RANGE | 155 | SAFE_RANGE |
| 146 | }; | 156 | }; |
| @@ -246,8 +256,10 @@ enum quantum_keycodes { | |||
| 246 | 256 | ||
| 247 | #define M(kc) (kc | QK_MACRO) | 257 | #define M(kc) (kc | QK_MACRO) |
| 248 | 258 | ||
| 259 | #define MACROTAP(kc) (kc | QK_MACRO | FUNC_TAP<<8) | ||
| 249 | #define MACRODOWN(...) (record->event.pressed ? MACRO(__VA_ARGS__) : MACRO_NONE) | 260 | #define MACRODOWN(...) (record->event.pressed ? MACRO(__VA_ARGS__) : MACRO_NONE) |
| 250 | 261 | ||
| 262 | |||
| 251 | // L-ayer, T-ap - 256 keycode max, 16 layer max | 263 | // L-ayer, T-ap - 256 keycode max, 16 layer max |
| 252 | #define LT(layer, kc) (kc | QK_LAYER_TAP | ((layer & 0xF) << 8)) | 264 | #define LT(layer, kc) (kc | QK_LAYER_TAP | ((layer & 0xF) << 8)) |
| 253 | 265 | ||
| @@ -286,14 +298,29 @@ enum quantum_keycodes { | |||
| 286 | #define OSM(mod) (mod | QK_ONE_SHOT_MOD) | 298 | #define OSM(mod) (mod | QK_ONE_SHOT_MOD) |
| 287 | 299 | ||
| 288 | // M-od, T-ap - 256 keycode max | 300 | // M-od, T-ap - 256 keycode max |
| 289 | #define MT(mod, kc) (kc | QK_MOD_TAP | ((mod & 0xF) << 8)) | 301 | #define MT(mod, kc) (kc | QK_MOD_TAP | ((mod & 0x1F) << 8)) |
| 302 | |||
| 290 | #define CTL_T(kc) MT(MOD_LCTL, kc) | 303 | #define CTL_T(kc) MT(MOD_LCTL, kc) |
| 304 | #define LCTL_T(kc) MT(MOD_LCTL, kc) | ||
| 305 | #define RCTL_T(kc) MT(MOD_RCTL, kc) | ||
| 306 | |||
| 291 | #define SFT_T(kc) MT(MOD_LSFT, kc) | 307 | #define SFT_T(kc) MT(MOD_LSFT, kc) |
| 308 | #define LSFT_T(kc) MT(MOD_LSFT, kc) | ||
| 309 | #define RSFT_T(kc) MT(MOD_RSFT, kc) | ||
| 310 | |||
| 292 | #define ALT_T(kc) MT(MOD_LALT, kc) | 311 | #define ALT_T(kc) MT(MOD_LALT, kc) |
| 312 | #define LALT_T(kc) MT(MOD_LALT, kc) | ||
| 313 | #define RALT_T(kc) MT(MOD_RALT, kc) | ||
| 314 | #define ALGR_T(kc) MT(MOD_RALT, kc) // dual-function AltGR | ||
| 315 | |||
| 293 | #define GUI_T(kc) MT(MOD_LGUI, kc) | 316 | #define GUI_T(kc) MT(MOD_LGUI, kc) |
| 317 | #define LGUI_T(kc) MT(MOD_LGUI, kc) | ||
| 318 | #define RGUI_T(kc) MT(MOD_RGUI, kc) | ||
| 319 | |||
| 294 | #define C_S_T(kc) MT((MOD_LCTL | MOD_LSFT), kc) // Control + Shift e.g. for gnome-terminal | 320 | #define C_S_T(kc) MT((MOD_LCTL | MOD_LSFT), kc) // Control + Shift e.g. for gnome-terminal |
| 295 | #define MEH_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT), kc) // Meh is a less hyper version of the Hyper key -- doesn't include Win or Cmd, so just alt+shift+ctrl | 321 | #define MEH_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT), kc) // Meh is a less hyper version of the Hyper key -- doesn't include Win or Cmd, so just alt+shift+ctrl |
| 296 | #define LCAG_T(kc) MT((MOD_LCTL | MOD_LALT | MOD_LGUI), kc) // Left control alt and gui | 322 | #define LCAG_T(kc) MT((MOD_LCTL | MOD_LALT | MOD_LGUI), kc) // Left control alt and gui |
| 323 | #define RCAG_T(kc) MT((MOD_RCTL | MOD_RALT | MOD_RGUI), kc) // Right control alt and gui | ||
| 297 | #define ALL_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT | MOD_LGUI), kc) // see http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/ | 324 | #define ALL_T(kc) MT((MOD_LCTL | MOD_LSFT | MOD_LALT | MOD_LGUI), kc) // see http://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/ |
| 298 | #define SCMD_T(kc) MT((MOD_LGUI | MOD_LSFT), kc) | 325 | #define SCMD_T(kc) MT((MOD_LGUI | MOD_LSFT), kc) |
| 299 | #define SWIN_T(kc) SCMD_T(kc) | 326 | #define SWIN_T(kc) SCMD_T(kc) |
diff --git a/quantum/rgblight.c b/quantum/rgblight.c index 52a09817a..dd1b91c63 100644 --- a/quantum/rgblight.c +++ b/quantum/rgblight.c | |||
| @@ -66,6 +66,8 @@ __attribute__ ((weak)) | |||
| 66 | const uint8_t RGBLED_SNAKE_INTERVALS[] PROGMEM = {100, 50, 20}; | 66 | const uint8_t RGBLED_SNAKE_INTERVALS[] PROGMEM = {100, 50, 20}; |
| 67 | __attribute__ ((weak)) | 67 | __attribute__ ((weak)) |
| 68 | const uint8_t RGBLED_KNIGHT_INTERVALS[] PROGMEM = {100, 50, 20}; | 68 | const uint8_t RGBLED_KNIGHT_INTERVALS[] PROGMEM = {100, 50, 20}; |
| 69 | __attribute__ ((weak)) | ||
| 70 | const uint16_t RGBLED_GRADIENT_RANGES[] PROGMEM = {360, 240, 180, 120, 90}; | ||
| 69 | 71 | ||
| 70 | rgblight_config_t rgblight_config; | 72 | rgblight_config_t rgblight_config; |
| 71 | rgblight_config_t inmem_config; | 73 | rgblight_config_t inmem_config; |
| @@ -219,6 +221,14 @@ void rgblight_step(void) { | |||
| 219 | } | 221 | } |
| 220 | rgblight_mode(mode); | 222 | rgblight_mode(mode); |
| 221 | } | 223 | } |
| 224 | void rgblight_step_reverse(void) { | ||
| 225 | uint8_t mode = 0; | ||
| 226 | mode = rgblight_config.mode - 1; | ||
| 227 | if (mode < 1) { | ||
| 228 | mode = RGBLIGHT_MODES; | ||
| 229 | } | ||
| 230 | rgblight_mode(mode); | ||
| 231 | } | ||
| 222 | 232 | ||
| 223 | void rgblight_mode(uint8_t mode) { | 233 | void rgblight_mode(uint8_t mode) { |
| 224 | if (!rgblight_config.enable) { | 234 | if (!rgblight_config.enable) { |
| @@ -237,7 +247,7 @@ void rgblight_mode(uint8_t mode) { | |||
| 237 | #ifdef RGBLIGHT_ANIMATIONS | 247 | #ifdef RGBLIGHT_ANIMATIONS |
| 238 | rgblight_timer_disable(); | 248 | rgblight_timer_disable(); |
| 239 | #endif | 249 | #endif |
| 240 | } else if (rgblight_config.mode >= 2 && rgblight_config.mode <= 23) { | 250 | } else if (rgblight_config.mode >= 2 && rgblight_config.mode <= 24) { |
| 241 | // MODE 2-5, breathing | 251 | // MODE 2-5, breathing |
| 242 | // MODE 6-8, rainbow mood | 252 | // MODE 6-8, rainbow mood |
| 243 | // MODE 9-14, rainbow swirl | 253 | // MODE 9-14, rainbow swirl |
| @@ -247,6 +257,12 @@ void rgblight_mode(uint8_t mode) { | |||
| 247 | #ifdef RGBLIGHT_ANIMATIONS | 257 | #ifdef RGBLIGHT_ANIMATIONS |
| 248 | rgblight_timer_enable(); | 258 | rgblight_timer_enable(); |
| 249 | #endif | 259 | #endif |
| 260 | } else if (rgblight_config.mode >= 25 && rgblight_config.mode <= 34) { | ||
| 261 | // MODE 25-34, static gradient | ||
| 262 | |||
| 263 | #ifdef RGBLIGHT_ANIMATIONS | ||
| 264 | rgblight_timer_disable(); | ||
| 265 | #endif | ||
| 250 | } | 266 | } |
| 251 | rgblight_sethsv(rgblight_config.hue, rgblight_config.sat, rgblight_config.val); | 267 | rgblight_sethsv(rgblight_config.hue, rgblight_config.sat, rgblight_config.val); |
| 252 | } | 268 | } |
| @@ -350,6 +366,17 @@ void rgblight_sethsv(uint16_t hue, uint8_t sat, uint8_t val) { | |||
| 350 | } else if (rgblight_config.mode >= 6 && rgblight_config.mode <= 14) { | 366 | } else if (rgblight_config.mode >= 6 && rgblight_config.mode <= 14) { |
| 351 | // rainbow mood and rainbow swirl, ignore the change of hue | 367 | // rainbow mood and rainbow swirl, ignore the change of hue |
| 352 | hue = rgblight_config.hue; | 368 | hue = rgblight_config.hue; |
| 369 | } else if (rgblight_config.mode >= 25 && rgblight_config.mode <= 34) { | ||
| 370 | // static gradient | ||
| 371 | uint16_t _hue; | ||
| 372 | int8_t direction = ((rgblight_config.mode - 25) % 2) ? -1 : 1; | ||
| 373 | uint16_t range = pgm_read_word(&RGBLED_GRADIENT_RANGES[(rgblight_config.mode - 25) / 2]); | ||
| 374 | for (uint8_t i = 0; i < RGBLED_NUM; i++) { | ||
| 375 | _hue = (range / RGBLED_NUM * i * direction + hue + 360) % 360; | ||
| 376 | dprintf("rgblight rainbow set hsv: %u,%u,%d,%u\n", i, _hue, direction, range); | ||
| 377 | sethsv(_hue, sat, val, (LED_TYPE *)&led[i]); | ||
| 378 | } | ||
| 379 | rgblight_set(); | ||
| 353 | } | 380 | } |
| 354 | } | 381 | } |
| 355 | rgblight_config.hue = hue; | 382 | rgblight_config.hue = hue; |
| @@ -450,7 +477,7 @@ void rgblight_task(void) { | |||
| 450 | } else if (rgblight_config.mode >= 21 && rgblight_config.mode <= 23) { | 477 | } else if (rgblight_config.mode >= 21 && rgblight_config.mode <= 23) { |
| 451 | // mode = 21 to 23, knight mode | 478 | // mode = 21 to 23, knight mode |
| 452 | rgblight_effect_knight(rgblight_config.mode - 21); | 479 | rgblight_effect_knight(rgblight_config.mode - 21); |
| 453 | } else { | 480 | } else if (rgblight_config.mode == 24) { |
| 454 | // mode = 24, christmas mode | 481 | // mode = 24, christmas mode |
| 455 | rgblight_effect_christmas(); | 482 | rgblight_effect_christmas(); |
| 456 | } | 483 | } |
| @@ -604,13 +631,13 @@ void rgblight_effect_christmas(void) { | |||
| 604 | static uint16_t last_timer = 0; | 631 | static uint16_t last_timer = 0; |
| 605 | uint16_t hue; | 632 | uint16_t hue; |
| 606 | uint8_t i; | 633 | uint8_t i; |
| 607 | if (timer_elapsed(last_timer) < 1000) { | 634 | if (timer_elapsed(last_timer) < RGBLIGHT_EFFECT_CHRISTMAS_INTERVAL) { |
| 608 | return; | 635 | return; |
| 609 | } | 636 | } |
| 610 | last_timer = timer_read(); | 637 | last_timer = timer_read(); |
| 611 | current_offset = (current_offset + 1) % 2; | 638 | current_offset = (current_offset + 1) % 2; |
| 612 | for (i = 0; i < RGBLED_NUM; i++) { | 639 | for (i = 0; i < RGBLED_NUM; i++) { |
| 613 | hue = 0 + ((RGBLED_NUM * (i + current_offset)) % 2) * 80; | 640 | hue = 0 + ((i/RGBLIGHT_EFFECT_CHRISTMAS_STEP + current_offset) % 2) * 120; |
| 614 | sethsv(hue, rgblight_config.sat, rgblight_config.val, (LED_TYPE *)&led[i]); | 641 | sethsv(hue, rgblight_config.sat, rgblight_config.val, (LED_TYPE *)&led[i]); |
| 615 | } | 642 | } |
| 616 | rgblight_set(); | 643 | rgblight_set(); |
diff --git a/quantum/rgblight.h b/quantum/rgblight.h index 726b8de72..2b3e791bf 100644 --- a/quantum/rgblight.h +++ b/quantum/rgblight.h | |||
| @@ -2,7 +2,7 @@ | |||
| 2 | #define RGBLIGHT_H | 2 | #define RGBLIGHT_H |
| 3 | 3 | ||
| 4 | #ifdef RGBLIGHT_ANIMATIONS | 4 | #ifdef RGBLIGHT_ANIMATIONS |
| 5 | #define RGBLIGHT_MODES 24 | 5 | #define RGBLIGHT_MODES 34 |
| 6 | #else | 6 | #else |
| 7 | #define RGBLIGHT_MODES 1 | 7 | #define RGBLIGHT_MODES 1 |
| 8 | #endif | 8 | #endif |
| @@ -22,6 +22,14 @@ | |||
| 22 | #define RGBLIGHT_EFFECT_DUALKNIGHT_LENGTH 4 | 22 | #define RGBLIGHT_EFFECT_DUALKNIGHT_LENGTH 4 |
| 23 | #endif | 23 | #endif |
| 24 | 24 | ||
| 25 | #ifndef RGBLIGHT_EFFECT_CHRISTMAS_INTERVAL | ||
| 26 | #define RGBLIGHT_EFFECT_CHRISTMAS_INTERVAL 1000 | ||
| 27 | #endif | ||
| 28 | |||
| 29 | #ifndef RGBLIGHT_EFFECT_CHRISTMAS_STEP | ||
| 30 | #define RGBLIGHT_EFFECT_CHRISTMAS_STEP 2 | ||
| 31 | #endif | ||
| 32 | |||
| 25 | #ifndef RGBLIGHT_HUE_STEP | 33 | #ifndef RGBLIGHT_HUE_STEP |
| 26 | #define RGBLIGHT_HUE_STEP 10 | 34 | #define RGBLIGHT_HUE_STEP 10 |
| 27 | #endif | 35 | #endif |
| @@ -65,6 +73,7 @@ void rgblight_decrease(void); | |||
| 65 | void rgblight_toggle(void); | 73 | void rgblight_toggle(void); |
| 66 | void rgblight_enable(void); | 74 | void rgblight_enable(void); |
| 67 | void rgblight_step(void); | 75 | void rgblight_step(void); |
| 76 | void rgblight_step_reverse(void); | ||
| 68 | void rgblight_mode(uint8_t mode); | 77 | void rgblight_mode(uint8_t mode); |
| 69 | void rgblight_set(void); | 78 | void rgblight_set(void); |
| 70 | void rgblight_update_dword(uint32_t dword); | 79 | void rgblight_update_dword(uint32_t dword); |
diff --git a/quantum/template/config.h b/quantum/template/config.h index b02f0c7eb..c61c4a618 100644 --- a/quantum/template/config.h +++ b/quantum/template/config.h | |||
| @@ -46,7 +46,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 46 | #define MATRIX_COL_PINS { F1, F0, B0 } | 46 | #define MATRIX_COL_PINS { F1, F0, B0 } |
| 47 | #define UNUSED_PINS | 47 | #define UNUSED_PINS |
| 48 | 48 | ||
| 49 | /* COL2ROW or ROW2COL */ | 49 | /* COL2ROW, ROW2COL, or CUSTOM_MATRIX */ |
| 50 | #define DIODE_DIRECTION COL2ROW | 50 | #define DIODE_DIRECTION COL2ROW |
| 51 | 51 | ||
| 52 | // #define BACKLIGHT_PIN B7 | 52 | // #define BACKLIGHT_PIN B7 |
diff --git a/tmk_core/common/action.c b/tmk_core/common/action.c index d485b46c7..f03670a7f 100644 --- a/tmk_core/common/action.c +++ b/tmk_core/common/action.c | |||
| @@ -49,6 +49,13 @@ void action_exec(keyevent_t event) | |||
| 49 | 49 | ||
| 50 | keyrecord_t record = { .event = event }; | 50 | keyrecord_t record = { .event = event }; |
| 51 | 51 | ||
| 52 | #if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) | ||
| 53 | if (has_oneshot_layer_timed_out()) { | ||
| 54 | dprintf("Oneshot layer: timeout\n"); | ||
| 55 | clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||
| 56 | } | ||
| 57 | #endif | ||
| 58 | |||
| 52 | #ifndef NO_ACTION_TAPPING | 59 | #ifndef NO_ACTION_TAPPING |
| 53 | action_tapping_process(record); | 60 | action_tapping_process(record); |
| 54 | #else | 61 | #else |
| @@ -100,7 +107,7 @@ bool process_record_quantum(keyrecord_t *record) { | |||
| 100 | return true; | 107 | return true; |
| 101 | } | 108 | } |
| 102 | 109 | ||
| 103 | void process_record(keyrecord_t *record) | 110 | void process_record(keyrecord_t *record) |
| 104 | { | 111 | { |
| 105 | if (IS_NOEVENT(record->event)) { return; } | 112 | if (IS_NOEVENT(record->event)) { return; } |
| 106 | 113 | ||
| @@ -126,13 +133,6 @@ void process_action(keyrecord_t *record, action_t action) | |||
| 126 | uint8_t tap_count = record->tap.count; | 133 | uint8_t tap_count = record->tap.count; |
| 127 | #endif | 134 | #endif |
| 128 | 135 | ||
| 129 | #if (defined(ONESHOT_TIMEOUT) && (ONESHOT_TIMEOUT > 0)) | ||
| 130 | if (has_oneshot_layer_timed_out()) { | ||
| 131 | dprintf("Oneshot layer: timeout\n"); | ||
| 132 | clear_oneshot_layer_state(ONESHOT_OTHER_KEY_PRESSED); | ||
| 133 | } | ||
| 134 | #endif | ||
| 135 | |||
| 136 | if (event.pressed) { | 136 | if (event.pressed) { |
| 137 | // clear the potential weak mods left by previously pressed keys | 137 | // clear the potential weak mods left by previously pressed keys |
| 138 | clear_weak_mods(); | 138 | clear_weak_mods(); |
diff --git a/tmk_core/common/action_code.h b/tmk_core/common/action_code.h index 33da35f35..b15aaa0eb 100644 --- a/tmk_core/common/action_code.h +++ b/tmk_core/common/action_code.h | |||
| @@ -47,10 +47,15 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 47 | * 0100|10| usage(10) (reserved) | 47 | * 0100|10| usage(10) (reserved) |
| 48 | * 0100|11| usage(10) (reserved) | 48 | * 0100|11| usage(10) (reserved) |
| 49 | * | 49 | * |
| 50 | * ACT_MOUSEKEY(0110): TODO: Not needed? | 50 | * |
| 51 | * ACT_MOUSEKEY(0101): TODO: Merge these two actions to conserve space? | ||
| 51 | * 0101|xxxx| keycode Mouse key | 52 | * 0101|xxxx| keycode Mouse key |
| 52 | * | 53 | * |
| 53 | * 011x|xxxx xxxx xxxx (reseved) | 54 | * ACT_SWAP_HANDS(0110): |
| 55 | * 0110|xxxx| keycode Swap hands (keycode on tap, or options) | ||
| 56 | * | ||
| 57 | * | ||
| 58 | * 0111|xxxx xxxx xxxx (reserved) | ||
| 54 | * | 59 | * |
| 55 | * | 60 | * |
| 56 | * Layer Actions(10xx) | 61 | * Layer Actions(10xx) |
| @@ -67,7 +72,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 67 | * ee: on event(01:press, 10:release, 11:both) | 72 | * ee: on event(01:press, 10:release, 11:both) |
| 68 | * | 73 | * |
| 69 | * 1001|xxxx|xxxx xxxx (reserved) | 74 | * 1001|xxxx|xxxx xxxx (reserved) |
| 70 | * 1001|oopp|BBBB BBBB 8-bit Bitwise Operation??? | ||
| 71 | * | 75 | * |
| 72 | * ACT_LAYER_TAP(101x): | 76 | * ACT_LAYER_TAP(101x): |
| 73 | * 101E|LLLL| keycode On/Off with tap key (0x00-DF)[TAP] | 77 | * 101E|LLLL| keycode On/Off with tap key (0x00-DF)[TAP] |
diff --git a/tmk_core/common/action_macro.h b/tmk_core/common/action_macro.h index aedc32ec6..f373f5068 100644 --- a/tmk_core/common/action_macro.h +++ b/tmk_core/common/action_macro.h | |||
| @@ -20,11 +20,33 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
| 20 | #include "progmem.h" | 20 | #include "progmem.h" |
| 21 | 21 | ||
| 22 | 22 | ||
| 23 | #define MACRO_NONE 0 | 23 | |
| 24 | typedef uint8_t macro_t; | ||
| 25 | |||
| 26 | #define MACRO_NONE (macro_t*)0 | ||
| 24 | #define MACRO(...) ({ static const macro_t __m[] PROGMEM = { __VA_ARGS__ }; &__m[0]; }) | 27 | #define MACRO(...) ({ static const macro_t __m[] PROGMEM = { __VA_ARGS__ }; &__m[0]; }) |
| 25 | #define MACRO_GET(p) pgm_read_byte(p) | 28 | #define MACRO_GET(p) pgm_read_byte(p) |
| 26 | 29 | ||
| 27 | typedef uint8_t macro_t; | 30 | // Sends press when the macro key is pressed, release when release, or tap_macro when the key has been tapped |
| 31 | #define MACRO_TAP_HOLD(record, press, release, tap_macro) ( ((record)->event.pressed) ? \ | ||
| 32 | ( ((record)->tap.count <= 0 || (record)->tap.interrupted) ? (press) : MACRO_NONE ) : \ | ||
| 33 | ( ((record)->tap.count > 0 && !((record)->tap.interrupted)) ? (tap_macro) : (release) ) ) | ||
| 34 | |||
| 35 | // Holds down the modifier mod when the macro key is held, or sends macro instead when tapped | ||
| 36 | #define MACRO_TAP_HOLD_MOD(record, macro, mod) MACRO_TAP_HOLD(record, (MACRO(D(mod), END)), MACRO(U(mod), END), macro) | ||
| 37 | |||
| 38 | // Holds down the modifier mod when the macro key is held, or pressed a shifted key when tapped (eg: shift+3 for #) | ||
| 39 | #define MACRO_TAP_SHFT_KEY_HOLD_MOD(record, key, mod) MACRO_TAP_HOLD_MOD(record, (MACRO(I(10), D(LSFT), T(key), U(LSFT), END)), mod) | ||
| 40 | |||
| 41 | |||
| 42 | // Momentary switch layer when held, sends macro if tapped | ||
| 43 | #define MACRO_TAP_HOLD_LAYER(record, macro, layer) ( ((record)->event.pressed) ? \ | ||
| 44 | ( ((record)->tap.count <= 0 || (record)->tap.interrupted) ? ({layer_on((layer)); MACRO_NONE; }) : MACRO_NONE ) : \ | ||
| 45 | ( ((record)->tap.count > 0 && !((record)->tap.interrupted)) ? (macro) : ({layer_off((layer)); MACRO_NONE; }) ) ) | ||
| 46 | |||
| 47 | // Momentary switch layer when held, presses a shifted key when tapped (eg: shift+3 for #) | ||
| 48 | #define MACRO_TAP_SHFT_KEY_HOLD_LAYER(record, key, layer) MACRO_TAP_HOLD_LAYER(record, MACRO(I(10), D(LSFT), T(key), U(LSFT), END), layer) | ||
| 49 | |||
| 28 | 50 | ||
| 29 | 51 | ||
| 30 | #ifndef NO_ACTION_MACRO | 52 | #ifndef NO_ACTION_MACRO |
diff --git a/tmk_core/common/keyboard.c b/tmk_core/common/keyboard.c index 765350792..3aa82231b 100644 --- a/tmk_core/common/keyboard.c +++ b/tmk_core/common/keyboard.c | |||
| @@ -14,6 +14,7 @@ GNU General Public License for more details. | |||
| 14 | You should have received a copy of the GNU General Public License | 14 | You should have received a copy of the GNU General Public License |
| 15 | along with this program. If not, see <http://www.gnu.org/licenses/>. | 15 | along with this program. If not, see <http://www.gnu.org/licenses/>. |
| 16 | */ | 16 | */ |
| 17 | |||
| 17 | #include <stdint.h> | 18 | #include <stdint.h> |
| 18 | #include "keyboard.h" | 19 | #include "keyboard.h" |
| 19 | #include "matrix.h" | 20 | #include "matrix.h" |
diff --git a/tmk_core/common/matrix.h b/tmk_core/common/matrix.h index cee3593ee..2543f5abc 100644 --- a/tmk_core/common/matrix.h +++ b/tmk_core/common/matrix.h | |||
| @@ -50,7 +50,7 @@ void matrix_init(void); | |||
| 50 | uint8_t matrix_scan(void); | 50 | uint8_t matrix_scan(void); |
| 51 | /* whether modified from previous scan. used after matrix_scan. */ | 51 | /* whether modified from previous scan. used after matrix_scan. */ |
| 52 | bool matrix_is_modified(void) __attribute__ ((deprecated)); | 52 | bool matrix_is_modified(void) __attribute__ ((deprecated)); |
| 53 | /* whether a swtich is on */ | 53 | /* whether a switch is on */ |
| 54 | bool matrix_is_on(uint8_t row, uint8_t col); | 54 | bool matrix_is_on(uint8_t row, uint8_t col); |
| 55 | /* matrix state on row */ | 55 | /* matrix state on row */ |
| 56 | matrix_row_t matrix_get_row(uint8_t row); | 56 | matrix_row_t matrix_get_row(uint8_t row); |
diff --git a/tmk_core/common/report.h b/tmk_core/common/report.h index 0c799eca3..8fb28b6ce 100644 --- a/tmk_core/common/report.h +++ b/tmk_core/common/report.h | |||
| @@ -134,13 +134,6 @@ typedef union { | |||
| 134 | } nkro; | 134 | } nkro; |
| 135 | #endif | 135 | #endif |
| 136 | } __attribute__ ((packed)) report_keyboard_t; | 136 | } __attribute__ ((packed)) report_keyboard_t; |
| 137 | /* | ||
| 138 | typedef struct { | ||
| 139 | uint8_t mods; | ||
| 140 | uint8_t reserved; | ||
| 141 | uint8_t keys[REPORT_KEYS]; | ||
| 142 | } __attribute__ ((packed)) report_keyboard_t; | ||
| 143 | */ | ||
| 144 | 137 | ||
| 145 | typedef struct { | 138 | typedef struct { |
| 146 | uint8_t buttons; | 139 | uint8_t buttons; |
diff --git a/tmk_core/protocol/lufa.mk b/tmk_core/protocol/lufa.mk index 151d26cbc..de0cc795f 100644 --- a/tmk_core/protocol/lufa.mk +++ b/tmk_core/protocol/lufa.mk | |||
| @@ -8,13 +8,14 @@ LUFA_PATH ?= $(LUFA_DIR)/LUFA-git | |||
| 8 | ifneq (, $(wildcard $(TMK_PATH)/$(LUFA_PATH)/LUFA/Build/lufa_sources.mk)) | 8 | ifneq (, $(wildcard $(TMK_PATH)/$(LUFA_PATH)/LUFA/Build/lufa_sources.mk)) |
| 9 | # New build system from 20120730 | 9 | # New build system from 20120730 |
| 10 | LUFA_ROOT_PATH = $(LUFA_PATH)/LUFA | 10 | LUFA_ROOT_PATH = $(LUFA_PATH)/LUFA |
| 11 | include $(TMK_PATH)/$(LUFA_PATH)/LUFA/Build/lufa_sources.mk | 11 | include $(TMK_PATH)/$(LUFA_PATH)/LUFA/Build/lufa_sources.mk |
| 12 | else | 12 | else |
| 13 | include $(TMK_PATH)/$(LUFA_PATH)/LUFA/makefile | 13 | include $(TMK_PATH)/$(LUFA_PATH)/LUFA/makefile |
| 14 | endif | 14 | endif |
| 15 | 15 | ||
| 16 | LUFA_SRC = lufa.c \ | 16 | LUFA_SRC = lufa.c \ |
| 17 | descriptor.c \ | 17 | descriptor.c \ |
| 18 | outputselect.c \ | ||
| 18 | $(LUFA_SRC_USB) | 19 | $(LUFA_SRC_USB) |
| 19 | 20 | ||
| 20 | ifeq ($(strip $(MIDI_ENABLE)), yes) | 21 | ifeq ($(strip $(MIDI_ENABLE)), yes) |
diff --git a/tmk_core/protocol/lufa/lufa.c b/tmk_core/protocol/lufa/lufa.c index 6dd5959dc..ba49284c9 100644 --- a/tmk_core/protocol/lufa/lufa.c +++ b/tmk_core/protocol/lufa/lufa.c | |||
| @@ -53,6 +53,7 @@ | |||
| 53 | #include "lufa.h" | 53 | #include "lufa.h" |
| 54 | #include "quantum.h" | 54 | #include "quantum.h" |
| 55 | #include <util/atomic.h> | 55 | #include <util/atomic.h> |
| 56 | #include "outputselect.h" | ||
| 56 | 57 | ||
| 57 | #ifdef NKRO_ENABLE | 58 | #ifdef NKRO_ENABLE |
| 58 | #include "keycode_config.h" | 59 | #include "keycode_config.h" |
| @@ -589,59 +590,33 @@ void EVENT_USB_Device_ControlRequest(void) | |||
| 589 | 590 | ||
| 590 | /******************************************************************************* | 591 | /******************************************************************************* |
| 591 | * Host driver | 592 | * Host driver |
| 592 | p | ||
| 593 | ******************************************************************************/ | 593 | ******************************************************************************/ |
| 594 | static uint8_t keyboard_leds(void) | 594 | static uint8_t keyboard_leds(void) |
| 595 | { | 595 | { |
| 596 | return keyboard_led_stats; | 596 | return keyboard_led_stats; |
| 597 | } | 597 | } |
| 598 | 598 | ||
| 599 | #define SendToUSB 1 | ||
| 600 | #define SendToBT 2 | ||
| 601 | #define SendToBLE 4 | ||
| 602 | |||
| 603 | static inline uint8_t where_to_send(void) { | ||
| 604 | #ifdef ADAFRUIT_BLE_ENABLE | ||
| 605 | #if 0 | ||
| 606 | if (adafruit_ble_is_connected()) { | ||
| 607 | // For testing, send to BLE as a priority | ||
| 608 | return SendToBLE; | ||
| 609 | } | ||
| 610 | #endif | ||
| 611 | |||
| 612 | // This is the real policy | ||
| 613 | if (USB_DeviceState != DEVICE_STATE_Configured) { | ||
| 614 | if (adafruit_ble_is_connected()) { | ||
| 615 | return SendToBLE; | ||
| 616 | } | ||
| 617 | } | ||
| 618 | #endif | ||
| 619 | return ((USB_DeviceState == DEVICE_STATE_Configured) ? SendToUSB : 0) | ||
| 620 | #ifdef BLUETOOTH_ENABLE | ||
| 621 | || SendToBT | ||
| 622 | #endif | ||
| 623 | ; | ||
| 624 | } | ||
| 625 | |||
| 626 | static void send_keyboard(report_keyboard_t *report) | 599 | static void send_keyboard(report_keyboard_t *report) |
| 627 | { | 600 | { |
| 601 | uint8_t timeout = 255; | ||
| 602 | uint8_t where = where_to_send(); | ||
| 603 | |||
| 628 | #ifdef BLUETOOTH_ENABLE | 604 | #ifdef BLUETOOTH_ENABLE |
| 629 | bluefruit_serial_send(0xFD); | 605 | if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |
| 630 | for (uint8_t i = 0; i < KEYBOARD_EPSIZE; i++) { | 606 | bluefruit_serial_send(0xFD); |
| 631 | bluefruit_serial_send(report->raw[i]); | 607 | for (uint8_t i = 0; i < KEYBOARD_EPSIZE; i++) { |
| 608 | bluefruit_serial_send(report->raw[i]); | ||
| 609 | } | ||
| 632 | } | 610 | } |
| 633 | #endif | 611 | #endif |
| 634 | 612 | ||
| 635 | uint8_t timeout = 255; | ||
| 636 | uint8_t where = where_to_send(); | ||
| 637 | |||
| 638 | #ifdef ADAFRUIT_BLE_ENABLE | 613 | #ifdef ADAFRUIT_BLE_ENABLE |
| 639 | if (where & SendToBLE) { | 614 | if (where == OUTPUT_ADAFRUIT_BLE) { |
| 640 | adafruit_ble_send_keys(report->mods, report->keys, sizeof(report->keys)); | 615 | adafruit_ble_send_keys(report->mods, report->keys, sizeof(report->keys)); |
| 641 | } | 616 | } |
| 642 | #endif | 617 | #endif |
| 643 | 618 | ||
| 644 | if (!(where & SendToUSB)) { | 619 | if (where != OUTPUT_USB && where != OUTPUT_USB_AND_BT) { |
| 645 | return; | 620 | return; |
| 646 | } | 621 | } |
| 647 | 622 | ||
| @@ -681,30 +656,31 @@ static void send_keyboard(report_keyboard_t *report) | |||
| 681 | static void send_mouse(report_mouse_t *report) | 656 | static void send_mouse(report_mouse_t *report) |
| 682 | { | 657 | { |
| 683 | #ifdef MOUSE_ENABLE | 658 | #ifdef MOUSE_ENABLE |
| 659 | uint8_t timeout = 255; | ||
| 660 | uint8_t where = where_to_send(); | ||
| 684 | 661 | ||
| 685 | #ifdef BLUETOOTH_ENABLE | 662 | #ifdef BLUETOOTH_ENABLE |
| 686 | bluefruit_serial_send(0xFD); | 663 | if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |
| 687 | bluefruit_serial_send(0x00); | 664 | bluefruit_serial_send(0xFD); |
| 688 | bluefruit_serial_send(0x03); | 665 | bluefruit_serial_send(0x00); |
| 689 | bluefruit_serial_send(report->buttons); | 666 | bluefruit_serial_send(0x03); |
| 690 | bluefruit_serial_send(report->x); | 667 | bluefruit_serial_send(report->buttons); |
| 691 | bluefruit_serial_send(report->y); | 668 | bluefruit_serial_send(report->x); |
| 692 | bluefruit_serial_send(report->v); // should try sending the wheel v here | 669 | bluefruit_serial_send(report->y); |
| 693 | bluefruit_serial_send(report->h); // should try sending the wheel h here | 670 | bluefruit_serial_send(report->v); // should try sending the wheel v here |
| 694 | bluefruit_serial_send(0x00); | 671 | bluefruit_serial_send(report->h); // should try sending the wheel h here |
| 672 | bluefruit_serial_send(0x00); | ||
| 673 | } | ||
| 695 | #endif | 674 | #endif |
| 696 | 675 | ||
| 697 | uint8_t timeout = 255; | ||
| 698 | |||
| 699 | uint8_t where = where_to_send(); | ||
| 700 | |||
| 701 | #ifdef ADAFRUIT_BLE_ENABLE | 676 | #ifdef ADAFRUIT_BLE_ENABLE |
| 702 | if (where & SendToBLE) { | 677 | if (where == OUTPUT_ADAFRUIT_BLE) { |
| 703 | // FIXME: mouse buttons | 678 | // FIXME: mouse buttons |
| 704 | adafruit_ble_send_mouse_move(report->x, report->y, report->v, report->h); | 679 | adafruit_ble_send_mouse_move(report->x, report->y, report->v, report->h); |
| 705 | } | 680 | } |
| 706 | #endif | 681 | #endif |
| 707 | if (!(where & SendToUSB)) { | 682 | |
| 683 | if (where != OUTPUT_USB && where != OUTPUT_USB_AND_BT) { | ||
| 708 | return; | 684 | return; |
| 709 | } | 685 | } |
| 710 | 686 | ||
| @@ -746,32 +722,34 @@ static void send_system(uint16_t data) | |||
| 746 | 722 | ||
| 747 | static void send_consumer(uint16_t data) | 723 | static void send_consumer(uint16_t data) |
| 748 | { | 724 | { |
| 725 | uint8_t timeout = 255; | ||
| 726 | uint8_t where = where_to_send(); | ||
| 749 | 727 | ||
| 750 | #ifdef BLUETOOTH_ENABLE | 728 | #ifdef BLUETOOTH_ENABLE |
| 751 | static uint16_t last_data = 0; | 729 | if (where == OUTPUT_BLUETOOTH || where == OUTPUT_USB_AND_BT) { |
| 752 | if (data == last_data) return; | 730 | static uint16_t last_data = 0; |
| 753 | last_data = data; | 731 | if (data == last_data) return; |
| 754 | uint16_t bitmap = CONSUMER2BLUEFRUIT(data); | 732 | last_data = data; |
| 755 | bluefruit_serial_send(0xFD); | 733 | uint16_t bitmap = CONSUMER2BLUEFRUIT(data); |
| 756 | bluefruit_serial_send(0x00); | 734 | bluefruit_serial_send(0xFD); |
| 757 | bluefruit_serial_send(0x02); | 735 | bluefruit_serial_send(0x00); |
| 758 | bluefruit_serial_send((bitmap>>8)&0xFF); | 736 | bluefruit_serial_send(0x02); |
| 759 | bluefruit_serial_send(bitmap&0xFF); | 737 | bluefruit_serial_send((bitmap>>8)&0xFF); |
| 760 | bluefruit_serial_send(0x00); | 738 | bluefruit_serial_send(bitmap&0xFF); |
| 761 | bluefruit_serial_send(0x00); | 739 | bluefruit_serial_send(0x00); |
| 762 | bluefruit_serial_send(0x00); | 740 | bluefruit_serial_send(0x00); |
| 763 | bluefruit_serial_send(0x00); | 741 | bluefruit_serial_send(0x00); |
| 742 | bluefruit_serial_send(0x00); | ||
| 743 | } | ||
| 764 | #endif | 744 | #endif |
| 765 | 745 | ||
| 766 | uint8_t timeout = 255; | ||
| 767 | uint8_t where = where_to_send(); | ||
| 768 | |||
| 769 | #ifdef ADAFRUIT_BLE_ENABLE | 746 | #ifdef ADAFRUIT_BLE_ENABLE |
| 770 | if (where & SendToBLE) { | 747 | if (where == OUTPUT_ADAFRUIT_BLE) { |
| 771 | adafruit_ble_send_consumer_key(data, 0); | 748 | adafruit_ble_send_consumer_key(data, 0); |
| 772 | } | 749 | } |
| 773 | #endif | 750 | #endif |
| 774 | if (!(where & SendToUSB)) { | 751 | |
| 752 | if (where != OUTPUT_USB && where != OUTPUT_USB_AND_BT) { | ||
| 775 | return; | 753 | return; |
| 776 | } | 754 | } |
| 777 | 755 | ||
diff --git a/tmk_core/protocol/lufa/outputselect.c b/tmk_core/protocol/lufa/outputselect.c new file mode 100644 index 000000000..5d2457bff --- /dev/null +++ b/tmk_core/protocol/lufa/outputselect.c | |||
| @@ -0,0 +1,56 @@ | |||
| 1 | /* | ||
| 2 | Copyright 2017 Priyadi Iman Nurcahyo | ||
| 3 | This program is free software: you can redistribute it and/or modify | ||
| 4 | it under the terms of the GNU General Public License as published by | ||
| 5 | the Free Software Foundation, either version 2 of the License, or | ||
| 6 | (at your option) any later version. | ||
| 7 | This program is distributed in the hope that it will be useful, | ||
| 8 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 9 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 10 | GNU General Public License for more details. | ||
| 11 | You should have received a copy of the GNU General Public License | ||
| 12 | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
| 13 | */ | ||
| 14 | |||
| 15 | #include "lufa.h" | ||
| 16 | #include "outputselect.h" | ||
| 17 | #ifdef ADAFRUIT_BLE_ENABLE | ||
| 18 | #include "adafruit_ble.h" | ||
| 19 | #endif | ||
| 20 | |||
| 21 | uint8_t desired_output = OUTPUT_DEFAULT; | ||
| 22 | |||
| 23 | void set_output(uint8_t output) { | ||
| 24 | set_output_user(output); | ||
| 25 | desired_output = output; | ||
| 26 | } | ||
| 27 | |||
| 28 | __attribute__((weak)) | ||
| 29 | void set_output_user(uint8_t output) { | ||
| 30 | } | ||
| 31 | |||
| 32 | uint8_t auto_detect_output(void) { | ||
| 33 | if (USB_DeviceState == DEVICE_STATE_Configured) { | ||
| 34 | return OUTPUT_USB; | ||
| 35 | } | ||
| 36 | |||
| 37 | #ifdef ADAFRUIT_BLE_ENABLE | ||
| 38 | if (adafruit_ble_is_connected()) { | ||
| 39 | return OUTPUT_ADAFRUIT_BLE; | ||
| 40 | } | ||
| 41 | #endif | ||
| 42 | |||
| 43 | #ifdef BLUETOOTH_ENABLE | ||
| 44 | return OUTPUT_BLUETOOTH; // should check if BT is connected here | ||
| 45 | #endif | ||
| 46 | |||
| 47 | return OUTPUT_NONE; | ||
| 48 | } | ||
| 49 | |||
| 50 | uint8_t where_to_send(void) { | ||
| 51 | if (desired_output == OUTPUT_AUTO) { | ||
| 52 | return auto_detect_output(); | ||
| 53 | } | ||
| 54 | return desired_output; | ||
| 55 | } | ||
| 56 | |||
diff --git a/keyboards/kc60/led.c b/tmk_core/protocol/lufa/outputselect.h index 50659d724..79b4dd35d 100644 --- a/keyboards/kc60/led.c +++ b/tmk_core/protocol/lufa/outputselect.h | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | /* | 1 | /* |
| 2 | Copyright 2012 Jun Wako <wakojun@gmail.com> | 2 | Copyright 2017 Priyadi Iman Nurcahyo |
| 3 | This program is free software: you can redistribute it and/or modify | 3 | This program is free software: you can redistribute it and/or modify |
| 4 | it under the terms of the GNU General Public License as published by | 4 | it under the terms of the GNU General Public License as published by |
| 5 | the Free Software Foundation, either version 2 of the License, or | 5 | the Free Software Foundation, either version 2 of the License, or |
| @@ -12,20 +12,30 @@ You should have received a copy of the GNU General Public License | |||
| 12 | along with this program. If not, see <http://www.gnu.org/licenses/>. | 12 | along with this program. If not, see <http://www.gnu.org/licenses/>. |
| 13 | */ | 13 | */ |
| 14 | 14 | ||
| 15 | #include <avr/io.h> | 15 | enum outputs { |
| 16 | #include "stdint.h" | 16 | OUTPUT_AUTO, |
| 17 | #include "led.h" | ||
| 18 | 17 | ||
| 18 | OUTPUT_NONE, | ||
| 19 | OUTPUT_USB, | ||
| 20 | OUTPUT_BLUETOOTH, | ||
| 21 | OUTPUT_ADAFRUIT_BLE, | ||
| 19 | 22 | ||
| 20 | void led_set(uint8_t usb_led) | 23 | // backward compatibility |
| 21 | { | 24 | OUTPUT_USB_AND_BT |
| 22 | if (usb_led & (1<<USB_LED_CAPS_LOCK)) { | 25 | }; |
| 23 | // output low | 26 | |
| 24 | DDRB |= (1<<2); | 27 | /** |
| 25 | PORTB &= ~(1<<2); | 28 | * backward compatibility for BLUETOOTH_ENABLE, send to BT and USB by default |
| 26 | } else { | 29 | */ |
| 27 | // Hi-Z | 30 | #ifndef OUTPUT_DEFAULT |
| 28 | DDRB &= ~(1<<2); | 31 | #ifdef BLUETOOTH_ENABLE |
| 29 | PORTB &= ~(1<<2); | 32 | #define OUTPUT_DEFAULT OUTPUT_USB_AND_BT |
| 30 | } | 33 | #else |
| 31 | } \ No newline at end of file | 34 | #define OUTPUT_DEFAULT OUTPUT_AUTO |
| 35 | #endif | ||
| 36 | #endif | ||
| 37 | |||
| 38 | void set_output(uint8_t output); | ||
| 39 | void set_output_user(uint8_t output); | ||
| 40 | uint8_t auto_detect_output(void); | ||
| 41 | uint8_t where_to_send(void); \ No newline at end of file | ||
diff --git a/tmk_core/protocol/vusb/vusb.c b/tmk_core/protocol/vusb/vusb.c index a8c13b928..022ac6f6b 100644 --- a/tmk_core/protocol/vusb/vusb.c +++ b/tmk_core/protocol/vusb/vusb.c | |||
| @@ -280,7 +280,7 @@ const PROGMEM uchar keyboard_hid_report[] = { | |||
| 280 | 0x95, 0x06, // Report Count (6), | 280 | 0x95, 0x06, // Report Count (6), |
| 281 | 0x75, 0x08, // Report Size (8), | 281 | 0x75, 0x08, // Report Size (8), |
| 282 | 0x15, 0x00, // Logical Minimum (0), | 282 | 0x15, 0x00, // Logical Minimum (0), |
| 283 | 0x25, 0xFF, 0x00, // Logical Maximum(255), | 283 | 0x26, 0xFF, 0x00, // Logical Maximum(255), |
| 284 | 0x05, 0x07, // Usage Page (Key Codes), | 284 | 0x05, 0x07, // Usage Page (Key Codes), |
| 285 | 0x19, 0x00, // Usage Minimum (0), | 285 | 0x19, 0x00, // Usage Minimum (0), |
| 286 | 0x29, 0xFF, // Usage Maximum (255), | 286 | 0x29, 0xFF, // Usage Maximum (255), |
| @@ -350,7 +350,7 @@ const PROGMEM uchar mouse_hid_report[] = { | |||
| 350 | 0xa1, 0x01, // COLLECTION (Application) | 350 | 0xa1, 0x01, // COLLECTION (Application) |
| 351 | 0x85, REPORT_ID_SYSTEM, // REPORT_ID (2) | 351 | 0x85, REPORT_ID_SYSTEM, // REPORT_ID (2) |
| 352 | 0x15, 0x01, // LOGICAL_MINIMUM (0x1) | 352 | 0x15, 0x01, // LOGICAL_MINIMUM (0x1) |
| 353 | 0x25, 0xb7, 0x00, // LOGICAL_MAXIMUM (0xb7) | 353 | 0x26, 0xb7, 0x00, // LOGICAL_MAXIMUM (0xb7) |
| 354 | 0x19, 0x01, // USAGE_MINIMUM (0x1) | 354 | 0x19, 0x01, // USAGE_MINIMUM (0x1) |
| 355 | 0x29, 0xb7, // USAGE_MAXIMUM (0xb7) | 355 | 0x29, 0xb7, // USAGE_MAXIMUM (0xb7) |
| 356 | 0x75, 0x10, // REPORT_SIZE (16) | 356 | 0x75, 0x10, // REPORT_SIZE (16) |
diff --git a/util/travis_build.sh b/util/travis_build.sh new file mode 100644 index 000000000..6bafd1941 --- /dev/null +++ b/util/travis_build.sh | |||
| @@ -0,0 +1,22 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | |||
| 3 | TRAVIS_COMMIT_MESSAGE="${TRAVIS_COMMIT_MESSAGE:-none}" | ||
| 4 | TRAVIS_COMMIT_RANGE="${TRAVIS_COMMIT_RANGE:-HEAD~1..HEAD}" | ||
| 5 | |||
| 6 | if [[ "$TRAVIS_COMMIT_MESSAGE" != *"[skip build]"* ]] ; then | ||
| 7 | exit_code=0 | ||
| 8 | NEFM=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -Ev '^(keyboards/)' | wc -l) | ||
| 9 | if [[ $NEFM -gt 0 ]] ; then | ||
| 10 | echo "Making all keymaps for all keyboards" | ||
| 11 | make all-keyboards AUTOGEN="true" | ||
| 12 | : $((exit_code = $exit_code + $?)) | ||
| 13 | else | ||
| 14 | MKB=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -oP '(?<=keyboards\/)([a-zA-Z0-9_]+)(?=\/)' | sort -u) | ||
| 15 | for KB in $MKB ; do | ||
| 16 | echo "Making all keymaps for $KB" | ||
| 17 | make "$KB" AUTOGEN=true | ||
| 18 | : $((exit_code = $exit_code + $?)) | ||
| 19 | done | ||
| 20 | fi | ||
| 21 | exit $exit_code | ||
| 22 | fi | ||
diff --git a/util/travis_compiled_push.sh b/util/travis_compiled_push.sh index f432976d0..de2481ce5 100644 --- a/util/travis_compiled_push.sh +++ b/util/travis_compiled_push.sh | |||
| @@ -7,21 +7,49 @@ rev=$(git rev-parse --short HEAD) | |||
| 7 | git config --global user.name "Travis CI" | 7 | git config --global user.name "Travis CI" |
| 8 | git config --global user.email "jack.humb+travis.ci@gmail.com" | 8 | git config --global user.email "jack.humb+travis.ci@gmail.com" |
| 9 | 9 | ||
| 10 | make ergodox-ez AUTOGEN=true | 10 | if [[ "$TRAVIS_BRANCH" == "master" ]] ; then |
| 11 | 11 | ||
| 12 | find . -name ".build" | xargs rm -rf | 12 | increment_version () |
| 13 | cd .. | 13 | { |
| 14 | git clone https://$GH_TOKEN@github.com/jackhumbert/qmk.fm.git | 14 | declare -a part=( ${1//\./ } ) |
| 15 | cd qmk.fm | 15 | part[2]=$((part[2] + 1)) |
| 16 | git submodule update --init --recursive | 16 | new="${part[*]}" |
| 17 | rm -rf keyboard | 17 | echo -e "${new// /.}" |
| 18 | rm -rf keyboards | 18 | } |
| 19 | cp -r ../qmk_firmware/keyboards . | 19 | |
| 20 | mkdir keyboards/ergodox_ez/ | 20 | NEFM=$(git diff --name-only -n 1 ${TRAVIS_COMMIT_RANGE} | grep -Ev '^(keyboards/)' | wc -l) |
| 21 | cp ../qmk_firmware/util/ergodox_ez.html keyboards/ergodox_ez/index.html | 21 | if [[ $NEFM -gt 0 ]] ; then |
| 22 | cp ../qmk_firmware/readme.md qmk_readme.md | 22 | echo "Essential files modified." |
| 23 | ./generate.sh | 23 | git fetch --tags |
| 24 | 24 | lasttag=$(git tag | grep -Ev '\-' | xargs -I@ git log --format=format:"%ai @%n" -1 @ | sort -V | awk '{print $4}' | tail -1) | |
| 25 | git add -A | 25 | newtag=$(increment_version $lasttag) |
| 26 | git commit -m "generated from qmk_firmware/$TRAVIS_BRANCH@${rev}" | 26 | git tag $newtag |
| 27 | git push | 27 | git push --tags -q https://$GH_TOKEN@github.com/qmk/qmk_firmware |
| 28 | else | ||
| 29 | echo "No essential files modified." | ||
| 30 | fi | ||
| 31 | |||
| 32 | if [[ "$TRAVIS_COMMIT_MESSAGE" != *"[skip build]"* ]] ; then | ||
| 33 | |||
| 34 | make ergodox-ez AUTOGEN=true | ||
| 35 | |||
| 36 | find . -name ".build" | xargs rm -rf | ||
| 37 | cd .. | ||
| 38 | git clone https://$GH_TOKEN@github.com/jackhumbert/qmk.fm.git | ||
| 39 | cd qmk.fm | ||
| 40 | git submodule update --init --recursive | ||
| 41 | #rm -rf keyboard | ||
| 42 | #rm -rf keyboards | ||
| 43 | yes | cp -rf ../qmk_firmware/keyboards . | ||
| 44 | #mkdir keyboards/ergodox_ez/ | ||
| 45 | cp ../qmk_firmware/util/ergodox_ez.html keyboards/ergodox_ez/index.html | ||
| 46 | cp ../qmk_firmware/readme.md qmk_readme.md | ||
| 47 | ./generate.sh | ||
| 48 | |||
| 49 | git add -A | ||
| 50 | git commit -m "generated from qmk/qmk_firmware@${rev}" | ||
| 51 | git push | ||
| 52 | |||
| 53 | fi | ||
| 54 | |||
| 55 | fi \ No newline at end of file | ||
