fix color control

This commit is contained in:
cyberman54 2022-10-31 18:44:04 +01:00
parent 57cd6778a6
commit 55737647a1
2 changed files with 70 additions and 60 deletions

View File

@ -2,9 +2,11 @@
#define _LED_H #define _LED_H
#ifdef HAS_RGB_LED #ifdef HAS_RGB_LED
#define FASTLED_INTERNAL
#include <FastLED.h> #include <FastLED.h>
#include "libpax_helpers.h" #include "libpax_helpers.h"
#endif #endif
#ifdef HAS_LORA #ifdef HAS_LORA
#include "lorawan.h" #include "lorawan.h"
#endif #endif
@ -14,10 +16,23 @@
#endif #endif
enum led_states { LED_OFF, LED_ON }; enum led_states { LED_OFF, LED_ON };
enum colors {
COLOR_WHITE = 0xFFFFFF,
COLOR_NONE = 0x000000,
COLOR_CYAN = 0x00FFFF,
COLOR_BLUE = 0x0000FF,
COLOR_GREEN = 0x008000,
COLOR_YELLOW = 0xFFFF00,
COLOR_ORANGE = 0xFFA500,
COLOR_RED = 0xFF0000,
COLOR_PINK = 0xFFC0CB
};
extern TaskHandle_t ledLoopTask; extern TaskHandle_t ledLoopTask;
void rgb_led_init(void); void rgb_led_init(void);
void led_sethue(uint8_t hue); void rgb_set_color(uint32_t color);
void ledLoop(void *parameter); void ledLoop(void *parameter);
void switch_LED(led_states state); void switch_LED(led_states state);
void switch_LED1(led_states state); void switch_LED1(led_states state);

View File

