summaryrefslogtreecommitdiff
path: root/keyboards/sofle/keymaps
diff options
context:
space:
mode:
authorJosef Adamcik <josef.adamcik@gmail.com>2019-11-09 17:05:37 +0100
committerJosef Adamcik <josef.adamcik@gmail.com>2020-04-29 09:15:45 +0200
commit168ba88ada31e9c70e39ee7a592595a7a771afe3 (patch)
tree60b8dc2ce1de34847219f00b4868c03f5461da2c /keyboards/sofle/keymaps
parente1217dae5a659448920a6b0a987f9a2d24ea498c (diff)
downloadqmk_firmware-168ba88ada31e9c70e39ee7a592595a7a771afe3.tar.gz
qmk_firmware-168ba88ada31e9c70e39ee7a592595a7a771afe3.zip
Add SofleKeyboard support to QMK firmware.
Diffstat (limited to 'keyboards/sofle/keymaps')
-rw-r--r--keyboards/sofle/keymaps/default/config.h9
-rw-r--r--keyboards/sofle/keymaps/default/keymap.c369
-rw-r--r--keyboards/sofle/keymaps/default/readme.md20
-rw-r--r--keyboards/sofle/keymaps/default/rules.mk5
4 files changed, 403 insertions, 0 deletions
diff --git a/keyboards/sofle/keymaps/default/config.h b/keyboards/sofle/keymaps/default/config.h
new file mode 100644
index 0000000000..8133e12fcf
--- /dev/null
+++ b/keyboards/sofle/keymaps/default/config.h
@@ -0,0 +1,9 @@
+#pragma once
+
+/* The way how "handedness" is decided (which half is which),
+see https://docs.qmk.fm/#/feature_split_keyboard?id=setting-handedness
+for more options.
+*/
+#define MASTER_LEFT
+
+#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 0000000000..894cb33cd1
--- /dev/null
+++ b/keyboards/sofle/keymaps/default/keymap.c
@@ -0,0 +1,369 @@
+#include QMK_KEYBOARD_H
+
+enum sofle_layers {
+ /* _M_XYZ = Mac Os, _W_XYZ = Win/Linux */
+ _M_QWERTY,
+ _W_QWERTY,
+ _M_COLEMAK,
+ _W_COLEMAK,
+ _M_LOWER,
+ _W_LOWER,
+ _M_RAISE,
+ _W_RAISE,
+ _ADJUST,
+};
+
+enum custom_keycodes {
+ KC_M_QWERTY = SAFE_RANGE,
+ KC_W_QWERTY,
+ KC_M_COLEMAK,
+ KC_W_COLEMAK,
+ KC_M_LOWER,
+ KC_W_LOWER,
+ KC_M_RAISE,
+ KC_W_RAISE,
+ KC_ADJUST,
+};
+
+/* Linux/win variants */
+#define KC_W_UNDO LCTL(KC_Z)
+#define KC_W_CUT LCTL(KC_X)
+#define KC_W_COPY LCTL(KC_C)
+#define KC_W_PASTE LCTL(KC_V)
+#define KC_W_PRVWD LCTL(KC_LEFT)
+#define KC_W_NXTWD LCTL(KC_RIGHT)
+#define KC_W_LSTRT KC_HOME
+#define KC_W_LEND KC_END
+#define KC_W_DLINE LCTL(KC_BSPC)
+
+/* Mac variants */
+#define KC_M_UNDO LGUI(KC_Z)
+#define KC_M_CUT LGUI(KC_X)
+#define KC_M_COPY LGUI(KC_C)
+#define KC_M_PASTE LGUI(KC_V)
+#define KC_M_PRVWD LALT(KC_LEFT)
+#define KC_M_NXTWD LALT(KC_RIGHT)
+#define KC_M_LSTRT LGUI(KC_LEFT)
+#define KC_M_LEND LGUI(KC_RIGHT)
+#define KC_M_DLINE LGUI(KC_BSPC)
+
+#define KC_____ KC_TRNS
+#define KC_XXXX KC_NO
+#define KC_RESET RESET
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+/*
+ * QWERTY
+ * ,-----------------------------------------. ,-----------------------------------------.
+ * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | ` |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | ESC | Q | W | E | R | T | | Y | U | I | O | P | Bspc |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | Tab | A | S | D | F | G |-------. ,-------| H | J | K | L | ; | ' |
+ * |------+------+------+------+------+------| | | |------+------+------+------+------+------|
+ * |LShift| Z | X | C | V | B |-------| |-------| N | M | , | . | / |RShift|
+ * `-----------------------------------------/ / \ \-----------------------------------------'
+ * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI |
+ * | | | | |/ / \ \ | | | | |
+ * `----------------------------------' '------''---------------------------'
+ */
+[_M_QWERTY] = LAYOUT_kc( \
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \
+ ESC, Q, W, E, R, T, Y, U, I, O, P, BSPC, \
+ TAB, A, S, D, F, G, H, J, K, L, SCLN, QUOT, \
+ LSFT, Z, X, C, V, B, MUTE, XXXX, N, M, COMM, DOT, SLSH, RSFT, \
+ LCTRL,LALT,LGUI,M_LOWER, ENT, SPC, M_RAISE, RGUI, RALT, RCTRL \
+),
+[_W_QWERTY] = LAYOUT_kc( \
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \
+ ESC, Q, W, E, R, T, Y, U, I, O, P, BSPC, \
+ TAB, A, S, D, F, G, H, J, K, L, SCLN, QUOT, \
+ LSFT, Z, X, C, V, B, MUTE, XXXX, N, M, COMM, DOT, SLSH, RSFT, \
+ LGUI, LALT,LCTRL,W_LOWER,ENT, SPC, W_RAISE, RCTRL,RALT, RGUI \
+),
+/*
+ * COLEMAK
+ * ,-----------------------------------------. ,-----------------------------------------.
+ * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | ` |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | ESC | Q | W | F | P | G | | J | L | U | Y | ; | Bspc |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | TAB | A | R | S | T | D |-------. ,-------| H | N | E | I | O | ' |
+ * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------|
+ * |LShift| Z | X | C | V | B |-------| |-------| K | M | , | . | / |RShift|
+ * `-----------------------------------------/ / \ \-----------------------------------------'
+ * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI |
+ * | | | | |/ / \ \ | | | | |
+ * `----------------------------------' '------''---------------------------'
+ */
+
+[_M_COLEMAK] = LAYOUT_kc( \
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \
+ ESC, Q, W, F, P, G, J, L, U, Y, SCLN, BSPC, \
+ TAB, A, R, S, T, D, H, N, E, I, O, QUOT, \
+ LSFT, Z, X, C, V, B, MUTE, XXXX, K, M, COMM, DOT, SLSH, RSFT, \
+ LCTRL,LALT,LGUI,M_LOWER, ENT, SPC, M_RAISE, RGUI, RALT, RCTRL \
+),
+[_W_COLEMAK] = LAYOUT_kc( \
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, GRV, \
+ ESC, Q, W, F, P, G, J, L, U, Y, SCLN, BSPC, \
+ TAB, A, R, S, T, D, H, N, E, I, O, QUOT, \
+ LSFT, Z, X, C, V, B, MUTE, XXXX, K, M, COMM, DOT, SLSH, RSFT, \
+ LGUI, LALT,LCTRL,W_LOWER,ENT, SPC, W_RAISE, RCTRL,RALT, RGUI \
+),
+/* LOWER
+ * ,-----------------------------------------. ,-----------------------------------------.
+ * | | F1 | F2 | F3 | F4 | F5 | | F6 | F7 | F8 | F9 | F10 | F11 |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | F12 |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | Tab | ! | @ | # | $ | % |-------. ,-------| ^ | & | * | ( | ) | | |
+ * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------|
+ * | Shift| = | - | + | { | } |-------| |-------| [ | ] | ; | : | \ | Shift|
+ * `-----------------------------------------/ / \ \-----------------------------------------'
+ * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI |
+ * | | | | |/ / \ \ | | | | |
+ * `----------------------------------' '------''---------------------------'
+ */
+[_M_LOWER] = LAYOUT_kc( \
+ ____, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11,\
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, F12, \
+ ____, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, PIPE, \
+ ____, EQL, MINS, PLUS, LCBR, RCBR, ____, ____, LBRC, RBRC, SCLN, COLN, BSLS, ____, \
+ ____, ____, ____, ____, ____, ____, ____, ____, ____, ____\
+),
+[_W_LOWER] = LAYOUT_kc( \
+ ____, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11,\
+ GRV, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, F12, \
+ ____, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, PIPE, \
+ ____, EQL, MINS, PLUS, LCBR, RCBR, ____, ____, LBRC, RBRC, SCLN, COLN, BSLS, ____, \
+ ____, ____, ____, ____, ____, ____, ____, ____, ____, ____\
+),
+/* RAISE
+ * ,----------------------------------------. ,-----------------------------------------.
+ * | | | | | | | | | | | | | |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | Esc | Ins | Pscr | Menu | | | | | PWrd | Up | NWrd | DLine| Bspc |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | Tab | LAt | LCtl |LShift| | Caps |-------. ,-------| | Left | Down | Rigth| Del | Bspc |
+ * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------|
+ * |Shift | Undo | Cut | Copy | Paste| |-------| |-------| | LStr | | LEnd | | Shift|
+ * `-----------------------------------------/ / \ \-----------------------------------------'
+ * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI |
+ * | | | | |/ / \ \ | | | | |
+ * `----------------------------------' '------''---------------------------'
+ */
+[_M_RAISE] = LAYOUT_kc( \
+ ____, ____ , ____ , ____ , ____ , ____, ____, ____ , ____, ____ , ____ ,____, \
+ ____, INS, PSCR, APP, XXXX, XXXX, PGUP, M_PRVWD, UP,M_NXTWD,M_DLINE,BSPC, \
+ ____, LALT, LCTL, LSFT, XXXX, CAPS, PGDN, LEFT, DOWN, RGHT, DEL, BSPC, \
+ ____,M_UNDO, M_CUT,M_COPY,M_PASTE,XXXX, ____, ____, XXXX, M_LSTRT, XXXX, M_LEND, XXXX, ____, \
+ ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \
+),
+[_W_RAISE] = LAYOUT_kc( \
+ ____, ____ , ____ , ____ , ____ , ____, ____, ____ , ____, ____ , ____ , ____, \
+ ____, INS, PSCR, APP, XXXX, XXXX, PGUP, W_PRVWD, UP,W_NXTWD,W_DLINE, BSPC, \
+ ____, LALT, LCTL, LSFT, XXXX, CAPS, PGDN, LEFT, DOWN, RGHT, DEL, BSPC, \
+ ____,W_UNDO, W_CUT,W_COPY,W_PASTE,XXXX, ____, ____, XXXX, W_LSTRT, XXXX, W_LEND, XXXX, ____, \
+ ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \
+),
+/* ADJUST
+ * ,-----------------------------------------. ,-----------------------------------------.
+ * | | | | | | | | | | | | | |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | RESET| |MACQWR|MACCOL| | | | | | | | | |
+ * |------+------+------+------+------+------| |------+------+------+------+------+------|
+ * | | |WINQWR|WINCOL| | |-------. ,-------| | VOLDO| MUTE | VOLUP| | |
+ * |------+------+------+------+------+------| MUTE | | |------+------+------+------+------+------|
+ * | | | | | | |-------| |-------| | PREV | PLAY | NEXT | | |
+ * `-----------------------------------------/ / \ \-----------------------------------------'
+ * | LGUI | LAlt | LCTR |LOWER | /Enter / \Space \ |RAISE | RCTR | RAlt | RGUI |
+ * | | | | |/ / \ \ | | | | |
+ * `----------------------------------' '------''---------------------------'
+ */
+ [_ADJUST] = LAYOUT_kc( \
+ XXXX , XXXX, XXXX , XXXX , XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, \
+ RESET, XXXX,M_QWERTY,M_COLEMAK, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, XXXX, \
+ XXXX , XXXX,W_QWERTY,W_COLEMAK, XXXX, XXXX, XXXX, VOLD, MUTE, VOLU, XXXX, XXXX, \
+ XXXX , XXXX, XXXX , XXXX , XXXX, XXXX, XXXX, XXXX, XXXX, MPRV, MPLY, MNXT, XXXX, XXXX, \
+ ____, ____, ____, ____, ____, ____, ____, ____, ____, ____ \
+ )
+};
+
+#ifdef OLED_DRIVER_ENABLE
+
+static void render_logo(void) {
+ static const char PROGMEM qmk_logo[] = {
+ 0x80,0x81,0x82,0x83,0x84,0x85,0x86,0x87,0x88,0x89,0x8a,0x8b,0x8c,0x8d,0x8e,0x8f,0x90,0x91,0x92,0x93,0x94,
+ 0xa0,0xa1,0xa2,0xa3,0xa4,0xa5,0xa6,0xa7,0xa8,0xa9,0xaa,0xab,0xac,0xad,0xae,0xaf,0xb0,0xb1,0xb2,0xb3,0xb4,
+ 0xc0,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,0xc8,0xc9,0xca,0xcb,0xcc,0xcd,0xce,0xcf,0xd0,0xd1,0xd2,0xd3,0xd4,0
+ };
+
+ oled_write_P(qmk_logo, false);
+}
+
+static void print_status_narrow(void) {
+ // Print current mode
+ oled_write_P(PSTR("\n\n"), false);
+ oled_write_ln_P(PSTR("MODE"), false);
+ oled_write_ln_P(PSTR(""), false);
+ switch (biton32(default_layer_state)) {
+ case _W_QWERTY:
+ oled_write_P(PSTR("Qwrt\nLinux"), false);
+ break;
+ case _M_QWERTY:
+ oled_write_P(PSTR("Qwrt\nMac\n"), false);
+ break;
+ case _W_COLEMAK:
+ oled_write_P(PSTR("Clmk\nLinux"), false);
+ break;
+ case _M_COLEMAK:
+ oled_write_P(PSTR("Clmk\nMac\n"), false);
+ break;
+ default:
+ oled_write_P(PSTR("Undefined\n"), false);
+ }
+ oled_write_P(PSTR("\n\n"), false);
+ // Print current layer
+ oled_write_ln_P(PSTR("LAYER"), false);
+ switch (biton32(layer_state)) {
+ case _M_COLEMAK:
+ case _W_COLEMAK:
+ case _M_QWERTY:
+ case _W_QWERTY:
+ oled_write_P(PSTR("Base\n"), false);
+ break;
+ case _M_RAISE:
+ case _W_RAISE:
+ oled_write_P(PSTR("Raise"), false);
+ break;
+ case _M_LOWER:
+ case _W_LOWER:
+ oled_write_P(PSTR("Lower"), false);
+ break;
+ case _ADJUST:
+ oled_write_P(PSTR("Adj\n"), false);
+ break;
+ default:
+ oled_write_ln_P(PSTR("Undef"), false);
+ }
+ oled_write_P(PSTR("\n\n"), false);
+ uint8_t led_usb_state = host_keyboard_leds();
+ oled_write_ln_P(led_usb_state & (1 << USB_LED_CAPS_LOCK) ? PSTR("CPSLK") : PSTR(" "), false);
+}
+
+oled_rotation_t oled_init_user(oled_rotation_t rotation) {
+ if (is_keyboard_master()) {
+ return OLED_ROTATION_270;
+ }
+ return rotation;
+}
+
+void oled_task_user(void) {
+ if (is_keyboard_master()) {
+ print_status_narrow();
+ } else {
+ render_logo();
+ }
+}
+
+#endif
+
+bool process_record_user(uint16_t keycode, keyrecord_t *record) {
+ switch (keycode) {
+ case KC_W_QWERTY:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_W_QWERTY);
+ }
+ return false;
+ break;
+ case KC_M_QWERTY:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_M_QWERTY);
+ }
+ return false;
+ break;
+ case KC_W_COLEMAK:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_W_COLEMAK);
+ }
+ return false;
+ break;
+ case KC_M_COLEMAK:
+ if (record->event.pressed) {
+ set_single_persistent_default_layer(_M_COLEMAK);
+ }
+ return false;
+ break;
+ case KC_M_LOWER:
+ if (record->event.pressed) {
+ layer_on(_M_LOWER);
+ update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST);
+ } else {
+ layer_off(_M_LOWER);
+ update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST);
+ }
+ return false;
+ break;
+ case KC_M_RAISE:
+ if (record->event.pressed) {
+ layer_on(_M_RAISE);
+ update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST);
+ } else {
+ layer_off(_M_RAISE);
+ update_tri_layer(_M_LOWER, _M_RAISE, _ADJUST);
+ }
+ return false;
+ break;
+ case KC_W_LOWER:
+ if (record->event.pressed) {
+ layer_on(_W_LOWER);
+ update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST);
+ } else {
+ layer_off(_W_LOWER);
+ update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST);
+ }
+ return false;
+ break;
+ case KC_W_RAISE:
+ if (record->event.pressed) {
+ layer_on(_W_RAISE);
+ update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST);
+ } else {
+ layer_off(_W_RAISE);
+ update_tri_layer(_W_LOWER, _W_RAISE, _ADJUST);
+ }
+ return false;
+ break;
+ case KC_ADJUST:
+ if (record->event.pressed) {
+ layer_on(_ADJUST);
+ } else {
+ layer_off(_ADJUST);
+ }
+ return false;
+ break;
+ }
+ return true;
+}
+
+#ifdef ENCODER_ENABLE
+
+void encoder_update_user(uint8_t index, bool clockwise) {
+ if (index == 0) {
+ if (clockwise) {
+ tap_code(KC_VOLU);
+ } else {
+ tap_code(KC_VOLD);
+ }
+ } else if (index == 1) {
+ if (clockwise) {
+ tap_code(KC_PGDOWN);
+ } else {
+ tap_code(KC_PGUP);
+ }
+ }
+}
+
+#endif
+
diff --git a/keyboards/sofle/keymaps/default/readme.md b/keyboards/sofle/keymaps/default/readme.md
new file mode 100644
index 0000000000..e409040ac7
--- /dev/null
+++ b/keyboards/sofle/keymaps/default/readme.md
@@ -0,0 +1,20 @@
+![SofleKeyboard defualt keymap](https://github.com/josefadamcik/SofleKeyboard/raw/master/Images/soflekeyboard.png)
+![SofleKeyboard adjust layer](https://github.com/josefadamcik/SofleKeyboard/raw/master/Images/soflekeyboard_layout_adjust.png)
+
+
+# Default keymap for Sofle Keyboard
+
+Layout in [Keyboard Layout Editor](http://www.keyboard-layout-editor.com/#/gists/76efb423a46cbbea75465cb468eef7ff) and [adjust layer](http://www.keyboard-layout-editor.com/#/gists/4bcf66f922cfd54da20ba04905d56bd4)
+
+
+Features:
+
+- Symmetric modifiers (CMD/Super, Alt/Opt, Ctrl, Shift)
+- Various modes, can be switched (using Adjust layer and the selected one is stored in EEPROM.
+- Modes for Qwerty and Colemak support
+- 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.
+- The OLED on master half shows selected mode and caps lock state and is rotated.
+- Left encoder controls volume up/down/mute. Right encoder PGUP/PGDOWN.
+
+
+
diff --git a/keyboards/sofle/keymaps/default/rules.mk b/keyboards/sofle/keymaps/default/rules.mk
new file mode 100644
index 0000000000..6da1df16fd
--- /dev/null
+++ b/keyboards/sofle/keymaps/default/rules.mk
@@ -0,0 +1,5 @@
+
+OLED_DRIVER_ENABLE = yes
+ENCODER_ENABLE = yes
+CONSOLE_ENABLE = yes
+EXTRAKEY_ENABLE = yes