tweaked guards to allow various combinations of RGB leds

This commit is contained in:
Gareth Coleman 2024-04-21 08:24:51 +01:00
parent e0513d4078
commit fb7a878d94
3 changed files with 68 additions and 100 deletions

View File

@ -41,7 +41,7 @@ class ScanI2C
BQ24295, BQ24295,
LSM6DS3, LSM6DS3,
TCA9555, TCA9555,
#ifdef HAS_NCP5623 #if defined(HAS_NCP5623) || defined(UNPHONE) || defined(RGBLED_RED)
NCP5623, NCP5623,
#endif #endif
} DeviceType; } DeviceType;

View File

@ -607,15 +607,14 @@ void setup()
} }
#endif #endif
#if !defined(ARCH_PORTDUINO) && !defined(ARCH_STM32WL) #ifdef UNPHONE
ambientLightingThread = new AmbientLightingThread(ScanI2C::DeviceType::NONE);
#elif defined(RGBLED_RED)
ambientLightingThread = new AmbientLightingThread(ScanI2C::DeviceType::NONE);
#elif !defined(ARCH_PORTDUINO) && !defined(ARCH_STM32WL)
if (rgb_found.type != ScanI2C::DeviceType::NONE) { if (rgb_found.type != ScanI2C::DeviceType::NONE) {
ambientLightingThread = new AmbientLightingThread(rgb_found.type); ambientLightingThread = new AmbientLightingThread(rgb_found.type);
} }
#ifdef UNPHONE
ambientLightingThread = new AmbientLightingThread(rgb_found.type);
#elif defined(RGBLED_RED)
ambientLightingThread = new AmbientLightingThread(rgb_found.type);
#endif
#endif #endif
#ifdef T_WATCH_S3 #ifdef T_WATCH_S3

View File

