fix holes in DNA effect (>32 pixel high segments)
avoid holes by using drawLine when there is a gap
This commit is contained in:
@@ -5055,9 +5055,21 @@ uint16_t mode_2Ddna(void) { // dna originally by by ldirko at https://pa
|
|||||||
|
|
||||||
SEGMENT.fadeToBlackBy(64);
|
SEGMENT.fadeToBlackBy(64);
|
||||||
|
|
||||||
|
// WLEDMM optimized to prevent holes at height > 32
|
||||||
|
int lastY1 = -1;
|
||||||
|
int lastY2 = -1;
|
||||||
for (int i = 0; i < cols; i++) {
|
for (int i = 0; i < cols; i++) {
|
||||||
SEGMENT.setPixelColorXY(i, beatsin8(SEGMENT.speed/8, 0, rows-1, 0, i*4 ), ColorFromPalette(SEGPALETTE, i*5+strip.now/17, beatsin8(5, 55, 255, 0, i*10), LINEARBLEND));
|
int posY1 = beatsin8(SEGMENT.speed/8, 0, rows-1, 0, i*4 );
|
||||||
SEGMENT.setPixelColorXY(i, beatsin8(SEGMENT.speed/8, 0, rows-1, 0, i*4+128), ColorFromPalette(SEGPALETTE, i*5+128+strip.now/17, beatsin8(5, 55, 255, 0, i*10+128), LINEARBLEND));
|
int posY2 = beatsin8(SEGMENT.speed/8, 0, rows-1, 0, i*4+128);
|
||||||
|
if ((i==0) || ((abs(lastY1 - posY1) < 2) && (abs(lastY2 - posY2) < 2))) { // use original code when no holes
|
||||||
|
SEGMENT.setPixelColorXY(i, posY1, ColorFromPalette(SEGPALETTE, i*5+strip.now/17, beatsin8(5, 55, 255, 0, i*10), LINEARBLEND));
|
||||||
|
SEGMENT.setPixelColorXY(i, posY2, ColorFromPalette(SEGPALETTE, i*5+128+strip.now/17, beatsin8(5, 55, 255, 0, i*10+128), LINEARBLEND));
|
||||||
|
} else { // draw line to prevent holes
|
||||||
|
SEGMENT.drawLine(i-1, lastY1, i, posY1, ColorFromPalette(SEGPALETTE, i*5+strip.now/17, beatsin8(5, 55, 255, 0, i*10), LINEARBLEND));
|
||||||
|
SEGMENT.drawLine(i-1, lastY2, i, posY2, ColorFromPalette(SEGPALETTE, i*5+128+strip.now/17, beatsin8(5, 55, 255, 0, i*10+128), LINEARBLEND));
|
||||||
|
}
|
||||||
|
lastY1 = posY1;
|
||||||
|
lastY2 = posY2;
|
||||||
}
|
}
|
||||||
SEGMENT.blur(SEGMENT.intensity>>3);
|
SEGMENT.blur(SEGMENT.intensity>>3);
|
||||||
|
|
||||||
|
|||||||
@@ -282,7 +282,7 @@ void IRAM_ATTR __attribute__((hot)) Segment::setPixelColorXY_fast(int x, int y,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if 0 // this is still a dangerous optimization
|
#if 0 // this is still a dangerous optimization
|
||||||
if ((i < UINT_MAX) && sameColor && (call > 0) && (!transitional) && (ledsrgb[i] == CRGB(scaled_col))) return; // WLEDMM looks like nothing to do
|
if ((i < UINT_MAX) && sameColor && (call > 0) && (!transitional) && (mode != FX_MODE_2DSCROLLTEXT) && (ledsrgb[i] == CRGB(scaled_col))) return; // WLEDMM looks like nothing to do
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// handle reverse and transpose
|
// handle reverse and transpose
|
||||||
@@ -344,7 +344,7 @@ void IRAM_ATTR_YN Segment::setPixelColorXY(int x, int y, uint32_t col) //WLEDMM:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if 0 // this is a dangerous optimization
|
#if 0 // this is a dangerous optimization
|
||||||
if ((i < UINT_MAX) && sameColor && (call > 0) && (!transitional) && (ledsrgb[i] == CRGB(col))) return; // WLEDMM looks like nothing to do
|
if ((i < UINT_MAX) && sameColor && (call > 0) && (!transitional) && (mode != FX_MODE_2DSCROLLTEXT) && (ledsrgb[i] == CRGB(col))) return; // WLEDMM looks like nothing to do
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (reverse ) x = cols - x - 1;
|
if (reverse ) x = cols - x - 1;
|
||||||
|
|||||||
Reference in New Issue
Block a user