diff options
author | Josef Adamcik <josef.adamcik@gmail.com> | 2019-11-09 17:05:37 +0100 |
---|---|---|
committer | Josef Adamcik <josef.adamcik@gmail.com> | 2020-04-29 09:15:45 +0200 |
commit | 168ba88ada31e9c70e39ee7a592595a7a771afe3 (patch) | |
tree | 60b8dc2ce1de34847219f00b4868c03f5461da2c | |
parent | e1217dae5a659448920a6b0a987f9a2d24ea498c (diff) | |
download | qmk_firmware-168ba88ada31e9c70e39ee7a592595a7a771afe3.tar.gz qmk_firmware-168ba88ada31e9c70e39ee7a592595a7a771afe3.zip |
Add SofleKeyboard support to QMK firmware.
-rw-r--r-- | keyboards/sofle/config.h | 4 | ||||
-rw-r--r-- | keyboards/sofle/keymaps/default/config.h | 9 | ||||
-rw-r--r-- | keyboards/sofle/keymaps/default/keymap.c | 369 | ||||
-rw-r--r-- | keyboards/sofle/keymaps/default/readme.md | 20 | ||||
-rw-r--r-- | keyboards/sofle/keymaps/default/rules.mk | 5 | ||||
-rw-r--r-- | keyboards/sofle/readme.md | 27 | ||||
-rw-r--r-- | keyboards/sofle/rev1/config.h | 38 | ||||
-rw-r--r-- | keyboards/sofle/rev1/info.json | 19 | ||||
-rw-r--r-- | keyboards/sofle/rev1/rev1.c | 1 | ||||
-rw-r--r-- | keyboards/sofle/rev1/rev1.h | 37 | ||||
-rw-r--r-- | keyboards/sofle/rev1/rules.mk | 2 | ||||
-rw-r--r-- | keyboards/sofle/rules.mk | 4 | ||||
-rw-r--r-- | keyboards/sofle/sofle.c | 5 | ||||
-rw-r--r-- | keyboards/sofle/sofle.h | 5 |
14 files changed, 545 insertions, 0 deletions
diff --git a/keyboards/sofle/config.h b/keyboards/sofle/config.h new file mode 100644 index 000000000..0ff762c00 --- /dev/null +++ b/keyboards/sofle/config.h | |||
@@ -0,0 +1,4 @@ | |||
1 | #pragma once | ||
2 | |||
3 | #include "config_common.h" | ||
4 | |||
diff --git a/keyboards/sofle/keymaps/default/config.h b/keyboards/sofle/keymaps/default/config.h new file mode 100644 index 000000000..8133e12fc --- /dev/null +++ b/keyboards/sofle/keymaps/default/config.h | |||
@@ -0,0 +1,9 @@ | |||
1 | #pragma once | ||
2 | |||
3 | /* The way how "handedness" is decided (which half is which), | ||
4 | see https://docs.qmk.fm/#/feature_split_keyboard?id=setting-handedness | ||
5 | for more options. | ||
6 | */ | ||
7 | #define MASTER_LEFT | ||
8 | |||
9 | #define TAPPING_FORCE_HOLD | ||
diff --git a/keyboards/sofle/keymaps/default/keymap.c b/keyboards/sofle/keymaps/default/keymap.c new file mode 100644 index 000000000..894cb33cd --- /dev/null +++ b/keyboards/sofle/keymaps/default/keymap.c | |||
@@ -0,0 +1,369 @@ | |||
1 | #include QMK_KEYBOARD_H | ||
2 | |||
3 | enum sofle_layers { | ||
4 | /* _M_XYZ = Mac Os, _W_XYZ = Win/Linux */ | ||
5 | _M_QWERTY, | ||
6 | _W_QWERTY, | ||
7 | _M_COLEMAK, | ||
8 | _W_COLEMAK, | ||
9 | _M_LOWER, | ||
10 | _W_LOWER, | ||
11 | _M_RAISE, | ||
12 | _W_RAISE, | ||
13 | _ADJUST, | ||
14 | }; | ||
15 | |||
16 | enum custom_keycodes { | ||
17 | KC_M_QWERTY = SAFE_RANGE, | ||
18 | KC_W_QWERTY, | ||
19 | KC_M_COLEMAK, | ||
20 | KC_W_COLEMAK, | ||
21 | KC_M_LOWER, | ||
22 | KC_W_LOWER, | ||
23 | KC_M_RAISE, | ||
24 | KC_W_RAISE, | ||
25 | KC_ADJUST, | ||
26 | }; | ||
27 | |||
28 | /* Linux/win variants */ | ||
29 | #define KC_W_UNDO LCTL(KC_Z) | ||
30 | #define KC_W_CUT LCTL(KC_X) | ||
31 | #define KC_W_COPY LCTL(KC_C) | ||
32 | #define KC_W_PASTE LCTL(KC_V) | ||
33 | #define KC_W_PRVWD LCTL(KC_LEFT) | ||
34 | #define KC_W_NXTWD LCTL(KC_RIGHT) | ||
35 | #define KC_W_LSTRT KC_HOME | ||
36 | #define KC_W_LEND KC_END | ||
37 | #define KC_W_DLINE LCTL(KC_BSPC) | ||
38 | |||
39 | /* Mac variants */ | ||
40 | #define KC_M_UNDO LGUI(KC_Z) | ||
41 | #define KC_M_CUT LGUI(KC_X) | ||
42 | #define KC_M_COPY LGUI(KC_C) | ||
43 | #define KC_M_PASTE LGUI(KC_V) | ||
44 | #define KC_M_PRVWD LALT(KC_LEFT) | ||
45 | #define KC_M_NXTWD LALT(KC_RIGHT) | ||
46 | #define KC_M_LSTRT LGUI(KC_LEFT) | ||
47 | #define KC_M_LEND LGUI(KC_RIGHT) | ||
48 | #define KC_M_DLINE LGUI(KC_BSPC) | ||
49 | |||
50 | #define KC_____ KC_TRNS | ||
51 | #define KC_XXXX KC_NO | ||
52 | #define KC_RESET RESET | ||
53 | |||
54 | const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||
55 | /* | ||
56 | * QWERTY | ||
57 | * ,-----------------------------------------. ,-----------------------------------------. | ||
58 | * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | ` | | ||
59 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
60 | * | ESC | Q | W | E | R | T | | Y | U | I | O | P | Bspc | | ||
61 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
62 | * | Tab | A | S | D | F | G |-------. ,-------| H | J | K | L | ; | ' | | ||
63 | * |------+------+------+------+------+------| | | |------+------+------+------+------+------| | ||
64 | * |LShift| Z | X | C | V | B |-------| |-------| N | M | , | . | / |RShift| | ||
65 | * `-----------------------------------------/ / \ \-----------------------------------------' | ||
66 | * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | | ||
67 | * | | | | |/ / \ \ | | | | | | ||
68 | * `----------------------------------' '------''---------------------------' | ||
69 | */ | ||
70 | [_M_QWERTY] = LAYOUT_kc( \ | ||
71 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \ | ||
72 | ESC, Q, W, E, R, T, Y, U, I, O, P, BSPC, \ | ||
73 | TAB, A, S, D, F, G, H, J, K, L, SCLN, QUOT, \ | ||
74 | LSFT, Z, X, C, V, B, MUTE, XXXX, N, M, COMM, DOT, SLSH, RSFT, \ | ||
75 | LCTRL,LALT,LGUI,M_LOWER, ENT, SPC, M_RAISE, RGUI, RALT, RCTRL \ | ||
76 | ), | ||
77 | [_W_QWERTY] = LAYOUT_kc( \ | ||
78 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \ | ||
79 | ESC, Q, W, E, R, T, Y, U, I, O, P, BSPC, \ | ||
80 | TAB, A, S, D, F, G, H, J, K, L, SCLN, QUOT, \ | ||
81 | LSFT, Z, X, C, V, B, MUTE, XXXX, N, M, COMM, DOT, SLSH, RSFT, \ | ||
82 | LGUI, LALT,LCTRL,W_LOWER,ENT, SPC, W_RAISE, RCTRL,RALT, RGUI \ | ||
83 | ), | ||
84 | /* | ||
85 | * COLEMAK | ||
86 | * ,-----------------------------------------. ,-----------------------------------------. | ||
87 | * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | ` | | ||
88 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
89 | * | ESC | Q | W | F | P | G | | J | L | U | Y | ; | Bspc | | ||
90 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
91 | * | TAB | A | R | S | T | D |-------. ,-------| H | N | E | I | O | ' | | ||
92 | * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| | ||
93 | * |LShift| Z | X | C | V | B |-------| |-------| K | M | , | . | / |RShift| | ||
94 | * `-----------------------------------------/ / \ \-----------------------------------------' | ||
95 | * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | | ||
96 | * | | | | |/ / \ \ | | | | | | ||
97 | * `----------------------------------' '------''---------------------------' | ||
98 | */ | ||
99 | |||
100 | [_M_COLEMAK] = LAYOUT_kc( \ | ||
101 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \ | ||
102 | ESC, Q, W, F, P, G, J, L, U, Y, SCLN, BSPC, \ | ||
103 | TAB, A, R, S, T, D, H, N, E, I, O, QUOT, \ | ||
104 | LSFT, Z, X, C, V, B, MUTE, XXXX, K, M, COMM, DOT, SLSH, RSFT, \ | ||
105 | LCTRL,LALT,LGUI,M_LOWER, ENT, SPC, M_RAISE, RGUI, RALT, RCTRL \ | ||
106 | ), | ||
107 | [_W_COLEMAK] = LAYOUT_kc( \ | ||
108 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \ | ||
109 | ESC, Q, W, F, P, G, J, L, U, Y, SCLN, BSPC, \ | ||
110 | TAB, A, R, S, T, D, H, N, E, I, O, QUOT, \ | ||
111 | LSFT, Z, X, C, V, B, MUTE, XXXX, K, M, COMM, DOT, SLSH, RSFT, \ | ||
112 | LGUI, LALT,LCTRL,W_LOWER,ENT, SPC, W_RAISE, RCTRL,RALT, RGUI \ | ||
113 | ), | ||
114 | /* LOWER | ||
115 | * ,-----------------------------------------. ,-----------------------------------------. | ||
116 | * | | F1 | F2 | F3 | F4 | F5 | | F6 | F7 | F8 | F9 | F10 | F11 | | ||
117 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
118 | * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | F12 | | ||
119 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
120 | * | Tab | ! | @ | # | $ | % |-------. ,-------| ^ | & | * | ( | ) | | | | ||
121 | * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| | ||
122 | * | Shift| = | - | + | { | } |-------| |-------| [ | ] | ; | : | \ | Shift| | ||
123 | * `-----------------------------------------/ / \ \-----------------------------------------' | ||
124 | * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | | ||
125 | * | | | | |/ / \ \ | | | | | | ||
126 | * `----------------------------------' '------''---------------------------' | ||
127 | */ | ||
128 | [_M_LOWER] = LAYOUT_kc( \ | ||
129 | ____, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11,\ | ||
130 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, F12, \ | ||
131 | ____, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, PIPE, \ | ||
132 | ____, EQL, MINS, PLUS, LCBR, RCBR, ____, ____, LBRC, RBRC, SCLN, COLN, BSLS, ____, \ | ||
133 | ____, ____, ____, ____, ____, ____, ____, ____, ____, ____\ | ||
134 | ), | ||
135 | [_W_LOWER] = LAYOUT_kc( \ | ||
136 | ____, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11,\ | ||
137 | GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, F12, \ | ||
138 | ____, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, PIPE, \ | ||
139 | ____, EQL, MINS, PLUS, LCBR, RCBR, ____, ____, LBRC, RBRC, SCLN, COLN, BSLS, ____, \ | ||
140 | ____, ____, ____, ____, ____, ____, ____, ____, ____, ____\ | ||
141 | ), | ||
142 | /* RAISE | ||
143 | * ,----------------------------------------. ,-----------------------------------------. | ||
144 | * | | | | | | | | | | | | | | | ||
145 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
146 | * | Esc | Ins | Pscr | Menu | | | | | PWrd | Up | NWrd | DLine| Bspc | | ||
147 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
148 | * | Tab | LAt | LCtl |LShift| | Caps |-------. ,-------| | Left | Down | Rigth| Del | Bspc | | ||
149 | * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| | ||
150 | * |Shift | Undo | Cut | Copy | Paste| |-------| |-------| | LStr | | LEnd | | Shift| | ||
151 | * `-----------------------------------------/ / \ \-----------------------------------------' | ||
152 | * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | | ||
153 | * | | | | |/ / \ \ | | | | | | ||
154 | * `----------------------------------' '------''---------------------------' | ||
155 | */ | ||
156 | [_M_RAISE] = LAYOUT_kc( \ | ||
157 | ____, ____ , ____ , ____ , ____ , ____, ____, ____ , ____, ____ , ____ ,____, \ | ||
158 | ____, INS, PSCR, APP, XXXX, XXXX, PGUP, M_PRVWD, UP,M_NXTWD,M_DLINE,BSPC, \ | ||
159 | ____, LALT, LCTL, LSFT, XXXX, CAPS, PGDN, LEFT, DOWN, RGHT, DEL, BSPC, \ | ||
160 | ____,M_UNDO, M_CUT,M_COPY,M_PASTE,XXXX, ____, ____, XXXX, M_LSTRT, XXXX, M_LEND, XXXX, ____, \ | ||
161 | ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \ | ||
162 | ), | ||
163 | [_W_RAISE] = LAYOUT_kc( \ | ||
164 | ____, ____ , ____ , ____ , ____ , ____, ____, ____ , ____, ____ , ____ , ____, \ | ||
165 | ____, INS, PSCR, APP, XXXX, XXXX, PGUP, W_PRVWD, UP,W_NXTWD,W_DLINE, BSPC, \ | ||
166 | ____, LALT, LCTL, LSFT, XXXX, CAPS, PGDN, LEFT, DOWN, RGHT, DEL, BSPC, \ | ||
167 | ____,W_UNDO, W_CUT,W_COPY,W_PASTE,XXXX, ____, ____, XXXX, W_LSTRT, XXXX, W_LEND, XXXX, ____, \ | ||
168 | ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \ | ||
169 | ), | ||
170 | /* ADJUST | ||
171 | * ,-----------------------------------------. ,-----------------------------------------. | ||
172 | * | | | | | | | | | | | | | | | ||
173 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
174 | * | RESET| |MACQWR|MACCOL| | | | | | | | | | | ||
175 | * |------+------+------+------+------+------| |------+------+------+------+------+------| | ||
176 | * | | |WINQWR|WINCOL| | |-------. ,-------| | VOLDO| MUTE | VOLUP| | | | ||
177 | * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------| | ||
178 | * | | | | | | |-------| |-------| | PREV | PLAY | NEXT | | | | ||
179 | * `-----------------------------------------/ / \ \-----------------------------------------' | ||
180 | * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI | | ||
181 | * | | | | |/ / \ \ | | | | | | ||
182 | * `----------------------------------' '------''---------------------------' | ||
183 | */ | ||
184 | [_ADJUST] = LAYOUT_kc( \ | ||
185 | XXXX , XXXX, XXXX , XXXX , XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, \ | ||
186 | RESET, XXXX,M_QWERTY,M_COLEMAK, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, \ | ||
187 | XXXX , XXXX,W_QWERTY,W_COLEMAK, XXXX, XXXX, XXXX, VOLD, MUTE, VOLU, XXXX, XXXX, \ | ||
188 | XXXX , XXXX, XXXX , XXXX , XXXX, XXXX, XXXX, XXXX, XXXX, MPRV, MPLY, MNXT, XXXX, XXXX, \ | ||
189 | ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \ | ||
190 | ) | ||
191 | }; | ||
192 | |||
193 | #ifdef OLED_DRIVER_ENABLE | ||
194 | |||
195 | static void render_logo(void) { | ||
196 | static const char PROGMEM qmk_logo[] = { | ||
197 | 0x80,0x81,0x82,0x83,0x84,0x85,0x86,0x87,0x88,0x89,0x8a,0x8b,0x8c,0x8d,0x8e,0x8f,0x90,0x91,0x92,0x93,0x94, | ||
198 | 0xa0,0xa1,0xa2,0xa3,0xa4,0xa5,0xa6,0xa7,0xa8,0xa9,0xaa,0xab,0xac,0xad,0xae,0xaf,0xb0,0xb1,0xb2,0xb3,0xb4, | ||
199 | 0xc0,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,0xc8,0xc9,0xca,0xcb,0xcc,0xcd,0xce,0xcf,0xd0,0xd1,0xd2,0xd3,0xd4,0 | ||
200 | }; | ||
201 | |||
202 | oled_write_P(qmk_logo, false); | ||
203 | } | ||
204 | |||
205 | static void print_status_narrow(void) { | ||
206 | // Print current mode | ||
207 | oled_write_P(PSTR("\n\n"), false); | ||
208 | oled_write_ln_P(PSTR("MODE"), false); | ||
209 | oled_write_ln_P(PSTR(""), false); | ||
210 | switch (biton32(default_layer_state)) { | ||
211 | case _W_QWERTY: | ||
212 | oled_write_P(PSTR("Qwrt\nLinux"), false); | ||
213 | break; | ||
214 | case _M_QWERTY: | ||
215 | oled_write_P(PSTR("Qwrt\nMac\n"), false); | ||
216 | break; | ||
217 | case _W_COLEMAK: | ||
218 | oled_write_P(PSTR("Clmk\nLinux"), false); | ||
219 | break; | ||
220 | case _M_COLEMAK: | ||
221 | oled_write_P(PSTR("Clmk\nMac\n"), false); | ||
222 | break; | ||
223 | default: | ||
224 | oled_write_P(PSTR("Undefined\n"), false); | ||
225 | } | ||
226 | oled_write_P(PSTR("\n\n"), false); | ||
227 | // Print current layer | ||
228 | oled_write_ln_P(PSTR("LAYER"), false); | ||
229 | switch (biton32(layer_state)) { | ||
230 | case _M_COLEMAK: | ||
231 | case _W_COLEMAK: | ||
232 | case _M_QWERTY: | ||
233 | case _W_QWERTY: | ||
234 | oled_write_P(PSTR("Base\n"), false); | ||
235 | break; | ||
236 | case _M_RAISE: | ||
237 | case _W_RAISE: | ||
238 | oled_write_P(PSTR("Raise"), false); | ||
239 | break; | ||
240 | case _M_LOWER: | ||
241 | case _W_LOWER: | ||
242 | oled_write_P(PSTR("Lower"), false); | ||
243 | break; | ||
244 | case _ADJUST: | ||
245 | oled_write_P(PSTR("Adj\n"), false); | ||
246 | break; | ||
247 | default: | ||
248 | oled_write_ln_P(PSTR("Undef"), false); | ||
249 | } | ||
250 | oled_write_P(PSTR("\n\n"), false); | ||
251 | uint8_t led_usb_state = host_keyboard_leds(); | ||
252 | oled_write_ln_P(led_usb_state & (1 << USB_LED_CAPS_LOCK) ? PSTR("CPSLK") : PSTR(" "), false); | ||
253 | } | ||
254 | |||
255 | oled_rotation_t oled_init_user(oled_rotation_t rotation) { | ||
256 | if (is_keyboard_master()) { | ||
257 | return OLED_ROTATION_270; | ||
258 | } | ||
259 | return rotation; | ||
260 | } | ||
261 | |||
262 | void oled_task_user(void) { | ||
263 | if (is_keyboard_master()) { | ||
264 | print_status_narrow(); | ||
265 | } else { | ||
266 | render_logo(); | ||
267 | } | ||
268 | } | ||
269 | |||
270 | #endif | ||
271 | |||
272 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||
273 | switch (keycode) { | ||
274 | case KC_W_QWERTY: | ||
275 | if (record->event.pressed) { | ||
276 | set_single_persistent_default_layer(_W_QWERTY); | ||
277 | } | ||
278 | return false; | ||
279 | break; | ||
280 | case KC_M_QWERTY: | ||
281 | if (record->event.pressed) { | ||
282 | set_single_persistent_default_layer(_M_QWERTY); | ||
283 | } | ||
284 | return false; | ||
285 | break; | ||
286 | case KC_W_COLEMAK: | ||
287 | if (record->event.pressed) { | ||
288 | set_single_persistent_default_layer(_W_COLEMAK); | ||
289 | } | ||
290 | return false; | ||
291 | break; | ||
292 | case KC_M_COLEMAK: | ||
293 | if (record->event.pressed) { | ||
294 | set_single_persistent_default_layer(_M_COLEMAK); | ||
295 | } | ||
296 | return false; | ||
297 | break; | ||
298 | case KC_M_LOWER: | ||
299 | if (record->event.pressed) { | ||
300 | layer_on(_M_LOWER); | ||
301 | update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST); | ||
302 | } else { | ||
303 | layer_off(_M_LOWER); | ||
304 | update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST); | ||
305 | } | ||
306 | return false; | ||
307 | break; | ||
308 | case KC_M_RAISE: | ||
309 | if (record->event.pressed) { | ||
310 | layer_on(_M_RAISE); | ||
311 | update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST); | ||
312 | } else { | ||
313 | layer_off(_M_RAISE); | ||
314 | update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST); | ||
315 | } | ||
316 | return false; | ||
317 | break; | ||
318 | case KC_W_LOWER: | ||
319 | if (record->event.pressed) { | ||
320 | layer_on(_W_LOWER); | ||
321 | update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST); | ||
322 | } else { | ||
323 | layer_off(_W_LOWER); | ||
324 | update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST); | ||
325 | } | ||
326 | return false; | ||
327 | break; | ||
328 | case KC_W_RAISE: | ||
329 | if (record->event.pressed) { | ||
330 | layer_on(_W_RAISE); | ||
331 | update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST); | ||
332 | } else { | ||
333 | layer_off(_W_RAISE); | ||
334 | update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST); | ||
335 | } | ||
336 | return false; | ||
337 | break; | ||
338 | case KC_ADJUST: | ||
339 | if (record->event.pressed) { | ||
340 | layer_on(_ADJUST); | ||
341 | } else { | ||
342 | layer_off(_ADJUST); | ||
343 | } | ||
344 | return false; | ||
345 | break; | ||
346 | } | ||
347 | return true; | ||
348 | } | ||
349 | |||
350 | #ifdef ENCODER_ENABLE | ||
351 | |||
352 | void encoder_update_user(uint8_t index, bool clockwise) { | ||
353 | if (index == 0) { | ||
354 | if (clockwise) { | ||
355 | tap_code(KC_VOLU); | ||
356 | } else { | ||
357 | tap_code(KC_VOLD); | ||
358 | } | ||
359 | } else if (index == 1) { | ||
360 | if (clockwise) { | ||
361 | tap_code(KC_PGDOWN); | ||
362 | } else { | ||
363 | tap_code(KC_PGUP); | ||
364 | } | ||
365 | } | ||
366 | } | ||
367 | |||
368 | #endif | ||
369 | |||
diff --git a/keyboards/sofle/keymaps/default/readme.md b/keyboards/sofle/keymaps/default/readme.md new file mode 100644 index 000000000..e409040ac --- /dev/null +++ b/keyboards/sofle/keymaps/default/readme.md | |||
@@ -0,0 +1,20 @@ | |||
1 |  | ||
2 |  | ||
3 | |||
4 | |||
5 | # Default keymap for Sofle Keyboard | ||
6 | |||
7 | Layout in [Keyboard Layout Editor](http://www.keyboard-layout-editor.com/#/gists/76efb423a46cbbea75465cb468eef7ff) and [adjust layer](http://www.keyboard-layout-editor.com/#/gists/4bcf66f922cfd54da20ba04905d56bd4) | ||
8 | |||
9 | |||
10 | Features: | ||
11 | |||
12 | - Symmetric modifiers (CMD/Super, Alt/Opt, Ctrl, Shift) | ||
13 | - Various modes, can be switched (using Adjust layer and the selected one is stored in EEPROM. | ||
14 | - Modes for Qwerty and Colemak support | ||
15 | - Modes for Mac vs Linux/Win support -> different order of modifiers and different action shortcuts on the "UPPER" layer (the red one in the image). Designed to simplify transtions when switching between operating systems often. | ||
16 | - The OLED on master half shows selected mode and caps lock state and is rotated. | ||
17 | - Left encoder controls volume up/down/mute. Right encoder PGUP/PGDOWN. | ||
18 | |||
19 | |||
20 | |||
diff --git a/keyboards/sofle/keymaps/default/rules.mk b/keyboards/sofle/keymaps/default/rules.mk new file mode 100644 index 000000000..6da1df16f --- /dev/null +++ b/keyboards/sofle/keymaps/default/rules.mk | |||
@@ -0,0 +1,5 @@ | |||
1 | |||
2 | OLED_DRIVER_ENABLE = yes | ||
3 | ENCODER_ENABLE = yes | ||
4 | CONSOLE_ENABLE = yes | ||
5 | EXTRAKEY_ENABLE = yes | ||
diff --git a/keyboards/sofle/readme.md b/keyboards/sofle/readme.md new file mode 100644 index 000000000..27071e6f3 --- /dev/null +++ b/keyboards/sofle/readme.md | |||
@@ -0,0 +1,27 @@ | |||
1 | # Sofle Keyboard | ||
2 | |||
3 |  | ||
4 | |||
5 | Sofle is 6×4+5 keys column-staggered split keyboard. Based on Lily58, Corne and Helix keyboards. | ||
6 | |||
7 | More details about the keyboard on my blog: [Let me introduce you SofleKeyboard - a split keyboard based on Lily58 and Crkbd](https://josef-adamcik.cz/electronics/let-me-introduce-you-sofle-keyboard-split-keyboard-based-on-lily58.html) | ||
8 | |||
9 | The current (temporary) build guide and a build log is available here: [SofleKeyboard build log/guide](https://josef-adamcik.cz/electronics/soflekeyboard-build-log-and-build-guide.html) | ||
10 | |||
11 | * Keyboard Maintainer: [Josef Adamcik](https://josef-adamcik.cz) [Twitter:@josefadamcik](https://twitter.com/josefadamcik) | ||
12 | * Hardware Supported: SofleKeyboard PCB, ProMicro | ||
13 | * Hardware Availability: [PCB & Case Data](https://github.com/josefadamcik/SofleKeyboard) | ||
14 | |||
15 | Make example for this keyboard (after setting up your build environment): | ||
16 | |||
17 | make sofle:default | ||
18 | |||
19 | Flash the default keymap: | ||
20 | |||
21 | make sofle:default:avrdude | ||
22 | |||
23 | Press reset button on he keyboard when asked. | ||
24 | |||
25 | Disconnect the first half, connect the second one and repeat the process. | ||
26 | |||
27 | See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs). | ||
diff --git a/keyboards/sofle/rev1/config.h b/keyboards/sofle/rev1/config.h new file mode 100644 index 000000000..154d1fae1 --- /dev/null +++ b/keyboards/sofle/rev1/config.h | |||
@@ -0,0 +1,38 @@ | |||
1 | #pragma once | ||
2 | |||
3 | /* USB Device descriptor parameter */ | ||
4 | #define VENDOR_ID 0xFC32 | ||
5 | #define PRODUCT_ID 0x0287 | ||
6 | #define DEVICE_VER 0x0001 | ||
7 | #define MANUFACTURER JosefAdamcik | ||
8 | #define PRODUCT Sofle | ||
9 | #define DESCRIPTION Sofle is 6×4+5keys+encoder column-staggered split keyboard. | ||
10 | |||
11 | /* key matrix size */ | ||
12 | // Rows are doubled-up | ||
13 | #define MATRIX_ROWS 10 | ||
14 | #define MATRIX_COLS 6 | ||
15 | |||
16 | // wiring of each half | ||
17 | #define MATRIX_ROW_PINS { C6, D7, E6, B4, B5 } | ||
18 | #define MATRIX_COL_PINS { F6, F7, B1, B3, B2, B6 } | ||
19 | #define DIODE_DIRECTION COL2ROW | ||
20 | |||
21 | #define TAPPING_TERM 100 | ||
22 | #define DEBOUNCE 5 | ||
23 | |||
24 | /* encoder support */ | ||
25 | #define ENCODERS_PAD_A { F5 } | ||
26 | #define ENCODERS_PAD_B { F4 } | ||
27 | #define ENCODERS_PAD_A_RIGHT { F4 } | ||
28 | #define ENCODERS_PAD_B_RIGHT { F5 } | ||
29 | #define ENCODER_RESOLUTION 2 | ||
30 | |||
31 | /* communication between sides */ | ||
32 | #define USE_SERIAL | ||
33 | #define SERIAL_USE_MULTI_TRANSACTION | ||
34 | #define SOFT_SERIAL_PIN D2 | ||
35 | |||
36 | #define NO_ACTION_MACRO | ||
37 | #define NO_ACTION_FUNCTION | ||
38 | |||
diff --git a/keyboards/sofle/rev1/info.json b/keyboards/sofle/rev1/info.json new file mode 100644 index 000000000..0a495dd3b --- /dev/null +++ b/keyboards/sofle/rev1/info.json | |||
@@ -0,0 +1,19 @@ | |||
1 | { | ||
2 | "keyboard_name": "Sofle", | ||
3 | "url": "https://github.com/josefadamcik/SofleKeyboard", | ||
4 | "maintainer": "Josef Adamcik <josef.adamcik@gmail.com>", | ||
5 | "width": 16.5, | ||
6 | "height": 5.25, | ||
7 | "layouts": { | ||
8 | "LAYOUT": { | ||
9 | "key_count": 60, | ||
10 | "layout": [ | ||
11 | {"x":0, "y":0.5}, {"x":1, "y":0.375}, {"x":2, "y":0.125}, {"x":3, "y":0}, {"x":4, "y":0.125}, {"x":5, "y":0.25}, {"x":10.5, "y":0.25}, {"x":11.5, "y":0.125}, {"x":12.5, "y":0}, {"x":13.5, "y":0.125}, {"x":14.5, "y":0.375}, {"x":15.5, "y":0.5}, | ||
12 | {"x":0, "y":1.5}, {"x":1, "y":1.375}, {"x":2, "y":1.125}, {"x":3, "y":1}, {"x":4, "y":1.125}, {"x":5, "y":1.25}, {"x":10.5, "y":1.25}, {"x":11.5, "y":1.125}, {"x":12.5, "y":1}, {"x":13.5, "y":1.125}, {"x":14.5, "y":1.375}, {"x":15.5, "y":1.5}, | ||
13 | {"x":0, "y":2.5}, {"x":1, "y":2.375}, {"x":2, "y":2.125}, {"x":3, "y":2}, {"x":4, "y":2.125}, {"x":5, "y":2.25}, {"x":10.5, "y":2.25}, {"x":11.5, "y":2.125}, {"x":12.5, "y":2}, {"x":13.5, "y":2.125}, {"x":14.5, "y":2.375}, {"x":15.5, "y":2.5}, | ||
14 | {"x":0, "y":3.5}, {"x":1, "y":3.375}, {"x":2, "y":3.125}, {"x":3, "y":3}, {"x":4, "y":3.125}, {"x":5, "y":3.25}, {"x":6, "y":2.75}, {"x":9.5, "y":2.75}, {"x":10.5, "y":3.25}, {"x":11.5, "y":3.125}, {"x":12.5, "y":3}, {"x":13.5, "y":3.125}, {"x":14.5, "y":3.375}, {"x":15.5, "y":3.5}, | ||
15 | {"x":1.5, "y":4.375}, {"x":2.5, "y":4.125}, {"x":3.5, "y":4.15}, {"x":4.5, "y":4.25}, {"x":6, "y":4.25, "h":1.5}, {"x":9.5, "y":4.25, "h":1.5}, {"x":11, "y":4.25}, {"x":12, "y":4.15}, {"x":13, "y":4.125}, {"x":14, "y":4.375} | ||
16 | ] | ||
17 | } | ||
18 | } | ||
19 | } | ||
diff --git a/keyboards/sofle/rev1/rev1.c b/keyboards/sofle/rev1/rev1.c new file mode 100644 index 000000000..bbb014c4d --- /dev/null +++ b/keyboards/sofle/rev1/rev1.c | |||
@@ -0,0 +1 @@ | |||
#include "sofle.h" | |||
diff --git a/keyboards/sofle/rev1/rev1.h b/keyboards/sofle/rev1/rev1.h new file mode 100644 index 000000000..86924e4d2 --- /dev/null +++ b/keyboards/sofle/rev1/rev1.h | |||
@@ -0,0 +1,37 @@ | |||
1 | #pragma once | ||
2 | #include "quantum.h" | ||
3 | |||
4 | #define LAYOUT( \ | ||
5 | L00, L01, L02, L03, L04, L05, R00, R01, R02, R03, R04, R05, \ | ||
6 | L10, L11, L12, L13, L14, L15, R10, R11, R12, R13, R14, R15, \ | ||
7 | L20, L21, L22, L23, L24, L25, R20, R21, R22, R23, R24, R25, \ | ||
8 | L30, L31, L32, L33, L34, L35, L45, R40, R30, R31, R32, R33, R34, R35, \ | ||
9 | L40, L41, L42, L43, L44, R41, R42, R43, R44, R45 \ | ||
10 | ) \ | ||
11 | { \ | ||
12 | { L00, L01, L02, L03, L04, L05 }, \ | ||
13 | { L10, L11, L12, L13, L14, L15 }, \ | ||
14 | { L20, L21, L22, L23, L24, L25 }, \ | ||
15 | { L30, L31, L32, L33, L34, L35 }, \ | ||
16 | { L40, L41, L42, L43, L44, L45 }, \ | ||
17 | { R05, R04, R03, R02, R01, R00 }, \ | ||
18 | { R15, R14, R13, R12, R11, R10 }, \ | ||
19 | { R25, R24, R23, R22, R21, R20 }, \ | ||
20 | { R35, R34, R33, R32, R31, R30 }, \ | ||
21 | { R45, R44, R43, R42, R41, R40 } \ | ||
22 | } | ||
23 | |||
24 | #define LAYOUT_kc( \ | ||
25 | L00, L01, L02, L03, L04, L05, R00, R01, R02, R03, R04, R05, \ | ||
26 | L10, L11, L12, L13, L14, L15, R10, R11, R12, R13, R14, R15, \ | ||
27 | L20, L21, L22, L23, L24, L25, R20, R21, R22, R23, R24, R25, \ | ||
28 | L30, L31, L32, L33, L34, L35, L45, R40, R30, R31, R32, R33, R34, R35, \ | ||
29 | L40, L41, L42, L43, L44, R41, R42, R43, R44, R45 \ | ||
30 | ) \ | ||
31 | LAYOUT( \ | ||
32 | KC_##L00, KC_##L01, KC_##L02, KC_##L03, KC_##L04, KC_##L05, KC_##R00, KC_##R01, KC_##R02, KC_##R03, KC_##R04, KC_##R05, \ | ||
33 | KC_##L10, KC_##L11, KC_##L12, KC_##L13, KC_##L14, KC_##L15, KC_##R10, KC_##R11, KC_##R12, KC_##R13, KC_##R14, KC_##R15, \ | ||
34 | KC_##L20, KC_##L21, KC_##L22, KC_##L23, KC_##L24, KC_##L25, KC_##R20, KC_##R21, KC_##R22, KC_##R23, KC_##R24, KC_##R25, \ | ||
35 | KC_##L30, KC_##L31, KC_##L32, KC_##L33, KC_##L34, KC_##L35, KC_##L45, KC_##R40, KC_##R30, KC_##R31, KC_##R32, KC_##R33, KC_##R34, KC_##R35 , \ | ||
36 | KC_##L40, KC_##L41, KC_##L42, KC_##L43, KC_##L44, KC_##R41, KC_##R42, KC_##R43, KC_##R44, KC_##R45 \ | ||
37 | ) | ||
diff --git a/keyboards/sofle/rev1/rules.mk b/keyboards/sofle/rev1/rules.mk new file mode 100644 index 000000000..2ba231d86 --- /dev/null +++ b/keyboards/sofle/rev1/rules.mk | |||
@@ -0,0 +1,2 @@ | |||
1 | ENCODER_ENABLE = yes | ||
2 | OLED_DRIVER_ENABLE = yes | ||
diff --git a/keyboards/sofle/rules.mk b/keyboards/sofle/rules.mk new file mode 100644 index 000000000..820061832 --- /dev/null +++ b/keyboards/sofle/rules.mk | |||
@@ -0,0 +1,4 @@ | |||
1 | MCU = atmega32u4 | ||
2 | BOOTLOADER = caterina | ||
3 | SPLIT_KEYBOARD = yes | ||
4 | DEFAULT_FOLDER = sofle/rev1 | ||
diff --git a/keyboards/sofle/sofle.c b/keyboards/sofle/sofle.c new file mode 100644 index 000000000..9d61b0e58 --- /dev/null +++ b/keyboards/sofle/sofle.c | |||
@@ -0,0 +1,5 @@ | |||
1 | #include "sofle.h" | ||
2 | |||
3 | bool process_record_kb(uint16_t keycode, keyrecord_t *record) { | ||
4 | return process_record_user(keycode, record); | ||
5 | } | ||
diff --git a/keyboards/sofle/sofle.h b/keyboards/sofle/sofle.h new file mode 100644 index 000000000..67bd529a1 --- /dev/null +++ b/keyboards/sofle/sofle.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #pragma once | ||
2 | |||
3 | #ifdef KEYBOARD_sofle_rev1 | ||
4 | #include "rev1.h" | ||
5 | #endif | ||