fix led color control
This commit is contained in:
		
							parent
							
								
									c55b7e8709
								
							
						
					
					
						commit
						681118c2ec
					
				@ -2,6 +2,7 @@
 | 
				
			|||||||
#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
 | 
				
			||||||
@ -16,10 +17,22 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
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);
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										89
									
								
								src/led.cpp
									
									
									
									
									
								
							
							
						
						
									
										89
									
								
								src/led.cpp
									
									
									
									
									
								
							@ -3,25 +3,23 @@
 | 
				
			|||||||
#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)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					#ifdef HAS_RGB_LED
 | 
				
			||||||
CRGB leds[RGB_LED_COUNT];
 | 
					CRGB leds[RGB_LED_COUNT];
 | 
				
			||||||
 | 
					 | 
				
			||||||
void led_setcolor(CRGB color) {
 | 
					 | 
				
			||||||
  for (int i = 0; i < RGB_LED_COUNT; i++)
 | 
					 | 
				
			||||||
    leds[i] = color;
 | 
					 | 
				
			||||||
  FastLED.show();
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void led_sethue(uint8_t hue) {
 | 
					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] = CHSV(hue, 0XFF, 100);
 | 
					    leds[i] = CRGB(color);
 | 
				
			||||||
  FastLED.show();
 | 
					  FastLED.show();
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -29,15 +27,11 @@ 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
 | 
				
			||||||
@ -45,9 +39,6 @@ void switch_LED(led_states state) {
 | 
				
			|||||||
    digitalWrite(HAS_LED, LOW);
 | 
					    digitalWrite(HAS_LED, LOW);
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
    digitalWrite(HAS_LED, HIGH);
 | 
					    digitalWrite(HAS_LED, HIGH);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					 | 
				
			||||||
      led_setcolor(CRGB::White);
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
  } else if (state == LED_OFF) {
 | 
					  } else if (state == LED_OFF) {
 | 
				
			||||||
    // switch LED off
 | 
					    // switch LED off
 | 
				
			||||||
@ -55,42 +46,32 @@ void switch_LED(led_states state) {
 | 
				
			|||||||
    digitalWrite(HAS_LED, HIGH);
 | 
					    digitalWrite(HAS_LED, HIGH);
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
    digitalWrite(HAS_LED, LOW);
 | 
					    digitalWrite(HAS_LED, LOW);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					 | 
				
			||||||
      led_setcolor(CRGB::Black);
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void switch_LED1(led_states state) {
 | 
					void switch_LED1(led_states state) {
 | 
				
			||||||
#ifdef HAS_TWO_LED
 | 
					#ifdef HAS_TWO_LED
 | 
				
			||||||
  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 (state == LED_ON) {
 | 
					  if (state == LED_ON) {
 | 
				
			||||||
    // switch LED on
 | 
					    // switch LED on
 | 
				
			||||||
#ifdef LED_ACTIVE_LOW
 | 
					#ifdef LED1_ACTIVE_LOW
 | 
				
			||||||
    digitalWrite(HAS_TWO_LED, 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
 | 
					#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) {
 | 
				
			||||||
@ -104,9 +85,7 @@ void ledLoop(void *parameter) {
 | 
				
			|||||||
        LEDState = LED_OFF;
 | 
					        LEDState = LED_OFF;
 | 
				
			||||||
        LEDBlinkStarted = 0;
 | 
					        LEDBlinkStarted = 0;
 | 
				
			||||||
        LEDBlinkDuration = 0;
 | 
					        LEDBlinkDuration = 0;
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					        LEDColor = COLOR_NONE;
 | 
				
			||||||
        led_setcolor(CRGB::Black);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        // In case of LoRaWAN led management blinked off
 | 
					        // In case of LoRaWAN led management blinked off
 | 
				
			||||||
        LEDState = LED_ON;
 | 
					        LEDState = LED_ON;
 | 
				
			||||||
@ -116,9 +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)) {
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					        LEDColor = COLOR_YELLOW;
 | 
				
			||||||
        led_setcolor(CRGB::Yellow);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
        // 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
 | 
				
			||||||
@ -126,19 +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:
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					          LEDColor = COLOR_PINK;
 | 
				
			||||||
          led_setcolor(CRGB::Pink);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
          break;
 | 
					          break;
 | 
				
			||||||
        case CONFIGPORT:
 | 
					        case CONFIGPORT:
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					          LEDColor = COLOR_CYAN;
 | 
				
			||||||
          led_setcolor(CRGB::Cyan);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
          break;
 | 
					          break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					          LEDColor = COLOR_BLUE;
 | 
				
			||||||
          led_setcolor(CRGB::Blue);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
          break;
 | 
					          break;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        // small blink 10ms on each 1/2sec (not when joining)
 | 
					        // small blink 10ms on each 1/2sec (not when joining)
 | 
				
			||||||
@ -146,25 +117,33 @@ 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)) {
 | 
				
			||||||
#ifdef HAS_RGB_LED
 | 
					        LEDColor = COLOR_RED;
 | 
				
			||||||
        led_setcolor(CRGB::Red);
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
        // 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)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user