diff options
| author | Jagoda Ślązak <jagoda.slazak@wecamo.io> | 2025-02-03 08:01:22 +0100 |
|---|---|---|
| committer | Jagoda Ślązak <jagoda.slazak@wecamo.io> | 2025-02-03 08:01:22 +0100 |
| commit | 4fa43b7fbcf553d985ad7c2b7eb0769d8f90cb8b (patch) | |
| tree | e69db5a44b231f1434044f6d75557b7890c72334 /src | |
| parent | 588f23456b836c99d5f966a20c0e55988879a879 (diff) | |
Add support for common 40px-high four-scan displays
Diffstat (limited to 'src')
| -rw-r--r-- | src/ESP32-VirtualMatrixPanel-I2S-DMA.h | 10 |
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; } |
