mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-11-23 17:06:52 +06:00
215 lines
5.3 KiB
C
215 lines
5.3 KiB
C
/* Copyright 2020 Brandon Schlack
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include "brandonschlack.h"
|
|
|
|
user_config_t user_config;
|
|
#ifdef STOPLIGHT_LED
|
|
static stoplight_led_t stoplight_led;
|
|
#endif
|
|
|
|
/**
|
|
* Resets user config in EEPROM
|
|
*
|
|
* Default is use rgb for layer indication
|
|
*/
|
|
void eeconfig_init_user(void) {
|
|
user_config.raw = 0;
|
|
user_config.rgb_layer_change = true;
|
|
user_config.rgb_theme = 0;
|
|
eeconfig_update_user(user_config.raw);
|
|
}
|
|
|
|
__attribute__((weak))
|
|
void matrix_init_keymap(void){ }
|
|
|
|
void matrix_init_user(void) {
|
|
matrix_init_keymap();
|
|
}
|
|
|
|
__attribute__((weak))
|
|
void keyboard_post_init_keymap(void){ }
|
|
|
|
/**
|
|
* Reads user config from EEPROM,
|
|
* calls RGB init if RGBs enabled
|
|
*/
|
|
void keyboard_post_init_user(void){
|
|
// Read the user config from EEPROM
|
|
user_config.raw = eeconfig_read_user();
|
|
// Do Stoplight Animation if enabled
|
|
#ifdef STOPLIGHT_LED
|
|
led_stoplight_start();
|
|
#endif
|
|
// Do RGB things if RGBs enabled
|
|
#if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
|
|
keyboard_post_init_rgb();
|
|
#endif
|
|
keyboard_post_init_keymap();
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
void shutdown_keymap(void) {}
|
|
|
|
/**
|
|
* On shutdown,
|
|
* If RGBs enabled,
|
|
* then set RGB color to Red
|
|
*/
|
|
void shutdown_user (void) {
|
|
#ifdef RGBLIGHT_ENABLE
|
|
rgblight_enable_noeeprom();
|
|
rgblight_mode_noeeprom(RGBLIGHT_MODE_STATIC_LIGHT);
|
|
rgblight_sethsv_noeeprom(0, 255, 127);
|
|
#endif // RGBLIGHT_ENABLE
|
|
#ifdef RGB_MATRIX_ENABLE
|
|
rgb_matrix_set_color_all( 0xFF, 0x00, 0x00 );
|
|
#endif //RGB_MATRIX_ENABLE
|
|
shutdown_keymap();
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
void suspend_power_down_keymap(void) {}
|
|
|
|
/**
|
|
* Set rgb_matrix suspend state to true if not already
|
|
*/
|
|
void suspend_power_down_user(void) {
|
|
#ifdef RGB_MATRIX_ENABLE
|
|
if (!g_suspend_state) {
|
|
rgb_matrix_set_suspend_state(true);
|
|
}
|
|
#endif //RGB_MATRIX_ENABLE
|
|
suspend_power_down_keymap();
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
void suspend_wakeup_init_keymap(void) {}
|
|
|
|
/**
|
|
* Set rgb_matrix suspend state to false if not already
|
|
*/
|
|
void suspend_wakeup_init_user(void) {
|
|
#ifdef RGB_MATRIX_ENABLE
|
|
if (g_suspend_state) {
|
|
rgb_matrix_set_suspend_state(false);
|
|
}
|
|
#endif //RGB_MATRIX_ENABLE
|
|
suspend_wakeup_init_keymap();
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
void matrix_scan_keymap(void) {}
|
|
|
|
/**
|
|
* Checks for Super CMD↯TAB
|
|
*/
|
|
void matrix_scan_user(void) {
|
|
matrix_scan_cmd_tab();
|
|
#ifdef STOPLIGHT_LED
|
|
matrix_scan_led_stoplight();
|
|
#endif
|
|
matrix_scan_keymap();
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
layer_state_t default_layer_state_set_keymap(layer_state_t state) {
|
|
return state;
|
|
}
|
|
|
|
/**
|
|
* For macropads, if a new default layer is set from DF()
|
|
* then automatically set that layer with layer_move()
|
|
*/
|
|
layer_state_t default_layer_state_set_user(layer_state_t state) {
|
|
#if defined(IS_MACROPAD)
|
|
layer_move(get_highest_layer(state));
|
|
#endif
|
|
return default_layer_state_set_keymap(state);
|
|
}
|
|
|
|
__attribute__ ((weak))
|
|
layer_state_t layer_state_set_keymap(layer_state_t state) {
|
|
return state;
|
|
}
|
|
|
|
/**
|
|
* Do RGB things (like layer indication) on layer change
|
|
*/
|
|
layer_state_t layer_state_set_user(layer_state_t state) {
|
|
#if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
|
|
state = layer_state_set_rgb(state);
|
|
#endif // RGBLIGHT_ENABLE
|
|
return layer_state_set_keymap(state);
|
|
}
|
|
|
|
__attribute__((weak)) bool led_update_keymap(led_t led_state) { return true; }
|
|
|
|
bool led_update_user(led_t led_state) {
|
|
#ifdef STOPLIGHT_LED
|
|
if (stoplight_led.is_active) {
|
|
return false;
|
|
}
|
|
#endif
|
|
return led_update_keymap(led_state);
|
|
}
|
|
|
|
#ifdef STOPLIGHT_LED
|
|
void led_stoplight_start(void) {
|
|
writePin(TOP_LED, LED_ON(false));
|
|
writePin(MIDDLE_LED, LED_ON(false));
|
|
writePin(BOTTOM_LED, LED_ON(false));
|
|
|
|
stoplight_led.is_active = true;
|
|
stoplight_led.timer = timer_read();
|
|
};
|
|
|
|
void led_stoplight_set(pin_t pin) {
|
|
writePin(pin, LED_ON(true));
|
|
};
|
|
|
|
void led_stoplight_end(void) {
|
|
// Reset timer and status variables
|
|
stoplight_led.is_active = false;
|
|
stoplight_led.index = 0;
|
|
stoplight_led.timer = 0;
|
|
led_update_kb(host_keyboard_led_state());
|
|
};
|
|
|
|
void matrix_scan_led_stoplight(void) {
|
|
if (stoplight_led.is_active) {
|
|
if (timer_elapsed(stoplight_led.timer) > (1000 * (stoplight_led.index + 1))) {
|
|
switch (stoplight_led.index){
|
|
case 0:
|
|
led_stoplight_set(TOP_LED);
|
|
stoplight_led.index++;
|
|
break;
|
|
case 1:
|
|
led_stoplight_set(MIDDLE_LED);
|
|
stoplight_led.index++;
|
|
break;
|
|
case 2:
|
|
led_stoplight_set(BOTTOM_LED);
|
|
stoplight_led.index++;
|
|
break;
|
|
default:
|
|
led_stoplight_end();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
};
|
|
#endif
|