3afb499930
Added secondary color transition Added option to have UI while receiving realtime Fixed mDNS not working Fixed Arduino OTA not working when locked but enabled
209 lines
5.0 KiB
C++
209 lines
5.0 KiB
C++
/*
|
|
* LED methods
|
|
*/
|
|
|
|
void setAllLeds() {
|
|
double d = briT*briMultiplier;
|
|
int val = d/100;
|
|
if (val > 255) val = 255;
|
|
if (useGammaCorrectionBri)
|
|
{
|
|
strip.setBrightness(gamma8[val]);
|
|
} else {
|
|
strip.setBrightness(val);
|
|
}
|
|
if (disableSecTransition)
|
|
{
|
|
for (byte i = 0; i<3; i++)
|
|
{
|
|
colSecT[i] = colSec[i];
|
|
}
|
|
whiteSecT = whiteSec;
|
|
}
|
|
if (useGammaCorrectionRGB)
|
|
{
|
|
strip.setColor(gamma8[colT[0]], gamma8[colT[1]], gamma8[colT[2]], gamma8[whiteT]);
|
|
strip.setSecondaryColor(gamma8[colSecT[0]], gamma8[colSecT[1]], gamma8[colSecT[2]], gamma8[whiteSecT]);
|
|
} else {
|
|
strip.setColor(colT[0], colT[1], colT[2], whiteT);
|
|
strip.setSecondaryColor(colSecT[0], colSecT[1], colSecT[2], whiteSecT);
|
|
}
|
|
}
|
|
|
|
void setLedsStandard()
|
|
{
|
|
for (byte i = 0; i<3; i++)
|
|
{
|
|
colOld[i] = col[i];
|
|
colT[i] = col[i];
|
|
colSecOld[i] = colSec[i];
|
|
colSecT[i] = colSec[i];
|
|
}
|
|
whiteOld = white;
|
|
briOld = bri;
|
|
whiteSecOld = whiteSec;
|
|
whiteT = white;
|
|
briT = bri;
|
|
whiteSecT = whiteSec;
|
|
setAllLeds();
|
|
}
|
|
|
|
bool colorChanged()
|
|
{
|
|
for (int i = 0; i < 3; i++)
|
|
{
|
|
if (col[i] != colIT[i]) return true;
|
|
if (colSec[i] != colSecIT[i]) return true;
|
|
}
|
|
if (white != whiteIT || whiteSec != whiteSecIT) return true;
|
|
if (bri != briIT) return true;
|
|
return false;
|
|
}
|
|
|
|
void colorUpdated(int callMode)
|
|
{
|
|
//call for notifier -> 0: init 1: direct change 2: button 3: notification 4: nightlight 5: other (NN)6: fx changed 7: hue 8: preset cycle
|
|
if (!colorChanged())
|
|
{
|
|
if (callMode == 6) notify(6);
|
|
return; //no change
|
|
}
|
|
if (callMode != 5 && nightlightActive && nightlightFade)
|
|
{
|
|
briNlT = bri;
|
|
nightlightDelayMs -= (millis() - nightlightStartTime);
|
|
nightlightStartTime = millis();
|
|
}
|
|
colIT[0] = col[0];
|
|
colIT[1] = col[1];
|
|
colIT[2] = col[2];
|
|
colSecIT[0] = colSec[0];
|
|
colSecIT[1] = colSec[1];
|
|
colSecIT[2] = colSec[2];
|
|
whiteIT = white;
|
|
whiteSecIT = whiteSec;
|
|
briIT = bri;
|
|
if (bri > 0) briLast = bri;
|
|
notify(callMode);
|
|
if (fadeTransition || sweepTransition)
|
|
{
|
|
//set correct delay if not using notification delay
|
|
if (callMode != 3) transitionDelayTemp = transitionDelay;
|
|
if (transitionDelayTemp == 0) {setLedsStandard();strip.trigger();return;}
|
|
|
|
if (transitionActive)
|
|
{
|
|
colOld[0] = colT[0];
|
|
colOld[1] = colT[1];
|
|
colOld[2] = colT[2];
|
|
whiteOld = whiteT;
|
|
colSecOld[0] = colSecT[0];
|
|
colSecOld[1] = colSecT[1];
|
|
colSecOld[2] = colSecT[2];
|
|
whiteSecOld = whiteSecT;
|
|
briOld = briT;
|
|
tperLast = 0;
|
|
}
|
|
transitionActive = true;
|
|
transitionStartTime = millis();
|
|
strip.setFastUpdateMode(true);
|
|
} else
|
|
{
|
|
setLedsStandard();
|
|
strip.trigger();
|
|
}
|
|
}
|
|
|
|
void handleTransitions()
|
|
{
|
|
if (transitionActive && transitionDelayTemp > 0)
|
|
{
|
|
float tper = (millis() - transitionStartTime)/(float)transitionDelayTemp;
|
|
if (tper >= 1.0)
|
|
{
|
|
transitionActive = false;
|
|
tperLast = 0;
|
|
if (sweepTransition) strip.unlockAll();
|
|
setLedsStandard();
|
|
strip.setFastUpdateMode(false);
|
|
return;
|
|
}
|
|
if (tper - tperLast < 0.004)
|
|
{
|
|
return;
|
|
}
|
|
tperLast = tper;
|
|
if (fadeTransition)
|
|
{
|
|
for (byte i = 0; i<3; i++)
|
|
{
|
|
colT[i] = colOld[i]+((col[i] - colOld[i])*tper);
|
|
colSecT[i] = colSecOld[i]+((colSec[i] - colSecOld[i])*tper);
|
|
}
|
|
whiteT = whiteOld +((white - whiteOld )*tper);
|
|
whiteSecT = whiteSecOld +((whiteSec - whiteSecOld )*tper);
|
|
briT = briOld +((bri - briOld )*tper);
|
|
}
|
|
if (sweepTransition)
|
|
{
|
|
strip.lockAll();
|
|
if (sweepDirection)
|
|
{
|
|
strip.unlockRange(0, (int)(tper*(double)ledCount));
|
|
} else
|
|
{
|
|
strip.unlockRange(ledCount - (int)(tper*(double)ledCount), ledCount);
|
|
}
|
|
if (!fadeTransition)
|
|
{
|
|
setLedsStandard();
|
|
}
|
|
}
|
|
if (fadeTransition) setAllLeds();
|
|
}
|
|
}
|
|
|
|
void handleNightlight()
|
|
{
|
|
if (nightlightActive)
|
|
{
|
|
if (!nightlightActiveOld) //init
|
|
{
|
|
nightlightStartTime = millis();
|
|
notify(4);
|
|
nightlightDelayMs = (int)(nightlightDelayMins*60000);
|
|
nightlightActiveOld = true;
|
|
briNlT = bri;
|
|
}
|
|
float nper = (millis() - nightlightStartTime)/((float)nightlightDelayMs);
|
|
if (nightlightFade)
|
|
{
|
|
bri = briNlT+((nightlightTargetBri - briNlT)*nper);
|
|
colorUpdated(5);
|
|
}
|
|
if (nper >= 1)
|
|
{
|
|
nightlightActive = false;
|
|
if (!nightlightFade)
|
|
{
|
|
bri = nightlightTargetBri;
|
|
colorUpdated(5);
|
|
}
|
|
if (bri == 0) briLast = briNlT;
|
|
}
|
|
} else if (nightlightActiveOld) //early de-init
|
|
{
|
|
nightlightActiveOld = false;
|
|
}
|
|
|
|
//also handle preset cycle here
|
|
if (presetCyclingEnabled && (millis() - presetCycledTime > presetCycleTime))
|
|
{
|
|
applyPreset(presetCycCurr,presetApplyBri,presetApplyCol,presetApplyFx);
|
|
presetCycCurr++; if (presetCycCurr > presetCycleMax) presetCycCurr = presetCycleMin;
|
|
if (presetCycCurr > 25) presetCycCurr = 1;
|
|
colorUpdated(8);
|
|
presetCycledTime = millis();
|
|
}
|
|
}
|