Merge branch '0_15' of https://github.com/Aircoookie/WLED into ledmaps-realtime
This commit is contained in:
		| @@ -5276,7 +5276,7 @@ uint16_t mode_2DLissajous(void) {            // By: Andrew Tuline | ||||
|  | ||||
|   return FRAMETIME; | ||||
| } // mode_2DLissajous() | ||||
| static const char _data_FX_MODE_2DLISSAJOUS[] PROGMEM = "Lissajous@X frequency,Fade rate,,,Speed;!;!;2;;c3=15"; | ||||
| static const char _data_FX_MODE_2DLISSAJOUS[] PROGMEM = "Lissajous@X frequency,Fade rate,,,Speed;!;!;2;c3=15"; | ||||
|  | ||||
|  | ||||
| /////////////////////// | ||||
| @@ -5288,7 +5288,7 @@ uint16_t mode_2Dmatrix(void) {                  // Matrix2D. By Jeremy Williams. | ||||
|   const uint16_t cols = SEGMENT.virtualWidth(); | ||||
|   const uint16_t rows = SEGMENT.virtualHeight(); | ||||
|  | ||||
|   uint16_t dataSize = (SEGLEN+7) >> 3; //1 bit per LED for trails | ||||
|   uint16_t dataSize = (SEGMENT.length()+7) >> 3; //1 bit per LED for trails | ||||
|   if (!SEGENV.allocateData(dataSize)) return mode_static(); //allocation failed | ||||
|  | ||||
|   if (SEGENV.call == 0) { | ||||
|   | ||||
| @@ -493,9 +493,9 @@ typedef struct Segment { | ||||
|  | ||||
|     ~Segment() { | ||||
|       #ifdef WLED_DEBUG | ||||
|       //Serial.printf("-- Destroying segment: %p\n", this); | ||||
|       //Serial.printf("-- Destroying segment: %p", this); | ||||
|       //if (name) Serial.printf(" %s (%p)", name, name); | ||||
|       //if (data) Serial.printf(" %d (%p)", (int)_dataLen, data); | ||||
|       //if (data) Serial.printf(" %d->(%p)", (int)_dataLen, data); | ||||
|       //Serial.println(); | ||||
|       #endif | ||||
|       if (name) { delete[] name; name = nullptr; } | ||||
|   | ||||
| @@ -290,7 +290,7 @@ void Segment::startTransition(uint16_t dur) { | ||||
|   _t = new Transition(dur); // no previous transition running | ||||
|   if (!_t) return; // failed to allocate data | ||||
|  | ||||
|   //DEBUG_PRINTF("-- Started transition: %p\n", this); | ||||
|   //DEBUG_PRINTF("-- Started transition: %p (%p)\n", this, _t); | ||||
|   loadPalette(_t->_palT, palette); | ||||
|   _t->_briT           = on ? opacity : 0; | ||||
|   _t->_cctT           = cct; | ||||
| @@ -317,8 +317,8 @@ void Segment::startTransition(uint16_t dur) { | ||||
| } | ||||
|  | ||||
| void Segment::stopTransition() { | ||||
|   //DEBUG_PRINTF("-- Stopping transition: %p\n", this); | ||||
|   if (isInTransition()) { | ||||
|     //DEBUG_PRINTF("-- Stopping transition: %p\n", this); | ||||
|     #ifndef WLED_DISABLE_MODE_BLEND | ||||
|     if (_t->_segT._dataT && _t->_segT._dataLenT > 0) { | ||||
|       //DEBUG_PRINTF("--  Released duplicate data (%d) for %p: %p\n", _t->_segT._dataLenT, this, _t->_segT._dataT); | ||||
| @@ -348,7 +348,7 @@ uint16_t IRAM_ATTR Segment::progress() { | ||||
|  | ||||
| #ifndef WLED_DISABLE_MODE_BLEND | ||||
| void Segment::swapSegenv(tmpsegd_t &tmpSeg) { | ||||
|   //DEBUG_PRINTF("--  Saving temp seg: %p (%p)\n", this, tmpSeg); | ||||
|   //DEBUG_PRINTF("--  Saving temp seg: %p->(%p) [%d->%p]\n", this, &tmpSeg, _dataLen, data); | ||||
|   tmpSeg._optionsT   = options; | ||||
|   for (size_t i=0; i<NUM_COLORS; i++) tmpSeg._colorT[i] = colors[i]; | ||||
|   tmpSeg._speedT     = speed; | ||||
| @@ -384,11 +384,10 @@ void Segment::swapSegenv(tmpsegd_t &tmpSeg) { | ||||
|     data      = _t->_segT._dataT; | ||||
|     _dataLen  = _t->_segT._dataLenT; | ||||
|   } | ||||
|   //DEBUG_PRINTF("--   temp seg data: %p (%d,%p)\n", this, _dataLen, data); | ||||
| } | ||||
|  | ||||
| void Segment::restoreSegenv(tmpsegd_t &tmpSeg) { | ||||
|   //DEBUG_PRINTF("--  Restoring temp seg: %p (%p)\n", this, tmpSeg); | ||||
|   //DEBUG_PRINTF("--  Restoring temp seg: %p->(%p) [%d->%p]\n", &tmpSeg, this, _dataLen, data); | ||||
|   if (_t && &(_t->_segT) != &tmpSeg) { | ||||
|     // update possibly changed variables to keep old effect running correctly | ||||
|     _t->_segT._aux0T = aux0; | ||||
| @@ -415,7 +414,6 @@ void Segment::restoreSegenv(tmpsegd_t &tmpSeg) { | ||||
|   call      = tmpSeg._callT; | ||||
|   data      = tmpSeg._dataT; | ||||
|   _dataLen  = tmpSeg._dataLenT; | ||||
|   //DEBUG_PRINTF("--   temp seg data: %p (%d,%p)\n", this, _dataLen, data); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| @@ -578,7 +576,7 @@ void Segment::setMode(uint8_t fx, bool loadDefaults) { | ||||
|         sOpt = extractModeDefaults(fx, "o1");   check1    = (sOpt >= 0) ? (bool)sOpt : false; | ||||
|         sOpt = extractModeDefaults(fx, "o2");   check2    = (sOpt >= 0) ? (bool)sOpt : false; | ||||
|         sOpt = extractModeDefaults(fx, "o3");   check3    = (sOpt >= 0) ? (bool)sOpt : false; | ||||
|         sOpt = extractModeDefaults(fx, "m12");  if (sOpt >= 0) map1D2D   = constrain(sOpt, 0, 7); | ||||
|         sOpt = extractModeDefaults(fx, "m12");  if (sOpt >= 0) map1D2D   = constrain(sOpt, 0, 7); else map1D2D = M12_Pixels;  // reset mapping if not defined (2D FX may not work) | ||||
|         sOpt = extractModeDefaults(fx, "si");   if (sOpt >= 0) soundSim  = constrain(sOpt, 0, 3); | ||||
|         sOpt = extractModeDefaults(fx, "rev");  if (sOpt >= 0) reverse   = (bool)sOpt; | ||||
|         sOpt = extractModeDefaults(fx, "mi");   if (sOpt >= 0) mirror    = (bool)sOpt; // NOTE: setting this option is a risky business | ||||
| @@ -1158,15 +1156,12 @@ void WS2812FX::service() { | ||||
|       uint16_t delay = FRAMETIME; | ||||
|  | ||||
|       if (!seg.freeze) { //only run effect function if not frozen | ||||
|         _virtualSegmentLength = seg.virtualLength(); | ||||
|         _colors_t[0] = seg.currentColor(0); | ||||
|         _colors_t[1] = seg.currentColor(1); | ||||
|         _colors_t[2] = seg.currentColor(2); | ||||
|         _virtualSegmentLength = seg.virtualLength(); //SEGLEN | ||||
|         _colors_t[0] = gamma32(seg.currentColor(0)); | ||||
|         _colors_t[1] = gamma32(seg.currentColor(1)); | ||||
|         _colors_t[2] = gamma32(seg.currentColor(2)); | ||||
|         seg.currentPalette(_currentPalette, seg.palette); // we need to pass reference | ||||
|  | ||||
|         if (!cctFromRgb || correctWB) busses.setSegmentCCT(seg.currentBri(true), correctWB); | ||||
|         for (int c = 0; c < NUM_COLORS; c++) _colors_t[c] = gamma32(_colors_t[c]); | ||||
|  | ||||
|         // Effect blending | ||||
|         // When two effects are being blended, each may have different segment data, this | ||||
|         // data needs to be saved first and then restored before running previous mode. | ||||
| @@ -1180,6 +1175,7 @@ void WS2812FX::service() { | ||||
|           Segment::tmpsegd_t _tmpSegData; | ||||
|           Segment::modeBlend(true);           // set semaphore | ||||
|           seg.swapSegenv(_tmpSegData);        // temporarily store new mode state (and swap it with transitional state) | ||||
|           _virtualSegmentLength = seg.virtualLength(); // update SEGLEN (mapping may have changed) | ||||
|           uint16_t d2 = (*_mode[tmpMode])();  // run old mode | ||||
|           seg.restoreSegenv(_tmpSegData);     // restore mode state (will also update transitional state) | ||||
|           delay = MIN(delay,d2);              // use shortest delay | ||||
|   | ||||
| @@ -166,7 +166,6 @@ bool deserializeConfig(JsonObject doc, bool fromFS) { | ||||
|       bool reversed = elm["rev"]; | ||||
|       bool refresh = elm["ref"] | false; | ||||
|       uint16_t freqkHz = elm[F("freq")] | 0;  // will be in kHz for DotStar and Hz for PWM (not yet implemented fully) | ||||
|       ledType |= refresh << 7; // hack bit 7 to indicate strip requires off refresh | ||||
|       uint8_t AWmode = elm[F("rgbwm")] | autoWhiteMode; | ||||
|       uint8_t maPerLed = elm[F("ledma")] | strip.milliampsPerLed; // replace with 55 when removing strip.milliampsPerLed | ||||
|       uint16_t maMax = elm[F("maxpwr")] | (strip.ablMilliampsMax * length) / total; // rough (incorrect?) per strip ABL calculation when no config exists | ||||
| @@ -175,6 +174,7 @@ bool deserializeConfig(JsonObject doc, bool fromFS) { | ||||
|         maPerLed = 0; | ||||
|         maMax = 0; | ||||
|       } | ||||
|       ledType |= refresh << 7; // hack bit 7 to indicate strip requires off refresh | ||||
|       if (fromFS) { | ||||
|         BusConfig bc = BusConfig(ledType, pins, start, length, colorOrder, reversed, skipFirst, AWmode, freqkHz, useGlobalLedBuffer, maPerLed, maMax); | ||||
|         mem += BusManager::memUsage(bc); | ||||
|   | ||||
| @@ -1506,6 +1506,8 @@ function setEffectParameters(idx) | ||||
| 		let text = slider.getAttribute("tooltip"); | ||||
| 		if ((!controlDefined && i<((idx<128)?2:nSliders)) || (slOnOff.length>i && slOnOff[i]!="")) { | ||||
| 			if (slOnOff.length>i && slOnOff[i]!="!") text = slOnOff[i]; | ||||
| 			// restore overwritten default tooltips | ||||
| 			if (i<2 && slOnOff[i]==="!") text = i==0 ? "Effect speed" : "Effect intensity"; | ||||
| 			slider.setAttribute("tooltip", text); | ||||
| 			slider.parentElement.classList.remove('hide'); | ||||
| 		} else | ||||
| @@ -1540,7 +1542,6 @@ function setEffectParameters(idx) | ||||
| 	var cslLabel = ''; | ||||
| 	var sep = ''; | ||||
| 	var cslCnt = 0, oCsel = csel; | ||||
| //	for (let i=0; i<gId("csl").querySelectorAll("button"); i++) { | ||||
| 	d.querySelectorAll("#csl button").forEach((e,i)=>{ | ||||
| 		var btn = gId("csl" + i); | ||||
| 		// if no controlDefined or coOnOff has a value | ||||
|   | ||||
							
								
								
									
										1243
									
								
								wled00/html_ui.h
									
									
									
									
									
								
							
							
						
						
									
										1243
									
								
								wled00/html_ui.h
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -136,7 +136,6 @@ void handleSettingsSet(AsyncWebServerRequest *request, byte subPage) | ||||
|         pins[i] = (request->arg(lp).length() > 0) ? request->arg(lp).toInt() : 255; | ||||
|       } | ||||
|       type = request->arg(lt).toInt(); | ||||
|       type |= request->hasArg(rf) << 7; // off refresh override | ||||
|       skip = request->arg(sl).toInt(); | ||||
|       colorOrder = request->arg(co).toInt(); | ||||
|       start = (request->hasArg(ls)) ? request->arg(ls).toInt() : t; | ||||
| @@ -176,6 +175,7 @@ void handleSettingsSet(AsyncWebServerRequest *request, byte subPage) | ||||
|         maPerLed = request->arg(la).toInt(); | ||||
|         maMax = request->arg(ma).toInt(); // if ABL is disabled this will be 0 | ||||
|       } | ||||
|       type |= request->hasArg(rf) << 7; // off refresh override | ||||
|       // actual finalization is done in WLED::loop() (removing old busses and adding new) | ||||
|       // this may happen even before this loop is finished so we do "doInitBusses" after the loop | ||||
|       if (busConfigs[s] != nullptr) delete busConfigs[s]; | ||||
|   | ||||
| @@ -373,7 +373,7 @@ uint8_t extractModeSlider(uint8_t mode, uint8_t slider, char *dest, uint8_t maxL | ||||
| } | ||||
|  | ||||
|  | ||||
| // extracts mode parameter defaults from last section of mode data (e.g. "Juggle@!,Trail;!,!,;!;sx=16,ix=240,1d") | ||||
| // extracts mode parameter defaults from last section of mode data (e.g. "Juggle@!,Trail;!,!,;!;012;sx=16,ix=240") | ||||
| int16_t extractModeDefaults(uint8_t mode, const char *segVar) | ||||
| { | ||||
|   if (mode < strip.getModeCount()) { | ||||
|   | ||||
| @@ -8,7 +8,7 @@ | ||||
|  */ | ||||
|  | ||||
| // version code in format yymmddb (b = daily build) | ||||
| #define VERSION 2311270 | ||||
| #define VERSION 2312020 | ||||
|  | ||||
| //uncomment this if you have a "my_config.h" file you'd like to use | ||||
| //#define WLED_USE_MY_CONFIG | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 ezcGman
					ezcGman