123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 |
- #include "quantum.h"
- #include "backlight.h"
- #include "eeprom.h"
- #include "eeconfig.h"
- #include "debug.h"
- backlight_config_t backlight_config;
- #ifndef BACKLIGHT_DEFAULT_LEVEL
- # define BACKLIGHT_DEFAULT_LEVEL BACKLIGHT_LEVELS
- #endif
- #ifdef BACKLIGHT_BREATHING
- static uint8_t breathing_period = BREATHING_PERIOD;
- #endif
- void backlight_init(void) {
-
- if (!eeconfig_is_enabled()) {
- eeconfig_init();
- eeconfig_update_backlight_default();
- }
- backlight_config.raw = eeconfig_read_backlight();
- if (backlight_config.level > BACKLIGHT_LEVELS) {
- backlight_config.level = BACKLIGHT_LEVELS;
- }
- backlight_set(backlight_config.enable ? backlight_config.level : 0);
- }
- void backlight_increase(void) {
- if (backlight_config.level < BACKLIGHT_LEVELS) {
- backlight_config.level++;
- }
- backlight_config.enable = 1;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight increase: %u\n", backlight_config.level);
- backlight_set(backlight_config.level);
- }
- void backlight_decrease(void) {
- if (backlight_config.level > 0) {
- backlight_config.level--;
- backlight_config.enable = !!backlight_config.level;
- eeconfig_update_backlight(backlight_config.raw);
- }
- dprintf("backlight decrease: %u\n", backlight_config.level);
- backlight_set(backlight_config.level);
- }
- void backlight_toggle(void) {
- bool enabled = backlight_config.enable;
- dprintf("backlight toggle: %u\n", enabled);
- if (enabled)
- backlight_disable();
- else
- backlight_enable();
- }
- void backlight_enable(void) {
- if (backlight_config.enable) return;
- backlight_config.enable = true;
- if (backlight_config.raw == 1)
- backlight_config.level = 1;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight enable\n");
- backlight_set(backlight_config.level);
- }
- void backlight_disable(void) {
- if (!backlight_config.enable) return;
- backlight_config.enable = false;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight disable\n");
- backlight_set(0);
- }
- bool is_backlight_enabled(void) {
- return backlight_config.enable;
- }
- void backlight_step(void) {
- backlight_config.level++;
- if (backlight_config.level > BACKLIGHT_LEVELS) {
- backlight_config.level = 0;
- }
- backlight_config.enable = !!backlight_config.level;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight step: %u\n", backlight_config.level);
- backlight_set(backlight_config.level);
- }
- void backlight_level_noeeprom(uint8_t level) {
- if (level > BACKLIGHT_LEVELS) level = BACKLIGHT_LEVELS;
- backlight_config.level = level;
- backlight_config.enable = !!backlight_config.level;
- backlight_set(backlight_config.level);
- }
- void backlight_level(uint8_t level) {
- backlight_level_noeeprom(level);
- eeconfig_update_backlight(backlight_config.raw);
- }
- uint8_t eeconfig_read_backlight(void) {
- return eeprom_read_byte(EECONFIG_BACKLIGHT);
- }
- void eeconfig_update_backlight(uint8_t val) {
- eeprom_update_byte(EECONFIG_BACKLIGHT, val);
- }
- void eeconfig_update_backlight_current(void) {
- eeconfig_update_backlight(backlight_config.raw);
- }
- void eeconfig_update_backlight_default(void) {
- backlight_config.enable = 1;
- #ifdef BACKLIGHT_DEFAULT_BREATHING
- backlight_config.breathing = 1;
- #else
- backlight_config.breathing = 0;
- #endif
- backlight_config.level = BACKLIGHT_DEFAULT_LEVEL;
- eeconfig_update_backlight(backlight_config.raw);
- }
- uint8_t get_backlight_level(void) {
- return backlight_config.level;
- }
- #ifdef BACKLIGHT_BREATHING
- void backlight_toggle_breathing(void) {
- bool breathing = backlight_config.breathing;
- dprintf("backlight breathing toggle: %u\n", breathing);
- if (breathing)
- backlight_disable_breathing();
- else
- backlight_enable_breathing();
- }
- void backlight_enable_breathing(void) {
- if (backlight_config.breathing) return;
- backlight_config.breathing = true;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight breathing enable\n");
- breathing_enable();
- }
- void backlight_disable_breathing(void) {
- if (!backlight_config.breathing) return;
- backlight_config.breathing = false;
- eeconfig_update_backlight(backlight_config.raw);
- dprintf("backlight breathing disable\n");
- breathing_disable();
- }
- bool is_backlight_breathing(void) {
- return backlight_config.breathing;
- }
- __attribute__((weak)) void breathing_period_set(uint8_t value) {
- breathing_period = value ? value : 1;
- }
- __attribute__((weak)) uint8_t get_breathing_period(void) {
- return breathing_period;
- }
- __attribute__((weak)) void breathing_period_default(void) {
- breathing_period_set(BREATHING_PERIOD);
- }
- __attribute__((weak)) void breathing_period_inc(void) {
- breathing_period_set(breathing_period + 1);
- }
- __attribute__((weak)) void breathing_period_dec(void) {
- breathing_period_set(breathing_period - 1);
- }
- __attribute__((weak)) void breathing_toggle(void) {
- if (is_breathing())
- breathing_disable();
- else
- breathing_enable();
- }
- #endif
- __attribute__((weak)) void backlight_init_ports(void) {}
- __attribute__((weak)) void backlight_set(uint8_t level) {}
- __attribute__((weak)) void backlight_task(void) {}
|