diff --git a/zmk-config/README.md b/zmk-config/README.md index b78e2120..7af0f67c 100644 --- a/zmk-config/README.md +++ b/zmk-config/README.md @@ -33,12 +33,16 @@ west build --board nice_nano -d build/nibble -- -DSHIELD=nibble -DZMK_CONFIG=/wo west build --board nice_nano -d build/tidbit -- -DSHIELD=tidbit -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config +west build --board nice_nano -d build/corne_artsey_left -- -DSHIELD=corne_artsey_left -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config + west build --board nrf52840_mdk_dongle -d build/pockettype/central -- -DSHIELD=pockettype_central -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config west build --board nice_nano -d build/pockettype/peripheral -- -DSHIELD=pockettype_peripheral -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config west build --board nice_nano -d build/tg4x -- -DSHIELD=tg4x -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config +west build --board nice_nano -d build/corne_left -- -DSHIELD=corne_left -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config + west build --board nice_nano -d build/tidbit_artsey_left -- -DSHIELD=tidbit_artsey_left -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config west build --board nice_nano -d build/steno_right_lily58 -- -DSHIELD=steno_right_lily58 -DZMK_CONFIG=/workspaces/zmk-config/zmk-config/config diff --git a/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.defconfig b/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.defconfig new file mode 100644 index 00000000..52203d08 --- /dev/null +++ b/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.defconfig @@ -0,0 +1,34 @@ +if SHIELD_CORNE_ARTSEY_LEFT + +config ZMK_KEYBOARD_NAME + default "ARTSEY L" + +config I2C + default y + +config SSD1306 + default y + +config SSD1306_REVERSE_MODE + default y + +config LVGL_HOR_RES_MAX + default 128 + +config LVGL_VER_RES_MAX + default 32 + +config LVGL_VDB_SIZE + default 64 + +config LVGL_DPI + default 148 + +config LVGL_BITS_PER_PIXEL + default 1 + +choice LVGL_COLOR_DEPTH + default LVGL_COLOR_DEPTH_1 +endchoice + +endif diff --git a/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.shield b/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.shield new file mode 100755 index 00000000..2934aa84 --- /dev/null +++ b/zmk-config/config/boards/shields/corne_artsey_left/Kconfig.shield @@ -0,0 +1,5 @@ +# Copyright (c) 2020 Pete Johanson +# SPDX-License-Identifier: MIT + +config SHIELD_CORNE_ARTSEY_LEFT + def_bool $(shields_list_contains,corne_artsey_left) diff --git a/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.conf b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.conf new file mode 100755 index 00000000..c1749de5 --- /dev/null +++ b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.conf @@ -0,0 +1,18 @@ +# Copyright (c) 2020 The ZMK Contributors +# SPDX-License-Identifier: MIT + +# Tune combos to allow proper ARTSEY support +CONFIG_ZMK_COMBO_MAX_COMBOS_PER_KEY=16 +CONFIG_ZMK_COMBO_MAX_KEYS_PER_COMBO=8 +CONFIG_ZMK_COMBO_MAX_PRESSED_COMBOS=8 + +# Enable Encoders +#CONFIG_EC11=y +#CONFIG_EC11_TRIGGER_GLOBAL_THREAD=y + +# Enable display (layer in use is helpful) +CONFIG_ZMK_DISPLAY=y + +# Enable WPM widget +#CONFIG_ZMK_WPM=y +CONFIG_ZMK_WIDGET_WPM_STATUS=y diff --git a/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.keymap b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.keymap new file mode 100644 index 00000000..e334d53c --- /dev/null +++ b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.keymap @@ -0,0 +1,99 @@ +/* + * Copyright (c) 2020 The ZMK Contributors + * + * SPDX-License-Identifier: MIT + */ + +#include +#include +#include + +// ARTS Row +#define KEY_A 4 +#define KEY_R 3 +#define KEY_T 2 +#define KEY_S 1 +// EYIO Row +#define KEY_E 10 +#define KEY_Y 9 +#define KEY_I 8 +#define KEY_O 7 + +#include "../../../artsey.dtsi" + +/ { + keymap { + compatible = "zmk,keymap"; + base { + label = "ARTSEY"; + bindings = < + &none + &layer_numbers_kp LAYER_ID_NUMBERS S &kp T &kp R &layer_parentheticals_kp LAYER_ID_PARENTHETICALS A + &none &none + &layer_navigation_kp LAYER_ID_NAVIGATION O &kp I &kp Y &layer_symbols_kp LAYER_ID_SYMBOLS E + &none &none &none &none &none &none &none + &bt BT_CLR &bt BT_PRV &bt BT_NXT + >; + }; + numbers { + label = "Number"; + bindings = < + &none + &layer_base_sl LAYER_ID_BASE LAYER_ID_F_ONE_SIX &kp N3 &kp N2 &layer_parentheticals_kp LAYER_ID_PARENTHETICALS N1 + &none &none + &layer_navigation_sl LAYER_ID_NAVIGATION LAYER_ID_F_SEVEN_TWELVE &kp N6 &kp N5 &layer_symbols_kp LAYER_ID_SYMBOLS N4 + &none &none &none &none &none &none &none &none &none &none + >; + }; + symbols { + label = "Symbol"; + bindings = < + &none + &layer_numbers_kp LAYER_ID_NUMBERS GRAVE &kp SEMI &kp BSLH &layer_parentheticals_none LAYER_ID_PARENTHETICALS 0 + &none &none + &layer_navigation_none LAYER_ID_NAVIGATION 0 &kp EQUAL &kp MINUS &layer_base_none LAYER_ID_BASE 0 + &none &none &none &none &none &none &none &none &none &none + >; + }; + parentheticals { + label = "Paren"; + bindings = < + &none + &layer_numbers_kp LAYER_ID_NUMBERS LBRC &kp LPAR &kp RPAR &layer_base_none LAYER_ID_BASE 0 + &none &none + &layer_navigation_kp LAYER_ID_NAVIGATION RBRC &kp LBKT &kp RBKT &layer_symbols_none LAYER_ID_SYMBOLS 0 + &none &none &none &none &none &none &none &none &none &none + >; + }; + navigation { + label = "Nav"; + bindings = < + &none + &layer_numbers_kp LAYER_ID_NUMBERS PG_UP &kp HOME &kp UP &layer_parentheticals_kp LAYER_ID_PARENTHETICALS END + &none &none + &layer_base_kp LAYER_ID_BASE PG_DN &kp LEFT &kp DOWN &layer_symbols_kp LAYER_ID_SYMBOLS RIGHT + &none &none &none &none &none &none &none &none &none &none + >; + }; + f_one_to_six{ + label = "F1-F6"; + bindings = < + &none + &layer_numbers_none LAYER_ID_NUMBERS 0 &kp F3 &kp F2 &layer_parentheticals_kp LAYER_ID_PARENTHETICALS F1 + &none &none + &layer_navigation_none LAYER_ID_NAVIGATION 0 &kp F6 &kp F5 &layer_symbols_kp LAYER_ID_SYMBOLS F4 + &none &none &none &none &none &none &none &none &none &none + >; + }; + f_seven_to_twelve { + label = "F7-F12"; + bindings = < + &none + &layer_numbers_none LAYER_ID_NUMBERS 0 &kp F9 &kp F8 &layer_parentheticals_kp LAYER_ID_PARENTHETICALS F7 + &none &none + &layer_navigation_none LAYER_ID_NAVIGATION 0 &kp F12 &kp F11 &layer_symbols_kp LAYER_ID_SYMBOLS F10 + &none &none &none &none &none &none &none &none &none &none + >; + }; + }; +}; diff --git a/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.overlay b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.overlay new file mode 100644 index 00000000..d3007dce --- /dev/null +++ b/zmk-config/config/boards/shields/corne_artsey_left/corne_artsey_left.overlay @@ -0,0 +1,74 @@ +/* + * Copyright (c) 2020 Pete Johanson + * + * SPDX-License-Identifier: MIT + */ + +#include + +/ { + chosen { + zmk,kscan = &kscan0; + zmk,matrix_transform = &default_transform; + }; + + default_transform: keymap_transform_0 { + compatible = "zmk,matrix-transform"; + columns = <6>; + rows = <4>; +// | SW1 | SW2 | SW3 | SW4 | SW5 | SW6 | +// | SW7 | SW8 | SW9 | SW10 | SW11 | SW12 | +// | SW13 | SW14 | SW15 | SW16 | SW17 | SW18 | +// | SW19 | SW20 | SW21 | + map = < +RC(0,0) RC(0,1) RC(0,2) RC(0,3) RC(0,4) RC(0,5) +RC(1,0) RC(1,1) RC(1,2) RC(1,3) RC(1,4) RC(1,5) +RC(2,0) RC(2,1) RC(2,2) RC(2,3) RC(2,4) RC(2,5) + RC(3,3) RC(3,4) RC(3,5) + >; + }; + + kscan0: kscan { + compatible = "zmk,kscan-gpio-matrix"; + label = "KSCAN"; + + diode-direction = "col2row"; + row-gpios + = <&pro_micro_d 4 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 5 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 6 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + , <&pro_micro_d 7 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)> + ; + + col-gpios + = <&pro_micro_a 3 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 2 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 1 GPIO_ACTIVE_HIGH> + , <&pro_micro_a 0 GPIO_ACTIVE_HIGH> + , <&pro_micro_d 15 GPIO_ACTIVE_HIGH> + , <&pro_micro_d 14 GPIO_ACTIVE_HIGH> + ; + }; + + // TODO: per-key RGB node(s)? +}; + +&pro_micro_i2c { + status = "okay"; + + oled: ssd1306@3c { + compatible = "solomon,ssd1306fb"; + reg = <0x3c>; + label = "DISPLAY"; + width = <128>; + height = <32>; + segment-offset = <0>; + page-offset = <0>; + display-offset = <0>; + multiplex-ratio = <31>; + segment-remap; + com-invdir; + com-sequential; + prechargep = <0x22>; + }; +};