Fix bug with clearScreen()

The use of clearFrameBuffer() internally was inadvertently blasting away the 'brightness' information via. the OE toggling. #366
This commit is contained in:
mrfaptastic 2023-01-08 00:16:29 +00:00
parent 9ca210d3ac
commit 5f13a3abff
2 changed files with 7 additions and 7 deletions

View file

@ -454,7 +454,7 @@ void MatrixPanel_I2S_DMA::updateMatrixDMABuffer(uint8_t red, uint8_t green, uint
* Those control bits are constants during the entire DMA sweep and never changed when updating just pixel colour data
* so we could set it once on DMA buffs initialization and forget.
* This effectively clears buffers to blank BLACK and makes it ready to display output.
* (Brightness control via OE bit manipulation is another case)
* (Brightness control via OE bit manipulation is another case) - this must be done as well seperately!
*/
void MatrixPanel_I2S_DMA::clearFrameBuffer(bool _buff_id){
if (!initialized)

View file

@ -386,7 +386,7 @@ class MatrixPanel_I2S_DMA {
/**
* A wrapper to fill whatever selected DMA buffer / screen with black
*/
inline void clearScreen(){ startWrite(); clearFrameBuffer(back_buffer_id); endWrite(); /*updateMatrixDMABuffer(0,0,0);*/ };
inline void clearScreen() { updateMatrixDMABuffer(0,0,0); };
#ifndef NO_FAST_FUNCTIONS
/**
@ -491,8 +491,6 @@ class MatrixPanel_I2S_DMA {
}
/**
* this is just a wrapper to control brightness
* with an 8-bit value (0-255), very popular in FastLED-based sketches :)
* @param uint8_t b - 8-bit brightness value
*/
void setBrightness(const uint8_t b)
@ -532,8 +530,10 @@ class MatrixPanel_I2S_DMA {
}
*/
// Takes a value between 0-255 now.
void setPanelBrightness(uint8_t b)
/**
* @param uint8_t b - 8-bit brightness value
*/
void setPanelBrightness(const uint8_t b)
{
setBrightness(b);
}
@ -616,8 +616,8 @@ class MatrixPanel_I2S_DMA {
* wipes DMA buffer(s) and reset all color/service bits
*/
inline void resetbuffers(){
clearFrameBuffer();
brtCtrlOEv2(brightness, 0);
if (m_cfg.double_buff){