[Keyboard] Add work louder micro (#17586)
* [Keyboard] Add work louder micro * Update keyboards/work_louder/micro/readme.md * Update readme * Update kb config files * Update to use encoder map Co-authored-by: Tom Barnes <barnestom@me.com>
This commit is contained in:
		
							parent
							
								
									9dbc0473ef
								
							
						
					
					
						commit
						5f36285fc5
					
				
					 11 changed files with 695 additions and 0 deletions
				
			
		
							
								
								
									
										92
									
								
								keyboards/work_louder/micro/keymaps/via/keymap.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								keyboards/work_louder/micro/keymaps/via/keymap.c
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,92 @@
 | 
			
		|||
// Copyright 2022 Christopher Courtney, aka Drashna Jael're  (@drashna) <drashna@live.com>
 | 
			
		||||
// SPDX-License-Identifier: GPL-2.0-or-later
 | 
			
		||||
 | 
			
		||||
#include QMK_KEYBOARD_H
 | 
			
		||||
 | 
			
		||||
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
			
		||||
    LAYOUT(
 | 
			
		||||
        KC_MPLY, KC_9,    KC_0,    KC_NO,
 | 
			
		||||
        KC_5,    KC_6,    KC_7,    KC_8,
 | 
			
		||||
        KC_1,    KC_2,    KC_3,    KC_4,
 | 
			
		||||
        TO(1),   KC_DOT,  KC_COMM, USER09
 | 
			
		||||
    ),
 | 
			
		||||
    LAYOUT(
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        TO(2),   _______, _______, _______
 | 
			
		||||
 | 
			
		||||
    ),
 | 
			
		||||
    LAYOUT(
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        TO(3),   _______, _______, _______
 | 
			
		||||
    ),
 | 
			
		||||
    LAYOUT(
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        _______, _______, _______, _______,
 | 
			
		||||
        TO(0),   _______, _______, _______
 | 
			
		||||
    )
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#if defined(ENCODER_MAP_ENABLE)
 | 
			
		||||
const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
 | 
			
		||||
    { ENCODER_CCW_CW(KC_VOLD, KC_VOLU),           ENCODER_CCW_CW(C(KC_Z), C(KC_Y))  },
 | 
			
		||||
    { ENCODER_CCW_CW(_______, _______),           ENCODER_CCW_CW(_______, _______)  },
 | 
			
		||||
    { ENCODER_CCW_CW(_______, _______),           ENCODER_CCW_CW(_______, _______)  },
 | 
			
		||||
    { ENCODER_CCW_CW(_______, _______),           ENCODER_CCW_CW(_______, _______)  }
 | 
			
		||||
};
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
typedef union {
 | 
			
		||||
    uint32_t raw;
 | 
			
		||||
    struct {
 | 
			
		||||
        uint8_t led_level : 3;
 | 
			
		||||
    };
 | 
			
		||||
} work_louder_config_t;
 | 
			
		||||
 | 
			
		||||
work_louder_config_t work_louder_config;
 | 
			
		||||
 | 
			
		||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
 | 
			
		||||
#ifdef CONSOLE_ENABLE
 | 
			
		||||
    uprintf("KL: kc: 0x%04X, col: %2u, row: %2u, pressed: %b, time: %5u, int: %b, count: %u\n", keycode, record->event.key.col, record->event.key.row, record->event.pressed, record->event.time, record->tap.interrupted, record->tap.count);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    switch (keycode) {
 | 
			
		||||
        case USER09:
 | 
			
		||||
            if (record->event.pressed) {
 | 
			
		||||
                work_louder_config.led_level++;
 | 
			
		||||
                if (work_louder_config.led_level > 4) {
 | 
			
		||||
                    work_louder_config.led_level = 0;
 | 
			
		||||
                }
 | 
			
		||||
                work_louder_micro_led_all_set((uint8_t)(work_louder_config.led_level * 255 / 4));
 | 
			
		||||
                eeconfig_update_user(work_louder_config.raw);
 | 
			
		||||
                layer_state_set_kb(layer_state);
 | 
			
		||||
            }
 | 
			
		||||
            break;
 | 
			
		||||
    }
 | 
			
		||||
    return true;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
layer_state_t layer_state_set_user(layer_state_t state) {
 | 
			
		||||
    layer_state_cmp(state, 1) ? work_louder_micro_led_1_on(): work_louder_micro_led_1_off();
 | 
			
		||||
    layer_state_cmp(state, 2) ? work_louder_micro_led_2_on(): work_louder_micro_led_2_off();
 | 
			
		||||
    layer_state_cmp(state, 3) ? work_louder_micro_led_3_on(): work_louder_micro_led_3_off();
 | 
			
		||||
 | 
			
		||||
    return state;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void eeconfig_init_user(void) {
 | 
			
		||||
    work_louder_config.raw = 0;
 | 
			
		||||
    work_louder_config.led_level = 1;
 | 
			
		||||
    eeconfig_update_user(work_louder_config.raw);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void matrix_init_user(void) {
 | 
			
		||||
    work_louder_config.raw = eeconfig_read_user();
 | 
			
		||||
    work_louder_micro_led_all_set((uint8_t)(work_louder_config.led_level * 255 / 4));
 | 
			
		||||
}
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue