aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJagoda Ślązak <jagoda.slazak@wecamo.io>2025-02-03 08:01:22 +0100
committerJagoda Ślązak <jagoda.slazak@wecamo.io>2025-02-03 08:01:22 +0100
commit4fa43b7fbcf553d985ad7c2b7eb0769d8f90cb8b (patch)
treee69db5a44b231f1434044f6d75557b7890c72334 /src
parent588f23456b836c99d5f966a20c0e55988879a879 (diff)
Add support for common 40px-high four-scan displays
Diffstat (limited to 'src')
-rw-r--r--src/ESP32-VirtualMatrixPanel-I2S-DMA.h10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/ESP32-VirtualMatrixPanel-I2S-DMA.h b/src/ESP32-VirtualMatrixPanel-I2S-DMA.h
index 18a6364..f6df7ab 100644
--- a/src/ESP32-VirtualMatrixPanel-I2S-DMA.h
+++ b/src/ESP32-VirtualMatrixPanel-I2S-DMA.h
@@ -56,7 +56,8 @@ enum PANEL_SCAN_RATE
NORMAL_ONE_SIXTEEN, // treated as the same
FOUR_SCAN_32PX_HIGH,
FOUR_SCAN_16PX_HIGH,
- FOUR_SCAN_64PX_HIGH
+ FOUR_SCAN_64PX_HIGH,
+ FOUR_SCAN_40PX_HIGH
};
// Chaining approach... From the perspective of the DISPLAY / LED side of the chain of panels.
@@ -413,6 +414,13 @@ inline VirtualCoords VirtualMatrixPanel::getCoords(int16_t virt_x, int16_t virt_
coords.x += (coords.x / panelResX) * panelResX;
coords.y = (coords.y >> 3) * 4 + (coords.y & 0b00000011);
break;
+ case FOUR_SCAN_40PX_HIGH:
+ if ((coords.y / 10) % 2 == 0)
+ coords.x += ((coords.x / panelResX) + 1) * panelResX;
+ else
+ coords.x += (coords.x / panelResX) * panelResX;
+ coords.y = (coords.y / 20) * 10 + (coords.y % 10);
+ break;
default:
break;
}