Merge remote-tracking branch 'origin/master' into develop
9 files changed, 182 insertions(+), 132 deletions(-) M keyboards/tau4/common/glcdfont.c -rwxr-xr-x => -rw-r--r-- M keyboards/tau4/config.h -rwxr-xr-x => -rw-r--r-- M keyboards/tau4/info.json M keyboards/tau4/keymaps/default/keymap.c A keyboards/tau4/keymaps/default/rules.mk M keyboards/tau4/readme.md M keyboards/tau4/rules.mk -rwxr-xr-x => -rw-r--r-- M keyboards/tau4/tau4.c -rwxr-xr-x => -rw-r--r-- D keyboards/tau4/tau4.h
M keyboards/tau4/common/glcdfont.c => keyboards/tau4/common/glcdfont.c +0 -0
M keyboards/tau4/config.h => keyboards/tau4/config.h +2 -32
@@ 19,35 19,6 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. #include "config_common.h" /* key matrix size */ #define MATRIX_ROWS 4 #define MATRIX_COLS 12 /* key matrix pins */ #define MATRIX_ROW_PINS { F4, F5, F6, F7 } #define MATRIX_COL_PINS { D4, D6, D7, B4, B5, B6, C6, C7, F1, F0, B0, B1 } /* COL2ROW or ROW2COL */ #define DIODE_DIRECTION COL2ROW /* Set 0 if debouncing isn't needed */ #define DEBOUNCE 5 #define RGB_DI_PIN B2 #ifdef RGB_DI_PIN #define RGBLIGHT_ANIMATIONS #define RGBLIGHT_LAYERS #define RGBLED_NUM 10 #define RGBLIGHT_HUE_STEP 8 #define RGBLIGHT_SAT_STEP 16 #define RGBLIGHT_VAL_STEP 8 #define RGBLIGHT_LIMIT_VAL 128 #endif #define ENCODERS_PAD_A { B3 } #define ENCODERS_PAD_B { B7 } #define ENCODER_RESOLUTION 1 // Buggy, currently disabled /* #define EXTERNAL_EEPROM_I2C_BASE_ADDRESS 0b10100000 @@ #define EXTERNAL_EEPROM_I2C_ADDRESS(loc) (EXTERNAL_EEPROM_I2C_BASE_ADDRESS | ((((loc) >> 8) & 0x07) << 1)) 56,9 27,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. #define EXTERNAL_EEPROM_ADDRESS_SIZE 1 #define EXTERNAL_EEPROM_WRITE_TIME 5 */ #define OLED_DISPLAY_ADDRESS 0x3C #define OLED_BRIGHTNESS 255 #define OLED_IC OLED_IC_SSD1306 #define RGBLIGHT_LAYERS_RETAIN_VAL #define OLED_DISPLAY_WIDTH 128 #define OLED_DISPLAY_HEIGHT 32 #define OLED_FONT_H "keyboards/tau4/common/glcdfont.c"
M keyboards/tau4/info.json => keyboards/tau4/info.json +110 -1
@@ 1,11 1,120 @@ { "keyboard_name": "tau4", "manufacturer": "taukeyboards", "url": "", "url": "https://gaskell.tech/tau/four.html", "maintainer": "qmk", "usb": { "vid": "0xFEED", "pid": "0x6060", "device_version": "0.0.1" }, "bootloader": "atmel-dfu", "build": { "lto": true }, "matrix_pins": { "rows": [ "F4", "F5", "F6", "F7" ], "cols": [ "D4", "D6", "D7", "B4", "B5", "B6", "C6", "C7", "F1", "F0", "B0", "B1" ] }, "processor": "atmega32u4", "features": { "bootmagic": true, "encoder": true, "extrakey": true, "mousekey": true, "nkro": true, "oled": true, "rgblight": true }, "community_layouts": [ "ortho_4x12" ], "diode_direction": "COL2ROW", "encoder": { "rotary": [ { "pin_a": "B3", "pin_b": "B7", "resolution": 1 } ] }, "rgblight": { "animations": { "alternating": true, "breathing": true, "christmas": true, "knight": true, "rainbow_mood": true, "rainbow_swirl": true, "rgb_test": true, "snake": true, "static_gradient": true, "twinkle": true }, "brightness_steps": 8, "hue_steps": 8, "layers": { "blink": false, "enabled": true, "max": 5, "override_rgb": false }, "led_count": 10, "max_brightness": 128, "pin": "B2", "saturation_steps": 16, "sleep": true }, "layouts": { "LAYOUT_ortho_4x12": { "layout": [ {"label": "Mute", "matrix": [0, 0], "x":0, "y":0}, {"label": "Q", "matrix": [0, 1], "x":1, "y":0}, {"label": "W", "matrix": [0, 2], "x":2, "y":0}, {"label": "E", "matrix": [0, 3], "x":3, "y":0}, {"label": "R", "matrix": [0, 4], "x":4, "y":0}, {"label": "T", "matrix": [0, 5], "x":5, "y":0}, {"label": "Y", "matrix": [0, 6], "x":6, "y":0}, {"label": "U", "matrix": [0, 7], "x":7, "y":0}, {"label": "I", "matrix": [0, 8], "x":8, "y":0}, {"label": "O", "matrix": [0, 9], "x":9, "y":0}, {"label": "P", "matrix": [0, 10], "x":10, "y":0}, {"label": "Backspace", "matrix": [0, 11], "x":11, "y":0}, {"label": "Esc", "matrix": [1, 0], "x":0, "y":1}, {"label": "A", "matrix": [1, 1], "x":1, "y":1}, {"label": "S", "matrix": [1, 2], "x":2, "y":1}, {"label": "D", "matrix": [1, 3], "x":3, "y":1}, {"label": "F", "matrix": [1, 4], "x":4, "y":1}, {"label": "G", "matrix": [1, 5], "x":5, "y":1}, {"label": "H", "matrix": [1, 6], "x":6, "y":1}, {"label": "J", "matrix": [1, 7], "x":7, "y":1}, {"label": "K", "matrix": [1, 8], "x":8, "y":1}, {"label": "L", "matrix": [1, 9], "x":9, "y":1}, {"label": ";:", "matrix": [1, 10], "x":10, "y":1}, {"label": "'\"", "matrix": [1, 11], "x":11, "y":1}, {"label": "Shift", "matrix": [2, 0], "x":0, "y":2}, {"label": "Z", "matrix": [2, 1], "x":1, "y":2}, {"label": "X", "matrix": [2, 2], "x":2, "y":2}, {"label": "C", "matrix": [2, 3], "x":3, "y":2}, {"label": "V", "matrix": [2, 4], "x":4, "y":2}, {"label": "B", "matrix": [2, 5], "x":5, "y":2}, {"label": "N", "matrix": [2, 6], "x":6, "y":2}, {"label": "M", "matrix": [2, 7], "x":7, "y":2}, {"label": ",<", "matrix": [2, 8], "x":8, "y":2}, {"label": ".>", "matrix": [2, 9], "x":9, "y":2}, {"label": "/?", "matrix": [2, 10], "x":10, "y":2}, {"label": "Enter", "matrix": [2, 11], "x":11, "y":2}, {"label": "Backspace", "matrix": [3, 0], "x":0, "y":3}, {"label": "Ctrl", "matrix": [3, 1], "x":1, "y":3}, {"label": "GUI", "matrix": [3, 2], "x":2, "y":3}, {"label": "Alt", "matrix": [3, 3], "x":3, "y":3}, {"label": "Lower", "matrix": [3, 4], "x":4, "y":3}, {"label": "Space", "matrix": [3, 5], "x":5, "y":3}, {"label": "Space", "matrix": [3, 6], "x":6, "y":3}, {"label": "Raise", "matrix": [3, 7], "x":7, "y":3}, {"label": "Left", "matrix": [3, 8], "x":8, "y":3}, {"label": "Down", "matrix": [3, 9], "x":9, "y":3}, {"label": "Up", "matrix": [3, 10], "x":10, "y":3}, {"label": "Right", "matrix": [3, 11], "x":11, "y":3} ] } } }
M keyboards/tau4/keymaps/default/keymap.c => keyboards/tau4/keymaps/default/keymap.c +12 -45
@@ 85,8 85,10 @@ void keyboard_post_init_user(void) { rgblight_layers = my_rgb_layers; // Uncomment for debug mode /* debug_enable=true; debug_matrix=true; */ //debug_enable=true; //debug_matrix=true; //debug_keyboard=true; //debug_mouse=true; } @@ layer_state_t layer_state_set_user(layer_state_t state) { 101,47 103,12 @@ layer_state_t layer_state_set_user(layer_state_t state) { return state; } bool encoder_update_user(uint8_t index, bool clockwise) { if (index == 0) { /* First encoder */ if (clockwise) { tap_code(KC_VOLU); } else { tap_code(KC_VOLD); } } return true; } #ifdef OLED_ENABLE static void render_status(void) { oled_write_P(PSTR("Tau.4 v1.0\n\n"), false); oled_write_P(PSTR("Layer:\n"), false); switch (get_highest_layer(layer_state)) { case _QWERTY: oled_write_P(PSTR("Default "), false); break; case _NUMPAD: oled_write_P(PSTR("Numpad "), false); break; case _LOWER: oled_write_P(PSTR("Lower "), false); break; case _RAISE: oled_write_P(PSTR("Raise "), false); break; case _ADJUST: oled_write_P(PSTR("Adjust "), false); break; default: oled_write_P(PSTR("Undefined"), false); } } bool oled_task_user(void) { render_status(); return false; } #ifdef ENCODER_MAP_ENABLE const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = { [_QWERTY] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU) }, [_NUMPAD] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, [_LOWER] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, [_RAISE] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, [_ADJUST] = { ENCODER_CCW_CW(KC_TRNS, KC_TRNS) }, }; #endif
A keyboards/tau4/keymaps/default/rules.mk => keyboards/tau4/keymaps/default/rules.mk +1 -0
M keyboards/tau4/readme.md => keyboards/tau4/readme.md +12 -2
@@ 6,11 6,21 @@ A 40% ortholinear keyboard, developed by Oliver Gaskell. More info on [gaskell.t * Keyboard Maintainer: [Oliver Gaskell](https://github.com/ogaskell) * Hardware Supported: Tau4 PCB rev1.0, Tau4 PCB rev1.1 * Hardware Availability: Group Buy - Opens 05 Feb 2021 [More Details](https://gaskell.tech/tau/four.html) * Hardware Availability: Group Buy took place between 05 Feb 2021 to 05 Mar 2021. [More Details](https://gaskell.tech/tau/four.html) Make example for this keyboard (after setting up your build environment): make tau4:default Flashing example for this keyboard: make tau4:default:flash 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). ## Bootloader Enter the bootloader in 2 ways: * **Bootmagic reset**: Hold down the top left key and plug in the keyboard. (If you built with an encoder in the top left, the "key" will be that encoder.) This will also clear EEPROM, so it is a good first step if the keyboard is misbehaving. * **Keycode in layout**: By default, `QK_BOOT` is assigned to the top right key on the `ADJUST` (fifth) layer.
M keyboards/tau4/rules.mk => keyboards/tau4/rules.mk +1 -19
@@ 1,25 1,7 @@ # MCU name MCU = atmega32u4 # Bootloader selection BOOTLOADER = atmel-dfu # Build Options # change yes to no to disable # BOOTMAGIC_ENABLE = no # Enable Bootmagic Lite MOUSEKEY_ENABLE = no # Mouse keys EXTRAKEY_ENABLE = yes # Audio control and System control CONSOLE_ENABLE = no # Console for debug COMMAND_ENABLE = no # Commands for debug and configuration NKRO_ENABLE = yes # Enable N-Key Rollover BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow AUDIO_ENABLE = no # Audio output ENCODER_ENABLE = yes # Rotary Encoder support OLED_ENABLE = yes OLED_DRIVER = SSD1306 # OLED display support # EEPROM_DRIVER ?= i2c # Driver for external EEPROM chip # This is currently not working due to QMK not officially supporting the chip used on the Tau4, I am working on a fix. LAYOUTS = ortho_4x12
M keyboards/tau4/tau4.c => keyboards/tau4/tau4.c +44 -1
@@ 15,4 15,47 @@ You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #include "tau4.h" #include "quantum.h" #ifdef ENCODER_ENABLE bool encoder_update_kb(uint8_t index, bool clockwise) { if (!encoder_update_user(index, clockwise)) { return false; } if (index == 0) { /* First encoder */ if (clockwise) { tap_code(KC_VOLU); } else { tap_code(KC_VOLD); } } return true; } #endif #ifdef OLED_ENABLE bool oled_task_kb(void) { if (!oled_task_user()) { return false; } oled_write_P(PSTR("Tau.4 v1.0\n\n"), false); oled_write_P(PSTR("Layer:\n"), false); switch (get_highest_layer(layer_state)) { case 0: oled_write_P(PSTR("Default "), false); break; case 1: oled_write_P(PSTR("Numpad "), false); break; case 2: oled_write_P(PSTR("Lower "), false); break; case 3: oled_write_P(PSTR("Raise "), false); break; case 4: oled_write_P(PSTR("Adjust "), false); break; default: oled_write_P(PSTR("Undefined"), false); } return true; } #endif
D keyboards/tau4/tau4.h => keyboards/tau4/tau4.h +0 -32
@@ 1,32 0,0 @@ /* Copyright 2020 Oliver Gaskell <me@gaskell.tech> This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #pragma once #include "quantum.h" #define LAYOUT_ortho_4x12( \ K000, K001, K002, K003, K004, K005, K006, K007, K008, K009, K010, K011, \ K100, K101, K102, K103, K104, K105, K106, K107, K108, K109, K110, K111, \ K200, K201, K202, K203, K204, K205, K206, K207, K208, K209, K210, K211, \ K300, K301, K302, K303, K304, K305, K306, K307, K308, K309, K310, K311 \ ) { \ { K000, K001, K002, K003, K004, K005, K006, K007, K008, K009, K010, K011 }, \ { K100, K101, K102, K103, K104, K105, K106, K107, K108, K109, K110, K111 }, \ { K200, K201, K202, K203, K204, K205, K206, K207, K208, K209, K210, K211 }, \ { K300, K301, K302, K303, K304, K305, K306, K307, K308, K309, K310, K311 } \ }