[Keymap] Drashna's Feature madness (#6128)
* Fix my Tap Dance issues after I broke them * Cleanup and organization of userspace documentation As well as some additional cleanup of functions due to review of documentation. * Enable Tapdance on Glow and remove more animations * Revert to Eager PR debouncing * Add better check for startup animation * Move where RGB Matrix defines are listed * Limit RGB Matrix max val * Update keyboard for Iris Rev 3 conflicts * Enable encoder support on planck ez * Remove is_master check from corne\'s OLED code * Overhaul OLED screens for my Corne * One last removal * Show RGB valu On both sides * Updates for OLED display info * Fix compile issues for rgb config * Disabled Space Cadet for all drashna keymaps * Fix OLED Screen configs * Minor OLED Tweaks * Revert some Iris changes * Fix song include * Handle MAKE macro for the Corne boards better * Add super hacky-hack for eeconfig initialization * Add audio support for Fractal since Elite Cs support it * Add defines for keycode steps * Add White layout * Update Corne RGB info * Add fun effects to layer indication for RGB Matrix enabled boards * Use proper define for product name detection * Update formatting * Use custom timeout mechanism for OLED timeout * Fix up OLED screen HSV code for new HSV structure * Better handle turning off RGB Matrix when sleeping * Disable MultiSplash Animation * Change Iris back to using serial * Why was RGB disabled?!?!?! * Limit val in rgb_matrix_layer_helper function * Remove EECONFIG setting for RGB matrix
This commit is contained in:
		
							parent
							
								
									840b9090a0
								
							
						
					
					
						commit
						d41961c9ed
					
				
					 38 changed files with 1451 additions and 1190 deletions
				
			
		| 
						 | 
				
			
			@ -18,21 +18,20 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		|||
#include "drashna.h"
 | 
			
		||||
 | 
			
		||||
#ifdef UNICODEMAP_ENABLE
 | 
			
		||||
#include "drashna_unicode.h"
 | 
			
		||||
#endif // UNICODEMAP_ENABLE
 | 
			
		||||
#    include "drashna_unicode.h"
 | 
			
		||||
#endif  // UNICODEMAP_ENABLE
 | 
			
		||||
#ifndef UNICODE_ENABLE
 | 
			
		||||
#   define UC(x) KC_NO
 | 
			
		||||
#    define UC(x) KC_NO
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
extern userspace_config_t userspace_config;
 | 
			
		||||
 | 
			
		||||
enum more_custom_keycodes {
 | 
			
		||||
    KC_SWAP_NUM = NEW_SAFE_RANGE
 | 
			
		||||
};
 | 
			
		||||
enum more_custom_keycodes { KC_SWAP_NUM = NEW_SAFE_RANGE };
 | 
			
		||||
 | 
			
		||||
//define layer change stuff for underglow indicator
 | 
			
		||||
// define layer change stuff for underglow indicator
 | 
			
		||||
bool skip_leds = false;
 | 
			
		||||
 | 
			
		||||
// clang-format off
 | 
			
		||||
#define LAYOUT_ergodox_pretty_base( \
 | 
			
		||||
    K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
 | 
			
		||||
    K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, \
 | 
			
		||||
| 
						 | 
				
			
			@ -301,9 +300,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
			
		|||
            ),
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
// clang-format on
 | 
			
		||||
 | 
			
		||||
bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
 | 
			
		||||
 | 
			
		||||
    switch (keycode) {
 | 
			
		||||
        case KC_1:
 | 
			
		||||
            if (IS_LAYER_ON(_GAMEPAD) && userspace_config.swapped_numbers) {
 | 
			
		||||
| 
						 | 
				
			
			@ -332,7 +331,7 @@ bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
 | 
			
		|||
            }
 | 
			
		||||
            break;
 | 
			
		||||
    }
 | 
			
		||||
    //switch (keycode) {
 | 
			
		||||
    // switch (keycode) {
 | 
			
		||||
    //  case KC_P00:
 | 
			
		||||
    //    if (!record->event.pressed) {
 | 
			
		||||
    //      register_code(KC_KP_0);
 | 
			
		||||
| 
						 | 
				
			
			@ -347,9 +346,9 @@ bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