@ -3,8 +3,12 @@
#include "led.h" #include "led.h"
static led_states LEDState = LED_OFF; // LED state global for state machine static led_states LEDState = LED_OFF; // LED state global for state machine
led_states previousLEDState =
LED_ON; // This will force LED to be off at boot since State is OFF
TaskHandle_t ledLoopTask; TaskHandle_t ledLoopTask;
static uint16_t LEDBlinkDuration = 0; // state machine variables
uint32_t LEDColor = COLOR_NONE, LEDBlinkDuration = 0; // state machine variables
static unsigned long LEDBlinkStarted = static unsigned long LEDBlinkStarted =
0; // When (in millis() led blink started) 0; // When (in millis() led blink started)
@ -12,18 +16,10 @@ static unsigned long LEDBlinkStarted =
CRGB leds[RGB_LED_COUNT]; CRGB leds[RGB_LED_COUNT];
#endif #endif
void led_setcolor(CRGB color) { void rgb_set_color(uint32_t color) {
#ifdef HAS_RGB_LED #ifdef HAS_RGB_LED
for (int i = 0; i < RGB_LED_COUNT; i++) for (int i = 0; i < RGB_LED_COUNT; i++)
leds[i] = color; leds[i] = CRGB(color);
FastLED.show();
#endif
}
void led_sethue(uint8_t hue) {
#ifdef HAS_RGB_LED
for (int i = 0; i < RGB_LED_COUNT; i++)
leds[i] = CHSV(hue, 0XFF, 100);
FastLED.show(); FastLED.show();
#endif #endif
} }
@ -31,62 +27,51 @@ void led_sethue(uint8_t hue) {
void rgb_led_init(void) { void rgb_led_init(void) {
#ifdef HAS_RGB_LED #ifdef HAS_RGB_LED
HAS_RGB_LED; HAS_RGB_LED;
led_setcolor(CRGB::Green); rgb_set_color(COLOR_NONE);
#endif #endif
} }
void switch_LED(led_states state) { void switch_LED(led_states state) {
static led_states previousLEDState = LED_OFF;
// led need to change state? avoid digitalWrite() for nothing
if (state != previousLEDState) {
previousLEDState = state;
#if (HAS_LED != NOT_A_PIN) #if (HAS_LED != NOT_A_PIN)
if (state == LED_ON) { if (state == LED_ON) {
// switch LED on // switch LED on
#ifdef LED_ACTIVE_LOW #ifdef LED_ACTIVE_LOW
digitalWrite(HAS_LED, LOW); digitalWrite(HAS_LED, LOW);
#else #else
digitalWrite(HAS_LED, HIGH); digitalWrite(HAS_LED, HIGH);
#endif #endif
led_setcolor(CRGB::White); } else if (state == LED_OFF) {
} else if (state == LED_OFF) { // switch LED off
// switch LED off
#ifdef LED_ACTIVE_LOW #ifdef LED_ACTIVE_LOW
digitalWrite(HAS_LED, HIGH); digitalWrite(HAS_LED, HIGH);
#else #else
digitalWrite(HAS_LED, LOW); digitalWrite(HAS_LED, LOW);
#endif
led_setcolor(CRGB::Black);
}
#endif #endif
} }
#endif
} }
void switch_LED1(led_states state) { void switch_LED1(led_states state) {
static led_states previousLEDState = LED_OFF; #ifdef HAS_TWO_LED
// led need to change state? avoid digitalWrite() for nothing if (state == LED_ON) {
if (state != previousLEDState) { // switch LED on
previousLEDState = state; #ifdef LED1_ACTIVE_LOW
#if (HAS_LED != NOT_A_PIN) digitalWrite(HAS_TWO_LED, LOW);
if (state == LED_ON) {
// switch LED on
#ifdef LED_ACTIVE_LOW
digitalWrite(HAS_TWO_LED, LOW);
#else #else
digitalWrite(HAS_TWO_LED, HIGH); digitalWrite(HAS_TWO_LED, HIGH);
#endif #endif
} else if (state == LED_OFF) { } else if (state == LED_OFF) {
// switch LED off // switch LED off
#ifdef LED_ACTIVE_LOW #ifdef LED1_ACTIVE_LOW
digitalWrite(HAS_TWO_LED, HIGH); digitalWrite(HAS_TWO_LED, HIGH);
#else #else
digitalWrite(HAS_TWO_LED, LOW); digitalWrite(HAS_TWO_LED, LOW);
#endif
}
#endif #endif
} }
#endif // HAS_TWO_LED
} }
#if (HAS_LED != NOT_A_PIN) || defined(HAS_RGB_LED) #if (HAS_LED != NOT_A_PIN) || defined(HAS_RGB_LED)
void ledLoop(void *parameter) { void ledLoop(void *parameter) {
@ -100,7 +85,7 @@ void ledLoop(void *parameter) {
LEDState = LED_OFF; LEDState = LED_OFF;
LEDBlinkStarted = 0; LEDBlinkStarted = 0;
LEDBlinkDuration = 0; LEDBlinkDuration = 0;
led_setcolor(CRGB::Black); LEDColor = COLOR_NONE;
} else { } else {
// In case of LoRaWAN led management blinked off // In case of LoRaWAN led management blinked off
LEDState = LED_ON; LEDState = LED_ON;
@ -110,7 +95,7 @@ void ledLoop(void *parameter) {
#if (HAS_LORA) #if (HAS_LORA)
// LED indicators for viusalizing LoRaWAN state // LED indicators for viusalizing LoRaWAN state
if (LMIC.opmode & (OP_JOINING | OP_REJOIN)) { if (LMIC.opmode & (OP_JOINING | OP_REJOIN)) {
led_setcolor(CRGB::Yellow); LEDColor = COLOR_YELLOW;
// quick blink 20ms on each 1/5 second // quick blink 20ms on each 1/5 second
LEDState = LEDState =
((millis() % 200) < 20) ? LED_ON : LED_OFF; // TX data pending ((millis() % 200) < 20) ? LED_ON : LED_OFF; // TX data pending
@ -118,13 +103,13 @@ void ledLoop(void *parameter) {
// select color to blink by message port // select color to blink by message port
switch (LMIC.pendTxPort) { switch (LMIC.pendTxPort) {
case STATUSPORT: case STATUSPORT:
led_setcolor(CRGB::Pink); LEDColor = COLOR_PINK;
break; break;
case CONFIGPORT: case CONFIGPORT:
led_setcolor(CRGB::Cyan); LEDColor = COLOR_CYAN;
break; break;
default: default:
led_setcolor(CRGB::Blue); LEDColor = COLOR_BLUE;
break; break;
} }
// small blink 10ms on each 1/2sec (not when joining) // small blink 10ms on each 1/2sec (not when joining)
@ -132,26 +117,36 @@ void ledLoop(void *parameter) {
// This should not happen so indicate a problem // This should not happen so indicate a problem
} else if (LMIC.opmode & } else if (LMIC.opmode &
((OP_TXDATA | OP_TXRXPEND | OP_JOINING | OP_REJOIN) == 0)) { ((OP_TXDATA | OP_TXRXPEND | OP_JOINING | OP_REJOIN) == 0)) {
led_setcolor(CRGB::Red); LEDColor = COLOR_RED;
// heartbeat long blink 200ms on each 2 seconds // heartbeat long blink 200ms on each 2 seconds
LEDState = ((millis() % 2000) < 200) ? LED_ON : LED_OFF; LEDState = ((millis() % 2000) < 200) ? LED_ON : LED_OFF;
} else } else
#elif (defined(HAS_RGB_LED) && ((WIFICOUNTER) || (BLECOUNTER)))
struct count_payload_t count;
libpax_counter_count(&count);
led_sethue(count.pax);
#endif // HAS_LORA #endif // HAS_LORA
{ {
// led off // led off
LEDColor = COLOR_NONE;
LEDState = LED_OFF; LEDState = LED_OFF;
} }
} }
// led need to change state? avoid digitalWrite() for nothing
switch_LED(LEDState); if (LEDState != previousLEDState) {
if (LEDState == LED_ON) {
rgb_set_color(LEDColor);
// if we have only single LED we use it to blink for status
#ifndef HAS_RGB_LED
switch_LED(LED_ON);
#endif
} else {
rgb_set_color(COLOR_NONE);
#ifndef HAS_RGB_LED
switch_LED(LED_OFF);
#endif
}
previousLEDState = LEDState;
}
// give yield to CPU // give yield to CPU
delay(5); delay(5);
} // while(1) } // while(1)
}; // ledloop() }; // ledloop()
#endif // #if (HAS_LED != NOT_A_PIN) || defined(HAS_RGB_LED) #endif // #if (HAS_LED != NOT_A_PIN) || defined(HAS_RGB_LED)