From 2a2d19d3954e115e2b15ec3b7d2ab89e3f9e9c8e Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Mon, 5 Jul 2021 22:49:28 -0500 Subject: [PATCH 01/22] Userspace: muppetjones (#1) Add and update lily58 to work with userspace Add and update kyria keymap to work with userspace Add and update planck keymap with userspace Add etchamouse code and docs to userpace Add userspace Update mouse encoder for smoother movement. Encoder + mouse Added casemodes by andrewjrae --- .../kyria/keymaps/muppetjones/.clang-format | 26 ++ keyboards/kyria/keymaps/muppetjones/README.md | 11 + keyboards/kyria/keymaps/muppetjones/config.h | 68 +++ keyboards/kyria/keymaps/muppetjones/keymap.c | 307 ++++++++++++ keyboards/kyria/keymaps/muppetjones/rules.mk | 14 + .../lily58/keymaps/muppetjones/README.md | 5 + keyboards/lily58/keymaps/muppetjones/config.h | 71 +++ .../keymaps/muppetjones/features/bongo_cat.c | 135 ++++++ keyboards/lily58/keymaps/muppetjones/keymap.c | 245 ++++++++++ keyboards/lily58/keymaps/muppetjones/rules.mk | 42 ++ keyboards/lily58/lib/layer_state_reader.c | 9 +- .../planck/keymaps/muppetjones/.clang-format | 26 ++ keyboards/planck/keymaps/muppetjones/config.h | 49 ++ keyboards/planck/keymaps/muppetjones/keymap.c | 441 ++++++++++++++++++ .../planck/keymaps/muppetjones/readme.md | 2 + keyboards/planck/keymaps/muppetjones/rules.mk | 4 + users/muppetjones/.clang-format | 26 ++ users/muppetjones/README.md | 23 + users/muppetjones/config.h | 34 ++ users/muppetjones/features/casemodes.c | 263 +++++++++++ users/muppetjones/features/casemodes.h | 47 ++ users/muppetjones/features/dancelayers.c | 103 ++++ users/muppetjones/features/dancelayers.h | 81 ++++ users/muppetjones/features/etchamouse.c | 136 ++++++ users/muppetjones/features/etchamouse.h | 61 +++ users/muppetjones/features/rgblayers.c | 15 + users/muppetjones/features/rgblayers.h | 15 + users/muppetjones/muppetjones.c | 57 +++ users/muppetjones/muppetjones.h | 51 ++ users/muppetjones/readme/dancelayers.md | 73 +++ users/muppetjones/readme/etchamouse.md | 69 +++ users/muppetjones/readme/rgblayers.md | 0 users/muppetjones/readme/tapmods.md | 25 + users/muppetjones/rules.mk | 17 + users/muppetjones/tapmods.h | 57 +++ users/muppetjones/wrappers.h | 110 +++++ 36 files changed, 2715 insertions(+), 3 deletions(-) create mode 100644 keyboards/kyria/keymaps/muppetjones/.clang-format create mode 100644 keyboards/kyria/keymaps/muppetjones/README.md create mode 100644 keyboards/kyria/keymaps/muppetjones/config.h create mode 100644 keyboards/kyria/keymaps/muppetjones/keymap.c create mode 100644 keyboards/kyria/keymaps/muppetjones/rules.mk create mode 100644 keyboards/lily58/keymaps/muppetjones/README.md create mode 100644 keyboards/lily58/keymaps/muppetjones/config.h create mode 100644 keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c create mode 100644 keyboards/lily58/keymaps/muppetjones/keymap.c create mode 100644 keyboards/lily58/keymaps/muppetjones/rules.mk create mode 100644 keyboards/planck/keymaps/muppetjones/.clang-format create mode 100644 keyboards/planck/keymaps/muppetjones/config.h create mode 100644 keyboards/planck/keymaps/muppetjones/keymap.c create mode 100644 keyboards/planck/keymaps/muppetjones/readme.md create mode 100644 keyboards/planck/keymaps/muppetjones/rules.mk create mode 100644 users/muppetjones/.clang-format create mode 100644 users/muppetjones/README.md create mode 100644 users/muppetjones/config.h create mode 100644 users/muppetjones/features/casemodes.c create mode 100644 users/muppetjones/features/casemodes.h create mode 100644 users/muppetjones/features/dancelayers.c create mode 100644 users/muppetjones/features/dancelayers.h create mode 100644 users/muppetjones/features/etchamouse.c create mode 100644 users/muppetjones/features/etchamouse.h create mode 100644 users/muppetjones/features/rgblayers.c create mode 100644 users/muppetjones/features/rgblayers.h create mode 100644 users/muppetjones/muppetjones.c create mode 100644 users/muppetjones/muppetjones.h create mode 100644 users/muppetjones/readme/dancelayers.md create mode 100644 users/muppetjones/readme/etchamouse.md create mode 100644 users/muppetjones/readme/rgblayers.md create mode 100644 users/muppetjones/readme/tapmods.md create mode 100644 users/muppetjones/rules.mk create mode 100644 users/muppetjones/tapmods.h create mode 100644 users/muppetjones/wrappers.h diff --git a/keyboards/kyria/keymaps/muppetjones/.clang-format b/keyboards/kyria/keymaps/muppetjones/.clang-format new file mode 100644 index 000000000000..df3dbd17b4ca --- /dev/null +++ b/keyboards/kyria/keymaps/muppetjones/.clang-format @@ -0,0 +1,26 @@ +--- +BasedOnStyle: Google +AlignAfterOpenBracket: Align +AlignConsecutiveAssignments: 'true' +AlignConsecutiveDeclarations: 'true' +AlignOperands: 'true' +AllowAllParametersOfDeclarationOnNextLine: 'false' +AlwaysBreakAfterDefinitionReturnType: None +AlwaysBreakAfterReturnType: None +AlwaysBreakBeforeMultilineStrings: 'false' +BinPackArguments: 'true' +BinPackParameters: 'true' +ColumnLimit: '160' +IndentCaseLabels: 'true' +IndentPPDirectives: AfterHash +IndentWidth: '4' +MaxEmptyLinesToKeep: '1' +PointerAlignment: Right +SortIncludes: 'false' +SpaceBeforeAssignmentOperators: 'true' +SpaceBeforeParens: ControlStatements +SpaceInEmptyParentheses: 'false' +TabWidth: '4' +UseTab: Never + +... diff --git a/keyboards/kyria/keymaps/muppetjones/README.md b/keyboards/kyria/keymaps/muppetjones/README.md new file mode 100644 index 000000000000..663ccdc77cee --- /dev/null +++ b/keyboards/kyria/keymaps/muppetjones/README.md @@ -0,0 +1,11 @@ +# Kyria + +## Compile + +```shell +make kyria:muppetjones:avrdude-split-left +``` + +```shell +make kyria:muppetjones:avrdude-split-right +``` diff --git a/keyboards/kyria/keymaps/muppetjones/config.h b/keyboards/kyria/keymaps/muppetjones/config.h new file mode 100644 index 000000000000..631b591113fe --- /dev/null +++ b/keyboards/kyria/keymaps/muppetjones/config.h @@ -0,0 +1,68 @@ +/* Copyright 2020 Stephen Bush + * + * 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 . + */ + +#pragma once + +#ifdef OLED_DRIVER_ENABLE +# define OLED_DISPLAY_128X64 +#endif + +#ifdef RGBLIGHT_ENABLE +// # define RGBLIGHT_ANIMATIONS +# define RGBLIGHT_HUE_STEP 8 +# define RGBLIGHT_SAT_STEP 16 +# define RGBLIGHT_VAL_STEP 16 +# define RGBLIGHT_LIMIT_VAL 150 +# define RGBLIGHT_SLEEP +// # define RGBLIGHT_LAYERS +#endif + +// If you are using an Elite C rev3 on the slave side, uncomment the lines below: +// #define SPLIT_USB_DETECT +// #define NO_USB_STARTUP_CHECK + +// EC11K encoders have a different resolution than other EC11 encoders. +// When using the default resolution of 4, if you notice your encoder skipping +// every other tick, lower the resolution to 2. +#define ENCODER_RESOLUTION 2 +#define ENCODER_DIRECTION_FLIP + +// The Leader key allows to flexibly assign macros to key sequences. +#define LEADER_PER_KEY_TIMING +#define LEADER_TIMEOUT 350 + +// Change "hold" time (default is 200 ms) +// -- used for tap dance and other tap mods +#define TAPPING_TERM 200 + +// Prevent normal rollover on alphas from accidentally triggering mods. +#define IGNORE_MOD_TAP_INTERRUPT + +// Enable rapid switch from tap to hold, disables double tap hold auto-repeat. +#define TAPPING_FORCE_HOLD + +// Reduce firmware size +// https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +// also requires EXTRAFLAGS in config.h +#define NO_ACTION_MACRO +#define NO_ACTION_FUNCTION + +// Allows to use either side as the master. Look at the documentation for info: +// https://docs.qmk.fm/#/config_options?id=setting-handedness +#define EE_HANDS + +// Allows media codes to properly register in macros and rotary encoder code +#define TAP_CODE_DELAY 10 diff --git a/keyboards/kyria/keymaps/muppetjones/keymap.c b/keyboards/kyria/keymaps/muppetjones/keymap.c new file mode 100644 index 000000000000..b3b8b9a7d380 --- /dev/null +++ b/keyboards/kyria/keymaps/muppetjones/keymap.c @@ -0,0 +1,307 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ +#include QMK_KEYBOARD_H +#include "muppetjones.h" +#include "rgblight.h" + +#define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) + +/* Layers from muppetjones.h + _CLMK_DH = 0, + _MOUSE, + _LOWER, + _RAISE, + _NAV, + _ADJUST, + */ + +/* + * Custom Keys + */ + +#ifdef ENCODER_ENABLE +bool encoder_update_standard(uint8_t index, bool clockwise); +#endif + +#ifdef RGBLIGHT_ENABLE +static rgblight_config_t home_rgb; + +void set_rgb_home(void); +void set_rgb_by_layer(layer_state_t); +#endif + +/* + * LAYERS + */ + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // clang-format off +/* + * Base Layer: Colemak DH + * + * ,-------------------------------------------. ,-------------------------------------------. + * |CAPSWORD| Q | W | F | P | B | | J | L | U | Y | ; : | | \ | + * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + * |ESC/HYPR| A | R | S | T | G | | M | N | E | I | O | ' " | + * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + * | LShift | Z | X | C | D | V |LShift|Leader| | Del | Tab | K | H | , < | . > | / ? | Sft/Ent| + * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + * | MUTE | Del | Enter| Space| Enter| | Bspc | Space| Hyper| Tab | AltGr| + * | | | Alt | Lower| Raise| | | Nav | Esc | Raise| | + * `----------------------------------' `----------------------------------' + */ +[_CLMK_DH] = LAYOUT_wrapper( + CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, + HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, + TD_LAYR, __COLEMAK_MOD_DH_L3________________________, KC_LSFT, KC_LEAD, KC_DEL, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, + KC_MUTE, KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, RAI_TAB, KC_RALT +), +[_QWERTY] = LAYOUT_wrapper( + _______, __QWERTY_L1________________________________, __QWERTY_R1________________________________, _______, + _______, __QWERTY_L2________________________________, __QWERTY_R2________________________________, _______, + _______, __QWERTY_L3________________________________, _______, _______, _______, _______, __QWERTY_R3________________________________, _______, + __BLANK____________________________________, __BLANK____________________________________ +), +[_MOUSE] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, _______, _______, _______, _______, __BLANK____________________________________, _______, + KC_BTN1, _______, _______, _______, _______, _______, _______, _______, _______, KC_BTN2 +), +/* + * Lower Layer: Numpad + * + * ,-------------------------------------------. ,-------------------------------------------. + * | | | | | | | | / ? | 7 & | 8 * | 9 ( | - _ | | + * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + * | | GUI | ALT | CTL | SFT | | | * | 4 $ | 5 % | 6 ^ | , < | + | + * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + * | | | | | | | | | | | | 0 ) | 1 ! | 2 @ | 3 # | = + | | + * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + * | | | | | | | | | | | | + * | | | Lower| | | | | Nav | 0 | . | | + * `----------------------------------' `----------------------------------' + */ + [_LOWER] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __NUMPAD_R1________________________________, _______, + _______, __BLANK_W_GACS_____________________________, __NUMPAD_R2________________________________, KC_PLUS, + _______, __BLANK____________________________________, _______, _______, _______, _______, __NUMPAD_R3________________________________, _______, + __BLANK____________________________________, _______, _______, KC_0, KC_DOT, _______ + ), +/* + * Raise Layer: Symbols + * + * ,-------------------------------------------. ,-------------------------------------------. + * | | ! | @ | { | } | | | | | & | € | | | \ | + * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + * | | # | $ | ( | ) | ` | | _ | - | / | * | % | ' " | + * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + * | | % | ^ | [ | ] | ~ | | | | | | + | = | , | . | / ? | - _ | + * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + * | | | | | | | | | | | | + * | | | Lower| | | | | Nav | Raise| | | + * `----------------------------------' `----------------------------------' + */ + // [_RAISE] = LAYOUT( + // _______, KC_EXLM, KC_AT, KC_LPRN, KC_RPRN, KC_PIPE, _______, KC_AMPR, _______, _______, _______, KC_BSLS, + // _______, KC_HASH, KC_DLR, KC_LBRC, KC_RBRC, KC_GRV, KC_UNDS, KC_MINS, KC_SLSH, KC_ASTR, KC_PERC, KC_QUOT, + // _______, KC_PERC, KC_CIRC, KC_LCBR, KC_RCBR, KC_TILD, _______, _______, _______, _______, KC_PLUS, KC_EQL, KC_COMM, KC_DOT, KC_SLSH, KC_MINS, + // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ + // ), + [_RAISE] = LAYOUT_wrapper( + _______, _______, _______, KC_GRV, KC_GRV, KC_BSLS, _______, KC_LPRN, KC_RPRN, KC_ASTR, _______, _______, + _______, _______, _______, KC_UNDS, KC_MINS, KC_TILD, KC_UNDS, KC_LBRC, KC_RBRC, KC_PERC, _______, _______, + _______, _______, _______, _______, KC_EQL, _______, _______, _______, _______, _______, _______, KC_LCBR, KC_RCBR, _______, _______, _______, + __BLANK____________________________________, __BLANK____________________________________ + ), +/* + * Navigation Layer + * + * ,-------------------------------------------. ,-------------------------------------------. + * | | | | | | | | PgUp | Home | Up | End | | ScrlLk | + * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + * | | GUI | ALT | CTL | SFT | | | PgDn | Left | Down | Up | Right| CapsLk | + * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + * | | | | | | | | | | | | | | | | | | + * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + * | | | | | | | | | | | | + * | | | Lower| | | | | Nav | Raise| | | + * `----------------------------------' `----------------------------------' + */ + [_NAV] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __NAV_R1___________________________________, KC_SLCK, + _______, __BLANK_W_GACS_____________________________, __NAV_R2___________________________________, KC_CAPS, + _______, __BLANK____________________________________, _______, _______, _______, _______, __NAV_R3___________________________________, _______, + __BLANK____________________________________, __BLANK____________________________________ + ), + /* + * Adjust Layer: Function keys, RGB + * + * ,-------------------------------------------. ,-------------------------------------------. + * | RESET | | | | | | | | F1 | F2 | F3 | F4 | | + * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + * | | TOG | SAI | HUI | VAI | MOD | | | F5 | F6 | F7 | F8 | | + * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + * | | | SAD | HUD | VAD | RMOD | | | | | | | F9 | F10 | F11 | F12 | | + * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + * | | | | | | | | | | | | + * | | | | | | | | | | | | + * `----------------------------------' `----------------------------------' + */ + [_ADJUST] = LAYOUT_wrapper( + RESET, _______, _______, _______, _______, _______, _______, KC_F1, KC_F2, KC_F3, KC_F4, _______, + _______, RGB_TOG, RGB_SAI, RGB_HUI, RGB_VAI, RGB_MOD, _______, KC_F5, KC_F6, KC_F7, KC_F8, _______, + _______, _______, RGB_SAD, RGB_HUD, RGB_VAD, RGB_RMOD,_______, _______, _______, _______, _______, KC_F9, KC_F10, KC_F11, KC_F12, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ + ) + // /* + // * Layer template + // * + // * ,-------------------------------------------. ,-------------------------------------------. + // * | | | | | | | | | | | | | | + // * |--------+------+------+------+------+------| |------+------+------+------+------+--------| + // * | | | | | | | | | | | | | | + // * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| + // * | | | | | | | | | | | | | | | | | | + // * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' + // * | | | | | | | | | | | | + // * | | | | | | | | | | | | + // * `----------------------------------' `----------------------------------' + // */ + // [_LAYERINDEX] = LAYOUT( + // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ + // ), + // clang-format on +}; + +/* + * + */ + +void keyboard_post_init_user(void) { + // Call the keymap level matrix init. + +#ifdef RGBLIGHT_ENABLE + set_rgb_home(); +#endif +} + +layer_state_t layer_state_set_user(layer_state_t state) { +#ifdef RGBLIGHT_ENABLE + set_rgb_by_layer(state); +#endif + return state; + // return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); +} + +bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { + // Regular user keycode case statement + switch (keycode) { + default: + return true; + } + return true; +} + +void post_process_record_user(uint16_t keycode, keyrecord_t *record) { + // Regular user keycode case statement + switch (keycode) { +#ifdef RGBLIGHT_ENABLE + case RGB_HUD: + case RGB_HUI: + case RGB_SAD: + case RGB_SAI: + case RGB_VAD: + case RGB_VAI: + set_rgb_home(); + break; +#endif + default: + break; + } +} + +#ifdef ENCODER_ENABLE +bool encoder_update_user(uint8_t index, bool clockwise) { +# ifdef POINTING_DEVICE_ENABLE + if (IS_LAYER_ON(_MOUSE)) + return encoder_update_mouse(index, clockwise); + else +# endif + return encoder_update_standard(index, clockwise); +} + +bool encoder_update_standard(uint8_t index, bool clockwise) { + if (index == 0) { + // Volume control + if (clockwise) { + tap_code(KC_VOLU); + } else { + tap_code(KC_VOLD); + } + } else if (index == 1) { + // Page up/Page down + if (clockwise) { + tap_code(KC_PGDN); + } else { + tap_code(KC_PGUP); + } + } + return true; +} +#endif + +#ifdef RGBLIGHT_ENABLE + +void set_rgb_home(void) { + home_rgb.raw = eeconfig_read_rgblight(); + // these get the current -- not eeprom + // home_rgb.hue = rgblight_get_hue(); + // home_rgb.sat = rgblight_get_sat(); + // home_rgb.val = rgblight_get_val(); +} + +void set_rgb_by_layer(layer_state_t state) { + if (!rgblight_is_enabled()) { + return; // lighting not enabled + } + + uint8_t offset = 0; + switch (get_highest_layer(state)) { + case _RAISE: + offset = 2 * RGBLIGHT_HUE_STEP; + break; + case _LOWER: + offset = -2 * RGBLIGHT_HUE_STEP; + break; + case _NAV: + offset = 1 * RGBLIGHT_HUE_STEP; + break; + case _MOUSE: + offset = -10 * RGBLIGHT_HUE_STEP; + break; + // case _ADJUST: // layer color not recommended on layer w/ rgb keys + // offset = -96; + // break; + default: // for any other layers, or the default layer + break; + } + rgblight_sethsv_noeeprom((home_rgb.hue + offset) % 255, home_rgb.sat, home_rgb.val); +} +#endif diff --git a/keyboards/kyria/keymaps/muppetjones/rules.mk b/keyboards/kyria/keymaps/muppetjones/rules.mk new file mode 100644 index 000000000000..90558c787077 --- /dev/null +++ b/keyboards/kyria/keymaps/muppetjones/rules.mk @@ -0,0 +1,14 @@ +OLED_DRIVER_ENABLE = no # Enables the use of OLED displays +ENCODER_ENABLE = yes # Enables the use of one or more encoders +RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow +LEADER_ENABLE = yes # Enable the Leader Key feature +MOUSEKEY_ENABLE = yes +TAP_DANCE_ENABLE = yes +POINTING_DEVICE_ENABLE = yes + +# Reduce firmware size +# https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +# also requires in config.h +# NO_ACTION_MACRO +# NO_ACTION_FUNCTION +# EXTRAFLAGS += -flto diff --git a/keyboards/lily58/keymaps/muppetjones/README.md b/keyboards/lily58/keymaps/muppetjones/README.md new file mode 100644 index 000000000000..c94d10b97f8c --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/README.md @@ -0,0 +1,5 @@ +# Lily58 + +```shell +qmk compile -kb lily58/rev1 -km muppetjones +``` diff --git a/keyboards/lily58/keymaps/muppetjones/config.h b/keyboards/lily58/keymaps/muppetjones/config.h new file mode 100644 index 000000000000..e9895430753a --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/config.h @@ -0,0 +1,71 @@ +/* +This is the c configuration file for the keymap + +Copyright 2012 Jun Wako +Copyright 2015 Jack Humbert + +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 . +*/ + +#pragma once + +//#define USE_MATRIX_I2C + +/* Select hand configuration */ + +#define MASTER_LEFT +// #define MASTER_RIGHT +// #define EE_HANDS + +// #define SSD1306OLED + +// 1 minute +#ifdef OLED_DRIVER_ENABLE + #define OLED_TIMEOUT 60000 +#endif + +#define USE_SERIAL_PD2 + +// Change "hold" time (default is 200 ms) +#define TAPPING_TERM 200 + +// Prevent normal rollover on alphas from accidentally triggering mods. +#define IGNORE_MOD_TAP_INTERRUPT + +// Enable rapid switch from tap to hold, disables double tap hold auto-repeat. +#define TAPPING_FORCE_HOLD + + +#undef RGBLED_NUM + +// Reduce firmware size +// https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +// also requires EXTRAFLAGS in config.h +#define NO_ACTION_MACRO +#define NO_ACTION_FUNCTION + +// #define RGBLIGHT_ANIMATIONS +// #define RGBLED_NUM 27 +// #define RGBLIGHT_LIMIT_VAL 120 +// #define RGBLIGHT_HUE_STEP 10 +// #define RGBLIGHT_SAT_STEP 17 +// #define RGBLIGHT_VAL_STEP 17 + +// Underglow +/* +#undef RGBLED_NUM +#define RGBLED_NUM 14 // Number of LEDs +#define RGBLIGHT_ANIMATIONS +#define RGBLIGHT_SLEEP +*/ diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c new file mode 100644 index 000000000000..7bbf642539d2 --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c @@ -0,0 +1,135 @@ +/** + * BONGO CAT! + +WPM-responsive animation of bongo cat! + +Source: + https://github.com/qmk/qmk_firmware/blob/master/keyboards/kyria/keymaps/j-inc/keymap.c +*/ + +#include QMK_KEYBOARD_H +#include +#include "config.h" // for OLED_TIMEOUT + +#ifdef OLED_DRIVER_ENABLE + +# define IDLE_FRAMES 5 +# define IDLE_SPEED 30 // below this wpm value your animation will idle + +// #define PREP_FRAMES 1 // uncomment if >1 + +# define TAP_FRAMES 2 +# define TAP_SPEED 40 // above this wpm value typing animation to triggere + +# define ANIM_FRAME_DURATION 200 // how long each frame lasts in ms +// #define SLEEP_TIMER 60000 // should sleep after this period of 0 wpm, needs fixing +# define ANIM_SIZE 636 // number of bytes in array, minimize for adequate firmware size, max is 1024 + +uint32_t anim_timer = 0; +uint32_t anim_sleep = 0; +uint8_t current_idle_frame = 0; +// uint8_t current_prep_frame = 0; // uncomment if PREP_FRAMES >1 +uint8_t current_tap_frame = 0; + +char wpm_str[12]; + +/* Animation */ + +static const char PROGMEM ANIM_IDLE[IDLE_FRAMES][ANIM_SIZE] = { + // clang-format off + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,16,8,8,4,4,4,8,48,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,24,100,130,2,2,2,2,2,1,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,192,193,193,194,4,8,16,32,64,128,0,0,0,128,128,128,128,64,64, + 64,64,32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,192,56,4,3,0,0,0,0,0,0,0,12,12,12,13,1,0,64,160,33,34,18,17,17,17,9,8,8,8,8,4,4,8,8,16,16,16,16,16,17,15,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,2,2,4,4,8,8,8,8,8,7, + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + }, + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,16,8,8,4,4,4,8,48,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,24,100,130,2,2,2,2,2,1,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,192,193,193,194,4,8,16,32,64,128,0,0,0,128,128,128,128,64,64, + 64,64,32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,192,56,4,3,0,0,0,0,0,0,0,12,12,12,13,1,0,64,160,33,34,18,17,17,17,9,8,8,8,8,4,4,8,8,16,16,16,16,16,17,15,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,2,2,4,4,8,8,8,8,8, + 7,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + }, + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,64,64,64,64,32,32,32,32,16,8,4,2,2,4,24,96,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,60,194,1,1,2,2,4,4,2,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,96,96,0,129,130,130,132,8,16,32,64,128,0,0,0,0,128,128,128,128,64,64,64,64,32, + 32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,25,6,0,0,0,0,0,0,0,24,24,24,27,3,0,64,160,34,36,20,18,18,18,11,8,8,8,8,5,5,9,9,16,16,16,16,16,17,15,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,2,2,4,4,8,8,8,8,8,7,0,0,0, + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + }, + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,8,4,2,1,1,2,12,48,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,30,225,0,0,1,1,2,2,1,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,192,193,193,194,4,8,16,32,64,128,0,0,0,128,128,128,128,64,64, + 64,64,32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,12,3,0,0,0,0,0,0,0,12,12,12,13,1,0,64,160,33,34,18,17,17,17,9,8,8,8,8,4,4,8,8,16,16,16,16,16,17,15,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,2,2,4,4,8,8,8,8,8, + 7,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + }, + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,8,8,4,2,2,2,4,56,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,28,226,1,1,2,2,2,2,1,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,192,193,193,194,4,8,16,32,64,128,0,0,0,128,128,128,128,64,64,64,64, + 32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,12,3,0,0,0,0,0,0,0,12,12,12,13,1,0,64,160,33,34,18,17,17,17,9,8,8,8,8,4,4,8,8,16,16,16,16,16,17,15,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,2,2,4,4,8,8,8,8,8,7,0,0, + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + } + // clang-format on +}; + +// Prep animation +static const char PROGMEM ANIM_PREP[][ANIM_SIZE] = { + // clang-format off + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,8,4,2,1,1,2,12,48,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,30,225,0,0,1,1,2,2,129,128,128,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,0,1,225,26,6,9,49,53,1,138,124,0,0,128,128,128,128,64,64, + 64,64,32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,12,3,0,0,24,6,5,152,153,132,195,124,65,65,64,64,32,33,34,18,17,17,17,9,8,8,8,8,4,4,4,4,4,4,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0, + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + } + // clang-format on +}; + +// Typing animation +static const char PROGMEM ANIM_TAP[TAP_FRAMES][ANIM_SIZE] = { + // clang-format off + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,8,4,2,1,1,2,12,48,64,128,0,0,0,0,0,0,0,248,248,248,248,0,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,30,225,0,0,1,1,2,2,129,128,128,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,0,1,1,2,4,8,16,32,67,135,7,1,0,184,188,190,159, + 95,95,79,76,32,32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,12,3,0,0,24,6,5,152,153,132,67,124,65,65,64,64,32,33,34,18,17,17,17,9,8,8,8,8,4,4,8,8,16,16,16,16,16,17,15,1,61,124,252,252,252,252,252,60,12,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,2,2,1,1,1, + 1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + }, + { + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,0,0,0,0,0,128,64,64,32,32,32,32,16,16,16,16,8,4,2,1,1,2,12,48,64,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,30,225,0,0,1,1,2,2,1,0,0,0,0,128,128,0,0,0,0,0,0,0,0,0,128,0,48,48,0,0,1,225,26,6,9,49,53,1,138,124,0,0,128,128,128,128,64,64,64,64,32, + 32,32,32,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,112,12,3,0,0,0,0,0,0,0,0,0,0,1,1,0,64,160,33,34,18,17,17,17,9,8,8,8,8,4,4,4,4,4,4,2,2,2,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,128,128,128,128,64,64,64,64,64,32,32,32,32,32,16,16,16,16,16,8,8,8,8,8,4,4,4,4,4,2,3,122,122,121,121,121,121,57,49,2,2,4,4,8,8,8,136,136,135,128, + 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 + } + // clang-format on +}; + +/* Functions */ + +const char *wpm_state(void) { + sprintf(wpm_str, "WPM: %03d", get_current_wpm()); + return wpm_str; +} + +void animation_phase(uint8_t wpm) { + // NOTE: Optimized the conditional. We don't need to recheck each. + // NOTE: Move this and the animation outside of the function. + + if (IDLE_SPEED >= wpm) { + current_idle_frame = (current_idle_frame + 1) % IDLE_FRAMES; + oled_write_raw_P(ANIM_IDLE[abs((IDLE_FRAMES - 1) - current_idle_frame)], ANIM_SIZE); + } else if (TAP_SPEED > wpm) { + oled_write_raw_P(ANIM_PREP[0], ANIM_SIZE); + } else { + current_tap_frame = (current_tap_frame + 1) % TAP_FRAMES; + oled_write_raw_P(ANIM_TAP[abs((TAP_FRAMES - 1) - current_tap_frame)], ANIM_SIZE); + } +} + +// Images credit j-inc(/James Incandenza) and pixelbenny. Credit to obosob for initial animation approach. +void render_bongo_cat(void) { + const uint8_t curr_wpm = get_current_wpm(); + + if (curr_wpm > 000) { + oled_on(); + anim_sleep = timer_read32(); + } else if (timer_elapsed32(anim_sleep) > OLED_TIMEOUT) { + oled_off(); + return; + } + + if (timer_elapsed32(anim_timer) > ANIM_FRAME_DURATION) { + anim_timer = timer_read32(); + animation_phase(curr_wpm); + } +} + +#endif diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c new file mode 100644 index 000000000000..b2cb9625e28f --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -0,0 +1,245 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#include QMK_KEYBOARD_H +#include "muppetjones.h" +#define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) + +#ifdef PROTOCOL_LUFA +# include "lufa.h" +# include "split_util.h" +#endif +#ifdef SSD1306OLED +# include "ssd1306.h" +#endif + +/* + * qmk compile -kb lily58/rev1 -km muppetjones + */ + +// GACS (Lower) +#define HR_LBRC LCTL_T(KC_LBRC) +#define HR_RBRC LSFT_T(KC_RBRC) + +extern uint8_t is_master; + +/* +enum layer_number { + _CLMK_DH = 0, + _QWERTY, + _MOUSE, + _LOWER, + _RAISE, + _NAV, + _ADJUST, +}; +*/ + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // clang-format off + +/* Colemak DH + * ,-----------------------------------------. ,-----------------------------------------. + * | ` | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | BADJ | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Tab | Q | W | F | P | B | | J | L | U | Y | ; | Bksp | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Esc | A | R | S | T | G |-------. ,-------| M | N | E | I | O | ' | + * |------+------+------+------+------+------| Raise | | Lower |------+------+------+------+------+------| + * |LShift| Z | X | C | D | V |-------| |-------| K | H | , | . | / |Enter | + * `-----------------------------------------/ / \ \-----------------------------------------' + * | Alt | LGUI |LOWER | /Space / \Space \ |RAISE | Ctrl | RGUI | + * | | | |/ / \ \ | | | | + * `----------------------------' '------''--------------------' + */ +[_CLMK_DH] = LAYOUT_wrapper( + KC_GRV, KC_1, KC_2, KC_3, KC_4, CAPSWRD, __BLANK____________________________________, KC_BSPC, + CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, + HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, + TD_LAYR, __COLEMAK_MOD_DH_L3________________________, HY_ESC, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, + KC_DEL, KC_DEL, HY_ESC, LOW_ENT, RAI_SPC, HY_ESC, RAI_TAB, KC_BSPC +), + +/* QWERTY + * ,-----------------------------------------. ,-----------------------------------------. + * | ESC | 1 | 2 | 3 | 4 | 5 | | 6 | 7 | 8 | 9 | 0 | ` | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | Tab | Q | W | E | R | T | | Y | U | I | O | P | - | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * |LCTRL | A | S | D | F | G |-------. ,-------| H | J | K | L | ; | ' | + * |------+------+------+------+------+------| [ | | ] |------+------+------+------+------+------| + * |LShift| Z | X | C | V | B |-------| |-------| N | M | , | . | / |RShift| + * `-----------------------------------------/ / \ \-----------------------------------------' + * | LAlt | LGUI |LOWER | /Space / \Enter \ |RAISE |BackSP| RGUI | + * | | | |/ / \ \ | | | | + * `----------------------------' '------''--------------------' + */ +[_QWERTY] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __QWERTY_L1________________________________, __QWERTY_R1________________________________, _______, + _______, __QWERTY_L2________________________________, __QWERTY_R2________________________________, _______, + _______, __QWERTY_L3________________________________, _______, _______, __QWERTY_R3________________________________, _______, + _______, _______, _______, _______, _______, _______, _______, _______ +), +[_MOUSE] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, _______, _______, __BLANK____________________________________, _______, + KC_BTN1, __BLANK____________________________________, _______, KC_BTN2 +), + +/* LOWER + * ,-----------------------------------------. ,-----------------------------------------. + * | ` | | Mute | Vol- | Vol+ | | | | | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | ~ | | | ` | | ( | | ) | 7 | 8 | 9 | \ | Bksp | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | | GUI | ALT | _ | - | { |-------. ,-------| } | 4 | 5 | 6 | * | ` | + * |------+------+------+------+------+------| | | |------+------+------+------+------+------| + * | | | | + | = | [ |-------| |-------| ] | 1 | 2 | 3 | | |Enter | + * `-----------------------------------------/ / \ \-----------------------------------------' + * | | |LOWER | / / \ \ | 0 | . | = | + * | | | |/ / \ \ | | | | + * `----------------------------' '------''--------------------' + */ +[_LOWER] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, __NUMPAD_R1________________________________, _______, + _______, __BLANK_W_GACS_____________________________, __NUMPAD_R2________________________________, KC_PLUS, + _______, __BLANK____________________________________, _______, _______, __NUMPAD_R3________________________________, _______, + __BLANK____________________________________, KC_0, KC_DOT, _______ +), +/* RAISE + * ,-----------------------------------------. ,-----------------------------------------. + * | |MS_A_0|MS_A_1|MS_A_2| | | | | | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | | | | | |MS_W_U| | | | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | | GUI | ALT | CTL | SFT |MS_W_D|-------. ,-------| | Left | Down | Up |Right | | + * |------+------+------+------+------+------|MS_W_L | |MS_W_R |------+------+------+------+------+------| + * | | MS_L | MS_D | MS_U | MS_R | |-------| |-------| |MS_W_L|MS_W_D|MS_W_U|MS_W_R| | + * `-----------------------------------------/ / \ \-----------------------------------------' + * | | | MS_2 | / MS_1 / \ \ |RAISE | | | + * | | | |/ / \ \ | | | | + * `----------------------------' '------''--------------------' + // */ + +[_RAISE] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, XXXXXXX, __NAV_R1___________________________________, _______, + _______, KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_MINS, __NAV_R2___________________________________, _______, + _______, XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_EQL, _______, _______, __NAV_R3___________________________________, _______, + _______, _______, _______, _______, _______, _______, _______, _______ +), +[_NAV] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + _______, __BLANK____________________________________, __NAV_R1___________________________________, _______, + _______, __BLANK_W_GACS_____________________________, __NAV_R2___________________________________, _______, + _______, __BLANK____________________________________, _______, _______, __NAV_R3___________________________________, _______, + _______, _______, _______, _______, _______, _______, _______, _______ +), + +/* ADJUST + * ,-----------------------------------------. ,-----------------------------------------. + * | | Reset| | | | | | Reset| | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | | | | | | | | | | | | | | + * |------+------+------+------+------+------| |------+------+------+------+------+------| + * | | | | | | |-------. ,-------| | |RGB ON| HUE+ | SAT+ | VAL+ | + * |------+------+------+------+------+------| | | |------+------+------+------+------+------| + * | | | | | | |-------| |-------| | | MODE | HUE- | SAT- | VAL- | + * `-----------------------------------------/ / \ \-----------------------------------------' + * | LAlt | LGUI |LOWER | /Space / \Enter \ |RAISE |BackSP| RGUI | + * | | | |/ / \ \ | | | | + * `----------------------------' '------''--------------------' + */ +[_ADJUST] = LAYOUT_wrapper( + _______, __BLANK____________________________________, __BLANK____________________________________, _______, + RESET, _______, _______, _______, _______, _______, _______, KC_F1, KC_F2, KC_F3, KC_F4, _______, + _______, RGB_TOG, RGB_SAI, RGB_HUI, RGB_VAI, RGB_MOD, _______, KC_F5, KC_F6, KC_F7, KC_F8, _______, + _______, _______, RGB_SAD, RGB_HUD, RGB_VAD, RGB_RMOD,_______, _______, _______, KC_F9, KC_F10, KC_F11, KC_F12, _______, + _______, _______, _______, _______, _______, _______, _______, _______ +) + + // clang-format on +}; + +// Setting ADJUST layer RGB back to default +// void update_tri_layer_RGB(uint8_t layer1, uint8_t layer2, uint8_t layer3) { +// if (IS_LAYER_ON(layer1) && IS_LAYER_ON(layer2)) { +// layer_on(layer3); +// } else { +// layer_off(layer3); +// } +// } + +// SSD1306 OLED update loop, make sure to enable OLED_DRIVER_ENABLE=yes in rules.mk +#ifdef OLED_DRIVER_ENABLE + +oled_rotation_t oled_init_user(oled_rotation_t rotation) { + if (!is_keyboard_master()) return OLED_ROTATION_180; // flips the display 180 degrees if offhand + return rotation; +} + +// When you add source files to SRC in rules.mk, you can use functions. +const char *read_layer_state(void); +const char *read_logo(void); +const char *wpm_state(void); +void render_bongo_cat(void); +void set_keylog(uint16_t keycode, keyrecord_t *record); +const char *read_keylog(void); +const char *read_keylogs(void); + +// const char *read_mode_icon(bool swap); +// const char *read_host_led_state(void); +// void set_timelog(void); +// const char *read_timelog(void); + +void oled_task_user(void) { + if (is_keyboard_master()) { + // If you want to change the display of OLED, you need to change here + oled_write_ln(read_layer_state(), false); + oled_write_ln(read_keylog(), false); + oled_write_ln(read_keylogs(), false); + // oled_write_ln(read_mode_icon(keymap_config.swap_lalt_lgui), false); + // oled_write_ln(read_host_led_state(), false); + // oled_write_ln(read_timelog(), false); + } else { + render_bongo_cat(); + oled_set_cursor(0, 6); + oled_write(wpm_state(), false); + // oled_write(read_logo(), false); + } +} +#endif // OLED_DRIVER_ENABLE + +bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { + if (record->event.pressed) { +#ifdef OLED_DRIVER_ENABLE + set_keylog(keycode, record); +#endif + // set_timelog(); + } + + // Regular user keycode case statement + switch (keycode) { + default: + return true; + } + + return true; +} diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk new file mode 100644 index 000000000000..1653a187bc49 --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -0,0 +1,42 @@ +# Build Options +# change to "no" to disable the options, or define them in the Makefile in +# the appropriate keymap folder that will get included automatically + + +# Reduce firmware size +# https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +# also requires in config.h +# NO_ACTION_MACRO +# NO_ACTION_FUNCTION +EXTRAFLAGS += -flto + + +BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration +MOUSEKEY_ENABLE = yes # Mouse keys +EXTRAKEY_ENABLE = no # Audio control and System control +CONSOLE_ENABLE = no # Console for debug +COMMAND_ENABLE = no # Commands for debug and configuration +NKRO_ENABLE = no # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work +BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality +MIDI_ENABLE = no # MIDI controls +AUDIO_ENABLE = no # Audio output on port C6 +UNICODE_ENABLE = no # Unicode +BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID +RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. +SWAP_HANDS_ENABLE = no # Enable one-hand typing +OLED_DRIVER_ENABLE= yes # OLED display +WPM_ENABLE = yes + +# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE +SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend + +# If you want to change the display of OLED, you need to change here +# SRC += ./lib/rgb_state_reader.c +SRC += ./lib/layer_state_reader.c +SRC += ./lib/logo_reader.c +SRC += ./lib/keylogger.c +SRC += ./features/bongo_cat.c +# SRC += ./features/casemodes.c + # ./lib/mode_icon_reader.c \ + # ./lib/host_led_state_reader.c \ + # ./lib/timelogger.c \ diff --git a/keyboards/lily58/lib/layer_state_reader.c b/keyboards/lily58/lib/layer_state_reader.c index 0e9dd7039bb6..8cf75ab8f447 100644 --- a/keyboards/lily58/lib/layer_state_reader.c +++ b/keyboards/lily58/lib/layer_state_reader.c @@ -4,14 +4,16 @@ #include "lily58.h" #define L_BASE 0 -#define L_LOWER (1 << 1) -#define L_RAISE (1 << 2) -#define L_ADJUST (1 << 3) +#define L_LOWER (1 << 2) +#define L_RAISE (1 << 3) +#define L_ADJUST (1 << 4) +#define L_ADJUST_DUO (L_RAISE | L_LOWER) #define L_ADJUST_TRI (L_ADJUST | L_RAISE | L_LOWER) char layer_state_str[24]; const char *read_layer_state(void) { + // TODO: Make this less hard-coded switch (layer_state) { case L_BASE: @@ -24,6 +26,7 @@ const char *read_layer_state(void) { snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); break; case L_ADJUST: + case L_ADJUST_DUO: case L_ADJUST_TRI: snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); break; diff --git a/keyboards/planck/keymaps/muppetjones/.clang-format b/keyboards/planck/keymaps/muppetjones/.clang-format new file mode 100644 index 000000000000..df3dbd17b4ca --- /dev/null +++ b/keyboards/planck/keymaps/muppetjones/.clang-format @@ -0,0 +1,26 @@ +--- +BasedOnStyle: Google +AlignAfterOpenBracket: Align +AlignConsecutiveAssignments: 'true' +AlignConsecutiveDeclarations: 'true' +AlignOperands: 'true' +AllowAllParametersOfDeclarationOnNextLine: 'false' +AlwaysBreakAfterDefinitionReturnType: None +AlwaysBreakAfterReturnType: None +AlwaysBreakBeforeMultilineStrings: 'false' +BinPackArguments: 'true' +BinPackParameters: 'true' +ColumnLimit: '160' +IndentCaseLabels: 'true' +IndentPPDirectives: AfterHash +IndentWidth: '4' +MaxEmptyLinesToKeep: '1' +PointerAlignment: Right +SortIncludes: 'false' +SpaceBeforeAssignmentOperators: 'true' +SpaceBeforeParens: ControlStatements +SpaceInEmptyParentheses: 'false' +TabWidth: '4' +UseTab: Never + +... diff --git a/keyboards/planck/keymaps/muppetjones/config.h b/keyboards/planck/keymaps/muppetjones/config.h new file mode 100644 index 000000000000..b4f5edf366de --- /dev/null +++ b/keyboards/planck/keymaps/muppetjones/config.h @@ -0,0 +1,49 @@ +#pragma once + +#ifdef AUDIO_ENABLE +# define STARTUP_SONG SONG(PLANCK_SOUND) +// #define STARTUP_SONG SONG(NO_SOUND) + +# define DEFAULT_LAYER_SONGS \ + { SONG(QWERTY_SOUND), SONG(COLEMAK_SOUND), SONG(DVORAK_SOUND) } +#endif + +/* + * MIDI options + */ + +/* Prevent use of disabled MIDI features in the keymap */ +//#define MIDI_ENABLE_STRICT 1 + +/* enable basic MIDI features: + - MIDI notes can be sent when in Music mode is on +*/ + +#define MIDI_BASIC + +/* enable advanced MIDI features: + - MIDI notes can be added to the keymap + - Octave shift and transpose + - Virtual sustain, portamento, and modulation wheel + - etc. +*/ +//#define MIDI_ADVANCED + +/* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ +//#define MIDI_TONE_KEYCODE_OCTAVES 2 + +// Most tactile encoders have detents every 4 stages +#define ENCODER_RESOLUTION 4 + +// Enable lighting layers +#define RGBLIGHT_LAYERS +#define RGBLIGHT_SLEEP + +// Change "hold" time (default is 200 ms) +#define TAPPING_TERM 200 + +// Prevent normal rollover on alphas from accidentally triggering mods. +#define IGNORE_MOD_TAP_INTERRUPT + +// Enable rapid switch from tap to hold, disables double tap hold auto-repeat. +#define TAPPING_FORCE_HOLD diff --git a/keyboards/planck/keymaps/muppetjones/keymap.c b/keyboards/planck/keymaps/muppetjones/keymap.c new file mode 100644 index 000000000000..27e7c942ee6f --- /dev/null +++ b/keyboards/planck/keymaps/muppetjones/keymap.c @@ -0,0 +1,441 @@ +/* Copyright 2020 Stephen Bush + * + * 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 . + */ + +/* + * qmk compile -kb planck/rev6 -km muppetjones + */ + +#include QMK_KEYBOARD_H +#include "muse.h" +#include "muppetjones.h" +#include "tapmods.h" + +#define LAYOUT_planck_wrapper(...) LAYOUT_planck_grid(__VA_ARGS__) + +/* Extend layers from muppetjones.h + _CLMK_DH = 0, + _QWERTY + _MOUSE, + _LOWER, + _RAISE, + _NAV, + _ADJUST, + */ +enum planck_layers { + _PLOVER = _ADJUST + 1, +}; + +enum planck_keycodes { + PLOVER = SAFE_RANGE, + BACKLIT, + EXT_PLV, +}; + +#define TM_VSFT LSFT_T(KC_V) + +// GACS (Lower) +#define HR_LBRC LCTL_T(KC_LBRC) +#define HR_RBRC LSFT_T(KC_RBRC) + +// Left-hand home row mods (lower)--- +// #define HOME_UND LCTL_T(KC_UNDS) // NOTE: Mod-tap restricted to basic keycodes +#define HOME_MIN LSFT_T(KC_MINS) + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + // clang-format off + +/* Colemak DH II + * ,-----------------------------------------------------------------------------------. + * | Q | W | F | P | B | Del | Bksp | J | L | U | Y | ; | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | A | R | S | T | G | | " | M | N | E | I | O | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Z | X | C | D | V SFT| Enter| Tab | K | H | , | . | / | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Brite| Ctrl | Alt |HY_ESC|Lower | Space |Raise |HY_ESC| Down | Up |Right | + * `-----------------------------------------------------------------------------------' + */ +[_CLMK_DH] = LAYOUT_planck_wrapper( + __COLEMAK_MOD_DH_L1________________________, KC_DEL, KC_BSPC, __COLEMAK_MOD_DH_R1________________________, + __COLEMAK_MOD_DH_L2_W_GACS_________________, CAPSWRD, KC_QUOT, __COLEMAK_MOD_DH_R2_W_SCAG_________________, + __COLEMAK_MOD_DH_L3________________________, KC_ENT, KC_TAB, __COLEMAK_MOD_DH_R3________________________, + TD_LAYR, XXXXXXX, XXXXXXX, HY_ESC, LOW_ENT, KC_BSPC, KC_BSPC, RAI_SPC, HY_ESC, KC_BSPC, XXXXXXX, XXXXXXX +), + +/* Qwerty + * ,-----------------------------------------------------------------------------------. + * | Tab | Q | W | E | R | T | Y | U | I | O | P | Bksp | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Esc | A | S | D | F | G | H | J | K | L | ; | " | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Shift| Z | X | C | V | B | N | M | , | . | / |Enter | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | + * `-----------------------------------------------------------------------------------' + */ +[_QWERTY] = LAYOUT_planck_wrapper( + __QWERTY_L1________________________________, _______, _______, __QWERTY_R1________________________________, + __QWERTY_L2________________________________, _______, _______, __QWERTY_R2________________________________, + __QWERTY_L3________________________________, _______, _______, __QWERTY_R3________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________ +), + +/* MOUSE + * No encoders. Just an empty layer. + */ +[_MOUSE] = LAYOUT_planck_wrapper( + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________ +), + +// /* Colemak DH +// * ,-----------------------------------------------------------------------------------. +// * | Tab | Q | W | F | P | B | J | L | U | Y | ; | Bksp | +// * |------+------+------+------+------+------+------+------+------+------+------+------| +// * | Esc | A | R | S | T | G | M | N | E | I | O | " | +// * |------+------+------+------+------+------+------+------+------+------+------+------| +// * | Shift| Z | X | C | D | V | K | H | , | . | / |Enter | +// * |------+------+------+------+------+------+------+------+------+------+------+------| +// * | Brite| Ctrl | Alt | GUI |Lower | Space |Raise | Left | Down | Up |Right | +// * `-----------------------------------------------------------------------------------' +// */ +// [_CLMK_DH] = LAYOUT_planck_grid( +// KC_TAB, KC_Q, KC_W, KC_F, KC_P, KC_B, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_BSPC, +// HY_ESC, HOME_A, HOME_R, HOME_S, HOME_T, KC_G, KC_M, HOME_N, HOME_E, HOME_I, HOME_O, KC_QUOT, +// KC_LSFT, KC_Z, KC_X, KC_C, KC_D, KC_V, KC_K, KC_H, KC_COMM, KC_DOT, KC_SLSH, KC_SFTENT, +// KC_LCTL, NUMPD, KC_LALT, KC_LGUI, LOWER, KC_SPC, KC_SPC, RAISE, KC_ENT, XXXXXXX, XXXXXXX, XXXXXXX +// ), +/* Lower (numpad, symbols) + * ,-----------------------------------------------------------------------------------. + * | | | ( | ) | ~ | | | | 7 & | 8 * | 9 ( | \ | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | { | } | ` | | | - _ | 4 $ | 5 % | 6 ^ | * | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | [ | ] | | | | = + | 1 ! | 2 @ | 3 # | | | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | | | | Space | | 0 | . | | | + * `-----------------------------------------------------------------------------------' + * 21.02.22: Removed F keys. + * 21.03.28: Completely revamped to contain 10-key numpad and symbols. + */ +[_LOWER] = LAYOUT_planck_wrapper( + XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, KC_TILD, _______, _______, __NUMPAD_R1________________________________, + KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_GRV, _______, _______, __NUMPAD_R2________________________________, + XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT, _______, _______, __NUMPAD_R3________________________________, + _______, _______, _______, _______, _______, _______, _______, __NUMPAD_R4________________________________ +), + +/* Raise +* ,-----------------------------------------------------------------------------------. +* | ` | | | | | | | Pg Up| HOME | | END | | +* |------+------+------+------+------+------+------+------+------+------+------+------| +* | GUI | ALT | CTL | SFT | | | | Pg Dn| LEFT | DOWN | UP |RIGHT | +* |------+------+------+------+------+------+------+------+------+------+------+------| +* | | | | | | | | | | | | | +* |------+------+------+------+------+------+------+------+------+------+------+------| +* | | | | | | | | Next | Vol- | Vol+ | Play | +* `-----------------------------------------------------------------------------------' +* 21.02.22: Removed F keys and replaced with useful programming keys. +*/ +[_RAISE] = LAYOUT_planck_wrapper( + XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, XXXXXXX, _______, _______, __NAV_R1___________________________________, + KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_MINS, _______, _______, __NAV_R2___________________________________, + XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_EQL, _______, _______, __NAV_R3___________________________________, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ +), + +/* Nav + * Available in raise. + */ +[_NAV] = LAYOUT_planck_wrapper( + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________, + __BLANK____________________________________, _______, _______, __BLANK____________________________________ +), + +/* Plover layer (http://opensteno.org) + * ,-----------------------------------------------------------------------------------. + * | # | # | # | # | # | # | # | # | # | # | # | # | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | S | T | P | H | * | * | F | P | L | T | D | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | S | K | W | R | * | * | R | B | G | S | Z | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | Exit | | | A | O | | E | U | | | | + * `-----------------------------------------------------------------------------------' + */ + +[_PLOVER] = LAYOUT_planck_grid( + KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1, KC_1 , + XXXXXXX, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, + XXXXXXX, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, + EXT_PLV, XXXXXXX, XXXXXXX, KC_C, KC_V, XXXXXXX, XXXXXXX, KC_N, KC_M, XXXXXXX, XXXXXXX, XXXXXXX +), + +/* Adjust (Lower + Raise) + * v------------------------RGB CONTROL--------------------v + * ,-----------------------------------------------------------------------------------. + * | | Reset|Debug | RGB |RGBMOD| HUE+ | HUE- | SAT+ | SAT- |BRGTH+|BRGTH-| | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | |Brite |MUSmod|Aud on|Audoff|AGnorm|AGswap|Qwerty|Colemk|CLMKII|Plover| | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | |Voice-|Voice+|Mus on|Musoff|MIDIon|MIDIof|ClmkDH| | | | | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | | | | | | | | | | + * `-----------------------------------------------------------------------------------' + */ +[_ADJUST] = LAYOUT_planck_wrapper( + __ADJUST_L1________________________________, AU_ON, AU_OFF, __ADJUST_R1________________________________, + __ADJUST_L2________________________________, MUV_DE, MUV_IN, XXXXXXX, CLMK_DH, QWERTY, PLOVER, XXXXXXX, + __ADJUST_L3________________________________, MI_ON, MI_OFF, __ADJUST_R3________________________________, + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, MU_MOD, MU_ON, MU_OFF, __BLANK_NOOP_______________________________ +) + +/* + * ,-----------------------------------------------------------------------------------. + * | | | | | | | | | | | | | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | | | | | | | | | | | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | | | | | | | | | | | + * |------+------+------+------+------+------+------+------+------+------+------+------| + * | | | | | | | | | | | | + * `-----------------------------------------------------------------------------------' +[_ADJUST] = LAYOUT_planck_grid( + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, + _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ +) + + */ + // clang-format on +}; + +#ifdef AUDIO_ENABLE +float plover_song[][2] = SONG(PLOVER_SOUND); +float plover_gb_song[][2] = SONG(PLOVER_GOODBYE_SOUND); +#endif + +/* Setup layer lighting +#define HSV_WHITE 0, 0, 255 +#define HSV_RED 0, 255, 255 +#define HSV_CORAL 11, 176, 255 +#define HSV_ORANGE 28, 255, 255 +#define HSV_GOLDENROD 30, 218, 218 +#define HSV_GOLD 36, 255, 255 +#define HSV_YELLOW 43, 255, 255 +#define HSV_CHARTREUSE 64, 255, 255 +#define HSV_GREEN 85, 255, 255 +#define HSV_SPRINGGREEN 106, 255, 255 +#define HSV_TURQUOISE 123, 90, 112 +#define HSV_TEAL 128, 255, 128 +#define HSV_CYAN 128, 255, 255 +#define HSV_AZURE 132, 102, 255 +#define HSV_BLUE 170, 255, 255 +#define HSV_PURPLE 191, 255, 255 +#define HSV_MAGENTA 213, 255, 255 +#define HSV_PINK 234, 128, 255 +#define HSV_BLACK 0, 0, 0 +#define HSV_OFF HSV_BLACK + * + */ + +#define LIGHT_GOLDEN 30, 255, 100 +#define LIGHT_MAGENTA 213, 255, 100 +#define LIGHT_AZURE 148, 255, 100 + +// Define light layers +// -- e.g., light up LEDS 3-6 with RED when the numpd layer is active +const rgblight_segment_t PROGMEM rgb_clmk_dh[] = RGBLIGHT_LAYER_SEGMENTS({0, 9, HSV_RED}); +const rgblight_segment_t PROGMEM rgb_lower[] = RGBLIGHT_LAYER_SEGMENTS({0, 9, LIGHT_GOLDEN}); +const rgblight_segment_t PROGMEM rgb_raise[] = RGBLIGHT_LAYER_SEGMENTS({0, 9, LIGHT_MAGENTA}); +const rgblight_segment_t PROGMEM rgb_numpd[] = RGBLIGHT_LAYER_SEGMENTS({0, 9, LIGHT_AZURE}); + +const rgblight_segment_t* const PROGMEM rgb_layers[] = RGBLIGHT_LAYERS_LIST(rgb_clmk_dh, rgb_lower, rgb_raise, rgb_numpd); + +void keyboard_post_init_user(void) { + rgblight_layers = rgb_layers; // Enable the LED layers +} + +layer_state_t layer_state_set_user(layer_state_t state) { + // rgblight_set_layer_state(0, layer_state_cmp(state, _CLMK_DH)); + // rgblight_set_layer_state(1, layer_state_cmp(state, _NUMPD)); + rgblight_set_layer_state(1, layer_state_cmp(state, _LOWER)); + rgblight_set_layer_state(2, layer_state_cmp(state, _RAISE)); + return state; + // return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); +} + +bool process_record_keymap(uint16_t keycode, keyrecord_t* record) { + switch (keycode) { + case BACKLIT: + if (record->event.pressed) { + register_code(KC_RSFT); +#ifdef BACKLIGHT_ENABLE + backlight_step(); +#endif +#ifdef KEYBOARD_planck_rev5 + writePinLow(E6); +#endif + } else { + unregister_code(KC_RSFT); +#ifdef KEYBOARD_planck_rev5 + writePinHigh(E6); +#endif + } + return false; + break; + case PLOVER: + if (record->event.pressed) { +#ifdef AUDIO_ENABLE + stop_all_notes(); + PLAY_SONG(plover_song); +#endif + layer_off(_RAISE); + layer_off(_LOWER); + layer_off(_ADJUST); + layer_on(_PLOVER); + if (!eeconfig_is_enabled()) { + eeconfig_init(); + } + keymap_config.raw = eeconfig_read_keymap(); + keymap_config.nkro = 1; + eeconfig_update_keymap(keymap_config.raw); + } + return false; + break; + case EXT_PLV: + if (record->event.pressed) { +#ifdef AUDIO_ENABLE + PLAY_SONG(plover_gb_song); +#endif + layer_off(_PLOVER); + } + return false; + break; + } + + return true; +} + +bool muse_mode = false; +uint8_t last_muse_note = 0; +uint16_t muse_counter = 0; +uint8_t muse_offset = 70; +uint16_t muse_tempo = 50; + +bool encoder_update(bool clockwise) { + if (muse_mode) { + if (IS_LAYER_ON(_RAISE)) { + if (clockwise) { + muse_offset++; + } else { + muse_offset--; + } + } else { + if (clockwise) { + muse_tempo += 1; + } else { + muse_tempo -= 1; + } + } + } else { + if (clockwise) { +#ifdef MOUSEKEY_ENABLE + tap_code(KC_MS_WH_DOWN); +#else + tap_code(KC_PGDN); +#endif + } else { +#ifdef MOUSEKEY_ENABLE + tap_code(KC_MS_WH_UP); +#else + tap_code(KC_PGUP); +#endif + } + } + return true; +} + +void dip_switch_update_user(uint8_t index, bool active) { + switch (index) { + case 0: { +#ifdef AUDIO_ENABLE + static bool play_sound = false; +#endif + if (active) { +#ifdef AUDIO_ENABLE + if (play_sound) { + PLAY_SONG(plover_song); + } +#endif + layer_on(_ADJUST); + } else { +#ifdef AUDIO_ENABLE + if (play_sound) { + PLAY_SONG(plover_gb_song); + } +#endif + layer_off(_ADJUST); + } +#ifdef AUDIO_ENABLE + play_sound = true; +#endif + break; + } + case 1: + if (active) { + muse_mode = true; + } else { + muse_mode = false; + } + } +} + +void matrix_scan_user(void) { +#ifdef AUDIO_ENABLE + if (muse_mode) { + if (muse_counter == 0) { + uint8_t muse_note = muse_offset + SCALE[muse_clock_pulse()]; + if (muse_note != last_muse_note) { + stop_note(compute_freq_for_midi_note(last_muse_note)); + play_note(compute_freq_for_midi_note(muse_note), 0xF); + last_muse_note = muse_note; + } + } + muse_counter = (muse_counter + 1) % muse_tempo; + } else { + if (muse_counter) { + stop_all_notes(); + muse_counter = 0; + } + } +#endif +} + +bool music_mask_user(uint16_t keycode) { + switch (keycode) { + case RAISE: + case LOWER: + return false; + default: + return true; + } +} diff --git a/keyboards/planck/keymaps/muppetjones/readme.md b/keyboards/planck/keymaps/muppetjones/readme.md new file mode 100644 index 000000000000..de9680b49851 --- /dev/null +++ b/keyboards/planck/keymaps/muppetjones/readme.md @@ -0,0 +1,2 @@ +# The Default Planck Layout + diff --git a/keyboards/planck/keymaps/muppetjones/rules.mk b/keyboards/planck/keymaps/muppetjones/rules.mk new file mode 100644 index 000000000000..7c8757e0c11f --- /dev/null +++ b/keyboards/planck/keymaps/muppetjones/rules.mk @@ -0,0 +1,4 @@ +SRC += muse.c + +MOUSEKEY_ENABLE = yes +TAP_DANCE_ENABLE = yes diff --git a/users/muppetjones/.clang-format b/users/muppetjones/.clang-format new file mode 100644 index 000000000000..df3dbd17b4ca --- /dev/null +++ b/users/muppetjones/.clang-format @@ -0,0 +1,26 @@ +--- +BasedOnStyle: Google +AlignAfterOpenBracket: Align +AlignConsecutiveAssignments: 'true' +AlignConsecutiveDeclarations: 'true' +AlignOperands: 'true' +AllowAllParametersOfDeclarationOnNextLine: 'false' +AlwaysBreakAfterDefinitionReturnType: None +AlwaysBreakAfterReturnType: None +AlwaysBreakBeforeMultilineStrings: 'false' +BinPackArguments: 'true' +BinPackParameters: 'true' +ColumnLimit: '160' +IndentCaseLabels: 'true' +IndentPPDirectives: AfterHash +IndentWidth: '4' +MaxEmptyLinesToKeep: '1' +PointerAlignment: Right +SortIncludes: 'false' +SpaceBeforeAssignmentOperators: 'true' +SpaceBeforeParens: ControlStatements +SpaceInEmptyParentheses: 'false' +TabWidth: '4' +UseTab: Never + +... diff --git a/users/muppetjones/README.md b/users/muppetjones/README.md new file mode 100644 index 000000000000..8bd8ac201942 --- /dev/null +++ b/users/muppetjones/README.md @@ -0,0 +1,23 @@ +# License + +Copyright 2020 Stephen J. Bush @muppetjones + +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 . + +# FEATURES + +- [Etch-a-sketch Encoders](readme/etchasketchencoders.md) +- [RGB Layers](readme/rgblayers.md) +- [Tap Dance Layers](readme/dancelayers.md) +- [Tap Mods](readme/tapmods.md) diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h new file mode 100644 index 000000000000..cb1e16db8b74 --- /dev/null +++ b/users/muppetjones/config.h @@ -0,0 +1,34 @@ +#pragma once + +#ifdef OLED_DRIVER_ENABLE +# define OLED_DISPLAY_128X64 +#endif + +#ifdef RGBLIGHT_ENABLE +// # define RGBLIGHT_ANIMATIONS +# define RGBLIGHT_HUE_STEP 8 +# define RGBLIGHT_SAT_STEP 16 +# define RGBLIGHT_VAL_STEP 16 +# define RGBLIGHT_LIMIT_VAL 150 +# define RGBLIGHT_SLEEP +// # define RGBLIGHT_LAYERS +#endif + +#ifdef TAP_DANCE_ENABLE +// Change "hold" time (default is 200 ms) +// -- used for tap dance and other tap mods +# define TAPPING_TERM 200 + +// Prevent normal rollover on alphas from accidentally triggering mods. +# define IGNORE_MOD_TAP_INTERRUPT + +// Enable rapid switch from tap to hold, disables double tap hold auto-repeat. +# define TAPPING_FORCE_HOLD + +#endif + +// Reduce firmware size +// https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +// also requires EXTRAFLAGS in config.h +#define NO_ACTION_MACRO +#define NO_ACTION_FUNCTION diff --git a/users/muppetjones/features/casemodes.c b/users/muppetjones/features/casemodes.c new file mode 100644 index 000000000000..937b9669d0e0 --- /dev/null +++ b/users/muppetjones/features/casemodes.c @@ -0,0 +1,263 @@ +/* Copyright 2021 Andrew Rae ajrae.nv@gmail.com @andrewjrae + * + * 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 . + */ + +#include "casemodes.h" + +/* The caps word concept started with me @iaap on splitkb.com discord. + * However it has been implemented and extended by many splitkb.com users: + * - @theol0403 made many improvements to initial implementation + * - @precondition used caps lock rather than shifting + * - @dnaq his own implementation which also used caps lock + * - @sevanteri added underscores on spaces + * - @metheon extended on @sevanteri's work and added specific modes for + * snake_case and SCREAMING_SNAKE_CASE + * - @baffalop came up with the idea for xcase, which he implements in his own + * repo, however this is implemented by @iaap with support also for one-shot-shift. + * - @sevanteri + * - fixed xcase waiting mode to allow more modified keys and keys from other layers. + * - Added @baffalop's separator defaulting on first keypress, with a + * configurable default separator and overrideable function to determine + * if the default should be used. + */ + + +#ifndef DEFAULT_XCASE_SEPARATOR +#define DEFAULT_XCASE_SEPARATOR KC_UNDS +#endif + +#define IS_OSM(keycode) (keycode >= QK_ONE_SHOT_MOD && keycode <= QK_ONE_SHOT_MOD_MAX) + +// bool to keep track of the caps word state +static bool caps_word_on = false; + +// enum to keep track of the xcase state +static enum xcase_state xcase_state = XCASE_OFF; +// the keycode of the xcase delimiter +static uint16_t xcase_delimiter; +// the number of keys to the last delimiter +static int8_t distance_to_last_delim = -1; + +// Check whether caps word is on +bool caps_word_enabled(void) { + return caps_word_on; +} + +// Enable caps word +void enable_caps_word(void) { + caps_word_on = true; +#ifndef CAPSWORD_USE_SHIFT + if (!host_keyboard_led_state().caps_lock) { + tap_code(KC_CAPS); + } +#endif +} + +// Disable caps word +void disable_caps_word(void) { + caps_word_on = false; +#ifndef CAPSWORD_USE_SHIFT + if (host_keyboard_led_state().caps_lock) { + tap_code(KC_CAPS); + } +#else + unregister_mods(MOD_LSFT); +#endif +} + +// Toggle caps word +void toggle_caps_word(void) { + if (caps_word_on) { + disable_caps_word(); + } + else { + enable_caps_word(); + } +} + +// Get xcase state +enum xcase_state get_xcase_state(void) { + return xcase_state; +} + +// Enable xcase and pickup the next keystroke as the delimiter +void enable_xcase(void) { + xcase_state = XCASE_WAIT; +} + +// Enable xcase with the specified delimiter +void enable_xcase_with(uint16_t delimiter) { + xcase_state = XCASE_ON; + xcase_delimiter = delimiter; + distance_to_last_delim = -1; +} + +// Disable xcase +void disable_xcase(void) { + xcase_state = XCASE_OFF; +} + +// Place the current xcase delimiter +static void place_delimiter(void) { + if (IS_OSM(xcase_delimiter)) { + // apparently set_oneshot_mods() is dumb and doesn't deal with handedness for you + uint8_t mods = xcase_delimiter & 0x10 ? (xcase_delimiter & 0x0F) << 4 : xcase_delimiter & 0xFF; + set_oneshot_mods(mods); + } else { + tap_code16(xcase_delimiter); + } +} + +// Removes a delimiter, used for double tap space exit +static void remove_delimiter(void) { + if (IS_OSM(xcase_delimiter)) { + clear_oneshot_mods(); + } else { + tap_code(KC_BSPC); + } +} + +// overrideable function to determine whether the case mode should stop +__attribute__ ((weak)) +bool terminate_case_modes(uint16_t keycode, const keyrecord_t *record) { + switch (keycode) { + // Keycodes to ignore (don't disable caps word) + case KC_A ... KC_Z: + case KC_1 ... KC_0: + case KC_MINS: + case KC_UNDS: + case KC_BSPC: + // If mod chording disable the mods + if (record->event.pressed && (get_mods() != 0)) { + return true; + } + break; + default: + if (record->event.pressed) { + return true; + } + break; + } + return false; +} + +/* overrideable function to determine whether to use the default separator on + * first keypress when waiting for the separator. */ +__attribute__ ((weak)) +bool use_default_xcase_separator(uint16_t keycode, const keyrecord_t *record) { + // for example: + /* switch (keycode) { */ + /* case KC_A ... KC_Z: */ + /* case KC_1 ... KC_0: */ + /* return true; */ + /* } */ + return false; +} + +bool process_case_modes(uint16_t keycode, const keyrecord_t *record) { + if (caps_word_on || xcase_state) { + if ((QK_MOD_TAP <= keycode && keycode <= QK_MOD_TAP_MAX) + || (QK_LAYER_TAP <= keycode && keycode <= QK_LAYER_TAP_MAX)) { + // Earlier return if this has not been considered tapped yet + if (record->tap.count == 0) + return true; + keycode = keycode & 0xFF; + } + + if (keycode >= QK_LAYER_TAP && keycode <= QK_ONE_SHOT_LAYER_MAX) { + // let special keys and normal modifiers go through + return true; + } + + if (xcase_state == XCASE_WAIT) { + // grab the next input to be the delimiter + if (use_default_xcase_separator(keycode, record)) { + enable_xcase_with(DEFAULT_XCASE_SEPARATOR); + } + else if (record->event.pressed) { + // factor in mods + if (get_mods() & MOD_MASK_SHIFT) { + keycode = LSFT(keycode); + } + else if (get_mods() & MOD_BIT(KC_RALT)) { + keycode = RALT(keycode); + } + enable_xcase_with(keycode); + return false; + } + else { + if (IS_OSM(keycode)) { + // this catches the OSM release if no other key was pressed + set_oneshot_mods(0); + enable_xcase_with(keycode); + return false; + } + // let other special keys go through + return true; + } + } + + if (record->event.pressed) { + // handle xcase mode + if (xcase_state == XCASE_ON) { + // place the delimiter if space is tapped + if (keycode == KC_SPACE) { + if (distance_to_last_delim != 0) { + place_delimiter(); + distance_to_last_delim = 0; + return false; + } + // remove the delimiter and disable modes + else { + remove_delimiter(); + disable_xcase(); + disable_caps_word(); + return true; + } + } + // decrement distance to delimiter on back space + else if (keycode == KC_BSPC) { + --distance_to_last_delim; + } + // don't increment distance to last delim if negative + else if (distance_to_last_delim >= 0) { + // puts back a one shot delimiter if you we're back to the delimiter pos + if (distance_to_last_delim == 0 && (IS_OSM(xcase_delimiter))) { + place_delimiter(); + } + ++distance_to_last_delim; + } + + } // end XCASE_ON + + // check if the case modes have been terminated + if (terminate_case_modes(keycode, record)) { + disable_caps_word(); + disable_xcase(); + } + +#ifdef CAPSWORD_USE_SHIFT + else if (keycode >= KC_A && keycode <= KC_Z){ + tap_code16(LSFT(keycode)); + return false; + } +#endif + + } // end if event.pressed + + return true; + } + return true; +} diff --git a/users/muppetjones/features/casemodes.h b/users/muppetjones/features/casemodes.h new file mode 100644 index 000000000000..4a8c00b3d2c2 --- /dev/null +++ b/users/muppetjones/features/casemodes.h @@ -0,0 +1,47 @@ +/* Copyright 2021 Andrew Rae ajrae.nv@gmail.com @andrewjrae + * + * 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 . + */ + +#pragma once + +#include QMK_KEYBOARD_H + +// Check whether caps word is on +bool caps_word_enabled(void); +// Enable caps word +void enable_caps_word(void); +// Disable caps word +void disable_caps_word(void); +// Toggle caps word +void toggle_caps_word(void); + +// enum for the xcase states +enum xcase_state { + XCASE_OFF = 0, // xcase is off + XCASE_ON, // xcase is actively on + XCASE_WAIT, // xcase is waiting for the delimiter input +}; + +// Get xcase state +enum xcase_state get_xcase_state(void); +// Enable xcase and pickup the next keystroke as the delimiter +void enable_xcase(void); +// Enable xcase with the specified delimiter +void enable_xcase_with(uint16_t delimiter); +// Disable xcase +void disable_xcase(void); + +// Function to be put in process user +bool process_case_modes(uint16_t keycode, const keyrecord_t *record); diff --git a/users/muppetjones/features/dancelayers.c b/users/muppetjones/features/dancelayers.c new file mode 100644 index 000000000000..a01ef85b4bcb --- /dev/null +++ b/users/muppetjones/features/dancelayers.c @@ -0,0 +1,103 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#ifdef TAP_DANCE_ENABLE + +# include QMK_KEYBOARD_H +# include "muppetjones.h" +# include "dancelayers.h" + +// typedef struct { +// bool is_press_action; +// td_state_t state; +// } td_tap_t; + +// Initialize tap structure associated with example tap dance key +static td_tap_t lyr_tap_state = {.is_press_action = true, .state = TD_NONE}; + +/* @brief Determine the current tap dance state + * @param A tap dance state struct. + * @return A struct. + */ +td_state_t cur_dance(qk_tap_dance_state_t *state) { + switch (state->count) { + case 1: + if (!state->pressed) + return TD_1X_TAP; + else + return TD_1X_HOLD; + case 2: + return TD_2X_TAP; + break; + case 3: + return TD_3X_TAP; + break; + case 4: + return TD_4X_TAP; + break; + default: + return TD_UNKNOWN; + } +} + +// Functions that control what our tap dance key does +__attribute__((weak)) void td_layer_finished(qk_tap_dance_state_t *state, void *user_data) { + lyr_tap_state.state = cur_dance(state); + switch (lyr_tap_state.state) { + case TD_1X_TAP: + if (layer_state_is(_MOUSE)) + layer_off(_MOUSE); + else + layer_on(_MOUSE); + break; + case TD_1X_HOLD: + layer_on(_ADJUST); + break; + case TD_2X_TAP: + // Toggle lower layer + if (layer_state_is(_LOWER)) + layer_off(_LOWER); + else + layer_on(_LOWER); + break; + case TD_3X_TAP: + // Toggle lower layer + if (layer_state_is(_RAISE)) + layer_off(_RAISE); + else + layer_on(_RAISE); + break; + case TD_4X_TAP: + // Toggle lower layer + if (layer_state_is(_ADJUST)) + layer_off(_ADJUST); + else + layer_on(_ADJUST); + break; + default: + break; + } +} + +__attribute__((weak)) void td_layer_reset(qk_tap_dance_state_t *state, void *user_data) { + // If the key was held down and now is released then switch off the layer + if (lyr_tap_state.state == TD_1X_HOLD) { + layer_off(_ADJUST); + } + lyr_tap_state.state = TD_NONE; +} + +#endif diff --git a/users/muppetjones/features/dancelayers.h b/users/muppetjones/features/dancelayers.h new file mode 100644 index 000000000000..131165606daa --- /dev/null +++ b/users/muppetjones/features/dancelayers.h @@ -0,0 +1,81 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#pragma once +#ifdef TAP_DANCE_ENABLE +# include QMK_KEYBOARD_H + +/* + * TAP DANCE + * https://docs.qmk.fm/#/feature_tap_dance + */ + +// Define a type for as many tap dance states as you need +typedef enum { + TD_NONE = 0, + TD_UNKNOWN, + TD_1X_TAP, + TD_1X_HOLD, + TD_2X_TAP, + TD_3X_TAP, + TD_4X_TAP, +} td_state_t; + +// Our custom tap dance key; add any other tap dance keys to this enum +enum { + TD_LAYERS = 0, // NOTE: Start at 0 as this is also an array index +}; + +typedef struct { + bool is_press_action; + td_state_t state; +} td_tap_t; + +// Declare the functions to be used with your tap dance key(s) + +/* @brief Determine the current tap dance state + * @param A tap dance state struct. + * @return A struct. + */ +td_state_t cur_dance(qk_tap_dance_state_t *state); + +// Functions associated with individual tap dances + +/* @brief Associate tap actions with layers. + * + * NOTE: Weak attribute. Can (and should) be defined in keymap.c + * + * @param state Pointer to a tap dance state object. + * @param user_data Pointer to user data. + * @return None. + */ +void td_layer_finished(qk_tap_dance_state_t *state, void *user_data); + +/* @brief Reset tap dance actions. + * + * NOTE: Weak attribute. Can (and should) be defined in keymap.c + * + * @param state Pointer to a tap dance state object. + * @param user_data Pointer to user data. + * @return None. + */ +void td_layer_reset(qk_tap_dance_state_t *state, void *user_data); + +/* Define tap dance actions. + */ +__attribute__((weak)) +qk_tap_dance_action_t tap_dance_actions[1] = {[TD_LAYERS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(NULL, td_layer_finished, td_layer_reset, 275)}; +#endif diff --git a/users/muppetjones/features/etchamouse.c b/users/muppetjones/features/etchamouse.c new file mode 100644 index 000000000000..2c05a4c0dce3 --- /dev/null +++ b/users/muppetjones/features/etchamouse.c @@ -0,0 +1,136 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + +# Description + +Use encoders to control mouse movement. Movement speed is determined by +how quickly and how many times you've "clicked" the encoder. Turning both +encoders together will yield diagonal movement. + +Several of the macros defined in quantum/mousekey.h are reused here. +However, the mouse movement is actually performed using the pointing_device +features instead. + +# Usage + +- Add the following to your rules.mk + + ENCODER_ENABLE = yes # Enables the use of one or more encoders + POINTING_DEVICE_ENABLE = yes + +- Add the following block to your keymap.c + + #ifdef ENCODER_ENABLE + void encoder_update_user(uint8_t index, bool clockwise) { + # ifdef POINTING_DEVICE_ENABLE + encoder_update_mouse(index, clockwise); + # endif + return; + #endif + +# Description + +- The faster you turn, the faster the mouse moves. +- The more turns for a given axis, the greater the movement on that axis. + +*/ + +#include QMK_KEYBOARD_H +#include "etchamouse.h" +#include "pointing_device.h" + +#ifdef POINTING_DEVICE_ENABLE +# ifdef ENCODER_ENABLE + +/** Track movement separately in both directions. This will allow us to + * smooth out the movement along diagonals + */ +typedef struct { + bool clockwise; + uint8_t count; + uint16_t timer; + uint16_t elapsed; +} key_tracker_t; + +static key_tracker_t tracker_x = {false, 0, 0, 0}; +static key_tracker_t tracker_y = {false, 0, 0, 0}; + +/** + * @brief Calculate the mouse move units for the given tracker. + * + * By using a key tracker rederence, we can minimize the amount of space + * required on the stack. As we will have the tracker object, we will also + * take the clockwise direction into account, which completely internalizes + * the movement unit logic within this single function. + * + * @param tracker: Pointer to a key tracker object. + * @return A integer from -127 to 127 + */ +static int8_t move_unit(key_tracker_t *tracker) { + if (0 == tracker->count) return 0; + + const uint16_t modifier = TAPPING_TERM_MOUSE_ENCODER < tracker->elapsed ? 1 : (TAPPING_TERM_MOUSE_ENCODER - tracker->elapsed) >> 1; + uint16_t speed = MOUSEKEY_INITIAL_SPEED + MOUSEKEY_MOVE_DELTA * modifier * (tracker->count >> 1); + + /* convert speed to USB mouse speed 1 to 127 */ + speed = (uint8_t)(speed / (1000.0f / MOUSEKEY_INTERVAL)); + speed = speed < 1 ? 1 : speed; + + return (tracker->clockwise ? 1 : -1) * (speed > MOUSEKEY_MOVE_MAX ? MOUSEKEY_MOVE_MAX : speed); +} + +/** + * @brief Update key press tracker + * + * Update the time elapsed since the last keypress. + * If the key has not been pressed since the tapping term, then reset the count to zero. + * If the key was pressed, update the timer and increment the count. + * Number of keypresses will degrade based on tapping term and zero out based + * on the persistenc term. + * + * @param tracker: The object to update + * @param pressed: A boolean indicating whether or not the key was pressed + * @return None. + */ +static void update_tracker(key_tracker_t *tracker, bool pressed, bool clockwise) { + tracker->elapsed = timer_elapsed(tracker->timer); + if (pressed) { + tracker->timer = timer_read(); + tracker->count += 1; + tracker->clockwise = clockwise; + } else if (TAPPING_TERM_PERSISTENCE < tracker->elapsed) { + tracker->count = 0; + } else if (TAPPING_TERM_MOUSE_ENCODER < tracker->elapsed) { + tracker->count >>= 1; + } +} + +bool encoder_update_mouse(uint8_t index, bool clockwise) { + report_mouse_t curr_report = pointing_device_get_report(); + + update_tracker(&tracker_x, 0 == index, clockwise); + update_tracker(&tracker_y, 1 == index, clockwise); + + curr_report.x += move_unit(&tracker_x); + curr_report.y += move_unit(&tracker_y); + + pointing_device_set_report(curr_report); + pointing_device_send(); + + return true; +} + +# endif +#endif diff --git a/users/muppetjones/features/etchamouse.h b/users/muppetjones/features/etchamouse.h new file mode 100644 index 000000000000..feead9017968 --- /dev/null +++ b/users/muppetjones/features/etchamouse.h @@ -0,0 +1,61 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#pragma once + +#ifdef POINTING_DEVICE_ENABLE +# ifdef ENCODER_ENABLE + +/* max value on report descriptor */ +# ifndef MOUSEKEY_MOVE_MAX +# define MOUSEKEY_MOVE_MAX 127 +# elif MOUSEKEY_MOVE_MAX > 127 +# error MOUSEKEY_MOVE_MAX needs to be smaller than 127 +# endif +# ifndef MOUSEKEY_MOVE_DELTA +# define MOUSEKEY_MOVE_DELTA 25 +# endif +# ifndef MOUSEKEY_INITIAL_SPEED +# define MOUSEKEY_INITIAL_SPEED 100 +# endif +# ifndef MOUSEKEY_INTERVAL +# define MOUSEKEY_INTERVAL 50 +# endif + +/** Amount of time (ms) before zeroing out the count. + * A higher value will result in smoother curves but may lower accuracy + */ +# ifndef TAPPING_TERM_PERSISTENCE +# define TAPPING_TERM_PERSISTENCE 601 +# endif + +/** Amount of time (ms) to register consecutive key presses + * A higher value will smooth out mouse movement and increase speed for + * consecutive presses. + */ +# ifndef TAPPING_TERM_MOUSE_ENCODER +# define TAPPING_TERM_MOUSE_ENCODER 200 +# endif + +/** @brief Update mouse position based on encoder movement. + * @param index The encoder index. 0 controls x-axis; 1 controls y-axis. + * @param clockwise Indicates direction encoder was turned. + * @returns None. + */ +bool encoder_update_mouse(uint8_t index, bool clockwise); + +# endif +#endif diff --git a/users/muppetjones/features/rgblayers.c b/users/muppetjones/features/rgblayers.c new file mode 100644 index 000000000000..e2a0785d26dd --- /dev/null +++ b/users/muppetjones/features/rgblayers.c @@ -0,0 +1,15 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ diff --git a/users/muppetjones/features/rgblayers.h b/users/muppetjones/features/rgblayers.h new file mode 100644 index 000000000000..e2a0785d26dd --- /dev/null +++ b/users/muppetjones/features/rgblayers.h @@ -0,0 +1,15 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ diff --git a/users/muppetjones/muppetjones.c b/users/muppetjones/muppetjones.c new file mode 100644 index 000000000000..55051bdbcd55 --- /dev/null +++ b/users/muppetjones/muppetjones.c @@ -0,0 +1,57 @@ +/* Copyright 2020 Stephen J. Bush @muppetjones + * + * 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 . + */ + +#include QMK_KEYBOARD_H +#include "muppetjones.h" +#include "tapmods.h" +#include "features/casemodes.h" + +/* Placeholder function + * If defined in a keymap.c, this will be ignored. + */ +__attribute__((weak)) bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { return true; } + +/* Handle keypresses + */ +bool process_record_user(uint16_t keycode, keyrecord_t *record) { + if (!process_case_modes(keycode, record)) { + return false; + } + // Regular user keycode case statement + switch (keycode) { + case CLMK_DH: + if (record->event.pressed) { + set_single_persistent_default_layer(_CLMK_DH); + } + return false; + break; + case QWERTY: + if (record->event.pressed) { + // print("mode just switched to qwerty and this is a huge string\n"); + set_single_persistent_default_layer(_QWERTY); + } + return false; + break; + case CAPSWRD: + if (record->event.pressed) { + toggle_caps_word(); + } + return false; + default: + break; + } + return process_record_keymap(keycode, record); +} diff --git a/users/muppetjones/muppetjones.h b/users/muppetjones/muppetjones.h new file mode 100644 index 000000000000..936f2e94fa03 --- /dev/null +++ b/users/muppetjones/muppetjones.h @@ -0,0 +1,51 @@ +/* Copyright 2020 Stephen J. Bush @muppetjones + * + * 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 . + */ + +#pragma once +#include QMK_KEYBOARD_H + +#include "tapmods.h" +#include "wrappers.h" +#include "features/casemodes.h" + +#ifdef ENCODER_ENABLE +# include "features/etchamouse.h" +#endif + +#ifdef TAP_DANCE_ENABLE +# include "features/dancelayers.h" +# define TD_LAYR TD(TD_LAYERS) +#else +# define TD_LAYR XXXXXXX +#endif + +/* Define layer names */ +enum userspace_layers { + _CLMK_DH = 0, + _QWERTY, + _MOUSE, // Intended for encoders. Mostly pass through. + _LOWER, + _RAISE, + _NAV, + _ADJUST, +}; + +// for casemodes +enum custom_keycodes { + CLMK_DH = SAFE_RANGE, + QWERTY, + CAPSWRD, +}; diff --git a/users/muppetjones/readme/dancelayers.md b/users/muppetjones/readme/dancelayers.md new file mode 100644 index 000000000000..85c4b7cad973 --- /dev/null +++ b/users/muppetjones/readme/dancelayers.md @@ -0,0 +1,73 @@ +# Tap Dance Layers + +This feature creates a key that changes the current layer via tap dance. By +default, this assumes that you have the following layers defined: + +- `_ADJUST` +- `_LOWER` +- `_RAISE` +- `_MOUSE` + +And sets up the following tap dance: + +| Count | Action | Layer | +| ----- | ------ | --------- | +| 1x | hold | `_ADJUST` | +| 1x | tap | `_MOUSE` | +| 2x | tap | `_LOWER` | +| 3x | tap | `_RAISE` | +| 4x | tap | `_ADJUST` | + +## Usage + +> NOTE: If you use other tap-dance functions, you may require additonal setup. + +1. Copy `features/dancelayers.{c,h}` into your keymap or userspace directory. +2. Add the following to your `rules.mk` + + ``` + TAP_DANCE_ENABLE = yes + + SRC += ./features/dancelayers.c + ``` + +3. Add the following to your `keymap.c`: + + ``` + #ifdef TAP_DANCE_ENABLE + # include "features/dancelayers.h" + # define TD_LAYR TD(TD_LAYERS) + #else + # define TD_LAYR XXXXXXX + #endif + ``` + +4. Add `TD_LYR` to your keymap. + +## Functions and Enumerations + +The following functions are available for use: + +- `cur_dance` + +The following tap dance enumerations are defined: + +- `TD_1X_HOLD` +- `TD_1X_TAP` +- `TD_2X_TAP` +- `TD_3X_TAP` +- `TD_4X_TAP` + +## Overriding the Defaults + +If you want to define different layers to tap dance actions, you'll need to +define two additional functions in your `keymap.c`: + +- `td_lyr_finished` +- `td_lyr_reset` + +Both of these functions are necessary and require a certain pattern for each +layer. "Tap" actions are handled in `*_finished` while "hold" actions are +resolved in `*_finished` and `*_reset`. + +See the implementation in `dancelayers.c` for an example. diff --git a/users/muppetjones/readme/etchamouse.md b/users/muppetjones/readme/etchamouse.md new file mode 100644 index 000000000000..efcf718b22ae --- /dev/null +++ b/users/muppetjones/readme/etchamouse.md @@ -0,0 +1,69 @@ +# Etch-a-Mouse + +Encoder-based mouse movement with acceleration! + +## Usage + +- Add the following to your rules.mk + + ``` + ENCODER_ENABLE = yes + POINTING_DEVICE_ENABLE = yes + ``` + +- Add the following block to your keymap.c + + ``` + #ifdef ENCODER_ENABLE + void encoder_update_user(uint8_t index, bool clockwise) { + # ifdef POINTING_DEVICE_ENABLE + encoder_update_mouse(index, clockwise); + # endif + return; + #endif + ``` + +> NOTE: I use the mousekey keycodes to add button one and two into my keymap. + +## How It Works + +> This implementation uses the pointing device library, but it reuses several +> of the same parameters from the mouse key acceleration. + +> The PD library is very light weight, but it does not animate cursor movement. +> tl;dr: The mouse movement will not be smooth! + +The acceleration has four parts: + +``` +initial speed + (delta * time * count) +``` + +1. **Initial Speed**. Uses the `MOUSEKEY_INITIAL_SPEED` parameter. +2. **Delta**. Uses the `MOUSEKEY_MOVE_DELTA` parameter. +3. **Time**. The faster you turn, the faster you move. + + Subtract the time elapsed since the last actuation from a tapping term, + defined by `TAPPING_TERM_MOUSE_ENCODER`†, with a minimum value of 1. + +4. **Count**. The more you turn, the faster you move. + + Count of the total number of actuations. This value will decay over time. + +† _I probably could and will eventually use `TAPPING_TERM`, but I did not want +to mess up my tap mods while experimenting with acceleration._ + +## Diagonal Movement + +Counting the number of actuations for a given axis allows us to persist movement +along a given axis to give us some diagonal movement when moving both axes, +which also helps with the acceleration a bit and makes the movement less blocky. + +## Time-based Decay (a.k.a., Deceleration) + +Originally, the actuation count zeroed out once the tapping term elapsed, but +this made the movement very choppy. Instead, the count will degrade on every +refresh after the tapping term has been exceeded; unfortunately, a refresh only +occurs on an actuation on either axis, so once the time elapsed exceeds the +persistence term, the count is cleared, which also removes any movement in that +axis. diff --git a/users/muppetjones/readme/rgblayers.md b/users/muppetjones/readme/rgblayers.md new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/users/muppetjones/readme/tapmods.md b/users/muppetjones/readme/tapmods.md new file mode 100644 index 000000000000..eb707e05d9d0 --- /dev/null +++ b/users/muppetjones/readme/tapmods.md @@ -0,0 +1,25 @@ +# Tap Mods + +## Standard Keys + +| Keycode | Tap | Hold | Description | +| -------- | ------- | ----- | ---------------------------------------------------- | +| `HY_ESC` | Esc | Hyper | Esc on tap; hyper when held | +| `HR_*` | A, O | LGUI | Home-row for Colemak mod-DH and right-handed numpad. | +| \'\' | R, I, 6 | LALT | Home-row for Colemak mod-DH and right-handed numpad. | +| \'\' | S, E, 5 | LCTL | Home-row for Colemak mod-DH and right-handed numpad. | +| \'\' | T, N, 4 | LSFT | Home-row for Colemak mod-DH and right-handed numpad. | + +## Layers + +| Keycode | Tap | Hold | Description | +| ------- | ----- | ----- | --------------------------- | +| LOWER | -- | Lower | Temporarily activate layer. | +| RAISE | -- | Raise | Temporarily activate layer. | +| NAV | -- | Nav | Temporarily activate layer. | +| LOW_ENT | Enter | Lower | | +| LOW_SPC | Space | Lower | | +| NAV_SPC | Space | Nav | | +| RAI_ENT | Enter | Raise | | +| RAI_SPC | Space | Raise | | +| RAI_TAB | Tab | Raise | | diff --git a/users/muppetjones/rules.mk b/users/muppetjones/rules.mk new file mode 100644 index 000000000000..0d7a8c1c879b --- /dev/null +++ b/users/muppetjones/rules.mk @@ -0,0 +1,17 @@ +# Reduce firmware size +# https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +# also requires in config.h +# NO_ACTION_MACRO +# NO_ACTION_FUNCTION +EXTRAFLAGS += -flto + +SRC += muppetjones.c +SRC += ./features/casemodes.c + +ifdef ENCODER_ENABLE + SRC += ./features/etchamouse.c +endif + +ifdef TAP_DANCE_ENABLE + SRC += ./features/dancelayers.c +endif diff --git a/users/muppetjones/tapmods.h b/users/muppetjones/tapmods.h new file mode 100644 index 000000000000..56bcce953554 --- /dev/null +++ b/users/muppetjones/tapmods.h @@ -0,0 +1,57 @@ +/* Copyright 2020 Stephen Bush + * + * 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 . + */ + +#pragma once +#include QMK_KEYBOARD_H + +/* Misc */ + +#define HY_ESC HYPR_T(KC_ESC) + +/* Tap Mod Layers */ + +#define LOWER MO(_LOWER) +#define RAISE MO(_RAISE) +#define NAV MO(_NAV) + +#define LOW_ENT LT(_LOWER, KC_ENT) +#define LOW_SPC LT(_LOWER, KC_SPC) +#define NAV_SPC LT(_NAV, KC_SPC) +#define RAI_ENT LT(_RAISE, KC_ENT) +#define RAI_SPC LT(_RAISE, KC_SPC) +#define RAI_TAB LT(_RAISE, KC_TAB) + +/* Miryoku Home-row Mods + +NOTE: Uses GACS. +*/ + +// Left-hand home row mods (colemak) +#define HR_A LGUI_T(KC_A) +#define HR_R LALT_T(KC_R) +#define HR_S LCTL_T(KC_S) +#define HR_T LSFT_T(KC_T) + +// Right-hand home row mods (colemak) +#define HR_N RSFT_T(KC_N) +#define HR_E RCTL_T(KC_E) +#define HR_I LALT_T(KC_I) +#define HR_O RGUI_T(KC_O) + +// Right-hand Numpad +#define HR_4 RSFT_T(KC_4) +#define HR_5 RCTL_T(KC_5) +#define HR_6 LALT_T(KC_6) diff --git a/users/muppetjones/wrappers.h b/users/muppetjones/wrappers.h new file mode 100644 index 000000000000..23f83da9f150 --- /dev/null +++ b/users/muppetjones/wrappers.h @@ -0,0 +1,110 @@ +/* Copyright 2020 Stephen Bush + * + * 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 . + */ + +#pragma once +#include "muppetjones.h" +#include "tapmods.h" + +/* Pattern adapted from users/drashna/wrapper.h + Define per-layout keymap sections. Also requires a wrapper. + + Example: + + #define LAYOUT_:name_wrapper(...) LAYOUT_:name(__VA_ARGS__) + + const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { + [_MODS] = LAYOUT_:name _wrapper( + _______, ___________________BLANK___________________, ... + ... + ), + } +*/ + +#ifdef MOUSEKEY_ENABLE +# define MK_WH_D KC_WH_D +# define MK_WH_U KC_WH_U +#else +# define MK_WH_D XXXXXXX +# define MK_WH_U XXXXXXX +#endif + +// clang-format off +/* Blank-ish */ +#define __BLANK____________________________________ _______, _______, _______, _______, _______ +#define __BLANK_NOOP_______________________________ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX +#define __BLANK_W_GACS_____________________________ KC_LGUI, KC_LALT, KC_LALT, KC_LSFT, _______ +#define __BLANK_W_SCAG_____________________________ _______, KC_RSFT, KC_RCTL, KC_LALT, KC_RGUI + +/* Adjust */ +#define __ADJUST_L1________________________________ RESET, DEBUG, XXXXXXX, TERM_ON, TERM_OFF +#define __ADJUST_L2________________________________ RGB_TOG, RGB_HUI, RGB_SAI, RGB_VAI, RGB_MOD +#define __ADJUST_L3________________________________ BACKLIT, RGB_HUD, RGB_SAD, RGB_VAD, XXXXXXX + +#define __ADJUST_R1________________________________ XXXXXXX, AG_NORM, AG_SWAP, XXXXXXX, XXXXXXX +#define __ADJUST_R2________________________________ XXXXXXX, CLMK_DH, QWERTY, XXXXXXX, XXXXXXX +#define __ADJUST_R3________________________________ __BLANK_NOOP_______________________________ + +/* COLEMAK mod-DH */ +#define __COLEMAK_MOD_DH_L1________________________ KC_Q, KC_W, KC_F, KC_P, KC_B +#define __COLEMAK_MOD_DH_L2_W_GACS_________________ HR_A, HR_R, HR_S, HR_T, KC_G +#define __COLEMAK_MOD_DH_L3________________________ KC_Z, KC_X, KC_C, KC_D, KC_V + +#define __COLEMAK_MOD_DH_R1________________________ KC_J, KC_L, KC_U, KC_Y, KC_SCLN +#define __COLEMAK_MOD_DH_R2_W_SCAG_________________ KC_M, HR_N, HR_E, HR_I, HR_O +#define __COLEMAK_MOD_DH_R3________________________ KC_K, KC_H, KC_COMM, KC_DOT, KC_SLASH + +/* NAV + * ,----------------------------------. + * | Pg Up| Home | Wh Dn| Wh Up| End | + * |------+------+------+------+------| + * | Pg Dn| Left | Down | Up | Right| + * |------+------+------+------+------| + * | xxxx | xxxx | xxxx | xxxx | xxxx | + * `----------------------------------' + */ +#define __NAV_R1___________________________________ KC_PGUP, KC_HOME, KC_WH_D, KC_WH_U, KC_END +#define __NAV_R2___________________________________ KC_PGDN, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT +#define __NAV_R3___________________________________ __BLANK_NOOP_______________________________ + +/* NUMPAD + * ,----------------------------------. + * | Bksp | 7 & | 8 * | 9 ( | \ | | + * |------+------+------+------+------| + * | - _ | 4 $ | 5 % | 6 ^ | * | + * |------+------+------+------+------| + * | = + | 1 ! | 2 @ | 3 # | | | + * |------+------+------+------+------| + * | | 0 ) | . > | | | + * `----------------------------------' + */ +#define __NUMPAD_R1________________________________ KC_BSPC, KC_7, KC_8, KC_9, KC_BSLS +#define __NUMPAD_R2________________________________ KC_MINS, HR_4, HR_5, HR_6, KC_ASTR +#define __NUMPAD_R3________________________________ KC_EQL, KC_1, KC_2, KC_3, KC_PIPE +#define __NUMPAD_R4________________________________ _______, KC_0, KC_DOT, _______, _______ + +#define __NUMPAD_R3_ALT____________________________ KC_0, KC_1, KC_2, KC_3, KC_EQ + +/* QWERTY */ +#define __QWERTY_L1________________________________ KC_Q, KC_W, KC_E, KC_R, KC_T +#define __QWERTY_L2________________________________ KC_A, KC_S, KC_D, KC_F, KC_G +#define __QWERTY_L3________________________________ KC_Z, KC_X, KC_C, KC_V, KC_B + +#define __QWERTY_R1________________________________ KC_Y, KC_U, KC_I, KC_O, KC_P +#define __QWERTY_R2________________________________ KC_H, KC_J, KC_K, KC_L, KC_SCLN +#define __QWERTY_R3________________________________ KC_N, KC_M, KC_COMM, KC_DOT, KC_SLASH + +// clang-format on +// __END__ From 1f726c98d194a20bba6d61f96645683a1966b011 Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Wed, 7 Jul 2021 09:21:47 -0500 Subject: [PATCH 02/22] Rollback lily58 state reader and add missing GPL --- keyboards/lily58/lib/layer_state_reader.c | 46 +++++++++++------------ users/muppetjones/config.h | 34 ++++++++++++----- 2 files changed, 47 insertions(+), 33 deletions(-) diff --git a/keyboards/lily58/lib/layer_state_reader.c b/keyboards/lily58/lib/layer_state_reader.c index 8cf75ab8f447..022e71f8d994 100644 --- a/keyboards/lily58/lib/layer_state_reader.c +++ b/keyboards/lily58/lib/layer_state_reader.c @@ -4,35 +4,33 @@ #include "lily58.h" #define L_BASE 0 -#define L_LOWER (1 << 2) -#define L_RAISE (1 << 3) -#define L_ADJUST (1 << 4) +#define L_LOWER (1 << 1) +#define L_RAISE (1 << 2) +#define L_ADJUST (1 << 3) #define L_ADJUST_DUO (L_RAISE | L_LOWER) #define L_ADJUST_TRI (L_ADJUST | L_RAISE | L_LOWER) char layer_state_str[24]; const char *read_layer_state(void) { - // TODO: Make this less hard-coded - switch (layer_state) - { - case L_BASE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); - break; - case L_RAISE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); - break; - case L_LOWER: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); - break; - case L_ADJUST: - case L_ADJUST_DUO: - case L_ADJUST_TRI: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); - break; - default: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); - } + switch (layer_state) { + case L_BASE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); + break; + case L_RAISE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); + break; + case L_LOWER: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); + break; + case L_ADJUST: + case L_ADJUST_DUO: + case L_ADJUST_TRI: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); + break; + default: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); + } - return layer_state_str; + return layer_state_str; } diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h index cb1e16db8b74..0e1191e4bc1d 100644 --- a/users/muppetjones/config.h +++ b/users/muppetjones/config.h @@ -1,29 +1,45 @@ +/* Copyright 2020 Stephen J. Bush @muppetjones + * + * 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 . + */ + #pragma once #ifdef OLED_DRIVER_ENABLE -# define OLED_DISPLAY_128X64 +# define OLED_DISPLAY_128X64 #endif #ifdef RGBLIGHT_ENABLE // # define RGBLIGHT_ANIMATIONS -# define RGBLIGHT_HUE_STEP 8 -# define RGBLIGHT_SAT_STEP 16 -# define RGBLIGHT_VAL_STEP 16 -# define RGBLIGHT_LIMIT_VAL 150 -# define RGBLIGHT_SLEEP +# define RGBLIGHT_HUE_STEP 8 +# define RGBLIGHT_SAT_STEP 16 +# define RGBLIGHT_VAL_STEP 16 +# define RGBLIGHT_LIMIT_VAL 150 +# define RGBLIGHT_SLEEP // # define RGBLIGHT_LAYERS #endif #ifdef TAP_DANCE_ENABLE // Change "hold" time (default is 200 ms) // -- used for tap dance and other tap mods -# define TAPPING_TERM 200 +# define TAPPING_TERM 200 // Prevent normal rollover on alphas from accidentally triggering mods. -# define IGNORE_MOD_TAP_INTERRUPT +# define IGNORE_MOD_TAP_INTERRUPT // Enable rapid switch from tap to hold, disables double tap hold auto-repeat. -# define TAPPING_FORCE_HOLD +# define TAPPING_FORCE_HOLD #endif From f5138d813d79166f37b44b2c3d8dd65c5cdc9056 Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Wed, 7 Jul 2021 09:26:57 -0500 Subject: [PATCH 03/22] Apply suggestions from code review Co-authored-by: Drashna Jaelre Co-authored-by: Joel Challis --- keyboards/kyria/keymaps/muppetjones/rules.mk | 4 ---- keyboards/lily58/keymaps/muppetjones/config.h | 5 ----- keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c | 8 ++++++-- keyboards/lily58/keymaps/muppetjones/keymap.c | 8 -------- keyboards/lily58/keymaps/muppetjones/rules.mk | 4 +--- users/muppetjones/features/etchamouse.h | 4 +--- users/muppetjones/rules.mk | 2 +- 7 files changed, 9 insertions(+), 26 deletions(-) diff --git a/keyboards/kyria/keymaps/muppetjones/rules.mk b/keyboards/kyria/keymaps/muppetjones/rules.mk index 90558c787077..33f0a0742b8f 100644 --- a/keyboards/kyria/keymaps/muppetjones/rules.mk +++ b/keyboards/kyria/keymaps/muppetjones/rules.mk @@ -8,7 +8,3 @@ POINTING_DEVICE_ENABLE = yes # Reduce firmware size # https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ -# also requires in config.h -# NO_ACTION_MACRO -# NO_ACTION_FUNCTION -# EXTRAFLAGS += -flto diff --git a/keyboards/lily58/keymaps/muppetjones/config.h b/keyboards/lily58/keymaps/muppetjones/config.h index e9895430753a..2c34e804d404 100644 --- a/keyboards/lily58/keymaps/muppetjones/config.h +++ b/keyboards/lily58/keymaps/muppetjones/config.h @@ -49,11 +49,6 @@ along with this program. If not, see . #undef RGBLED_NUM -// Reduce firmware size -// https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ -// also requires EXTRAFLAGS in config.h -#define NO_ACTION_MACRO -#define NO_ACTION_FUNCTION // #define RGBLIGHT_ANIMATIONS // #define RGBLED_NUM 27 diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c index 7bbf642539d2..0b476207b0f3 100644 --- a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c @@ -9,7 +9,6 @@ WPM-responsive animation of bongo cat! #include QMK_KEYBOARD_H #include -#include "config.h" // for OLED_TIMEOUT #ifdef OLED_DRIVER_ENABLE @@ -95,7 +94,12 @@ static const char PROGMEM ANIM_TAP[TAP_FRAMES][ANIM_SIZE] = { /* Functions */ const char *wpm_state(void) { - sprintf(wpm_str, "WPM: %03d", get_current_wpm()); + uint8_t n = get_current_wpm(); + char wpm_counter[4]; + wpm_counter[3] = '\0'; + wpm_counter[2] = '0' + n % 10; + wpm_counter[1] = ( n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; + wpm_counter[0] = n / 10 ? '0' + n / 10 : ' '; return wpm_str; } diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index b2cb9625e28f..9bcf2b69947b 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -18,13 +18,6 @@ #include "muppetjones.h" #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) -#ifdef PROTOCOL_LUFA -# include "lufa.h" -# include "split_util.h" -#endif -#ifdef SSD1306OLED -# include "ssd1306.h" -#endif /* * qmk compile -kb lily58/rev1 -km muppetjones @@ -34,7 +27,6 @@ #define HR_LBRC LCTL_T(KC_LBRC) #define HR_RBRC LSFT_T(KC_RBRC) -extern uint8_t is_master; /* enum layer_number { diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index 1653a187bc49..8e266da75bc6 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -6,9 +6,7 @@ # Reduce firmware size # https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ # also requires in config.h -# NO_ACTION_MACRO -# NO_ACTION_FUNCTION -EXTRAFLAGS += -flto +LTO_ENABLE = yes BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration diff --git a/users/muppetjones/features/etchamouse.h b/users/muppetjones/features/etchamouse.h index feead9017968..4fce78d348d8 100644 --- a/users/muppetjones/features/etchamouse.h +++ b/users/muppetjones/features/etchamouse.h @@ -16,8 +16,7 @@ #pragma once -#ifdef POINTING_DEVICE_ENABLE -# ifdef ENCODER_ENABLE +#if defined(POINTING_DEVICE_ENABLE) && defined(ENCODER_ENABLE) /* max value on report descriptor */ # ifndef MOUSEKEY_MOVE_MAX @@ -57,5 +56,4 @@ */ bool encoder_update_mouse(uint8_t index, bool clockwise); -# endif #endif diff --git a/users/muppetjones/rules.mk b/users/muppetjones/rules.mk index 0d7a8c1c879b..144b268ba0ca 100644 --- a/users/muppetjones/rules.mk +++ b/users/muppetjones/rules.mk @@ -3,7 +3,7 @@ # also requires in config.h # NO_ACTION_MACRO # NO_ACTION_FUNCTION -EXTRAFLAGS += -flto +LTO_ENABLE = yes SRC += muppetjones.c SRC += ./features/casemodes.c From 74534b5ec085d9237269126a36e76b5255d73b20 Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Sat, 10 Jul 2021 16:51:00 -0500 Subject: [PATCH 04/22] fix lily58 keymap --- .../keymaps/muppetjones/features/bongo_cat.c | 84 ++++++++++--------- .../keymaps/muppetjones/features/bongo_cat.h | 3 + keyboards/lily58/keymaps/muppetjones/keymap.c | 58 +++++++------ users/muppetjones/rules.mk | 2 +- 4 files changed, 75 insertions(+), 72 deletions(-) create mode 100644 keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c index 0b476207b0f3..e83759cd0b7e 100644 --- a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c @@ -12,25 +12,24 @@ WPM-responsive animation of bongo cat! #ifdef OLED_DRIVER_ENABLE -# define IDLE_FRAMES 5 -# define IDLE_SPEED 30 // below this wpm value your animation will idle +# define IDLE_FRAMES 5 +# define IDLE_SPEED 30 // below this wpm value your animation will idle // #define PREP_FRAMES 1 // uncomment if >1 -# define TAP_FRAMES 2 -# define TAP_SPEED 40 // above this wpm value typing animation to triggere +# define TAP_FRAMES 2 +# define TAP_SPEED 40 // above this wpm value typing animation to triggere -# define ANIM_FRAME_DURATION 200 // how long each frame lasts in ms +# define ANIM_FRAME_DURATION 200 // how long each frame lasts in ms // #define SLEEP_TIMER 60000 // should sleep after this period of 0 wpm, needs fixing -# define ANIM_SIZE 636 // number of bytes in array, minimize for adequate firmware size, max is 1024 +# define ANIM_SIZE 636 // number of bytes in array, minimize for adequate firmware size, max is 1024 uint32_t anim_timer = 0; uint32_t anim_sleep = 0; uint8_t current_idle_frame = 0; // uint8_t current_prep_frame = 0; // uncomment if PREP_FRAMES >1 uint8_t current_tap_frame = 0; - -char wpm_str[12]; +char wpm_str[12]; /* Animation */ @@ -94,46 +93,49 @@ static const char PROGMEM ANIM_TAP[TAP_FRAMES][ANIM_SIZE] = { /* Functions */ const char *wpm_state(void) { - uint8_t n = get_current_wpm(); - char wpm_counter[4]; - wpm_counter[3] = '\0'; - wpm_counter[2] = '0' + n % 10; - wpm_counter[1] = ( n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; - wpm_counter[0] = n / 10 ? '0' + n / 10 : ' '; - return wpm_str; + sprintf(wpm_str, "WPM: %03d", get_current_wpm()); + return wpm_str; + // + // uint8_t n = get_current_wpm(); + // char * wpm_counter = "WPM: "; + // // wpm_counter[7] = '\0'; + // wpm_counter[7] = '0' + n % 10; + // wpm_counter[6] = (n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; + // wpm_counter[5] = n / 10 ? '0' + n / 10 : ' '; + // return wpm_counter; } void animation_phase(uint8_t wpm) { - // NOTE: Optimized the conditional. We don't need to recheck each. - // NOTE: Move this and the animation outside of the function. - - if (IDLE_SPEED >= wpm) { - current_idle_frame = (current_idle_frame + 1) % IDLE_FRAMES; - oled_write_raw_P(ANIM_IDLE[abs((IDLE_FRAMES - 1) - current_idle_frame)], ANIM_SIZE); - } else if (TAP_SPEED > wpm) { - oled_write_raw_P(ANIM_PREP[0], ANIM_SIZE); - } else { - current_tap_frame = (current_tap_frame + 1) % TAP_FRAMES; - oled_write_raw_P(ANIM_TAP[abs((TAP_FRAMES - 1) - current_tap_frame)], ANIM_SIZE); - } + // NOTE: Optimized the conditional. We don't need to recheck each. + // NOTE: Move this and the animation outside of the function. + + if (IDLE_SPEED >= wpm) { + current_idle_frame = (current_idle_frame + 1) % IDLE_FRAMES; + oled_write_raw_P(ANIM_IDLE[abs((IDLE_FRAMES - 1) - current_idle_frame)], ANIM_SIZE); + } else if (TAP_SPEED > wpm) { + oled_write_raw_P(ANIM_PREP[0], ANIM_SIZE); + } else { + current_tap_frame = (current_tap_frame + 1) % TAP_FRAMES; + oled_write_raw_P(ANIM_TAP[abs((TAP_FRAMES - 1) - current_tap_frame)], ANIM_SIZE); + } } // Images credit j-inc(/James Incandenza) and pixelbenny. Credit to obosob for initial animation approach. void render_bongo_cat(void) { - const uint8_t curr_wpm = get_current_wpm(); - - if (curr_wpm > 000) { - oled_on(); - anim_sleep = timer_read32(); - } else if (timer_elapsed32(anim_sleep) > OLED_TIMEOUT) { - oled_off(); - return; - } - - if (timer_elapsed32(anim_timer) > ANIM_FRAME_DURATION) { - anim_timer = timer_read32(); - animation_phase(curr_wpm); - } + const uint8_t curr_wpm = get_current_wpm(); + + if (curr_wpm > 000) { + oled_on(); + anim_sleep = timer_read32(); + } else if (timer_elapsed32(anim_sleep) > OLED_TIMEOUT) { + oled_off(); + return; + } + + if (timer_elapsed32(anim_timer) > ANIM_FRAME_DURATION) { + anim_timer = timer_read32(); + animation_phase(curr_wpm); + } } #endif diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h new file mode 100644 index 000000000000..967613099186 --- /dev/null +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h @@ -0,0 +1,3 @@ +void render_bongo_cat(void); +void animation_phase(uint8_t wpm); +const char *wpm_state(void); diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index 9bcf2b69947b..aa6a86541751 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -18,7 +18,6 @@ #include "muppetjones.h" #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) - /* * qmk compile -kb lily58/rev1 -km muppetjones */ @@ -27,7 +26,6 @@ #define HR_LBRC LCTL_T(KC_LBRC) #define HR_RBRC LSFT_T(KC_RBRC) - /* enum layer_number { _CLMK_DH = 0, @@ -61,8 +59,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { KC_GRV, KC_1, KC_2, KC_3, KC_4, CAPSWRD, __BLANK____________________________________, KC_BSPC, CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, - TD_LAYR, __COLEMAK_MOD_DH_L3________________________, HY_ESC, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, - KC_DEL, KC_DEL, HY_ESC, LOW_ENT, RAI_SPC, HY_ESC, RAI_TAB, KC_BSPC + TD_LAYR, __COLEMAK_MOD_DH_L3________________________, CAPSWRD, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, + KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, KC_BSPC ), /* QWERTY @@ -183,8 +181,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { #ifdef OLED_DRIVER_ENABLE oled_rotation_t oled_init_user(oled_rotation_t rotation) { - if (!is_keyboard_master()) return OLED_ROTATION_180; // flips the display 180 degrees if offhand - return rotation; + if (!is_keyboard_master()) return OLED_ROTATION_180; // flips the display 180 degrees if offhand + return rotation; } // When you add source files to SRC in rules.mk, you can use functions. @@ -202,36 +200,36 @@ const char *read_keylogs(void); // const char *read_timelog(void); void oled_task_user(void) { - if (is_keyboard_master()) { - // If you want to change the display of OLED, you need to change here - oled_write_ln(read_layer_state(), false); - oled_write_ln(read_keylog(), false); - oled_write_ln(read_keylogs(), false); - // oled_write_ln(read_mode_icon(keymap_config.swap_lalt_lgui), false); - // oled_write_ln(read_host_led_state(), false); - // oled_write_ln(read_timelog(), false); - } else { - render_bongo_cat(); - oled_set_cursor(0, 6); - oled_write(wpm_state(), false); - // oled_write(read_logo(), false); - } + if (is_keyboard_master()) { + // If you want to change the display of OLED, you need to change here + oled_write_ln(read_layer_state(), false); + oled_write_ln(read_keylog(), false); + oled_write_ln(read_keylogs(), false); + // oled_write_ln(read_mode_icon(keymap_config.swap_lalt_lgui), false); + // oled_write_ln(read_host_led_state(), false); + // oled_write_ln(read_timelog(), false); + } else { + render_bongo_cat(); + oled_set_cursor(0, 6); + oled_write(wpm_state(), false); + // oled_write(read_logo(), false); + } } #endif // OLED_DRIVER_ENABLE bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { - if (record->event.pressed) { + if (record->event.pressed) { #ifdef OLED_DRIVER_ENABLE - set_keylog(keycode, record); + set_keylog(keycode, record); #endif - // set_timelog(); - } + // set_timelog(); + } - // Regular user keycode case statement - switch (keycode) { - default: - return true; - } + // Regular user keycode case statement + switch (keycode) { + default: + return true; + } - return true; + return true; } diff --git a/users/muppetjones/rules.mk b/users/muppetjones/rules.mk index 144b268ba0ca..2dc9d4e26f68 100644 --- a/users/muppetjones/rules.mk +++ b/users/muppetjones/rules.mk @@ -6,7 +6,7 @@ LTO_ENABLE = yes SRC += muppetjones.c -SRC += ./features/casemodes.c +SRC += features/casemodes.c ifdef ENCODER_ENABLE SRC += ./features/etchamouse.c From 7f874201a7fbcb69d1c77c39f1194479f8add34d Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Sun, 11 Jul 2021 10:57:11 -0500 Subject: [PATCH 05/22] Updates to user and lily for muppetjones. Updated parameters for etchamouse for smoother mouse movement. Updated lily keymap and userspace to actually work together. --- .../keymaps/muppetjones/features/bongo_cat.c | 18 ++--- .../keymaps/muppetjones/features/bongo_cat.h | 15 +++- keyboards/lily58/keymaps/muppetjones/keymap.c | 78 ++++++++++--------- keyboards/lily58/keymaps/muppetjones/rules.mk | 17 ++-- users/muppetjones/config.h | 4 - users/muppetjones/features/dancelayers.h | 1 + users/muppetjones/features/etchamouse.c | 12 ++- users/muppetjones/features/etchamouse.h | 40 +++++----- users/muppetjones/muppetjones.h | 3 - users/muppetjones/tapmods.h | 5 ++ 10 files changed, 101 insertions(+), 92 deletions(-) diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c index e83759cd0b7e..4b8747c5f048 100644 --- a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c @@ -8,7 +8,6 @@ WPM-responsive animation of bongo cat! */ #include QMK_KEYBOARD_H -#include #ifdef OLED_DRIVER_ENABLE @@ -93,16 +92,13 @@ static const char PROGMEM ANIM_TAP[TAP_FRAMES][ANIM_SIZE] = { /* Functions */ const char *wpm_state(void) { - sprintf(wpm_str, "WPM: %03d", get_current_wpm()); - return wpm_str; - // - // uint8_t n = get_current_wpm(); - // char * wpm_counter = "WPM: "; - // // wpm_counter[7] = '\0'; - // wpm_counter[7] = '0' + n % 10; - // wpm_counter[6] = (n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; - // wpm_counter[5] = n / 10 ? '0' + n / 10 : ' '; - // return wpm_counter; + uint8_t n = get_current_wpm(); + // index: 01234567 + char *wpm_counter = "WPM: "; + wpm_counter[7] = '0' + n % 10; + wpm_counter[6] = (n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; + wpm_counter[5] = n / 10 ? '0' + n / 10 : ' '; + return wpm_counter; } void animation_phase(uint8_t wpm) { diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h index 967613099186..1025ccfa1b48 100644 --- a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.h @@ -1,3 +1,14 @@ -void render_bongo_cat(void); -void animation_phase(uint8_t wpm); +/** + * BONGO CAT! + +WPM-responsive animation of bongo cat! + +Source: + https://github.com/qmk/qmk_firmware/blob/master/keyboards/kyria/keymaps/j-inc/keymap.c +*/ + +#pragma once + const char *wpm_state(void); +void animation_phase(uint8_t wpm); +void render_bongo_cat(void); diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index aa6a86541751..f543b5ee305a 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -16,8 +16,13 @@ #include QMK_KEYBOARD_H #include "muppetjones.h" +#include "features/bongo_cat.h" #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) +#ifdef PROTOCOL_LUFA +# include "split_util.h" +#endif + /* * qmk compile -kb lily58/rev1 -km muppetjones */ @@ -26,18 +31,6 @@ #define HR_LBRC LCTL_T(KC_LBRC) #define HR_RBRC LSFT_T(KC_RBRC) -/* -enum layer_number { - _CLMK_DH = 0, - _QWERTY, - _MOUSE, - _LOWER, - _RAISE, - _NAV, - _ADJUST, -}; -*/ - const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { // clang-format off @@ -56,10 +49,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------' '------''--------------------' */ [_CLMK_DH] = LAYOUT_wrapper( - KC_GRV, KC_1, KC_2, KC_3, KC_4, CAPSWRD, __BLANK____________________________________, KC_BSPC, - CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, + KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_CAPS, __BLANK____________________________________, KC_BSPC, + KC_CAPS, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, - TD_LAYR, __COLEMAK_MOD_DH_L3________________________, CAPSWRD, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, + TD_LAYR, __COLEMAK_MOD_DH_L3________________________, KC_CAPS, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, KC_BSPC ), @@ -168,15 +161,6 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { // clang-format on }; -// Setting ADJUST layer RGB back to default -// void update_tri_layer_RGB(uint8_t layer1, uint8_t layer2, uint8_t layer3) { -// if (IS_LAYER_ON(layer1) && IS_LAYER_ON(layer2)) { -// layer_on(layer3); -// } else { -// layer_off(layer3); -// } -// } - // SSD1306 OLED update loop, make sure to enable OLED_DRIVER_ENABLE=yes in rules.mk #ifdef OLED_DRIVER_ENABLE @@ -186,33 +170,53 @@ oled_rotation_t oled_init_user(oled_rotation_t rotation) { } // When you add source files to SRC in rules.mk, you can use functions. -const char *read_layer_state(void); -const char *read_logo(void); -const char *wpm_state(void); -void render_bongo_cat(void); +const char *read_layer_state_user(void); void set_keylog(uint16_t keycode, keyrecord_t *record); const char *read_keylog(void); const char *read_keylogs(void); -// const char *read_mode_icon(bool swap); -// const char *read_host_led_state(void); -// void set_timelog(void); -// const char *read_timelog(void); +char layer_state_str[24]; + +const char *read_layer_state_user(void) { + switch (get_highest_layer(layer_state)) { + case _CLMK_DH: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); + break; + case _QWERTY: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Qwerty"); + break; + case _MOUSE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Mouse"); + break; + case _LOWER: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); + break; + case _RAISE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); + break; + case _NAV: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Nav"); + break; + case _ADJUST: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); + break; + default: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); + } + + return layer_state_str; +} void oled_task_user(void) { if (is_keyboard_master()) { // If you want to change the display of OLED, you need to change here - oled_write_ln(read_layer_state(), false); + oled_write_ln(read_layer_state_user(), false); oled_write_ln(read_keylog(), false); oled_write_ln(read_keylogs(), false); - // oled_write_ln(read_mode_icon(keymap_config.swap_lalt_lgui), false); - // oled_write_ln(read_host_led_state(), false); - // oled_write_ln(read_timelog(), false); } else { render_bongo_cat(); oled_set_cursor(0, 6); oled_write(wpm_state(), false); - // oled_write(read_logo(), false); } } #endif // OLED_DRIVER_ENABLE diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index 8e266da75bc6..aa976d231046 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -2,15 +2,8 @@ # change to "no" to disable the options, or define them in the Makefile in # the appropriate keymap folder that will get included automatically - -# Reduce firmware size -# https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ -# also requires in config.h -LTO_ENABLE = yes - - BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration -MOUSEKEY_ENABLE = yes # Mouse keys +MOUSEKEY_ENABLE = no # Mouse keys EXTRAKEY_ENABLE = no # Audio control and System control CONSOLE_ENABLE = no # Console for debug COMMAND_ENABLE = no # Commands for debug and configuration @@ -27,6 +20,9 @@ WPM_ENABLE = yes # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend +TAP_DANCE_ENABLE = yes + +LTO_ENABLE = yes # If you want to change the display of OLED, you need to change here # SRC += ./lib/rgb_state_reader.c @@ -38,3 +34,8 @@ SRC += ./features/bongo_cat.c # ./lib/mode_icon_reader.c \ # ./lib/host_led_state_reader.c \ # ./lib/timelogger.c \ + +# Reduce firmware size +# https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ +# also requires in config.h +# LTO_ENABLE = yes diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h index 0e1191e4bc1d..5ffb654538e7 100644 --- a/users/muppetjones/config.h +++ b/users/muppetjones/config.h @@ -16,10 +16,6 @@ #pragma once -#ifdef OLED_DRIVER_ENABLE -# define OLED_DISPLAY_128X64 -#endif - #ifdef RGBLIGHT_ENABLE // # define RGBLIGHT_ANIMATIONS # define RGBLIGHT_HUE_STEP 8 diff --git a/users/muppetjones/features/dancelayers.h b/users/muppetjones/features/dancelayers.h index 131165606daa..23defcca92df 100644 --- a/users/muppetjones/features/dancelayers.h +++ b/users/muppetjones/features/dancelayers.h @@ -38,6 +38,7 @@ typedef enum { enum { TD_LAYERS = 0, // NOTE: Start at 0 as this is also an array index }; +# define TD_LAYR TD(TD_LAYERS) typedef struct { bool is_press_action; diff --git a/users/muppetjones/features/etchamouse.c b/users/muppetjones/features/etchamouse.c index 2c05a4c0dce3..1c857afc960d 100644 --- a/users/muppetjones/features/etchamouse.c +++ b/users/muppetjones/features/etchamouse.c @@ -51,17 +51,16 @@ features instead. #include "etchamouse.h" #include "pointing_device.h" -#ifdef POINTING_DEVICE_ENABLE -# ifdef ENCODER_ENABLE +#if defined(POINTING_DEVICE_ENABLE) && defined(ENCODER_ENABLE) /** Track movement separately in both directions. This will allow us to * smooth out the movement along diagonals */ typedef struct { - bool clockwise; - uint8_t count; - uint16_t timer; - uint16_t elapsed; + bool clockwise : 1; + uint8_t count : 7; + uint16_t timer : 16; + uint16_t elapsed : 16; } key_tracker_t; static key_tracker_t tracker_x = {false, 0, 0, 0}; @@ -132,5 +131,4 @@ bool encoder_update_mouse(uint8_t index, bool clockwise) { return true; } -# endif #endif diff --git a/users/muppetjones/features/etchamouse.h b/users/muppetjones/features/etchamouse.h index 4fce78d348d8..86b0d03c6ec4 100644 --- a/users/muppetjones/features/etchamouse.h +++ b/users/muppetjones/features/etchamouse.h @@ -19,35 +19,35 @@ #if defined(POINTING_DEVICE_ENABLE) && defined(ENCODER_ENABLE) /* max value on report descriptor */ -# ifndef MOUSEKEY_MOVE_MAX -# define MOUSEKEY_MOVE_MAX 127 -# elif MOUSEKEY_MOVE_MAX > 127 -# error MOUSEKEY_MOVE_MAX needs to be smaller than 127 -# endif -# ifndef MOUSEKEY_MOVE_DELTA -# define MOUSEKEY_MOVE_DELTA 25 -# endif -# ifndef MOUSEKEY_INITIAL_SPEED -# define MOUSEKEY_INITIAL_SPEED 100 -# endif -# ifndef MOUSEKEY_INTERVAL -# define MOUSEKEY_INTERVAL 50 -# endif +# ifndef MOUSEKEY_MOVE_MAX +# define MOUSEKEY_MOVE_MAX 127 +# elif MOUSEKEY_MOVE_MAX > 127 +# error MOUSEKEY_MOVE_MAX needs to be smaller than 127 +# endif +# ifndef MOUSEKEY_MOVE_DELTA +# define MOUSEKEY_MOVE_DELTA 25 +# endif +# ifndef MOUSEKEY_INITIAL_SPEED +# define MOUSEKEY_INITIAL_SPEED 100 +# endif +# ifndef MOUSEKEY_INTERVAL +# define MOUSEKEY_INTERVAL 75 +# endif /** Amount of time (ms) before zeroing out the count. * A higher value will result in smoother curves but may lower accuracy */ -# ifndef TAPPING_TERM_PERSISTENCE -# define TAPPING_TERM_PERSISTENCE 601 -# endif +# ifndef TAPPING_TERM_PERSISTENCE +# define TAPPING_TERM_PERSISTENCE 150 +# endif /** Amount of time (ms) to register consecutive key presses * A higher value will smooth out mouse movement and increase speed for * consecutive presses. */ -# ifndef TAPPING_TERM_MOUSE_ENCODER -# define TAPPING_TERM_MOUSE_ENCODER 200 -# endif +# ifndef TAPPING_TERM_MOUSE_ENCODER +# define TAPPING_TERM_MOUSE_ENCODER 50 +# endif /** @brief Update mouse position based on encoder movement. * @param index The encoder index. 0 controls x-axis; 1 controls y-axis. diff --git a/users/muppetjones/muppetjones.h b/users/muppetjones/muppetjones.h index 936f2e94fa03..ef8e2ead152c 100644 --- a/users/muppetjones/muppetjones.h +++ b/users/muppetjones/muppetjones.h @@ -27,9 +27,6 @@ #ifdef TAP_DANCE_ENABLE # include "features/dancelayers.h" -# define TD_LAYR TD(TD_LAYERS) -#else -# define TD_LAYR XXXXXXX #endif /* Define layer names */ diff --git a/users/muppetjones/tapmods.h b/users/muppetjones/tapmods.h index 56bcce953554..e22a8270d1c4 100644 --- a/users/muppetjones/tapmods.h +++ b/users/muppetjones/tapmods.h @@ -17,6 +17,11 @@ #pragma once #include QMK_KEYBOARD_H +/* Define a stand-in from dancelayers.h in case tap-dance isn't enabled */ +#ifndef TAP_DANCE_ENABLE +# define TD_LAYR XXXXXXX +#endif + /* Misc */ #define HY_ESC HYPR_T(KC_ESC) From ae8d7f12730ccd2ec75c54431b5124838bd71716 Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Sun, 11 Jul 2021 14:06:33 -0500 Subject: [PATCH 06/22] Update keyboards/lily58/keymaps/muppetjones/config.h Co-authored-by: Drashna Jaelre --- keyboards/lily58/keymaps/muppetjones/config.h | 1 - 1 file changed, 1 deletion(-) diff --git a/keyboards/lily58/keymaps/muppetjones/config.h b/keyboards/lily58/keymaps/muppetjones/config.h index 2c34e804d404..f20f0889c7f2 100644 --- a/keyboards/lily58/keymaps/muppetjones/config.h +++ b/keyboards/lily58/keymaps/muppetjones/config.h @@ -35,7 +35,6 @@ along with this program. If not, see . #define OLED_TIMEOUT 60000 #endif -#define USE_SERIAL_PD2 // Change "hold" time (default is 200 ms) #define TAPPING_TERM 200 From 7d26091c88d41e9e98b85b85d1f31bc59ba91fc3 Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Sat, 31 Jul 2021 12:25:09 -0500 Subject: [PATCH 07/22] Updated keymaps and userspace --- keyboards/kyria/keymaps/muppetjones/config.h | 12 +-- keyboards/kyria/keymaps/muppetjones/keymap.c | 100 ++++++------------ keyboards/kyria/keymaps/muppetjones/rules.mk | 1 + .../lily58/keymaps/muppetjones/README.md | 8 ++ keyboards/lily58/keymaps/muppetjones/config.h | 29 +---- keyboards/lily58/keymaps/muppetjones/keymap.c | 41 ++++--- keyboards/lily58/keymaps/muppetjones/rules.mk | 25 +---- keyboards/planck/keymaps/muppetjones/keymap.c | 52 ++------- keyboards/planck/keymaps/muppetjones/rules.mk | 1 + lib/chibios | 2 +- lib/chibios-contrib | 2 +- users/muppetjones/README.md | 2 +- users/muppetjones/config.h | 2 + users/muppetjones/features/casemodes.c | 94 +++++++--------- users/muppetjones/features/combos.c | 36 +++++++ users/muppetjones/features/combos.h | 17 +++ users/muppetjones/features/dancelayers.c | 5 - users/muppetjones/features/etchamouse.c | 35 +----- users/muppetjones/features/rgblayers.c | 54 ++++++++++ users/muppetjones/features/rgblayers.h | 7 ++ users/muppetjones/muppetjones.h | 8 ++ users/muppetjones/readme/rgblayers.md | 60 +++++++++++ users/muppetjones/rules.mk | 8 ++ users/muppetjones/tapmods.h | 12 +++ users/muppetjones/wrappers.h | 62 ++++++++++- 25 files changed, 388 insertions(+), 287 deletions(-) create mode 100644 users/muppetjones/features/combos.c create mode 100644 users/muppetjones/features/combos.h diff --git a/keyboards/kyria/keymaps/muppetjones/config.h b/keyboards/kyria/keymaps/muppetjones/config.h index 631b591113fe..49b5e768ac97 100644 --- a/keyboards/kyria/keymaps/muppetjones/config.h +++ b/keyboards/kyria/keymaps/muppetjones/config.h @@ -20,16 +20,6 @@ # define OLED_DISPLAY_128X64 #endif -#ifdef RGBLIGHT_ENABLE -// # define RGBLIGHT_ANIMATIONS -# define RGBLIGHT_HUE_STEP 8 -# define RGBLIGHT_SAT_STEP 16 -# define RGBLIGHT_VAL_STEP 16 -# define RGBLIGHT_LIMIT_VAL 150 -# define RGBLIGHT_SLEEP -// # define RGBLIGHT_LAYERS -#endif - // If you are using an Elite C rev3 on the slave side, uncomment the lines below: // #define SPLIT_USB_DETECT // #define NO_USB_STARTUP_CHECK @@ -66,3 +56,5 @@ // Allows media codes to properly register in macros and rotary encoder code #define TAP_CODE_DELAY 10 + +#define COMBO_COUNT 1 diff --git a/keyboards/kyria/keymaps/muppetjones/keymap.c b/keyboards/kyria/keymaps/muppetjones/keymap.c index b3b8b9a7d380..a5164c3f3f84 100644 --- a/keyboards/kyria/keymaps/muppetjones/keymap.c +++ b/keyboards/kyria/keymaps/muppetjones/keymap.c @@ -16,6 +16,7 @@ #include QMK_KEYBOARD_H #include "muppetjones.h" #include "rgblight.h" +#include #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) @@ -36,13 +37,6 @@ bool encoder_update_standard(uint8_t index, bool clockwise); #endif -#ifdef RGBLIGHT_ENABLE -static rgblight_config_t home_rgb; - -void set_rgb_home(void); -void set_rgb_by_layer(layer_state_t); -#endif - /* * LAYERS */ @@ -82,23 +76,23 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { KC_BTN1, _______, _______, _______, _______, _______, _______, _______, _______, KC_BTN2 ), /* - * Lower Layer: Numpad + * Lower Layer: Numpad and some symbols * * ,-------------------------------------------. ,-------------------------------------------. - * | | | | | | | | / ? | 7 & | 8 * | 9 ( | - _ | | + * | | ~ | ` | ( | ) | xxxx | | / ? | 7 & | 8 * | 9 ( | - _ | | * |--------+------+------+------+------+------| |------+------+------+------+------+--------| - * | | GUI | ALT | CTL | SFT | | | * | 4 $ | 5 % | 6 ^ | , < | + | + * | | LGUI | LALT |LCTL [|LSFT ]| _ - | | * | 4 $ | 5 % | 6 ^ | , < | + | * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| - * | | | | | | | | | | | | 0 ) | 1 ! | 2 @ | 3 # | = + | | + * | | xxxx | xxxx | { | } | LSFT | | | | | | 0 ) | 1 ! | 2 @ | 3 # | = + | | * `----------------------+------+------+------+------+------| |------+------+------+------+------+----------------------' * | | | | | | | | | | | | * | | | Lower| | | | | Nav | 0 | . | | * `----------------------------------' `----------------------------------' */ [_LOWER] = LAYOUT_wrapper( - _______, __BLANK____________________________________, __NUMPAD_R1________________________________, _______, - _______, __BLANK_W_GACS_____________________________, __NUMPAD_R2________________________________, KC_PLUS, - _______, __BLANK____________________________________, _______, _______, _______, _______, __NUMPAD_R3________________________________, _______, + _______, __SYMBOLS_L1_______________________________, __NUMPAD_R1________________________________, _______, + _______, __SYMBOLS_L2_______________________________, __NUMPAD_R2________________________________, KC_PLUS, + _______, __SYMBOLS_L3_______________________________, _______, _______, _______, _______, __NUMPAD_R3________________________________, _______, __BLANK____________________________________, _______, _______, KC_0, KC_DOT, _______ ), /* @@ -122,13 +116,13 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ // ), [_RAISE] = LAYOUT_wrapper( - _______, _______, _______, KC_GRV, KC_GRV, KC_BSLS, _______, KC_LPRN, KC_RPRN, KC_ASTR, _______, _______, - _______, _______, _______, KC_UNDS, KC_MINS, KC_TILD, KC_UNDS, KC_LBRC, KC_RBRC, KC_PERC, _______, _______, - _______, _______, _______, _______, KC_EQL, _______, _______, _______, _______, _______, _______, KC_LCBR, KC_RCBR, _______, _______, _______, + _______, XXXXXXX, XXXXXXX, KC_GRV, KC_GRV, KC_BSLS, XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, KC_ASTR, _______, + _______, XXXXXXX, XXXXXXX, KC_UNDS, KC_MINS, KC_TILD, KC_UNDS, KC_MINS, KC_LBRC, KC_RBRC, KC_PERC, _______, + _______, XXXXXXX, XXXXXXX, KC_PLUS, KC_EQL, KC_GRV, _______, _______, _______, _______, KC_PLUS, KC_EQL, KC_LCBR, KC_RCBR, XXXXXXX, _______, __BLANK____________________________________, __BLANK____________________________________ ), /* - * Navigation Layer + * Navigation Layer (w/ symbols on left) * * ,-------------------------------------------. ,-------------------------------------------. * | | | | | | | | PgUp | Home | Up | End | | ScrlLk | @@ -142,9 +136,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------------' `----------------------------------' */ [_NAV] = LAYOUT_wrapper( - _______, __BLANK____________________________________, __NAV_R1___________________________________, KC_SLCK, - _______, __BLANK_W_GACS_____________________________, __NAV_R2___________________________________, KC_CAPS, - _______, __BLANK____________________________________, _______, _______, _______, _______, __NAV_R3___________________________________, _______, + _______, __SYMBOLS_L1_______________________________, __NAV_R1___________________________________, KC_SLCK, + _______, __SYMBOLS_L2_______________________________, __NAV_R2___________________________________, KC_CAPS, + _______, __SYMBOLS_L3_______________________________, _______, _______, _______, _______, __NAV_R3___________________________________, _______, __BLANK____________________________________, __BLANK____________________________________ ), /* @@ -207,10 +201,9 @@ layer_state_t layer_state_set_user(layer_state_t state) { set_rgb_by_layer(state); #endif return state; - // return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); } -bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { +bool process_record_keymap(uint16_t keycode, keyrecord_t* record) { // Regular user keycode case statement switch (keycode) { default: @@ -219,24 +212,6 @@ bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { return true; } -void post_process_record_user(uint16_t keycode, keyrecord_t *record) { - // Regular user keycode case statement - switch (keycode) { -#ifdef RGBLIGHT_ENABLE - case RGB_HUD: - case RGB_HUI: - case RGB_SAD: - case RGB_SAI: - case RGB_VAD: - case RGB_VAI: - set_rgb_home(); - break; -#endif - default: - break; - } -} - #ifdef ENCODER_ENABLE bool encoder_update_user(uint8_t index, bool clockwise) { # ifdef POINTING_DEVICE_ENABLE @@ -257,51 +232,46 @@ bool encoder_update_standard(uint8_t index, bool clockwise) { } } else if (index == 1) { // Page up/Page down +# ifdef MOUSEKEY_ENABLE + if (clockwise) { + tap_code(KC_WH_D); + } else { + tap_code(KC_WH_U); + } +# else if (clockwise) { tap_code(KC_PGDN); } else { tap_code(KC_PGUP); } +# endif } return true; } #endif #ifdef RGBLIGHT_ENABLE - -void set_rgb_home(void) { - home_rgb.raw = eeconfig_read_rgblight(); - // these get the current -- not eeprom - // home_rgb.hue = rgblight_get_hue(); - // home_rgb.sat = rgblight_get_sat(); - // home_rgb.val = rgblight_get_val(); -} - -void set_rgb_by_layer(layer_state_t state) { - if (!rgblight_is_enabled()) { - return; // lighting not enabled - } - - uint8_t offset = 0; +void set_layer_hsv(layer_state_t state, HSV* layer_color) { + int32_t h = layer_color->h, s = layer_color->s, v = layer_color->v; switch (get_highest_layer(state)) { case _RAISE: - offset = 2 * RGBLIGHT_HUE_STEP; + h += 2 * RGBLIGHT_HUE_STEP; break; case _LOWER: - offset = -2 * RGBLIGHT_HUE_STEP; + h += -2 * RGBLIGHT_HUE_STEP; break; case _NAV: - offset = 1 * RGBLIGHT_HUE_STEP; + h += 1 * RGBLIGHT_HUE_STEP; break; case _MOUSE: - offset = -10 * RGBLIGHT_HUE_STEP; + h += -7 * RGBLIGHT_HUE_STEP; break; - // case _ADJUST: // layer color not recommended on layer w/ rgb keys - // offset = -96; - // break; - default: // for any other layers, or the default layer + default: break; } - rgblight_sethsv_noeeprom((home_rgb.hue + offset) % 255, home_rgb.sat, home_rgb.val); + layer_color->h = h % 255; + layer_color->s = s; + layer_color->v = v % 255; + return; } #endif diff --git a/keyboards/kyria/keymaps/muppetjones/rules.mk b/keyboards/kyria/keymaps/muppetjones/rules.mk index 33f0a0742b8f..68ba6ae4f14b 100644 --- a/keyboards/kyria/keymaps/muppetjones/rules.mk +++ b/keyboards/kyria/keymaps/muppetjones/rules.mk @@ -5,6 +5,7 @@ LEADER_ENABLE = yes # Enable the Leader Key feature MOUSEKEY_ENABLE = yes TAP_DANCE_ENABLE = yes POINTING_DEVICE_ENABLE = yes +COMBO_ENABLE = yes # Reduce firmware size # https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ diff --git a/keyboards/lily58/keymaps/muppetjones/README.md b/keyboards/lily58/keymaps/muppetjones/README.md index c94d10b97f8c..356c8e4e5cdf 100644 --- a/keyboards/lily58/keymaps/muppetjones/README.md +++ b/keyboards/lily58/keymaps/muppetjones/README.md @@ -3,3 +3,11 @@ ```shell qmk compile -kb lily58/rev1 -km muppetjones ``` + +``` +make lily58/rev1:muppetjones:avrdude-split-left +``` + +``` +make lily58/rev1:muppetjones:avrdude-split-left +``` diff --git a/keyboards/lily58/keymaps/muppetjones/config.h b/keyboards/lily58/keymaps/muppetjones/config.h index 2c34e804d404..68cf8e079d5a 100644 --- a/keyboards/lily58/keymaps/muppetjones/config.h +++ b/keyboards/lily58/keymaps/muppetjones/config.h @@ -20,19 +20,11 @@ along with this program. If not, see . #pragma once -//#define USE_MATRIX_I2C - /* Select hand configuration */ -#define MASTER_LEFT -// #define MASTER_RIGHT -// #define EE_HANDS - -// #define SSD1306OLED - // 1 minute #ifdef OLED_DRIVER_ENABLE - #define OLED_TIMEOUT 60000 +# define OLED_TIMEOUT 60000 #endif #define USE_SERIAL_PD2 @@ -46,21 +38,8 @@ along with this program. If not, see . // Enable rapid switch from tap to hold, disables double tap hold auto-repeat. #define TAPPING_FORCE_HOLD - #undef RGBLED_NUM - -// #define RGBLIGHT_ANIMATIONS -// #define RGBLED_NUM 27 -// #define RGBLIGHT_LIMIT_VAL 120 -// #define RGBLIGHT_HUE_STEP 10 -// #define RGBLIGHT_SAT_STEP 17 -// #define RGBLIGHT_VAL_STEP 17 - -// Underglow -/* -#undef RGBLED_NUM -#define RGBLED_NUM 14 // Number of LEDs -#define RGBLIGHT_ANIMATIONS -#define RGBLIGHT_SLEEP -*/ +// Allows to use either side as the master. Look at the documentation for info: +// https://docs.qmk.fm/#/config_options?id=setting-handedness +#define EE_HANDS diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index f543b5ee305a..4f20dbf0d73d 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -19,10 +19,6 @@ #include "features/bongo_cat.h" #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) -#ifdef PROTOCOL_LUFA -# include "split_util.h" -#endif - /* * qmk compile -kb lily58/rev1 -km muppetjones */ @@ -52,8 +48,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_CAPS, __BLANK____________________________________, KC_BSPC, KC_CAPS, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, - TD_LAYR, __COLEMAK_MOD_DH_L3________________________, KC_CAPS, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, - KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, KC_BSPC + TD_LAYR, __COLEMAK_MOD_DH_L3_W_SFTV_________________, KC_CAPS, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, + KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, HY_BSPC, NAV_SPC, HY_ESC, KC_BSPC ), /* QWERTY @@ -123,9 +119,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [_RAISE] = LAYOUT_wrapper( _______, __BLANK____________________________________, __BLANK____________________________________, _______, - _______, XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, XXXXXXX, __NAV_R1___________________________________, _______, - _______, KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_MINS, __NAV_R2___________________________________, _______, - _______, XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_EQL, _______, _______, __NAV_R3___________________________________, _______, + _______, __SYMBOLS_L1_______________________________, __NAV_R1___________________________________, _______, + _______, __SYMBOLS_L2_______________________________, __NAV_R2___________________________________, _______, + _______, __SYMBOLS_L3_______________________________, _______, _______, __NAV_R3___________________________________, _______, _______, _______, _______, _______, _______, _______, _______, _______ ), [_NAV] = LAYOUT_wrapper( @@ -151,10 +147,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------' '------''--------------------' */ [_ADJUST] = LAYOUT_wrapper( - _______, __BLANK____________________________________, __BLANK____________________________________, _______, - RESET, _______, _______, _______, _______, _______, _______, KC_F1, KC_F2, KC_F3, KC_F4, _______, - _______, RGB_TOG, RGB_SAI, RGB_HUI, RGB_VAI, RGB_MOD, _______, KC_F5, KC_F6, KC_F7, KC_F8, _______, - _______, _______, RGB_SAD, RGB_HUD, RGB_VAD, RGB_RMOD,_______, _______, _______, KC_F9, KC_F10, KC_F11, KC_F12, _______, + _______, __BLANK____________________________________, _______, CLMK_DH, QWERTY, _______, _______, _______, + RESET, __ADJUST_L1________________________________, __MEDIA_R1_________________________________, _______, + _______, __ADJUST_L2________________________________, __MEDIA_R2_________________________________, _______, + _______, __ADJUST_L3________________________________, _______, _______, __MEDIA_R3_________________________________, _______, _______, _______, _______, _______, _______, _______, _______, _______ ) @@ -178,32 +174,35 @@ const char *read_keylogs(void); char layer_state_str[24]; const char *read_layer_state_user(void) { + // NOTE; switch (get_highest_layer(layer_state)) { case _CLMK_DH: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); + return "Layer: Colemak"; break; case _QWERTY: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Qwerty"); + return "Layer: QWERTY "; break; case _MOUSE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Mouse"); + return "Layer: Mouse "; break; case _LOWER: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); + return "Layer: Lower "; break; case _RAISE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); + return "Layer: Raise "; break; case _NAV: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Nav"); + return "Layer: Nav "; break; case _ADJUST: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); + return "Layer: Adjust "; break; default: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); + break; } + char *layer_state_str = "Layer: Und- "; + layer_state_str[10] = '0' + layer_state % 10; return layer_state_str; } diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index aa976d231046..efcc50278320 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -2,27 +2,10 @@ # change to "no" to disable the options, or define them in the Makefile in # the appropriate keymap folder that will get included automatically -BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration -MOUSEKEY_ENABLE = no # Mouse keys -EXTRAKEY_ENABLE = no # Audio control and System control -CONSOLE_ENABLE = no # Console for debug -COMMAND_ENABLE = no # Commands for debug and configuration -NKRO_ENABLE = no # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work -BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality -MIDI_ENABLE = no # MIDI controls -AUDIO_ENABLE = no # Audio output on port C6 -UNICODE_ENABLE = no # Unicode -BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID -RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight. -SWAP_HANDS_ENABLE = no # Enable one-hand typing OLED_DRIVER_ENABLE= yes # OLED display WPM_ENABLE = yes - -# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE -SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend TAP_DANCE_ENABLE = yes - -LTO_ENABLE = yes +COMBO_ENABLE = yes # If you want to change the display of OLED, you need to change here # SRC += ./lib/rgb_state_reader.c @@ -30,12 +13,8 @@ SRC += ./lib/layer_state_reader.c SRC += ./lib/logo_reader.c SRC += ./lib/keylogger.c SRC += ./features/bongo_cat.c -# SRC += ./features/casemodes.c - # ./lib/mode_icon_reader.c \ - # ./lib/host_led_state_reader.c \ - # ./lib/timelogger.c \ # Reduce firmware size # https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ # also requires in config.h -# LTO_ENABLE = yes +LTO_ENABLE = yes diff --git a/keyboards/planck/keymaps/muppetjones/keymap.c b/keyboards/planck/keymaps/muppetjones/keymap.c index 27e7c942ee6f..9b0dbe7cf834 100644 --- a/keyboards/planck/keymaps/muppetjones/keymap.c +++ b/keyboards/planck/keymaps/muppetjones/keymap.c @@ -21,7 +21,6 @@ #include QMK_KEYBOARD_H #include "muse.h" #include "muppetjones.h" -#include "tapmods.h" #define LAYOUT_planck_wrapper(...) LAYOUT_planck_grid(__VA_ARGS__) @@ -44,16 +43,6 @@ enum planck_keycodes { EXT_PLV, }; -#define TM_VSFT LSFT_T(KC_V) - -// GACS (Lower) -#define HR_LBRC LCTL_T(KC_LBRC) -#define HR_RBRC LSFT_T(KC_RBRC) - -// Left-hand home row mods (lower)--- -// #define HOME_UND LCTL_T(KC_UNDS) // NOTE: Mod-tap restricted to basic keycodes -#define HOME_MIN LSFT_T(KC_MINS) - const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { // clang-format off @@ -69,9 +58,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `-----------------------------------------------------------------------------------' */ [_CLMK_DH] = LAYOUT_planck_wrapper( - __COLEMAK_MOD_DH_L1________________________, KC_DEL, KC_BSPC, __COLEMAK_MOD_DH_R1________________________, + __COLEMAK_MOD_DH_L1________________________, KC_DEL, KC_BSPC, __COLEMAK_MOD_DH_R1_W_QUOT_________________, __COLEMAK_MOD_DH_L2_W_GACS_________________, CAPSWRD, KC_QUOT, __COLEMAK_MOD_DH_R2_W_SCAG_________________, - __COLEMAK_MOD_DH_L3________________________, KC_ENT, KC_TAB, __COLEMAK_MOD_DH_R3________________________, + __COLEMAK_MOD_DH_L3_W_SFTV_________________, KC_ENT, KC_TAB, __COLEMAK_MOD_DH_R3________________________, TD_LAYR, XXXXXXX, XXXXXXX, HY_ESC, LOW_ENT, KC_BSPC, KC_BSPC, RAI_SPC, HY_ESC, KC_BSPC, XXXXXXX, XXXXXXX ), @@ -134,7 +123,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * 21.03.28: Completely revamped to contain 10-key numpad and symbols. */ [_LOWER] = LAYOUT_planck_wrapper( - XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, KC_TILD, _______, _______, __NUMPAD_R1________________________________, + KC_TILD, KC_GRV, KC_LPRN, KC_RPRN, KC_TILD, _______, _______, __NUMPAD_R1________________________________, KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_GRV, _______, _______, __NUMPAD_R2________________________________, XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT, _______, _______, __NUMPAD_R3________________________________, _______, _______, _______, _______, _______, _______, _______, __NUMPAD_R4________________________________ @@ -201,10 +190,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `-----------------------------------------------------------------------------------' */ [_ADJUST] = LAYOUT_planck_wrapper( - __ADJUST_L1________________________________, AU_ON, AU_OFF, __ADJUST_R1________________________________, - __ADJUST_L2________________________________, MUV_DE, MUV_IN, XXXXXXX, CLMK_DH, QWERTY, PLOVER, XXXXXXX, - __ADJUST_L3________________________________, MI_ON, MI_OFF, __ADJUST_R3________________________________, - XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, MU_MOD, MU_ON, MU_OFF, __BLANK_NOOP_______________________________ + __ADJUST_L1________________________________, MUV_IN, PLOVER, __MEDIA_R1_________________________________, + __ADJUST_L2________________________________, MUV_DE, CLMK_DH, __MEDIA_R2_________________________________, + __ADJUST_L3________________________________, MU_MOD, QWERTY, __MEDIA_R3_________________________________, + XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX ) /* @@ -233,30 +222,6 @@ float plover_song[][2] = SONG(PLOVER_SOUND); float plover_gb_song[][2] = SONG(PLOVER_GOODBYE_SOUND); #endif -/* Setup layer lighting -#define HSV_WHITE 0, 0, 255 -#define HSV_RED 0, 255, 255 -#define HSV_CORAL 11, 176, 255 -#define HSV_ORANGE 28, 255, 255 -#define HSV_GOLDENROD 30, 218, 218 -#define HSV_GOLD 36, 255, 255 -#define HSV_YELLOW 43, 255, 255 -#define HSV_CHARTREUSE 64, 255, 255 -#define HSV_GREEN 85, 255, 255 -#define HSV_SPRINGGREEN 106, 255, 255 -#define HSV_TURQUOISE 123, 90, 112 -#define HSV_TEAL 128, 255, 128 -#define HSV_CYAN 128, 255, 255 -#define HSV_AZURE 132, 102, 255 -#define HSV_BLUE 170, 255, 255 -#define HSV_PURPLE 191, 255, 255 -#define HSV_MAGENTA 213, 255, 255 -#define HSV_PINK 234, 128, 255 -#define HSV_BLACK 0, 0, 0 -#define HSV_OFF HSV_BLACK - * - */ - #define LIGHT_GOLDEN 30, 255, 100 #define LIGHT_MAGENTA 213, 255, 100 #define LIGHT_AZURE 148, 255, 100 @@ -275,12 +240,9 @@ void keyboard_post_init_user(void) { } layer_state_t layer_state_set_user(layer_state_t state) { - // rgblight_set_layer_state(0, layer_state_cmp(state, _CLMK_DH)); - // rgblight_set_layer_state(1, layer_state_cmp(state, _NUMPD)); rgblight_set_layer_state(1, layer_state_cmp(state, _LOWER)); rgblight_set_layer_state(2, layer_state_cmp(state, _RAISE)); return state; - // return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); } bool process_record_keymap(uint16_t keycode, keyrecord_t* record) { diff --git a/keyboards/planck/keymaps/muppetjones/rules.mk b/keyboards/planck/keymaps/muppetjones/rules.mk index 7c8757e0c11f..1db412715d96 100644 --- a/keyboards/planck/keymaps/muppetjones/rules.mk +++ b/keyboards/planck/keymaps/muppetjones/rules.mk @@ -2,3 +2,4 @@ SRC += muse.c MOUSEKEY_ENABLE = yes TAP_DANCE_ENABLE = yes +COMBO_ENABLE = yes diff --git a/lib/chibios b/lib/chibios index ffe54d63cb10..313416b8fda9 160000 --- a/lib/chibios +++ b/lib/chibios @@ -1 +1 @@ -Subproject commit ffe54d63cb10a355add318f8e922e39f1c3d4bfd +Subproject commit 313416b8fda90d9973a749a0a35970956852c286 diff --git a/lib/chibios-contrib b/lib/chibios-contrib index 61baa6b03613..e3a3a2404771 160000 --- a/lib/chibios-contrib +++ b/lib/chibios-contrib @@ -1 +1 @@ -Subproject commit 61baa6b036138c155f7cfc5646d833d9423f3243 +Subproject commit e3a3a24047717af33b098266e11c2e4e5102206a diff --git a/users/muppetjones/README.md b/users/muppetjones/README.md index 8bd8ac201942..6569c01d951c 100644 --- a/users/muppetjones/README.md +++ b/users/muppetjones/README.md @@ -17,7 +17,7 @@ along with this program. If not, see . # FEATURES -- [Etch-a-sketch Encoders](readme/etchasketchencoders.md) +- [Etch-a-sketch Encoders](readme/etchamouse.md) - [RGB Layers](readme/rgblayers.md) - [Tap Dance Layers](readme/dancelayers.md) - [Tap Mods](readme/tapmods.md) diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h index 5ffb654538e7..297106a84a99 100644 --- a/users/muppetjones/config.h +++ b/users/muppetjones/config.h @@ -44,3 +44,5 @@ // also requires EXTRAFLAGS in config.h #define NO_ACTION_MACRO #define NO_ACTION_FUNCTION + +#define COMBO_COUNT 3 diff --git a/users/muppetjones/features/casemodes.c b/users/muppetjones/features/casemodes.c index 937b9669d0e0..da7c5e8fa9f0 100644 --- a/users/muppetjones/features/casemodes.c +++ b/users/muppetjones/features/casemodes.c @@ -33,9 +33,8 @@ * if the default should be used. */ - #ifndef DEFAULT_XCASE_SEPARATOR -#define DEFAULT_XCASE_SEPARATOR KC_UNDS +# define DEFAULT_XCASE_SEPARATOR KC_UNDS #endif #define IS_OSM(keycode) (keycode >= QK_ONE_SHOT_MOD && keycode <= QK_ONE_SHOT_MOD_MAX) @@ -51,9 +50,7 @@ static uint16_t xcase_delimiter; static int8_t distance_to_last_delim = -1; // Check whether caps word is on -bool caps_word_enabled(void) { - return caps_word_on; -} +bool caps_word_enabled(void) { return caps_word_on; } // Enable caps word void enable_caps_word(void) { @@ -81,33 +78,26 @@ void disable_caps_word(void) { void toggle_caps_word(void) { if (caps_word_on) { disable_caps_word(); - } - else { + } else { enable_caps_word(); } } // Get xcase state -enum xcase_state get_xcase_state(void) { - return xcase_state; -} +enum xcase_state get_xcase_state(void) { return xcase_state; } // Enable xcase and pickup the next keystroke as the delimiter -void enable_xcase(void) { - xcase_state = XCASE_WAIT; -} +void enable_xcase(void) { xcase_state = XCASE_WAIT; } // Enable xcase with the specified delimiter void enable_xcase_with(uint16_t delimiter) { - xcase_state = XCASE_ON; - xcase_delimiter = delimiter; + xcase_state = XCASE_ON; + xcase_delimiter = delimiter; distance_to_last_delim = -1; } // Disable xcase -void disable_xcase(void) { - xcase_state = XCASE_OFF; -} +void disable_xcase(void) { xcase_state = XCASE_OFF; } // Place the current xcase delimiter static void place_delimiter(void) { @@ -130,33 +120,33 @@ static void remove_delimiter(void) { } // overrideable function to determine whether the case mode should stop -__attribute__ ((weak)) -bool terminate_case_modes(uint16_t keycode, const keyrecord_t *record) { - switch (keycode) { - // Keycodes to ignore (don't disable caps word) - case KC_A ... KC_Z: - case KC_1 ... KC_0: - case KC_MINS: - case KC_UNDS: - case KC_BSPC: - // If mod chording disable the mods - if (record->event.pressed && (get_mods() != 0)) { - return true; - } - break; - default: - if (record->event.pressed) { - return true; - } - break; - } - return false; +__attribute__((weak)) bool terminate_case_modes(uint16_t keycode, const keyrecord_t *record) { + switch (keycode) { + // Keycodes to ignore (don't disable caps word) + case KC_A ... KC_Z: + case KC_1 ... KC_0: + case KC_MINS: + case KC_BSPC: + // If mod chording disable the mods + if (record->event.pressed && (get_mods() != 0)) { + return true; + } + break; + case KC_UNDS: + // Allow to be pressed with or without a modifier (prob w/ shift) + break; + default: + if (record->event.pressed) { + return true; + } + break; + } + return false; } /* overrideable function to determine whether to use the default separator on * first keypress when waiting for the separator. */ -__attribute__ ((weak)) -bool use_default_xcase_separator(uint16_t keycode, const keyrecord_t *record) { +__attribute__((weak)) bool use_default_xcase_separator(uint16_t keycode, const keyrecord_t *record) { // for example: /* switch (keycode) { */ /* case KC_A ... KC_Z: */ @@ -168,11 +158,9 @@ bool use_default_xcase_separator(uint16_t keycode, const keyrecord_t *record) { bool process_case_modes(uint16_t keycode, const keyrecord_t *record) { if (caps_word_on || xcase_state) { - if ((QK_MOD_TAP <= keycode && keycode <= QK_MOD_TAP_MAX) - || (QK_LAYER_TAP <= keycode && keycode <= QK_LAYER_TAP_MAX)) { + if ((QK_MOD_TAP <= keycode && keycode <= QK_MOD_TAP_MAX) || (QK_LAYER_TAP <= keycode && keycode <= QK_LAYER_TAP_MAX)) { // Earlier return if this has not been considered tapped yet - if (record->tap.count == 0) - return true; + if (record->tap.count == 0) return true; keycode = keycode & 0xFF; } @@ -185,19 +173,16 @@ bool process_case_modes(uint16_t keycode, const keyrecord_t *record) { // grab the next input to be the delimiter if (use_default_xcase_separator(keycode, record)) { enable_xcase_with(DEFAULT_XCASE_SEPARATOR); - } - else if (record->event.pressed) { + } else if (record->event.pressed) { // factor in mods if (get_mods() & MOD_MASK_SHIFT) { keycode = LSFT(keycode); - } - else if (get_mods() & MOD_BIT(KC_RALT)) { + } else if (get_mods() & MOD_BIT(KC_RALT)) { keycode = RALT(keycode); } enable_xcase_with(keycode); return false; - } - else { + } else { if (IS_OSM(keycode)) { // this catches the OSM release if no other key was pressed set_oneshot_mods(0); @@ -240,22 +225,21 @@ bool process_case_modes(uint16_t keycode, const keyrecord_t *record) { ++distance_to_last_delim; } - } // end XCASE_ON + } // end XCASE_ON // check if the case modes have been terminated if (terminate_case_modes(keycode, record)) { disable_caps_word(); disable_xcase(); } - #ifdef CAPSWORD_USE_SHIFT - else if (keycode >= KC_A && keycode <= KC_Z){ + else if (keycode >= KC_A && keycode <= KC_Z) { tap_code16(LSFT(keycode)); return false; } #endif - } // end if event.pressed + } // end if event.pressed return true; } diff --git a/users/muppetjones/features/combos.c b/users/muppetjones/features/combos.c new file mode 100644 index 000000000000..9496973d2f65 --- /dev/null +++ b/users/muppetjones/features/combos.c @@ -0,0 +1,36 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#ifdef COMBO_ENABLE +# include QMK_KEYBOARD_H + +enum combos { + K_H_TAB, + H_COMM_TAB, + L_U_SCLN, +}; + +const uint16_t PROGMEM k_h_tab[] = {KC_K, KC_H, COMBO_END}; +const uint16_t PROGMEM h_comm_tab[] = {KC_H, KC_COMM, COMBO_END}; +const uint16_t PROGMEM l_u_scln[] = {KC_L, KC_U, COMBO_END}; + +// COMBO_COUNT defined in config.h +combo_t key_combos[COMBO_COUNT] = { + [K_H_TAB] = COMBO(k_h_tab, KC_TAB), + [H_COMM_TAB] = COMBO(h_comm_tab, KC_TAB), + [L_U_SCLN] = COMBO(l_u_scln, KC_SCLN), +}; +#endif diff --git a/users/muppetjones/features/combos.h b/users/muppetjones/features/combos.h new file mode 100644 index 000000000000..af092904e4f8 --- /dev/null +++ b/users/muppetjones/features/combos.h @@ -0,0 +1,17 @@ +/* Copyright 2020 Stephen J. Bush + * + * 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 . + */ + +#pragma once diff --git a/users/muppetjones/features/dancelayers.c b/users/muppetjones/features/dancelayers.c index a01ef85b4bcb..e7e5f2a6f242 100644 --- a/users/muppetjones/features/dancelayers.c +++ b/users/muppetjones/features/dancelayers.c @@ -20,11 +20,6 @@ # include "muppetjones.h" # include "dancelayers.h" -// typedef struct { -// bool is_press_action; -// td_state_t state; -// } td_tap_t; - // Initialize tap structure associated with example tap dance key static td_tap_t lyr_tap_state = {.is_press_action = true, .state = TD_NONE}; diff --git a/users/muppetjones/features/etchamouse.c b/users/muppetjones/features/etchamouse.c index 1c857afc960d..e1d4c38e81de 100644 --- a/users/muppetjones/features/etchamouse.c +++ b/users/muppetjones/features/etchamouse.c @@ -12,40 +12,7 @@ * * You should have received a copy of the GNU General Public License * along with this program. If not, see . - -# Description - -Use encoders to control mouse movement. Movement speed is determined by -how quickly and how many times you've "clicked" the encoder. Turning both -encoders together will yield diagonal movement. - -Several of the macros defined in quantum/mousekey.h are reused here. -However, the mouse movement is actually performed using the pointing_device -features instead. - -# Usage - -- Add the following to your rules.mk - - ENCODER_ENABLE = yes # Enables the use of one or more encoders - POINTING_DEVICE_ENABLE = yes - -- Add the following block to your keymap.c - - #ifdef ENCODER_ENABLE - void encoder_update_user(uint8_t index, bool clockwise) { - # ifdef POINTING_DEVICE_ENABLE - encoder_update_mouse(index, clockwise); - # endif - return; - #endif - -# Description - -- The faster you turn, the faster the mouse moves. -- The more turns for a given axis, the greater the movement on that axis. - -*/ + */ #include QMK_KEYBOARD_H #include "etchamouse.h" diff --git a/users/muppetjones/features/rgblayers.c b/users/muppetjones/features/rgblayers.c index e2a0785d26dd..46858ae671da 100644 --- a/users/muppetjones/features/rgblayers.c +++ b/users/muppetjones/features/rgblayers.c @@ -13,3 +13,57 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ + +#ifdef RGBLIGHT_ENABLE +# include QMK_KEYBOARD_H +# include "rgblayers.h" + +static rgblight_config_t home_rgb; + +__attribute__((weak)) void set_layer_hsv(layer_state_t state, HSV* offset) {} + +/* Placeholder function + * If defined in a keymap.c, this will be ignored. + */ +__attribute__((weak)) void post_process_record_keymap(uint16_t keycode, keyrecord_t* record) { return; } + +void post_process_record_user(uint16_t keycode, keyrecord_t* record) { + // Regular user keycode case statement + switch (keycode) { +# ifdef RGBLIGHT_ENABLE + case RGB_HUD: + case RGB_HUI: + case RGB_SAD: + case RGB_SAI: + case RGB_VAD: + case RGB_VAI: + set_rgb_home(); + break; +# endif + default: + break; + } +} + +void set_rgb_home(void) { + home_rgb.raw = eeconfig_read_rgblight(); + // these get the current -- not eeprom + // home_rgb.hue = rgblight_get_hue(); + // home_rgb.sat = rgblight_get_sat(); + // home_rgb.val = rgblight_get_val(); +} + +void set_rgb_by_layer(layer_state_t state) { + if (!rgblight_is_enabled()) { + return; // lighting not enabled + } + + HSV layer_color = {home_rgb.hue, home_rgb.sat, home_rgb.val}; + set_layer_hsv(state, &layer_color); + rgblight_sethsv_noeeprom( // + layer_color.h, // all 3 MUST be btwn 0 and 255 + layer_color.s, // + layer_color.v // + ); +} +#endif diff --git a/users/muppetjones/features/rgblayers.h b/users/muppetjones/features/rgblayers.h index e2a0785d26dd..35be7d7fe406 100644 --- a/users/muppetjones/features/rgblayers.h +++ b/users/muppetjones/features/rgblayers.h @@ -13,3 +13,10 @@ * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ + +#pragma once +#ifdef RGBLIGHT_ENABLE + +void set_rgb_by_layer(layer_state_t); +void set_rgb_home(void); +#endif diff --git a/users/muppetjones/muppetjones.h b/users/muppetjones/muppetjones.h index ef8e2ead152c..f5b2a3a4656e 100644 --- a/users/muppetjones/muppetjones.h +++ b/users/muppetjones/muppetjones.h @@ -21,10 +21,18 @@ #include "wrappers.h" #include "features/casemodes.h" +#ifdef COMBO_ENABLE +# include "features/combos.h" +#endif + #ifdef ENCODER_ENABLE # include "features/etchamouse.h" #endif +#ifdef RGBLIGHT_ENABLE +# include "features/rgblayers.h" +#endif + #ifdef TAP_DANCE_ENABLE # include "features/dancelayers.h" #endif diff --git a/users/muppetjones/readme/rgblayers.md b/users/muppetjones/readme/rgblayers.md index e69de29bb2d1..fb6980017764 100644 --- a/users/muppetjones/readme/rgblayers.md +++ b/users/muppetjones/readme/rgblayers.md @@ -0,0 +1,60 @@ +# Dynamic Underglow Lighting Per-Layer + +This bit of code allows you to define layer lighting that respects your current eeprom settings, e.g., brightness. It does this by storing the base state rgb + +## Setup + +1. Enable RGB underglow in your `rules.mk` + + ``` + RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow + ``` + +2. (Optional) Add RGB configuration to your `config.h` + + ``` + #ifdef RGBLIGHT_ENABLE + // # define RGBLIGHT_ANIMATIONS + # define RGBLIGHT_HUE_STEP 8 + # define RGBLIGHT_SAT_STEP 16 + # define RGBLIGHT_VAL_STEP 16 + # define RGBLIGHT_LIMIT_VAL 150 + # define RGBLIGHT_SLEEP + // # define RGBLIGHT_LAYERS + #endif + ``` + +3. Add `set_layer_hsv` function. This is where you define your layer-specific colors by setting the HSV properties on the `layer_color` pointer. This example uses the QMK RGB configuration parameters to keep the layer colors offset based on the current EEPROM HSV. + + > NOTE: The HSV values should be between 0 and 255, but setting the modulus on saturation causes the lights to go white on my board. I _think_ this is due to overflow, but I haven't had the chance to try and resolve it yet. + + + ``` + #ifdef RGBLIGHT_ENABLE + void set_layer_hsv(layer_state_t state, HSV* layer_color) { + int32_t h = layer_color->h, s = layer_color->s, v = layer_color->v; + switch (get_highest_layer(state)) { + case _RAISE: + h += 2 * RGBLIGHT_HUE_STEP; + break; + case _LOWER: + h += -2 * RGBLIGHT_HUE_STEP; + break; + case _NAV: + h += 1 * RGBLIGHT_HUE_STEP; + break; + case _MOUSE: + h += -7 * RGBLIGHT_HUE_STEP; + break; + default: + break; + } + layer_color->h = h % 255; + layer_color->s = s; + layer_color->v = v % 255; + return; + } + #endif + ``` + +4. (Optional) If you're using `post_process_record_user`, you'll need to change the name in your keymap to `post_process_record_keymap`. We use the user function to update the HSV state after one of the RGB keycodes is pressed. diff --git a/users/muppetjones/rules.mk b/users/muppetjones/rules.mk index 2dc9d4e26f68..1decc2ed98b1 100644 --- a/users/muppetjones/rules.mk +++ b/users/muppetjones/rules.mk @@ -8,10 +8,18 @@ LTO_ENABLE = yes SRC += muppetjones.c SRC += features/casemodes.c +ifdef COMBO_ENABLE + SRC += ./features/combos.c +endif + ifdef ENCODER_ENABLE SRC += ./features/etchamouse.c endif +ifdef RGBLIGHT_ENABLE + SRC += ./features/rgblayers.c +endif + ifdef TAP_DANCE_ENABLE SRC += ./features/dancelayers.c endif diff --git a/users/muppetjones/tapmods.h b/users/muppetjones/tapmods.h index e22a8270d1c4..6eb3846ef4d5 100644 --- a/users/muppetjones/tapmods.h +++ b/users/muppetjones/tapmods.h @@ -25,6 +25,7 @@ /* Misc */ #define HY_ESC HYPR_T(KC_ESC) +#define HY_BSPC HYPR_T(KC_BSPC) /* Tap Mod Layers */ @@ -60,3 +61,14 @@ NOTE: Uses GACS. #define HR_4 RSFT_T(KC_4) #define HR_5 RCTL_T(KC_5) #define HR_6 LALT_T(KC_6) + +// Layout-specific mods +#define TM_VSFT LSFT_T(KC_V) // For Using V in layer combos (e.g., planck) + +// GACS (Lower) +#define HR_LBRC LCTL_T(KC_LBRC) +#define HR_RBRC LSFT_T(KC_RBRC) + +// Left-hand home row mods (lower)--- +// #define HOME_UND LCTL_T(KC_UNDS) // NOTE: Mod-tap restricted to basic keycodes +#define HOME_MIN LSFT_T(KC_MINS) diff --git a/users/muppetjones/wrappers.h b/users/muppetjones/wrappers.h index 23f83da9f150..f601c5de275b 100644 --- a/users/muppetjones/wrappers.h +++ b/users/muppetjones/wrappers.h @@ -49,9 +49,10 @@ #define __BLANK_W_SCAG_____________________________ _______, KC_RSFT, KC_RCTL, KC_LALT, KC_RGUI /* Adjust */ +// NOTE: The "BACKLIT" keycode is planck specific #define __ADJUST_L1________________________________ RESET, DEBUG, XXXXXXX, TERM_ON, TERM_OFF #define __ADJUST_L2________________________________ RGB_TOG, RGB_HUI, RGB_SAI, RGB_VAI, RGB_MOD -#define __ADJUST_L3________________________________ BACKLIT, RGB_HUD, RGB_SAD, RGB_VAD, XXXXXXX +#define __ADJUST_L3________________________________ XXXXXXX, RGB_HUD, RGB_SAD, RGB_VAD, XXXXXXX #define __ADJUST_R1________________________________ XXXXXXX, AG_NORM, AG_SWAP, XXXXXXX, XXXXXXX #define __ADJUST_R2________________________________ XXXXXXX, CLMK_DH, QWERTY, XXXXXXX, XXXXXXX @@ -61,11 +62,57 @@ #define __COLEMAK_MOD_DH_L1________________________ KC_Q, KC_W, KC_F, KC_P, KC_B #define __COLEMAK_MOD_DH_L2_W_GACS_________________ HR_A, HR_R, HR_S, HR_T, KC_G #define __COLEMAK_MOD_DH_L3________________________ KC_Z, KC_X, KC_C, KC_D, KC_V +#define __COLEMAK_MOD_DH_L3_W_SFTV_________________ KC_Z, KC_X, KC_C, KC_D, TM_VSFT +#define __COLEMAK_MOD_DH_R1_W_QUOT_________________ KC_J, KC_L, KC_U, KC_Y, KC_QUOT #define __COLEMAK_MOD_DH_R1________________________ KC_J, KC_L, KC_U, KC_Y, KC_SCLN #define __COLEMAK_MOD_DH_R2_W_SCAG_________________ KC_M, HR_N, HR_E, HR_I, HR_O #define __COLEMAK_MOD_DH_R3________________________ KC_K, KC_H, KC_COMM, KC_DOT, KC_SLASH +/* Guitar + * ,----------------------------------. + * | Pg Up| Next | Prev | Brm+ | Vol+ | + * |------+------+------+------+------| + * | Pg Dn| Play | Stop | Brm- | Vol- | + * |------+------+------+------+------| + * | xxxx | xxxx | xxxx | xxxx | xxxx | + * `----------------------------------' + */ +// _______, _______, _______, _______, _______, _______ +// Not sure why, but this does not work +// #ifdef MIDI_ADVANCED +// #define __GUITAR_1E_L______________________________ MI_E_1, MI_F_1, MI_Fs_1, MI_G_1, MI_Gs_1 +// #define __GUITAR_2A_L______________________________ MI_A_1, MI_As_1, MI_B_1, MI_C_2, MI_Cs_2 +// #define __GUITAR_3D_L______________________________ MI_D_2, MI_Ds_2, MI_E_2, MI_F_2, MI_Fs_2 +// #define __GUITAR_4G_L______________________________ MI_G_2, MI_Gs_2, MI_A_2, MI_As_2, MI_B_2 +// #define __GUITAR_5B_L______________________________ MI_B_2, MI_C_3, MI_Cs_3, MI_D_3, MI_Ds_3 +// #define __GUITAR_6E_L______________________________ MI_E_3, MI_F_3, MI_Fs_3, MI_G_3, MI_Gs_3 +// +// #define __GUITAR_1E_R______________________________ MI_A_1, MI_As_1, MI_B_1, MI_C_2, MI_Cs_2 +// #define __GUITAR_2A_R______________________________ MI_D_2, MI_Ds_2, MI_E_2, MI_F_2, MI_Fs_2 +// #define __GUITAR_3D_R______________________________ MI_G_2, MI_Gs_2, MI_A_2, MI_As_2, MI_B_2 +// #define __GUITAR_4G_R______________________________ MI_C_3, MI_Cs_3, MI_D_3, MI_Ds_3, MI_E_3 +// #define __GUITAR_5B_R______________________________ MI_E_3, MI_F_3, MI_Fs_3, MI_G_3, MI_Gs_3 +// #define __GUITAR_6E_R______________________________ MI_A_3, MI_As_3, MI_B_3, MI_C_4, MI_Cs_4 +// #endif + + +/* MEDIA + * ,----------------------------------. + * | Pg Up| Next | Prev | Brm+ | Vol+ | + * |------+------+------+------+------| + * | Pg Dn| Play | Stop | Brm- | Vol- | + * |------+------+------+------+------| + * | xxxx | xxxx | xxxx | xxxx | xxxx | + * `----------------------------------' + */ +// What it MUV_IN and MUV_DE (5C2A and B)? +// https://github.com/qmk/qmk_firmware/blob/7e832e46de26989b81f2fbf58a0f391b2b0c1aaf/quantum/quantum_keycodes.h#L135 +#define __MEDIA_R1_________________________________ AU_ON, MI_ON, MU_ON, KC_BRMU, KC_VOLU +#define __MEDIA_R2_________________________________ AU_OFF, MI_OFF, MU_OFF, KC_BRMD, KC_VOLD +#define __MEDIA_R3_________________________________ KC_MPLY, KC_MSTP, KC_MNXT, KC_MPRV, KC_MUTE + + /* NAV * ,----------------------------------. * | Pg Up| Home | Wh Dn| Wh Up| End | @@ -106,5 +153,18 @@ #define __QWERTY_R2________________________________ KC_H, KC_J, KC_K, KC_L, KC_SCLN #define __QWERTY_R3________________________________ KC_N, KC_M, KC_COMM, KC_DOT, KC_SLASH +/* SYMBOLS + * ,----------------------------------. + * | ~ | ` | ( | ) | | + * |------+------+------+------+------| + * | LGUI | LALT |LCTL [|LSFT ]| _ - | + * |------+------+------+------+------| + * | xxxx | xxxx | { | } | LSFT | + * `----------------------------------' + */ + #define __SYMBOLS_L1_______________________________ KC_TILD, KC_GRV, KC_LPRN, KC_RPRN, XXXXXXX + #define __SYMBOLS_L2_______________________________ KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_UNDS + #define __SYMBOLS_L3_______________________________ XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT + // clang-format on // __END__ From f126e1efcc0848d72c46783a6878afb54e73be8c Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Sat, 31 Jul 2021 12:31:35 -0500 Subject: [PATCH 08/22] Little more cleanup. --- keyboards/planck/keymaps/muppetjones/config.h | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/keyboards/planck/keymaps/muppetjones/config.h b/keyboards/planck/keymaps/muppetjones/config.h index b4f5edf366de..6fbcbc1c9af2 100644 --- a/keyboards/planck/keymaps/muppetjones/config.h +++ b/keyboards/planck/keymaps/muppetjones/config.h @@ -12,9 +12,6 @@ * MIDI options */ -/* Prevent use of disabled MIDI features in the keymap */ -//#define MIDI_ENABLE_STRICT 1 - /* enable basic MIDI features: - MIDI notes can be sent when in Music mode is on */ @@ -29,11 +26,9 @@ */ //#define MIDI_ADVANCED -/* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ -//#define MIDI_TONE_KEYCODE_OCTAVES 2 - -// Most tactile encoders have detents every 4 stages -#define ENCODER_RESOLUTION 4 +/* + * Other options + */ // Enable lighting layers #define RGBLIGHT_LAYERS From b435568b05de6e13173c75f2f6fd26c4acf8314b Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Mon, 23 Aug 2021 23:57:08 -0500 Subject: [PATCH 09/22] Update keyboards/lily58/keymaps/muppetjones/rules.mk Co-authored-by: Ryan --- keyboards/lily58/keymaps/muppetjones/rules.mk | 4 ---- 1 file changed, 4 deletions(-) diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index efcc50278320..f4f9c28b438d 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -1,7 +1,3 @@ -# Build Options -# change to "no" to disable the options, or define them in the Makefile in -# the appropriate keymap folder that will get included automatically - OLED_DRIVER_ENABLE= yes # OLED display WPM_ENABLE = yes TAP_DANCE_ENABLE = yes From 61f0b5957731e0f0401d5a07fcf106c4327c6771 Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Tue, 24 Aug 2021 15:57:02 -0500 Subject: [PATCH 10/22] Rollback accidental libchibios update --- lib/chibios | 2 +- lib/chibios-contrib | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/chibios b/lib/chibios index 313416b8fda9..ffe54d63cb10 160000 --- a/lib/chibios +++ b/lib/chibios @@ -1 +1 @@ -Subproject commit 313416b8fda90d9973a749a0a35970956852c286 +Subproject commit ffe54d63cb10a355add318f8e922e39f1c3d4bfd diff --git a/lib/chibios-contrib b/lib/chibios-contrib index e3a3a2404771..61baa6b03613 160000 --- a/lib/chibios-contrib +++ b/lib/chibios-contrib @@ -1 +1 @@ -Subproject commit e3a3a24047717af33b098266e11c2e4e5102206a +Subproject commit 61baa6b036138c155f7cfc5646d833d9423f3243 From 3cd082d24f554a0a8fdffabecab0f0cf9f9d8e11 Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Sun, 20 Mar 2022 11:29:18 -0500 Subject: [PATCH 11/22] Apply suggestions from code review Co-authored-by: Drashna Jaelre --- keyboards/kyria/keymaps/muppetjones/config.h | 2 +- .../lily58/keymaps/muppetjones/features/bongo_cat.c | 12 +----------- keyboards/lily58/keymaps/muppetjones/keymap.c | 5 +++-- keyboards/lily58/keymaps/muppetjones/rules.mk | 2 +- keyboards/planck/keymaps/muppetjones/config.h | 12 ++++++++++++ 5 files changed, 18 insertions(+), 15 deletions(-) diff --git a/keyboards/kyria/keymaps/muppetjones/config.h b/keyboards/kyria/keymaps/muppetjones/config.h index 49b5e768ac97..73d13d1d61b9 100644 --- a/keyboards/kyria/keymaps/muppetjones/config.h +++ b/keyboards/kyria/keymaps/muppetjones/config.h @@ -16,7 +16,7 @@ #pragma once -#ifdef OLED_DRIVER_ENABLE +#ifdef OLED_ENABLE # define OLED_DISPLAY_128X64 #endif diff --git a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c index 4b8747c5f048..23f6493efc6a 100644 --- a/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c +++ b/keyboards/lily58/keymaps/muppetjones/features/bongo_cat.c @@ -9,7 +9,7 @@ WPM-responsive animation of bongo cat! #include QMK_KEYBOARD_H -#ifdef OLED_DRIVER_ENABLE +#ifdef OLED_ENABLE # define IDLE_FRAMES 5 # define IDLE_SPEED 30 // below this wpm value your animation will idle @@ -28,7 +28,6 @@ uint32_t anim_sleep = 0; uint8_t current_idle_frame = 0; // uint8_t current_prep_frame = 0; // uncomment if PREP_FRAMES >1 uint8_t current_tap_frame = 0; -char wpm_str[12]; /* Animation */ @@ -91,15 +90,6 @@ static const char PROGMEM ANIM_TAP[TAP_FRAMES][ANIM_SIZE] = { /* Functions */ -const char *wpm_state(void) { - uint8_t n = get_current_wpm(); - // index: 01234567 - char *wpm_counter = "WPM: "; - wpm_counter[7] = '0' + n % 10; - wpm_counter[6] = (n /= 10) % 10 ? '0' + (n) % 10 : (n / 10) % 10 ? '0' : ' '; - wpm_counter[5] = n / 10 ? '0' + n / 10 : ' '; - return wpm_counter; -} void animation_phase(uint8_t wpm) { // NOTE: Optimized the conditional. We don't need to recheck each. diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index 4f20dbf0d73d..a40ab56de458 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -206,7 +206,7 @@ const char *read_layer_state_user(void) { return layer_state_str; } -void oled_task_user(void) { +bool oled_task_user(void) { if (is_keyboard_master()) { // If you want to change the display of OLED, you need to change here oled_write_ln(read_layer_state_user(), false); @@ -215,7 +215,8 @@ void oled_task_user(void) { } else { render_bongo_cat(); oled_set_cursor(0, 6); - oled_write(wpm_state(), false); + oled_write_P(WPM: " false); + oled_write(get_u8_str(get_current_wpm(), ' '), false); } } #endif // OLED_DRIVER_ENABLE diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index f4f9c28b438d..1761f2971cee 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -1,4 +1,4 @@ -OLED_DRIVER_ENABLE= yes # OLED display +OLED_ENABLE= yes # OLED display WPM_ENABLE = yes TAP_DANCE_ENABLE = yes COMBO_ENABLE = yes diff --git a/keyboards/planck/keymaps/muppetjones/config.h b/keyboards/planck/keymaps/muppetjones/config.h index 6fbcbc1c9af2..1046d214991d 100644 --- a/keyboards/planck/keymaps/muppetjones/config.h +++ b/keyboards/planck/keymaps/muppetjones/config.h @@ -1,3 +1,15 @@ + /* Copyright 2020 Stephen Bush + * + * 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. + */ #pragma once #ifdef AUDIO_ENABLE From c22d91eed47d49c4f492bdab184c186d3744de73 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 11:51:22 -0500 Subject: [PATCH 12/22] Update kyria keymap --- keyboards/kyria/keymaps/muppetjones/config.h | 6 ++-- keyboards/kyria/keymaps/muppetjones/keymap.c | 38 ++++++++++---------- keyboards/kyria/keymaps/muppetjones/rules.mk | 2 +- 3 files changed, 23 insertions(+), 23 deletions(-) diff --git a/keyboards/kyria/keymaps/muppetjones/config.h b/keyboards/kyria/keymaps/muppetjones/config.h index 73d13d1d61b9..92d495be4aa9 100644 --- a/keyboards/kyria/keymaps/muppetjones/config.h +++ b/keyboards/kyria/keymaps/muppetjones/config.h @@ -36,7 +36,8 @@ // Change "hold" time (default is 200 ms) // -- used for tap dance and other tap mods -#define TAPPING_TERM 200 +// -- defined in user namespace +// #define TAPPING_TERM 200 // Prevent normal rollover on alphas from accidentally triggering mods. #define IGNORE_MOD_TAP_INTERRUPT @@ -56,5 +57,4 @@ // Allows media codes to properly register in macros and rotary encoder code #define TAP_CODE_DELAY 10 - -#define COMBO_COUNT 1 +#define COMBO_TERM 40 diff --git a/keyboards/kyria/keymaps/muppetjones/keymap.c b/keyboards/kyria/keymaps/muppetjones/keymap.c index a5164c3f3f84..71a3f6068cdd 100644 --- a/keyboards/kyria/keymaps/muppetjones/keymap.c +++ b/keyboards/kyria/keymaps/muppetjones/keymap.c @@ -58,10 +58,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------------' `----------------------------------' */ [_CLMK_DH] = LAYOUT_wrapper( - CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, + CAPSWRD, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1_W_QUOT_________________, KC_BSLS, HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, TD_LAYR, __COLEMAK_MOD_DH_L3________________________, KC_LSFT, KC_LEAD, KC_DEL, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, - KC_MUTE, KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, RAI_TAB, KC_RALT + KC_MUTE, KC_DEL, HY_ESC, LOW_BSP, RAI_ENT, KC_BSPC, NAV_SPC, HY_ESC, RAI_TAB, KC_RALT ), [_QWERTY] = LAYOUT_wrapper( _______, __QWERTY_L1________________________________, __QWERTY_R1________________________________, _______, @@ -91,9 +91,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { */ [_LOWER] = LAYOUT_wrapper( _______, __SYMBOLS_L1_______________________________, __NUMPAD_R1________________________________, _______, - _______, __SYMBOLS_L2_______________________________, __NUMPAD_R2________________________________, KC_PLUS, - _______, __SYMBOLS_L3_______________________________, _______, _______, _______, _______, __NUMPAD_R3________________________________, _______, - __BLANK____________________________________, _______, _______, KC_0, KC_DOT, _______ + _______, __SYMBOLS_L2_______________________________, __NUMPAD_R2________________________________, KC_COMM, + _______, __SYMBOLS_L3_______________________________, _______, _______, _______, _______, __NUMPAD_R3________________________________, KC_DOT, + __BLANK____________________________________, _______, KC_SPC, KC_0, KC_DOT, _______ ), /* * Raise Layer: Symbols @@ -116,9 +116,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { // _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ // ), [_RAISE] = LAYOUT_wrapper( - _______, XXXXXXX, XXXXXXX, KC_GRV, KC_GRV, KC_BSLS, XXXXXXX, XXXXXXX, KC_LPRN, KC_RPRN, KC_ASTR, _______, - _______, XXXXXXX, XXXXXXX, KC_UNDS, KC_MINS, KC_TILD, KC_UNDS, KC_MINS, KC_LBRC, KC_RBRC, KC_PERC, _______, - _______, XXXXXXX, XXXXXXX, KC_PLUS, KC_EQL, KC_GRV, _______, _______, _______, _______, KC_PLUS, KC_EQL, KC_LCBR, KC_RCBR, XXXXXXX, _______, + _______, XXXXXXX, XXXXXXX, KC_GRV, KC_GRV, KC_BSLS, __SYMBOLS_R1_______________________________, _______, + _______, XXXXXXX, XXXXXXX, KC_UNDS, KC_MINS, KC_TILD, __SYMBOLS_R2_______________________________, _______, + _______, XXXXXXX, XXXXXXX, KC_PLUS, KC_EQL, KC_GRV, _______, _______, _______, _______, __SYMBOLS_R3_______________________________, _______, __BLANK____________________________________, __BLANK____________________________________ ), /* @@ -136,16 +136,16 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------------' `----------------------------------' */ [_NAV] = LAYOUT_wrapper( - _______, __SYMBOLS_L1_______________________________, __NAV_R1___________________________________, KC_SLCK, - _______, __SYMBOLS_L2_______________________________, __NAV_R2___________________________________, KC_CAPS, - _______, __SYMBOLS_L3_______________________________, _______, _______, _______, _______, __NAV_R3___________________________________, _______, + _______, __VIM_L1___________________________________, __NAV_R1___________________________________, KC_SLCK, + _______, __BLANK_W_GACS_____________________________, __NAV_R2___________________________________, KC_CAPS, + _______, __BLANK____________________________________, _______, _______, _______, _______, __NAV_R3___________________________________, _______, __BLANK____________________________________, __BLANK____________________________________ ), /* * Adjust Layer: Function keys, RGB * * ,-------------------------------------------. ,-------------------------------------------. - * | RESET | | | | | | | | F1 | F2 | F3 | F4 | | + * | RESET |RESET |DEBUG | | | | | | F1 | F2 | F3 | F4 | | * |--------+------+------+------+------+------| |------+------+------+------+------+--------| * | | TOG | SAI | HUI | VAI | MOD | | | F5 | F6 | F7 | F8 | | * |--------+------+------+------+------+------+-------------. ,-------------+------+------+------+------+------+--------| @@ -156,9 +156,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * `----------------------------------' `----------------------------------' */ [_ADJUST] = LAYOUT_wrapper( - RESET, _______, _______, _______, _______, _______, _______, KC_F1, KC_F2, KC_F3, KC_F4, _______, - _______, RGB_TOG, RGB_SAI, RGB_HUI, RGB_VAI, RGB_MOD, _______, KC_F5, KC_F6, KC_F7, KC_F8, _______, - _______, _______, RGB_SAD, RGB_HUD, RGB_VAD, RGB_RMOD,_______, _______, _______, _______, _______, KC_F9, KC_F10, KC_F11, KC_F12, _______, + RESET, __ADJUST_L1________________________________, __MEDIA_R1_________________________________, _______, + _______, __ADJUST_L2________________________________, __MEDIA_R2_________________________________, _______, + _______, __ADJUST_L3________________________________, _______, _______, _______, _______, __MEDIA_R3_________________________________, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ ) // /* @@ -255,16 +255,16 @@ void set_layer_hsv(layer_state_t state, HSV* layer_color) { int32_t h = layer_color->h, s = layer_color->s, v = layer_color->v; switch (get_highest_layer(state)) { case _RAISE: - h += 2 * RGBLIGHT_HUE_STEP; + h += 3 * RGBLIGHT_HUE_STEP; break; case _LOWER: - h += -2 * RGBLIGHT_HUE_STEP; + h += -3 * RGBLIGHT_HUE_STEP; break; case _NAV: - h += 1 * RGBLIGHT_HUE_STEP; + h += 2 * RGBLIGHT_HUE_STEP; break; case _MOUSE: - h += -7 * RGBLIGHT_HUE_STEP; + h += -8 * RGBLIGHT_HUE_STEP; break; default: break; diff --git a/keyboards/kyria/keymaps/muppetjones/rules.mk b/keyboards/kyria/keymaps/muppetjones/rules.mk index 68ba6ae4f14b..b7e46ecfd200 100644 --- a/keyboards/kyria/keymaps/muppetjones/rules.mk +++ b/keyboards/kyria/keymaps/muppetjones/rules.mk @@ -1,4 +1,4 @@ -OLED_DRIVER_ENABLE = no # Enables the use of OLED displays +OLED_ENABLE = no # Enables the use of OLED displays ENCODER_ENABLE = yes # Enables the use of one or more encoders RGBLIGHT_ENABLE = yes # Enable keyboard RGB underglow LEADER_ENABLE = yes # Enable the Leader Key feature From fd8e886efb171ec63e3915b005544edb74cad6e4 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 11:53:48 -0500 Subject: [PATCH 13/22] Move kyria keymap to splitkb/kyria --- keyboards/{ => splitkb}/kyria/keymaps/muppetjones/.clang-format | 0 keyboards/{ => splitkb}/kyria/keymaps/muppetjones/README.md | 0 keyboards/{ => splitkb}/kyria/keymaps/muppetjones/config.h | 0 keyboards/{ => splitkb}/kyria/keymaps/muppetjones/keymap.c | 0 keyboards/{ => splitkb}/kyria/keymaps/muppetjones/rules.mk | 0 5 files changed, 0 insertions(+), 0 deletions(-) rename keyboards/{ => splitkb}/kyria/keymaps/muppetjones/.clang-format (100%) rename keyboards/{ => splitkb}/kyria/keymaps/muppetjones/README.md (100%) rename keyboards/{ => splitkb}/kyria/keymaps/muppetjones/config.h (100%) rename keyboards/{ => splitkb}/kyria/keymaps/muppetjones/keymap.c (100%) rename keyboards/{ => splitkb}/kyria/keymaps/muppetjones/rules.mk (100%) diff --git a/keyboards/kyria/keymaps/muppetjones/.clang-format b/keyboards/splitkb/kyria/keymaps/muppetjones/.clang-format similarity index 100% rename from keyboards/kyria/keymaps/muppetjones/.clang-format rename to keyboards/splitkb/kyria/keymaps/muppetjones/.clang-format diff --git a/keyboards/kyria/keymaps/muppetjones/README.md b/keyboards/splitkb/kyria/keymaps/muppetjones/README.md similarity index 100% rename from keyboards/kyria/keymaps/muppetjones/README.md rename to keyboards/splitkb/kyria/keymaps/muppetjones/README.md diff --git a/keyboards/kyria/keymaps/muppetjones/config.h b/keyboards/splitkb/kyria/keymaps/muppetjones/config.h similarity index 100% rename from keyboards/kyria/keymaps/muppetjones/config.h rename to keyboards/splitkb/kyria/keymaps/muppetjones/config.h diff --git a/keyboards/kyria/keymaps/muppetjones/keymap.c b/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c similarity index 100% rename from keyboards/kyria/keymaps/muppetjones/keymap.c rename to keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c diff --git a/keyboards/kyria/keymaps/muppetjones/rules.mk b/keyboards/splitkb/kyria/keymaps/muppetjones/rules.mk similarity index 100% rename from keyboards/kyria/keymaps/muppetjones/rules.mk rename to keyboards/splitkb/kyria/keymaps/muppetjones/rules.mk From 47e7ea10fdad0abcca1b9913e99fefa2d7c01f95 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 11:56:32 -0500 Subject: [PATCH 14/22] Update planck keymap --- keyboards/planck/keymaps/muppetjones/keymap.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/keyboards/planck/keymaps/muppetjones/keymap.c b/keyboards/planck/keymaps/muppetjones/keymap.c index 9b0dbe7cf834..518ab4323313 100644 --- a/keyboards/planck/keymaps/muppetjones/keymap.c +++ b/keyboards/planck/keymaps/muppetjones/keymap.c @@ -123,9 +123,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { * 21.03.28: Completely revamped to contain 10-key numpad and symbols. */ [_LOWER] = LAYOUT_planck_wrapper( - KC_TILD, KC_GRV, KC_LPRN, KC_RPRN, KC_TILD, _______, _______, __NUMPAD_R1________________________________, - KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_GRV, _______, _______, __NUMPAD_R2________________________________, - XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT, _______, _______, __NUMPAD_R3________________________________, + __SYMBOLS_L1_______________________________, _______, _______, __NUMPAD_R1________________________________, + __SYMBOLS_L2_______________________________, _______, _______, __NUMPAD_R2________________________________, + __SYMBOLS_L3_______________________________, _______, _______, __NUMPAD_R3________________________________, _______, _______, _______, _______, _______, _______, _______, __NUMPAD_R4________________________________ ), From e1b4a494421cfad7ad8d2f2bbc77f312c4c66e81 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 11:57:56 -0500 Subject: [PATCH 15/22] Remove all changes to keyboards/lily58/lib/layer_state_reader.c --- keyboards/lily58/lib/layer_state_reader.c | 39 +++++++++++------------ 1 file changed, 19 insertions(+), 20 deletions(-) diff --git a/keyboards/lily58/lib/layer_state_reader.c b/keyboards/lily58/lib/layer_state_reader.c index 022e71f8d994..0e9dd7039bb6 100644 --- a/keyboards/lily58/lib/layer_state_reader.c +++ b/keyboards/lily58/lib/layer_state_reader.c @@ -7,30 +7,29 @@ #define L_LOWER (1 << 1) #define L_RAISE (1 << 2) #define L_ADJUST (1 << 3) -#define L_ADJUST_DUO (L_RAISE | L_LOWER) #define L_ADJUST_TRI (L_ADJUST | L_RAISE | L_LOWER) char layer_state_str[24]; const char *read_layer_state(void) { - switch (layer_state) { - case L_BASE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); - break; - case L_RAISE: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); - break; - case L_LOWER: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); - break; - case L_ADJUST: - case L_ADJUST_DUO: - case L_ADJUST_TRI: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); - break; - default: - snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); - } + switch (layer_state) + { + case L_BASE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default"); + break; + case L_RAISE: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise"); + break; + case L_LOWER: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower"); + break; + case L_ADJUST: + case L_ADJUST_TRI: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust"); + break; + default: + snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state); + } - return layer_state_str; + return layer_state_str; } From 4dcec9d97e504cc85e67750bb4269debafa1807f Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 12:02:19 -0500 Subject: [PATCH 16/22] Update lily58 keymap --- keyboards/lily58/keymaps/muppetjones/keymap.c | 14 +++++++------- keyboards/lily58/keymaps/muppetjones/rules.mk | 1 + 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index a40ab56de458..ef552f39a19c 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -46,10 +46,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { */ [_CLMK_DH] = LAYOUT_wrapper( KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_CAPS, __BLANK____________________________________, KC_BSPC, - KC_CAPS, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1________________________, KC_BSLS, + KC_CAPS, __COLEMAK_MOD_DH_L1________________________, __COLEMAK_MOD_DH_R1_W_QUOT_________________, KC_BSPC, HY_ESC, __COLEMAK_MOD_DH_L2_W_GACS_________________, __COLEMAK_MOD_DH_R2_W_SCAG_________________, KC_QUOT, TD_LAYR, __COLEMAK_MOD_DH_L3_W_SFTV_________________, KC_CAPS, KC_TAB, __COLEMAK_MOD_DH_R3________________________, KC_SFTENT, - KC_DEL, HY_ESC, LOW_SPC, RAI_ENT, HY_BSPC, NAV_SPC, HY_ESC, KC_BSPC + XXXXXXX, XXXXXXX, HY_ESC, LOW_ENT, NAV_SPC, HY_BSPC, XXXXXXX, XXXXXXX ), /* QWERTY @@ -97,10 +97,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { */ [_LOWER] = LAYOUT_wrapper( _______, __BLANK____________________________________, __BLANK____________________________________, _______, - _______, __BLANK____________________________________, __NUMPAD_R1________________________________, _______, - _______, __BLANK_W_GACS_____________________________, __NUMPAD_R2________________________________, KC_PLUS, - _______, __BLANK____________________________________, _______, _______, __NUMPAD_R3________________________________, _______, - __BLANK____________________________________, KC_0, KC_DOT, _______ + _______, __SYMBOLS_L1_______________________________, __NUMPAD_R1________________________________, _______, + _______, __SYMBOLS_L2_______________________________, __NUMPAD_R2________________________________, KC_COMM, + _______, __SYMBOLS_L3_______________________________, _______, _______, __NUMPAD_R3________________________________, KC_DOT, + _______, _______, _______, _______, KC_SPC, KC_0, KC_DOT, _______ ), /* RAISE * ,-----------------------------------------. ,-----------------------------------------. @@ -126,7 +126,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { ), [_NAV] = LAYOUT_wrapper( _______, __BLANK____________________________________, __BLANK____________________________________, _______, - _______, __BLANK____________________________________, __NAV_R1___________________________________, _______, + _______, __VIM_L1___________________________________, __NAV_R1___________________________________, _______, _______, __BLANK_W_GACS_____________________________, __NAV_R2___________________________________, _______, _______, __BLANK____________________________________, _______, _______, __NAV_R3___________________________________, _______, _______, _______, _______, _______, _______, _______, _______, _______ diff --git a/keyboards/lily58/keymaps/muppetjones/rules.mk b/keyboards/lily58/keymaps/muppetjones/rules.mk index 1761f2971cee..1323bea8935a 100644 --- a/keyboards/lily58/keymaps/muppetjones/rules.mk +++ b/keyboards/lily58/keymaps/muppetjones/rules.mk @@ -2,6 +2,7 @@ OLED_ENABLE= yes # OLED display WPM_ENABLE = yes TAP_DANCE_ENABLE = yes COMBO_ENABLE = yes +EXTRAKEY_ENABLE = yes # If you want to change the display of OLED, you need to change here # SRC += ./lib/rgb_state_reader.c From 7cb370b26f244e1f9b33be960e6f9723848d34a2 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 12:07:51 -0500 Subject: [PATCH 17/22] Recommended change --- keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c b/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c index 71a3f6068cdd..63dca952d580 100644 --- a/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c +++ b/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c @@ -252,7 +252,7 @@ bool encoder_update_standard(uint8_t index, bool clockwise) { #ifdef RGBLIGHT_ENABLE void set_layer_hsv(layer_state_t state, HSV* layer_color) { - int32_t h = layer_color->h, s = layer_color->s, v = layer_color->v; + uint16_t h = layer_color->h, s = layer_color->s, v = layer_color->v; switch (get_highest_layer(state)) { case _RAISE: h += 3 * RGBLIGHT_HUE_STEP; From b2d719e2e6eb07c3362650ce882277fafe75b5e9 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 12:12:59 -0500 Subject: [PATCH 18/22] Update keymap readme --- keyboards/splitkb/kyria/keymaps/muppetjones/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/keyboards/splitkb/kyria/keymaps/muppetjones/README.md b/keyboards/splitkb/kyria/keymaps/muppetjones/README.md index 663ccdc77cee..20fdd470251a 100644 --- a/keyboards/splitkb/kyria/keymaps/muppetjones/README.md +++ b/keyboards/splitkb/kyria/keymaps/muppetjones/README.md @@ -3,9 +3,9 @@ ## Compile ```shell -make kyria:muppetjones:avrdude-split-left +make splitkb/kyria/rev1:muppetjones:avrdude-split-left ``` ```shell -make kyria:muppetjones:avrdude-split-right +make splitkb/kyria/rev1:muppetjones:avrdude-split-right ``` From 330e138278fbf34db75c7fccbe8d662ae9c7b8d6 Mon Sep 17 00:00:00 2001 From: Stephen Bush Date: Sun, 20 Mar 2022 12:33:41 -0500 Subject: [PATCH 19/22] Update kyria keymap and userspace --- .../kyria/keymaps/muppetjones/keymap.c | 1 - users/muppetjones/config.h | 3 +- users/muppetjones/features/combos.c | 6 +- users/muppetjones/readme/wrappers.md | 153 ++++++++++++++++++ users/muppetjones/tapmods.h | 3 + users/muppetjones/wrappers.h | 147 +++++++++++++---- 6 files changed, 274 insertions(+), 39 deletions(-) create mode 100644 users/muppetjones/readme/wrappers.md diff --git a/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c b/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c index 63dca952d580..ca4a3063412c 100644 --- a/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c +++ b/keyboards/splitkb/kyria/keymaps/muppetjones/keymap.c @@ -16,7 +16,6 @@ #include QMK_KEYBOARD_H #include "muppetjones.h" #include "rgblight.h" -#include #define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h index 297106a84a99..63447fb41817 100644 --- a/users/muppetjones/config.h +++ b/users/muppetjones/config.h @@ -29,7 +29,7 @@ #ifdef TAP_DANCE_ENABLE // Change "hold" time (default is 200 ms) // -- used for tap dance and other tap mods -# define TAPPING_TERM 200 +# define TAPPING_TERM 175 // Prevent normal rollover on alphas from accidentally triggering mods. # define IGNORE_MOD_TAP_INTERRUPT @@ -46,3 +46,4 @@ #define NO_ACTION_FUNCTION #define COMBO_COUNT 3 +#define COMBO_TERM 40 diff --git a/users/muppetjones/features/combos.c b/users/muppetjones/features/combos.c index 9496973d2f65..a6d14bb25c79 100644 --- a/users/muppetjones/features/combos.c +++ b/users/muppetjones/features/combos.c @@ -18,19 +18,19 @@ # include QMK_KEYBOARD_H enum combos { - K_H_TAB, H_COMM_TAB, L_U_SCLN, + J_M_CAPS, }; -const uint16_t PROGMEM k_h_tab[] = {KC_K, KC_H, COMBO_END}; const uint16_t PROGMEM h_comm_tab[] = {KC_H, KC_COMM, COMBO_END}; const uint16_t PROGMEM l_u_scln[] = {KC_L, KC_U, COMBO_END}; +const uint16_t PROGMEM j_m_caps[] = {KC_J, KC_M, COMBO_END}; // COMBO_COUNT defined in config.h combo_t key_combos[COMBO_COUNT] = { - [K_H_TAB] = COMBO(k_h_tab, KC_TAB), [H_COMM_TAB] = COMBO(h_comm_tab, KC_TAB), [L_U_SCLN] = COMBO(l_u_scln, KC_SCLN), + [J_M_CAPS] = COMBO(j_m_caps, KC_CAPS), }; #endif diff --git a/users/muppetjones/readme/wrappers.md b/users/muppetjones/readme/wrappers.md new file mode 100644 index 000000000000..e8365ab7addc --- /dev/null +++ b/users/muppetjones/readme/wrappers.md @@ -0,0 +1,153 @@ +# Keymap Wrappers + +> Pattern adapted from users/drashna/wrapper.h + +Defines several object macros for common keycode sets. Each macro typically +covers 5 keycodes with a left- or right-hand orientation, and macros are +generally grouped into rows of three or four. + +> TODO: Use keymap builder to generate images. + +## Example + +``` +#define LAYOUT_wrapper(...) LAYOUT(__VA_ARGS__) + +const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { +// clang-format off +[_MODS] = LAYOUT_wrapper( + _______, ___________________BLANK___________________, ... + ... +), +//clang-format on +} +``` + +Substitute the appropriate `LAYOUT` function, e.g., `LAYOUT_planck_grid` for your board. + +## Wrappers + +> **How to Read the Tables** +> +> - Headers are numbered when wrapper is not hand-specific +> - Headers use `L` and `R` to indicate handedness +> - Headers use `P`, `R`, `M`, and `I` to indicate pinky, ring, middle, and index, respectively +> - Wrappers define a maximum of **five** keycodes -- hands are shown on the same row for readability + +### Alpha: Colemak mod-DH + +| # | LP | LR | LM | LI | LI+ | RI+ | RI | RM | RR | RP | +| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | +| 1 | Q | W | F | P | B | J | L | U | Y | ;ˆ | +| 2 | A° | R° | S° | T° | G | M | N° | E° | I° | O° | +| 3 | Z | X | C | D | V˜ | K | H | , | . | / | + +- **ˆ:** (Optional) Replace `;` with `'` (top-right) +- **°:** (Optional) Home row modifiers on tap-hold (GACS, SCAG) +- **˜:** (Optional) Tap-hold `shift` on `v` + +### Alpha: QWERTY + +| # | LP | LR | LM | LI | LI+ | RI+ | RI | RM | RR | RP | +| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | +| 1 | Q | W | E | R | T | Y | U | I | O | P | +| 2 | A | S | D | F | G | H | J | K | L | ; | +| 3 | Z | X | C | V | B | N | M | , | . | / | + +### Blank(-ish) + +Defines macros for common filler. + +| 1 | 2 | 3 | 4 | 5 | +| ---- | ---- | ---- | ---- | ---- | +| TRNS | TRNS | TRNS | TRNS | TRNS | +| xxxx | xxxx | xxxx | xxxx | xxxx | + +| LP | LR | LM | LI | LI+ | RI+ | RI | RM | RR | RP | +| ---- | ---- | ---- | ---- | ---- | ---- | ---- | ---- | ---- | ---- | +| LGUI | LALT | LCTL | LSFT | TRNS | TRNS | RSFT | RCTL | LALT | RGUI | + +### Adjust + +| # | LP | LR | LM | LI | LI+ | RI+ | RI | RM | RR | RP | +| --- | ------ | ----- | ---- | ----- | ------ | ---- | ------ | ------ | ---- | ---- | +| 1 | Reset | Debug | xxxx | Term+ | Term- | xxxx | AGNORM | AGSWAP | xxxx | xxxx | +| 2 | RgbTog | Hue+ | Sat+ | Val+ | RgbMod | xxxx | CLMKDH | QWERTY | xxxx | xxxx | +| 3 | xxxx | Hue- | Sat- | Val- | xxxx | xxxx | xxxx | xxxx | xxxx | xxxx | + +> Recommend: Define Right side per-board + +### Function + +| # | 1 | 2 | 3 | 4 | +| --- | --- | --- | --- | --- | +| 1 | F1 | F2 | F3 | F4 | +| 2 | F5 | F6 | F7 | F8 | +| 3 | F9 | F10 | F11 | F12 | + +### Media + +| # | 1 | 2 | 3 | 4 | 5 | +| --- | ----- | ----- | ----- | ---- | ---- | +| 1 | AuOn | MiOn | MuOn | Brm+ | Vol+ | +| 2 | AuOff | MiOff | MuOff | Brm- | Vol- | +| 3 | Play | Stop | Next | Prev | Mute | + +### Nav + +| # | RI+ | RI | RM | RR | RP | +| --- | ----- | ---- | ----- | ----- | ----- | +| 1 | Pg Up | Home | Wh Dn | Wh Up | End | +| 2 | Pg Dn | Left | Down | Up | Right | +| 3 | xxxx | xxxx | xxxx | xxxx | xxxx | + +### Numpad + +- `X Y` indicates the character `X` on keypress and character `Y` on `shift` keypress +- Second table shows characters with `alt` keypress + +| # | RI+ | RI | RM | RR | RP | +| --- | ----- | ----- | ----- | ----- | ----- | +| 1 | Del | `7 &` | `8 _` | `9 (` | | +| 2 | `- _` | `4 $` | `5 %` | `6 ^` | `*` | +| 3 | `= +` | `1 !` | `2 @` | `3 #` | `, <` | +| 4 | | `0 )` | `. >` | | | + +| # | RI+ | RI | RM | RR | RP | +| --- | ----- | ----- | ----- | ----- | ----- | +| 1 | | `¶ ‡` | `• °` | `ª ·` | `« »` | +| 2 | `– —` | `¢ ›` | `∞ fi` | `§ fl` | `° °` | +| 3 | `≠ ±` | `¡ ⁄` | `™ €` | `£ ‹` | `≤ ¯` | +| 4 | | | `º ‚` | | | + +### Symbols + +| # | LP | LR | LM | LI | LI+ | +| --- | ---- | ---- | ---- | ---- | ---- | +| 1 | ~ | \` | ( | ) | | +| 2 | LGUI | LALT | \[ ° | \] ° | \_ - | +| 3 | xxxx | xxxx | { | } | LSFT | + +- **°:** Home row modifiers on tap-hold (GACS, SCAG) + +### VIM + +| # | LP | LR | LM | LI | LI+ | +| --- | --- | --- | --- | --- | --- | +| 1 | Q° | W° | : | | | + +- **°:** Via transparency + +## Typical Layers + +My keymaps typically use the following layers. + +| # | Name | Via | Left | Right | +| --- | ---------- | ------------- | --------- | ------ | +| 0 | Colemak DH | Adjust | | | +| 1 | QWERTY | Adjust | | | +| 2 | Mouse | tap-dance | n/a | n/a | +| 3 | Lower | L home thumb | symbols | numpad | +| 4 | Raise | L outer thumb | | | +| 5 | Nav | R home thumb | home mods | nav | +| 6 | Adjust | tap-dance | RGB | MEDIA | diff --git a/users/muppetjones/tapmods.h b/users/muppetjones/tapmods.h index 6eb3846ef4d5..af3d160c5b5e 100644 --- a/users/muppetjones/tapmods.h +++ b/users/muppetjones/tapmods.h @@ -33,9 +33,12 @@ #define RAISE MO(_RAISE) #define NAV MO(_NAV) +#define ADJ_DEL LT(_ADJUST, KC_DEL) #define LOW_ENT LT(_LOWER, KC_ENT) #define LOW_SPC LT(_LOWER, KC_SPC) +#define LOW_BSP LT(_LOWER, KC_BSPC) #define NAV_SPC LT(_NAV, KC_SPC) +#define RAI_BSP LT(_RAISE, KC_BSPC) #define RAI_ENT LT(_RAISE, KC_ENT) #define RAI_SPC LT(_RAISE, KC_SPC) #define RAI_TAB LT(_RAISE, KC_TAB) diff --git a/users/muppetjones/wrappers.h b/users/muppetjones/wrappers.h index f601c5de275b..301554f5d5af 100644 --- a/users/muppetjones/wrappers.h +++ b/users/muppetjones/wrappers.h @@ -42,14 +42,29 @@ #endif // clang-format off -/* Blank-ish */ +/* Blank-ish + * ,----------------------------------. * ,----------------------------------. + * | TRNS | TRNS | TRNS | TRNS | TRNS | * | xxxx | xxxx | xxxx | xxxx | xxxx | + * `----------------------------------' * `----------------------------------' + * ,----------------------------------. * ,----------------------------------. + * | LGUI | LALT | LCTL | LSFT | TRNS | * | TRNS | RSFT | RCTL | LALT | RGUI | + * `----------------------------------' * `----------------------------------' +*/ #define __BLANK____________________________________ _______, _______, _______, _______, _______ #define __BLANK_NOOP_______________________________ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX -#define __BLANK_W_GACS_____________________________ KC_LGUI, KC_LALT, KC_LALT, KC_LSFT, _______ +#define __BLANK_W_GACS_____________________________ KC_LGUI, KC_LALT, KC_LCTL, KC_LSFT, _______ #define __BLANK_W_SCAG_____________________________ _______, KC_RSFT, KC_RCTL, KC_LALT, KC_RGUI -/* Adjust */ -// NOTE: The "BACKLIT" keycode is planck specific +/* Adjust LH + * ,----------------------------------. ,----------------------------------. + * |Reset |Debug | xxxx |Term+ |Term- | | xxxx |AGNORM|AGSWAP| xxxx | xxxx | + * |------+------+------+------+------| |------+------+------+------+------| + * |RgbTog| Hue+ | Sat+ | Val+ |RgbMod| | xxxx |CLMKDH|QWERTY| xxxx | xxxx | + * |------+------+------+------+------| |------+------+------+------+------| + * | xxxx | Hue- | Sat- | Val- | xxxx | | xxxx | xxxx | xxxx | xxxx | xxxx | + * `----------------------------------' `----------------------------------' + */ + // NOTE: The "BACKLIT" keycode is planck specific #define __ADJUST_L1________________________________ RESET, DEBUG, XXXXXXX, TERM_ON, TERM_OFF #define __ADJUST_L2________________________________ RGB_TOG, RGB_HUI, RGB_SAI, RGB_VAI, RGB_MOD #define __ADJUST_L3________________________________ XXXXXXX, RGB_HUD, RGB_SAD, RGB_VAD, XXXXXXX @@ -58,7 +73,27 @@ #define __ADJUST_R2________________________________ XXXXXXX, CLMK_DH, QWERTY, XXXXXXX, XXXXXXX #define __ADJUST_R3________________________________ __BLANK_NOOP_______________________________ -/* COLEMAK mod-DH */ +/* Colemak mod-DH + * ,----------------------------------. ,----------------------------------. + * | Q | W | F | P | B | | J | L | U | Y | ;ˆ | + * |------+------+------+------+------| |------+------+------+------+------| + * | A | R | S | T | G | | M | N | E | I | O | + * |------+------+------+------+------| |------+------+------+------+------| + * | Z | X | C | D | V˜ | | K | H | , | . | / | + * `----------------------------------' `----------------------------------' + * ˆ Alternate: KC_QUOT + * ° Alternate: Home row mods (GASC, SCAG) + * ˜ Alternate: Hold for shift + * + * Colemak mod-DH (alt and alt+shift) + * ,----------------------------------. ,----------------------------------. + * | œ Œ | ∑ „ | | π ∏ | ı | | ∆ Ô | | | ¥ Á | æ Æ | + * |------+------+------+------+------| |------+------+------+------+------| + * | å Å | ® ‰ | ß Í | † ˇ | © ˝ | | µ  | ˜ ˜ | ´ ´ | ˆ ˆ | Ø | + * |------+------+------+------+------| |------+------+------+------+------| + * | Ω ¸ | ≈ ˛ | ç Ç | Î | √ ◊ | | ˚  | Ó | ≤ ¯ | ≥ ˘ | ÷ ¿ | + * `----------------------------------' `----------------------------------' + */ #define __COLEMAK_MOD_DH_L1________________________ KC_Q, KC_W, KC_F, KC_P, KC_B #define __COLEMAK_MOD_DH_L2_W_GACS_________________ HR_A, HR_R, HR_S, HR_T, KC_G #define __COLEMAK_MOD_DH_L3________________________ KC_Z, KC_X, KC_C, KC_D, KC_V @@ -69,17 +104,41 @@ #define __COLEMAK_MOD_DH_R2_W_SCAG_________________ KC_M, HR_N, HR_E, HR_I, HR_O #define __COLEMAK_MOD_DH_R3________________________ KC_K, KC_H, KC_COMM, KC_DOT, KC_SLASH +/* Function (4 columns) + * ,---------------------------. + * | F1 | F2 | F3 | F4 | + * |------+------+------+------| + * | F5 | F6 | F7 | F8 | + * |------+------+------+------| + * | F9 | F10 | F11 | F12 | + * `---------------------------' + */ +#define __FUNC_X1_________________________ KC_F1, KC_F2, KC_F3, KC_F4 +#define __FUNC_X2_________________________ KC_F5, KC_F6, KC_F7, KC_F8 +#define __FUNC_X3_________________________ KC_F9, KC_F10, KC_F11, KC_F12 + +/* Game + */ +#define __GAME_L1__________________________________ KC_BTN3, KC_BTN2, KC_UP, KC_BTN1, KC_BTN5 +#define __GAME_L2__________________________________ KC_BTN4, KC_LEFT, KC_DOWN, KC_RIGHT,XXXXXXX +#define __GAME_L3__________________________________ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX + +#define __GAME_R1__________________________________ KC_Q, KC_1, KC_2, KC_3, XXXXXXX +#define __GAME_R2__________________________________ XXXXXXX, KC_4, KC_5, KC_6, XXXXXXX +#define __GAME_R3__________________________________ XXXXXXX, KC_7, KC_8, KC_9, XXXXXXX + + /* Guitar - * ,----------------------------------. - * | Pg Up| Next | Prev | Brm+ | Vol+ | - * |------+------+------+------+------| - * | Pg Dn| Play | Stop | Brm- | Vol- | - * |------+------+------+------+------| - * | xxxx | xxxx | xxxx | xxxx | xxxx | - * `----------------------------------' + * ,----------------------------------. ,----------------------------------. + * | E | F |• F♯ | G |• G♯ | | A |• A♯ | B |• C | C♯ | + * | A | A♯ |• B | C |• C♯ | | D |• D♯ | E |• F | F♯ | + * | D | D♯ |• E | F |• F♯ | | G |• G♯ | A |• A♯ | B | + * | G | G♯ |• A | A♯ |• B | | C |• C♯ | D |• D♯ | E | + * | B | C |• C♯ | D |• D♯ | | E |• F | F♯ |• G | G♯ | + * | E | F |• F♯ | G |• G♯ | | A |• A♯ | B |• C | C♯ | + * `----------------------------------' `----------------------------------' */ -// _______, _______, _______, _______, _______, _______ -// Not sure why, but this does not work +// Not sure why, but this does not work (possibly due to the lowercase 's'?) // #ifdef MIDI_ADVANCED // #define __GUITAR_1E_L______________________________ MI_E_1, MI_F_1, MI_Fs_1, MI_G_1, MI_Gs_1 // #define __GUITAR_2A_L______________________________ MI_A_1, MI_As_1, MI_B_1, MI_C_2, MI_Cs_2 @@ -99,11 +158,11 @@ /* MEDIA * ,----------------------------------. - * | Pg Up| Next | Prev | Brm+ | Vol+ | + * | AuOn | MiOn | MuOn | Brm+ | Vol+ | * |------+------+------+------+------| - * | Pg Dn| Play | Stop | Brm- | Vol- | + * | AuOff| MiOff| MuOff| Brm- | Vol- | * |------+------+------+------+------| - * | xxxx | xxxx | xxxx | xxxx | xxxx | + * | Play | Stop | Next | Prev | Mute | * `----------------------------------' */ // What it MUV_IN and MUV_DE (5C2A and B)? @@ -126,25 +185,33 @@ #define __NAV_R2___________________________________ KC_PGDN, KC_LEFT, KC_DOWN, KC_UP, KC_RIGHT #define __NAV_R3___________________________________ __BLANK_NOOP_______________________________ -/* NUMPAD - * ,----------------------------------. - * | Bksp | 7 & | 8 * | 9 ( | \ | | - * |------+------+------+------+------| - * | - _ | 4 $ | 5 % | 6 ^ | * | - * |------+------+------+------+------| - * | = + | 1 ! | 2 @ | 3 # | | | - * |------+------+------+------+------| - * | | 0 ) | . > | | | - * `----------------------------------' +/* NUMPAD * (alt, alt+shift) + * ,----------------------------------. * ,----------------------------------. + * | Del | 7 & | 8 * | 9 ( | \ | | * | | ¶ ‡ | • ° | ª · | « » | + * |------+------+------+------+------| * |------+------+------+------+------| + * | - _ | 4 $ | 5 % | 6 ^ | * | * | – — | ¢ › | ∞ fi | § fl | ° ° | + * |------+------+------+------+------| * |------+------+------+------+------| + * | = + | 1 ! | 2 @ | 3 # | , | * | ≠ ± | ¡ ⁄ | ™ € | £ ‹ | ≤ ¯ | + * |------+------+------+------+------| * |------+------+------+------+------| + * | | 0 ) | . > | | | * | | | º ‚ | | | + * `----------------------------------' * `----------------------------------' */ -#define __NUMPAD_R1________________________________ KC_BSPC, KC_7, KC_8, KC_9, KC_BSLS -#define __NUMPAD_R2________________________________ KC_MINS, HR_4, HR_5, HR_6, KC_ASTR -#define __NUMPAD_R3________________________________ KC_EQL, KC_1, KC_2, KC_3, KC_PIPE +#define __NUMPAD_R1________________________________ KC_GRV, KC_7, KC_8, KC_9, KC_BSLS +#define __NUMPAD_R2________________________________ KC_MINS, HR_4, HR_5, HR_6, KC_COMM +#define __NUMPAD_R3________________________________ KC_EQL, KC_1, KC_2, KC_3, KC_DOT #define __NUMPAD_R4________________________________ _______, KC_0, KC_DOT, _______, _______ #define __NUMPAD_R3_ALT____________________________ KC_0, KC_1, KC_2, KC_3, KC_EQ -/* QWERTY */ +/* Qwerty + * ,----------------------------------. ,----------------------------------. + * | Q | W | E | R | T | | Y | U | I | O | P | + * |------+------+------+------+------| |------+------+------+------+------| + * | A | S | D | F | G | | H | J | K | L | ; | + * |------+------+------+------+------| |------+------+------+------+------| + * | Z | X | C | V | B | | N | M | , | . | / | + * `----------------------------------' `----------------------------------' + */ #define __QWERTY_L1________________________________ KC_Q, KC_W, KC_E, KC_R, KC_T #define __QWERTY_L2________________________________ KC_A, KC_S, KC_D, KC_F, KC_G #define __QWERTY_L3________________________________ KC_Z, KC_X, KC_C, KC_V, KC_B @@ -162,9 +229,21 @@ * | xxxx | xxxx | { | } | LSFT | * `----------------------------------' */ - #define __SYMBOLS_L1_______________________________ KC_TILD, KC_GRV, KC_LPRN, KC_RPRN, XXXXXXX - #define __SYMBOLS_L2_______________________________ KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_UNDS - #define __SYMBOLS_L3_______________________________ XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT +#define __SYMBOLS_L1_______________________________ KC_TILD, KC_GRV, KC_LPRN, KC_RPRN, XXXXXXX +#define __SYMBOLS_L2_______________________________ KC_LGUI, KC_LALT, HR_LBRC, HR_RBRC, KC_UNDS +#define __SYMBOLS_L3_______________________________ XXXXXXX, XXXXXXX, KC_LCBR, KC_RCBR, KC_LSFT + +#define __SYMBOLS_R1_______________________________ KC_TILD, KC_LPRN, KC_RPRN, XXXXXXX, XXXXXXX +#define __SYMBOLS_R2_______________________________ KC_UNDS, HR_LBRC, HR_RBRC, XXXXXXX, XXXXXXX +#define __SYMBOLS_R3_______________________________ KC_PLUS, KC_LCBR, KC_RCBR, XXXXXXX, XXXXXXX + +/* VIM + * -- Roll through ":wq" via transparency + * ,----------------------------------. + * | Q | W | : | | | + * `----------------------------------' + */ +#define __VIM_L1___________________________________ _______, _______, KC_COLN, _______, _______ // clang-format on // __END__ From 229c2556d7ede860526386c80dddaba53e373a8a Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Thu, 24 Mar 2022 09:19:45 -0500 Subject: [PATCH 20/22] Apply suggestions from code review Co-authored-by: Drashna Jaelre --- keyboards/lily58/keymaps/muppetjones/README.md | 4 ++-- keyboards/lily58/keymaps/muppetjones/keymap.c | 7 ++++--- users/muppetjones/config.h | 5 ----- 3 files changed, 6 insertions(+), 10 deletions(-) diff --git a/keyboards/lily58/keymaps/muppetjones/README.md b/keyboards/lily58/keymaps/muppetjones/README.md index 356c8e4e5cdf..38cea9cfc26b 100644 --- a/keyboards/lily58/keymaps/muppetjones/README.md +++ b/keyboards/lily58/keymaps/muppetjones/README.md @@ -5,9 +5,9 @@ qmk compile -kb lily58/rev1 -km muppetjones ``` ``` -make lily58/rev1:muppetjones:avrdude-split-left +qmk flash -kb lily58/rev1 -km muppetjones -bl avrdude-split-left ``` ``` -make lily58/rev1:muppetjones:avrdude-split-left +qmk flash -kb lily58/rev1 -km muppetjones -bl avrdude-split-right ``` diff --git a/keyboards/lily58/keymaps/muppetjones/keymap.c b/keyboards/lily58/keymaps/muppetjones/keymap.c index ef552f39a19c..6e0248228990 100644 --- a/keyboards/lily58/keymaps/muppetjones/keymap.c +++ b/keyboards/lily58/keymaps/muppetjones/keymap.c @@ -158,7 +158,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { }; // SSD1306 OLED update loop, make sure to enable OLED_DRIVER_ENABLE=yes in rules.mk -#ifdef OLED_DRIVER_ENABLE +#ifdef OLED_ENABLE oled_rotation_t oled_init_user(oled_rotation_t rotation) { if (!is_keyboard_master()) return OLED_ROTATION_180; // flips the display 180 degrees if offhand @@ -215,15 +215,16 @@ bool oled_task_user(void) { } else { render_bongo_cat(); oled_set_cursor(0, 6); - oled_write_P(WPM: " false); + oled_write_P(PSTR("WPM: "), false); oled_write(get_u8_str(get_current_wpm(), ' '), false); } + return false; } #endif // OLED_DRIVER_ENABLE bool process_record_keymap(uint16_t keycode, keyrecord_t *record) { if (record->event.pressed) { -#ifdef OLED_DRIVER_ENABLE +#ifdef OLED_ENABLE set_keylog(keycode, record); #endif // set_timelog(); diff --git a/users/muppetjones/config.h b/users/muppetjones/config.h index 63447fb41817..e8afa9d8c5ce 100644 --- a/users/muppetjones/config.h +++ b/users/muppetjones/config.h @@ -39,11 +39,6 @@ #endif -// Reduce firmware size -// https://thomasbaart.nl/2018/12/01/reducing-firmware-size-in-qmk/ -// also requires EXTRAFLAGS in config.h -#define NO_ACTION_MACRO -#define NO_ACTION_FUNCTION #define COMBO_COUNT 3 #define COMBO_TERM 40 From 0c5e1e627c156a719e544327810095cc79859e66 Mon Sep 17 00:00:00 2001 From: "Stephen J. Bush" Date: Thu, 24 Mar 2022 09:33:18 -0500 Subject: [PATCH 21/22] Renamed users/muppetjones/README.md to lc --- users/muppetjones/{README.md => readme.md} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename users/muppetjones/{README.md => readme.md} (100%) diff --git a/users/muppetjones/README.md b/users/muppetjones/readme.md similarity index 100% rename from users/muppetjones/README.md rename to users/muppetjones/readme.md From 7573994e640207e03184c69502dba8b351fad3cd Mon Sep 17 00:00:00 2001 From: Stephen J Bush <2041619+muppetjones@users.noreply.github.com> Date: Tue, 29 Mar 2022 10:00:19 -0500 Subject: [PATCH 22/22] Update keyboards/lily58/keymaps/muppetjones/config.h Co-authored-by: Drashna Jaelre --- keyboards/lily58/keymaps/muppetjones/config.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/keyboards/lily58/keymaps/muppetjones/config.h b/keyboards/lily58/keymaps/muppetjones/config.h index b341265cb79e..bee5ee45da01 100644 --- a/keyboards/lily58/keymaps/muppetjones/config.h +++ b/keyboards/lily58/keymaps/muppetjones/config.h @@ -23,7 +23,7 @@ along with this program. If not, see . /* Select hand configuration */ // 1 minute -#ifdef OLED_DRIVER_ENABLE +#ifdef OLED_ENABLE # define OLED_TIMEOUT 60000 #endif