Live mainseg improvements
Make override work in mainseg mode Move unfreeze on turn on from UI to JSON parser Fix mainseg not unfreezing on timeout
This commit is contained in:
		| @@ -140,7 +140,7 @@ void notify(byte callMode, bool followUp) | ||||
|  | ||||
| void realtimeLock(uint32_t timeoutMs, byte md) | ||||
| { | ||||
|   if (!realtimeMode) { | ||||
|   if (!realtimeMode && !realtimeOverride) { | ||||
|     uint16_t stop, start; | ||||
|     if (useMainSegmentOnly) { | ||||
|       WS2812FX::Segment& mainseg = strip.getMainSegment(); | ||||
| @@ -152,30 +152,41 @@ void realtimeLock(uint32_t timeoutMs, byte md) | ||||
|       stop  = strip.getLengthTotal(); | ||||
|     } | ||||
|     // clear strip/segment | ||||
|     if (useMainSegmentOnly || !realtimeOverride) for (uint16_t i = start; i < stop; i++) strip.setPixelColor(i,0,0,0,0); | ||||
|     // if WLED was off and using main segment only, turn non-main segments off | ||||
|     for (uint16_t i = start; i < stop; i++) strip.setPixelColor(i,0,0,0,0); | ||||
|     // if WLED was off and using main segment only, freeze non-main segments so they stay off | ||||
|     if (useMainSegmentOnly && bri == 0) { | ||||
|       for (uint8_t s=0; s < strip.getMaxSegments(); s++) { | ||||
|         if (s != strip.getMainSegmentId()) strip.getSegment(s).setOption(SEG_OPTION_ON, false, s); | ||||
|         else                               strip.getSegment(s).setOption(SEG_OPTION_ON, true, s); | ||||
|         strip.getSegment(s).setOption(SEG_OPTION_FREEZE, true, s); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   // if strip is off (bri==0) and not already in RTM | ||||
|   if (briT == 0 && !realtimeMode && !realtimeOverride) { | ||||
|     strip.setBrightness(scaledBri(briLast), true); | ||||
|   } | ||||
|  | ||||
|   if (realtimeTimeout != UINT32_MAX) { | ||||
|     if (timeoutMs == 255001 || timeoutMs == 65000) realtimeTimeout = UINT32_MAX; | ||||
|     else                                           realtimeTimeout = millis() + timeoutMs; | ||||
|   } | ||||
|   // if strip is off (bri==0) and not already in RTM | ||||
|   if (briT == 0 && !realtimeMode) { | ||||
|     strip.setBrightness(scaledBri(briLast), true); | ||||
|     realtimeTimeout = (timeoutMs == 255001 || timeoutMs == 65000) ? UINT32_MAX : millis() + timeoutMs; | ||||
|   } | ||||
|   realtimeMode = md; | ||||
|  | ||||
|   if (arlsForceMaxBri && !realtimeOverride) strip.setBrightness(scaledBri(255), true); | ||||
|   if (realtimeOverride) return; | ||||
|   if (arlsForceMaxBri) strip.setBrightness(scaledBri(255), true); | ||||
|   if (briT > 0 && md == REALTIME_MODE_GENERIC) strip.show(); | ||||
| } | ||||
|  | ||||
| void exitRealtime() { | ||||
|   if (!realtimeMode) return; | ||||
|   if (realtimeOverride == REALTIME_OVERRIDE_ONCE) realtimeOverride = REALTIME_OVERRIDE_NONE; | ||||
|   strip.setBrightness(scaledBri(bri)); | ||||
|   realtimeTimeout = 0; // cancel realtime mode immediately | ||||
|   realtimeMode = REALTIME_MODE_INACTIVE; // inform UI immediately | ||||
|   realtimeIP[0] = 0; | ||||
|   if (useMainSegmentOnly) { // unfreeze live segment again | ||||
|     strip.getMainSegment().setOption(SEG_OPTION_FREEZE, false, strip.getMainSegmentId()); | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| #define TMP2NET_OUT_PORT 65442 | ||||
|  | ||||
| @@ -203,13 +214,7 @@ void handleNotifications() | ||||
|   } | ||||
|  | ||||
|   //unlock strip when realtime UDP times out | ||||
|   if (realtimeMode && millis() > realtimeTimeout) | ||||
|   { | ||||
|     if (realtimeOverride == REALTIME_OVERRIDE_ONCE) realtimeOverride = REALTIME_OVERRIDE_NONE; | ||||
|     strip.setBrightness(scaledBri(bri)); | ||||
|     realtimeMode = REALTIME_MODE_INACTIVE; | ||||
|     realtimeIP[0] = 0; | ||||
|   } | ||||
|   if (realtimeMode && millis() > realtimeTimeout) exitRealtime(); | ||||
|  | ||||
|   //receive UDP notifications | ||||
|   if (!udpConnected) return; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 cschwinne
					cschwinne