@ -26,29 +26,14 @@
#ifdef HAS_NCP5623 #ifdef HAS_NCP5623
#include <graphics/RAKled.h> #include <graphics/RAKled.h>
uint8_t red = 0;
uint8_t green = 0;
uint8_t blue = 0;
uint8_t colorState = 1;
uint8_t brightnessIndex = 0;
uint8_t brightnessValues[] = {0, 10, 20, 30, 50, 90, 160, 170}; // blue gets multiplied by 1.5
bool ascending = true;
#endif #endif
#ifdef UNPHONE #ifdef UNPHONE
#include "unPhone.h" #include "unPhone.h"
extern unPhone unphone; extern unPhone unphone;
uint8_t red = 0;
uint8_t green = 0;
uint8_t blue = 0;
uint8_t colorState = 1;
const uint8_t duration = 15;
uint8_t counter = 0;
#endif #endif
#ifdef RGBLED_RED #if defined(HAS_NCP5623) || defined(UNPHONE) || defined(RGBLED_RED)
uint8_t red = 0; uint8_t red = 0;
uint8_t green = 0; uint8_t green = 0;
uint8_t blue = 0; uint8_t blue = 0;
@ -130,53 +115,27 @@ int32_t ExternalNotificationModule::runOnce()
millis()) { millis()) {
getExternal(2) ? setExternalOff(2) : setExternalOn(2); getExternal(2) ? setExternalOff(2) : setExternalOn(2);
} }
#if defined(HAS_NCP5623) || defined(UNPHONE) || defined(RGBLED_RED)
red = (colorState & 4) ? brightnessValues[brightnessIndex] : 0; // Red enabled on colorState = 4,5,6,7
green = (colorState & 2) ? brightnessValues[brightnessIndex] : 0; // Green enabled on colorState = 2,3,6,7
blue = (colorState & 1) ? (brightnessValues[brightnessIndex] * 1.5) : 0; // Blue enabled on colorState = 1,3,5,7
#ifdef HAS_NCP5623 #ifdef HAS_NCP5623
if (rgb_found.type == ScanI2C::NCP5623) { if (rgb_found.type == ScanI2C::NCP5623) {
red = (colorState & 4) ? brightnessValues[brightnessIndex] : 0; // Red enabled on colorState = 4,5,6,7
green = (colorState & 2) ? brightnessValues[brightnessIndex] : 0; // Green enabled on colorState = 2,3,6,7
blue = (colorState & 1) ? (brightnessValues[brightnessIndex] * 1.5) : 0; // Blue enabled on colorState = 1,3,5,7
rgb.setColor(red, green, blue); rgb.setColor(red, green, blue);
if (ascending) { // fade in
brightnessIndex++;
if (brightnessIndex == (sizeof(brightnessValues) - 1)) {
ascending = false;
}
} else {
brightnessIndex--; // fade out
}
if (brightnessIndex == 0) {
ascending = true;
colorState++; // next color
if (colorState > 7) {
colorState = 1;
}
}
} }
#endif #endif
#ifdef UNPHONE #ifdef UNPHONE
red = colorState & 4; // Red enabled on colorState = 4,5,6,7
green = colorState & 2; // Green enabled on colorState = 2,3,6,7
blue = colorState & 1; // Blue enabled on colorState = 1,3,5,7
unphone.rgb(red, green, blue); unphone.rgb(red, green, blue);
counter++; // tick on
if (counter > duration) {
counter = 0;
colorState++; // next color
if (colorState > 7) {
colorState = 1;
}
}
#endif #endif
#ifdef RGBLED_CA
#ifdef RGBLED_RED analogWrite(RGBLED_RED, 255 - red); // CA type needs reverse logic
red = (colorState & 4) ? brightnessValues[brightnessIndex] : 0; // Red enabled on colorState = 4,5,6,7 analogWrite(RGBLED_GREEN, 255 - green);
green = (colorState & 2) ? brightnessValues[brightnessIndex] : 0; // Green enabled on colorState = 2,3,6,7 analogWrite(RGBLED_BLUE, 255 - blue);
blue = (colorState & 1) ? (brightnessValues[brightnessIndex] * 1.5) : 0; // Blue enabled on colorState = 1,3,5,7 #elif defined(RGBLED_RED)
analogWrite(RGBLED_RED, red); analogWrite(RGBLED_RED, red);
analogWrite(RGBLED_GREEN, green); analogWrite(RGBLED_GREEN, green);
analogWrite(RGBLED_BLUE, blue); analogWrite(RGBLED_BLUE, blue);
#endif
if (ascending) { // fade in if (ascending) { // fade in
brightnessIndex++; brightnessIndex++;
if (brightnessIndex == (sizeof(brightnessValues) - 1)) { if (brightnessIndex == (sizeof(brightnessValues) - 1)) {
@ -192,6 +151,7 @@ int32_t ExternalNotificationModule::runOnce()
colorState = 1; colorState = 1;
} }
} }
}
#endif #endif
#ifdef T_WATCH_S3 #ifdef T_WATCH_S3
@ -221,7 +181,6 @@ int32_t ExternalNotificationModule::runOnce()
return EXT_NOTIFICATION_DEFAULT_THREAD_MS; return EXT_NOTIFICATION_DEFAULT_THREAD_MS;
} }
}
bool ExternalNotificationModule::wantPacket(const meshtastic_MeshPacket *p) bool ExternalNotificationModule::wantPacket(const meshtastic_MeshPacket *p)
{ {
@ -265,7 +224,7 @@ void ExternalNotificationModule::setExternalOn(uint8_t index)
unphone.rgb(red, green, blue); unphone.rgb(red, green, blue);
#endif #endif
#ifdef RGBLED_CA #ifdef RGBLED_CA
analogWrite(RGBLED_RED, 255 - red); analogWrite(RGBLED_RED, 255 - red); // CA type needs reverse logic
analogWrite(RGBLED_GREEN, 255 - green); analogWrite(RGBLED_GREEN, 255 - green);
analogWrite(RGBLED_BLUE, 255 - blue); analogWrite(RGBLED_BLUE, 255 - blue);
#elif defined(RGBLED_RED) #elif defined(RGBLED_RED)
@ -315,21 +274,21 @@ void ExternalNotificationModule::setExternalOff(uint8_t index)
blue = 0; blue = 0;
unphone.rgb(red, green, blue); unphone.rgb(red, green, blue);
#endif #endif
#ifdef RGBLED_CA #ifdef RGBLED_RED
red = 0; red = 0;
green = 0; green = 0;
blue = 0; blue = 0;
analogWrite(RGBLED_RED, 255 - red); #ifdef RGBLED_CA
analogWrite(RGBLED_RED, 255 - red); // CA type needs reverse logic
analogWrite(RGBLED_GREEN, 255 - green); analogWrite(RGBLED_GREEN, 255 - green);
analogWrite(RGBLED_BLUE, 255 - blue); analogWrite(RGBLED_BLUE, 255 - blue);
#elif defined(RGBLED_RED) #else
red = 0;
green = 0;
blue = 0;
analogWrite(RGBLED_RED, red); analogWrite(RGBLED_RED, red);
analogWrite(RGBLED_GREEN, green); analogWrite(RGBLED_GREEN, green);
analogWrite(RGBLED_BLUE, blue); analogWrite(RGBLED_BLUE, blue);
#endif #endif
#endif
#ifdef T_WATCH_S3 #ifdef T_WATCH_S3
drv.stop(); drv.stop();
#endif #endif
@ -427,6 +386,16 @@ ExternalNotificationModule::ExternalNotificationModule()
rgb.begin(); rgb.begin();
rgb.setCurrent(10); rgb.setCurrent(10);
} }
#endif
#ifdef RGBLED_RED
pinMode(RGBLED_RED, OUTPUT); // set up the RGB led pins
pinMode(RGBLED_GREEN, OUTPUT);
pinMode(RGBLED_BLUE, OUTPUT);
#endif
#ifdef RGBLED_CA
analogWrite(RGBLED_RED, 255); // with a common anode type, logic is reversed
analogWrite(RGBLED_GREEN, 255); // so we want to initialise with lights off
analogWrite(RGBLED_BLUE, 255);
#endif #endif
} else { } else {
LOG_INFO("External Notification Module Disabled\n"); LOG_INFO("External Notification Module Disabled\n");