void matrix_scan_keymap(void) {  // runs frequently to update info
 | 
			
		||||
    uint8_t modifiers = get_mods();
 | 
			
		||||
    uint8_t modifiers     = get_mods();
 | 
			
		||||
    uint8_t led_usb_state = host_keyboard_leds();
 | 
			
		||||
    uint8_t one_shot = get_oneshot_mods();
 | 
			
		||||
    uint8_t one_shot      = get_oneshot_mods();
 | 
			
		||||
 | 
			
		||||
    if (!skip_leds) {
 | 
			
		||||
        ergodox_board_led_off();
 | 
			
		||||
| 
						 | 
				
			
			@ -360,24 +359,21 @@ void matrix_scan_keymap(void) {  // runs frequently to update info
 | 
			
		|||
        // Since we're not using the LEDs here for layer indication anymore,
 | 
			
		||||
        // then lets use them for modifier indicators.  Shame we don't have 4...
 | 
			
		||||
        // Also, no "else", since we want to know each, independently.
 | 
			
		||||
        if ( ( modifiers | one_shot ) & MOD_MASK_SHIFT || led_usb_state & (1<<USB_LED_CAPS_LOCK) ) {
 | 
			
		||||
        if ((modifiers | one_shot) & MOD_MASK_SHIFT || led_usb_state & (1 << USB_LED_CAPS_LOCK)) {
 | 
			
		||||
            ergodox_right_led_2_on();
 | 
			
		||||
            ergodox_right_led_2_set( 50 );
 | 
			
		||||
            ergodox_right_led_2_set(50);
 | 
			
		||||
        }
 | 
			
		||||
        if ( ( modifiers | one_shot ) & MOD_MASK_CTRL) {
 | 
			
		||||
        if ((modifiers | one_shot) & MOD_MASK_CTRL) {
 | 
			
		||||
            ergodox_right_led_1_on();
 | 
			
		||||
            ergodox_right_led_1_set( 10 );
 | 
			
		||||
            ergodox_right_led_1_set(10);
 | 
			
		||||
        }
 | 
			
		||||
        if ( ( modifiers | one_shot ) & MOD_MASK_ALT) {
 | 
			
		||||
        if ((modifiers | one_shot) & MOD_MASK_ALT) {
 | 
			
		||||
            ergodox_right_led_3_on();
 | 
			
		||||
            ergodox_right_led_3_set( 10 );
 | 
			
		||||
            ergodox_right_led_3_set(10);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
bool indicator_is_this_led_used_keyboard(uint8_t index) {
 | 
			
		||||
    switch (index) {
 | 
			
		||||
        case 13 ... 14:
 | 
			
		||||
| 
						 | 
				
			
			@ -388,76 +384,83 @@ bool indicator_is_this_led_used_keyboard(uint8_t index) {
 | 
			
		|||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#ifdef RGB_MATRIX_ENABLE
 | 
			
		||||
 | 
			
		||||
void suspend_power_down_keymap(void) {
 | 
			
		||||
    rgb_matrix_set_suspend_state(true);
 | 
			
		||||
}
 | 
			
		||||
void suspend_power_down_keymap(void) { rgb_matrix_set_suspend_state(true); }
 | 
			
		||||
 | 
			
		||||
void suspend_wakeup_init_keymap(void) {
 | 
			
		||||
    rgb_matrix_set_suspend_state(false);
 | 
			
		||||
}
 | 
			
		||||
void suspend_wakeup_init_keymap(void) { rgb_matrix_set_suspend_state(false); }
 | 
			
		||||
 | 
			
		||||
void rgb_matrix_indicators_user(void) {
 | 
			
		||||
    if ( userspace_config.rgb_layer_change &&
 | 
			
		||||
#ifdef RGB_DISABLE_WHEN_USB_SUSPENDED
 | 
			
		||||
    if (userspace_config.rgb_layer_change &&
 | 
			
		||||
#    ifdef RGB_DISABLE_WHEN_USB_SUSPENDED
 | 
			
		||||
        !g_suspend_state &&
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(RGBLIGHT_ENABLE)
 | 
			
		||||
#    endif
 | 
			
		||||
#    if defined(RGBLIGHT_ENABLE)
 | 
			
		||||
        (!rgblight_config.enable && rgb_matrix_config.enable)
 | 
			
		||||
#else
 | 
			
		||||
#    else
 | 
			
		||||
        rgb_matrix_config.enable
 | 
			
		||||
#endif
 | 
			
		||||
#    endif
 | 
			
		||||
    ) {
 | 
			
		||||
        switch (biton32(layer_state)) {
 | 
			
		||||
            case _MODS:
 | 
			
		||||
                rgb_matrix_layer_helper(0xFF, 0xFF, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
            case _GAMEPAD:
 | 
			
		||||
                rgb_matrix_layer_helper(0xFF, 0x80, 0x00, LED_FLAG_MODIFIER);
 | 
			
		||||
                rgb_matrix_set_color(32, 0x00, 0xFF, 0x00); // Q
 | 
			
		||||
                rgb_matrix_set_color(31, 0x00, 0xFF, 0xFF); // W
 | 
			
		||||
                rgb_matrix_set_color(30, 0xFF, 0x00, 0x00); // E
 | 
			
		||||
                rgb_matrix_set_color(29, 0xFF, 0x80, 0x00); // R
 | 
			
		||||
                rgb_matrix_set_color(37, 0x00, 0xFF, 0xFF); // A
 | 
			
		||||
                rgb_matrix_set_color(36, 0x00, 0xFF, 0xFF); // S
 | 
			
		||||
                rgb_matrix_set_color(35, 0x00, 0xFF, 0xFF); // D
 | 
			
		||||
                rgb_matrix_set_color(34, 0x7A, 0x00, 0xFF); // F
 | 
			
		||||
 | 
			
		||||
                rgb_matrix_set_color(userspace_config.swapped_numbers ? 27 : 26, 0xFF, 0xFF, 0xFF); // 1
 | 
			
		||||
                rgb_matrix_set_color(userspace_config.swapped_numbers ? 26 : 27, 0x00, 0xFF, 0x00); // 2
 | 
			
		||||
                rgb_matrix_set_color(25, 0x7A, 0x00, 0xFF); // 3
 | 
			
		||||
                rgb_matrix_layer_helper(HSV_ORANGE, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                rgb_matrix_set_color(32, 0x00, 0xFF, 0x00);  // Q
 | 
			
		||||
                rgb_matrix_set_color(31, 0x00, 0xFF, 0xFF);  // W
 | 
			
		||||
                rgb_matrix_set_color(30, 0xFF, 0x00, 0x00);  // E
 | 
			
		||||
                rgb_matrix_set_color(29, 0xFF, 0x80, 0x00);  // R
 | 
			
		||||
                rgb_matrix_set_color(37, 0x00, 0xFF, 0xFF);  // A
 | 
			
		||||
                rgb_matrix_set_color(36, 0x00, 0xFF, 0xFF);  // S
 | 
			
		||||
                rgb_matrix_set_color(35, 0x00, 0xFF, 0xFF);  // D
 | 
			
		||||
                rgb_matrix_set_color(34, 0x7A, 0x00, 0xFF);  // F
 | 
			
		||||
 | 
			
		||||
                rgb_matrix_set_color(userspace_config.swapped_numbers ? 27 : 26, 0xFF, 0xFF, 0xFF);  // 1
 | 
			
		||||
                rgb_matrix_set_color(userspace_config.swapped_numbers ? 26 : 27, 0x00, 0xFF, 0x00);  // 2
 | 
			
		||||
                rgb_matrix_set_color(25, 0x7A, 0x00, 0xFF);                                          // 3
 | 
			
		||||
                break;
 | 
			
		||||
            case _DIABLO:
 | 
			
		||||
                rgb_matrix_layer_helper(0xFF, 0x00, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed * 8, LED_FLAG_MODIFIER);
 | 
			
		||||
                break;
 | 
			
		||||
            case _RAISE:
 | 
			
		||||
                rgb_matrix_layer_helper(0xFF, 0xFF, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                rgb_matrix_layer_helper(HSV_YELLOW, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                break;
 | 
			
		||||
            case _LOWER:
 | 
			
		||||
                rgb_matrix_layer_helper(0x00, 0xFF, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                rgb_matrix_layer_helper(HSV_GREEN, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                break;
 | 
			
		||||
            case _ADJUST:
 | 
			
		||||
                rgb_matrix_layer_helper(0xFF, 0x00, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
            default:
 | 
			
		||||
                rgb_matrix_layer_helper(HSV_RED, 1, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                break;
 | 
			
		||||
            default: {
 | 
			
		||||
                bool mods_enabled = IS_LAYER_ON(_MODS);
 | 
			
		||||
                switch (biton32(default_layer_state)) {
 | 
			
		||||
                    case _QWERTY:
 | 
			
		||||
                        rgb_matrix_layer_helper(0x00, 0xFF, 0xFF, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_CYAN, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _COLEMAK:
 | 
			
		||||
                        rgb_matrix_layer_helper(0xFF, 0x00, 0xFF, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_MAGENTA, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _DVORAK:
 | 
			
		||||
                        rgb_matrix_layer_helper(0x00, 0xFF, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_SPRINGGREEN, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _WORKMAN:
 | 
			
		||||
                        rgb_matrix_layer_helper(0xD9, 0xA5, 0x21, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_GOLDENROD, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _NORMAN:
 | 
			
		||||
                        rgb_matrix_layer_helper(0xFF, 0x7C, 0x4D, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_CORAL, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _MALTRON:
 | 
			
		||||
                        rgb_matrix_layer_helper(0xFF, 0xFF, 0x00, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_YELLOW, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _EUCALYN:
 | 
			
		||||
                        rgb_matrix_layer_helper(0xFF, 0x80, 0xBF, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_PINK, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                    case _CARPLAX:
 | 
			
		||||
                        rgb_matrix_layer_helper(0x00, 0x00, 0xFF, LED_FLAG_MODIFIER); break;
 | 
			
		||||
                        rgb_matrix_layer_helper(HSV_BLUE, mods_enabled, rgb_matrix_config.speed, LED_FLAG_MODIFIER);
 | 
			
		||||
                        break;
 | 
			
		||||
                }
 | 
			
		||||
                break;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif //RGB_MATRIX_INIT
 | 
			
		||||
#endif  // RGB_MATRIX_INIT
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue