From 16546ee06fa71bd9b9e9d3fda7c8816675e12185 Mon Sep 17 00:00:00 2001 From: "Colin T.A. Gray" Date: Tue, 5 Dec 2017 11:56:15 -0700 Subject: Add 'rgblight_disable' and 'rgblight_setrgb_at/rgblight_sethsv_at' Refactors rgblight_toggle to use rgblight_enable or rgblight_disable Use 'rgblight_setrgb_at/rgblight_sethsv_at' to control an individual LED --- quantum/rgblight.c | 46 +++++++++++++++++++++++++++++++++++----------- quantum/rgblight.h | 3 +++ 2 files changed, 38 insertions(+), 11 deletions(-) (limited to 'quantum') diff --git a/quantum/rgblight.c b/quantum/rgblight.c index 78072a61de..63eda47cda 100644 --- a/quantum/rgblight.c +++ b/quantum/rgblight.c @@ -245,17 +245,12 @@ void rgblight_mode(uint8_t mode) { } void rgblight_toggle(void) { - rgblight_config.enable ^= 1; - eeconfig_update_rgblight(rgblight_config.raw); - xprintf("rgblight toggle: rgblight_config.enable = %u\n", rgblight_config.enable); + xprintf("rgblight toggle: rgblight_config.enable = %u\n", !rgblight_config.enable); if (rgblight_config.enable) { - rgblight_mode(rgblight_config.mode); - } else { - #ifdef RGBLIGHT_ANIMATIONS - rgblight_timer_disable(); - #endif - _delay_ms(50); - rgblight_set(); + rgblight_disable(); + } + else { + rgblight_enable(); } } @@ -266,6 +261,17 @@ void rgblight_enable(void) { rgblight_mode(rgblight_config.mode); } +void rgblight_disable(void) { + rgblight_config.enable = 0; + eeconfig_update_rgblight(rgblight_config.raw); + xprintf("rgblight disable: rgblight_config.enable = %u\n", rgblight_config.enable); + #ifdef RGBLIGHT_ANIMATIONS + rgblight_timer_disable(); + #endif + _delay_ms(50); + rgblight_set(); +} + void rgblight_increase_hue(void) { uint16_t hue; @@ -365,7 +371,8 @@ void rgblight_sethsv(uint16_t hue, uint8_t sat, uint8_t val) { } void rgblight_setrgb(uint8_t r, uint8_t g, uint8_t b) { - // dprintf("rgblight set rgb: %u,%u,%u\n", r,g,b); + if (!rgblight_config.enable) { return; } + for (uint8_t i = 0; i < RGBLED_NUM; i++) { led[i].r = r; led[i].g = g; @@ -374,6 +381,23 @@ void rgblight_setrgb(uint8_t r, uint8_t g, uint8_t b) { rgblight_set(); } +void rgblight_setrgb_at(uint8_t r, uint8_t g, uint8_t b, uint8_t index) { + if (!rgblight_config.enable || index >= RGBLED_NUM) { return; } + + led[index].r = r; + led[index].g = g; + led[index].b = b; + rgblight_set(); +} + +void rgblight_sethsv_at(uint16_t hue, uint8_t sat, uint8_t val, uint8_t index) { + if (!rgblight_config.enable) { return; } + + LED_TYPE tmp_led; + sethsv(hue, sat, val, &tmp_led); + rgblight_setrgb_at(tmp_led.r, tmp_led.g, tmp_led.b, index); +} + #ifndef RGBLIGHT_CUSTOM_DRIVER void rgblight_set(void) { if (rgblight_config.enable) { diff --git a/quantum/rgblight.h b/quantum/rgblight.h index fb79ce6ded..6d362e1d51 100644 --- a/quantum/rgblight.h +++ b/quantum/rgblight.h @@ -99,6 +99,7 @@ void rgblight_increase(void); void rgblight_decrease(void); void rgblight_toggle(void); void rgblight_enable(void); +void rgblight_disable(void); void rgblight_step(void); void rgblight_step_reverse(void); uint32_t rgblight_get_mode(void); @@ -113,6 +114,8 @@ void rgblight_increase_val(void); void rgblight_decrease_val(void); void rgblight_sethsv(uint16_t hue, uint8_t sat, uint8_t val); void rgblight_setrgb(uint8_t r, uint8_t g, uint8_t b); +void rgblight_setrgb_at(uint8_t r, uint8_t g, uint8_t b, uint8_t index); +void rgblight_sethsv_at(uint16_t hue, uint8_t sat, uint8_t val, uint8_t index); uint32_t eeconfig_read_rgblight(void); void eeconfig_update_rgblight(uint32_t val); -- cgit v1.2.3