scroll works

This commit is contained in:
Michael 2021-11-23 23:08:05 +01:00
parent 917777d2c5
commit c4a4bb0ff8
4 changed files with 102 additions and 26 deletions

View File

@ -62,6 +62,11 @@ LedMatrix::LedMatrix(int dataPin, int clkPin, int csPin, unsigned int colums, un
setIntensity(7); setIntensity(7);
} }
void LedMatrix::power(bool on)
{
shutdown(!on); // shut down on power off
}
bool LedMatrix::drawText( const char *str) bool LedMatrix::drawText( const char *str)
{ {
strncpy(textBuf, str, TEXT_BUFFER_SIZE -1); strncpy(textBuf, str, TEXT_BUFFER_SIZE -1);
@ -70,6 +75,7 @@ bool LedMatrix::drawText( const char *str)
textWidth = strlen(textBuf) * charWidth; textWidth = strlen(textBuf) * charWidth;
if(textWidth < displayWidth) if(textWidth < displayWidth)
{ {
clear();
textPosX = (displayWidth - textWidth) / 2; // center textPosX = (displayWidth - textWidth) / 2; // center
} }
else else
@ -78,7 +84,6 @@ bool LedMatrix::drawText( const char *str)
// Append a space between end of text and the beginning of the repeting text. // Append a space between end of text and the beginning of the repeting text.
appendSpace(); appendSpace();
} }
clear();
drawTextAt(textBuf, textPosX, textPosY); drawTextAt(textBuf, textPosX, textPosY);
refresh(); // refresh display with new string content refresh(); // refresh display with new string content
return true; return true;
@ -102,7 +107,7 @@ bool LedMatrix::scrollText()
if(textWidth < displayWidth) return false; // do not scroll when text fits into the display if(textWidth < displayWidth) return false; // do not scroll when text fits into the display
textPosX--; textPosX--;
if(textPosX + textWidth < 0) if(textPosX + textWidth < (int)0)
{ {
textPosX = 0; // start from the beginning after text scrolled out of display; textPosX = 0; // start from the beginning after text scrolled out of display;
} }
@ -255,7 +260,7 @@ void LedMatrix::refresh()
void LedMatrix::refreshByteOfBuffer(int i) void LedMatrix::refreshByteOfBuffer(int i)
{ {
int line = i / modulesPerRow; int line = i / modulesPerRow;
int addr = line / 8 + i % modulesPerRow; int addr = (line / 8) * modulesPerRow + i % modulesPerRow;
byte b = buffer[i]; byte b = buffer[i];
if (moduleOrientation == ORIENTATION_NORMAL || moduleOrientation == ORIENTATION_UPSIDE_DOWN) if (moduleOrientation == ORIENTATION_NORMAL || moduleOrientation == ORIENTATION_UPSIDE_DOWN)
{ {

View File

@ -60,11 +60,11 @@ class LedMatrix
ModuleOrientation moduleOrientation; ModuleOrientation moduleOrientation;
byte buffer[MATRIX_BUFFER_SIZE]; byte buffer[MATRIX_BUFFER_SIZE];
LedControl* ledControl; LedControl* ledControl;
const unsigned int charWidth = 6; const int charWidth = 6;
const unsigned int charHeight = 8; const int charHeight = 8;
char textBuf[TEXT_BUFFER_SIZE]; char textBuf[TEXT_BUFFER_SIZE];
char appendTextBuf[TEXT_APPEND_BUFFER_SIZE]; char appendTextBuf[TEXT_APPEND_BUFFER_SIZE];
unsigned int textWidth; // width of text [pixel] int textWidth; // width of text [pixel]
int textPosX; // horizontal pixel position of scrolling text int textPosX; // horizontal pixel position of scrolling text
int textPosY; // vertical pixelposition of scrolling text; int textPosY; // vertical pixelposition of scrolling text;

View File

@ -524,6 +524,7 @@ const uint16_t kGpioNiceList[] PROGMEM = {
#ifdef USE_DISPLAY_MAX7219_MATRIX #ifdef USE_DISPLAY_MAX7219_MATRIX
#undef USE_DISPLAY_MAX7219 #undef USE_DISPLAY_MAX7219
#undef USE_DISPLAY_TM1637 #undef USE_DISPLAY_TM1637
#define USE_DISPLAY_MODES1TO5
AGPIO(GPIO_MAX7219CLK), AGPIO(GPIO_MAX7219CLK),
AGPIO(GPIO_MAX7219DIN), AGPIO(GPIO_MAX7219DIN),
AGPIO(GPIO_MAX7219CS), AGPIO(GPIO_MAX7219CS),

View File

@ -131,16 +131,22 @@ and setting it to 3 alternates between time and date.
\*********************************************************************************************/ \*********************************************************************************************/
#define XDSP_19 19 #define XDSP_19 19
#define CMD_MAX_LEN 55
#include <time.h>
#include <LedMatrix.h> #include <LedMatrix.h>
LedMatrix *max7219_Matrix; LedMatrix *max7219_Matrix = nullptr;
bool max2791Matrix_init_done = false; bool max2791Matrix_initDriver_done = false;
byte modulesPerRow = 4; struct
byte modulesPerCol = 1; {
byte modulesPerRow = 4;
byte modulesPerCol = 1;
bool show_clock = false;
const char* timeFormat;
bool MAX7291Matrix_init(void) } LedMatrix_settings;
bool MAX7291Matrix_initDriver(void)
{ {
if (!PinUsed(GPIO_MAX7219DIN) || !PinUsed(GPIO_MAX7219CLK) || !PinUsed(GPIO_MAX7219CS)) if (!PinUsed(GPIO_MAX7219DIN) || !PinUsed(GPIO_MAX7219CLK) || !PinUsed(GPIO_MAX7219CS))
{ {
@ -151,27 +157,79 @@ bool MAX7291Matrix_init(void)
Settings->display_model = XDSP_19; Settings->display_model = XDSP_19;
if (Settings->display_width) // [pixel] if (Settings->display_width) // [pixel]
{ {
modulesPerRow = (Settings->display_width - 1) / 8 + 1; LedMatrix_settings.modulesPerRow = (Settings->display_width - 1) / 8 + 1;
} }
Settings->display_width = 8 * modulesPerRow; Settings->display_width = 8 * LedMatrix_settings.modulesPerRow;
Settings->display_cols[0] = Settings->display_width; Settings->display_cols[0] = Settings->display_width;
if (Settings->display_height) // [pixel] if (Settings->display_height) // [pixel]
{ {
modulesPerCol = (Settings->display_height - 1) / 8 + 1; LedMatrix_settings.modulesPerCol = (Settings->display_height - 1) / 8 + 1;
} }
Settings->display_height = 8 * modulesPerCol; Settings->display_height = 8 * LedMatrix_settings. modulesPerCol;
Settings->display_rows = Settings->display_height; Settings->display_rows = Settings->display_height;
Settings->display_cols[1] = Settings->display_height; Settings->display_cols[1] = Settings->display_height;
max7219_Matrix = new LedMatrix(Pin(GPIO_MAX7219DIN), Pin(GPIO_MAX7219CLK), Pin(GPIO_MAX7219CS), modulesPerRow, modulesPerCol); max7219_Matrix = new LedMatrix(Pin(GPIO_MAX7219DIN), Pin(GPIO_MAX7219CLK), Pin(GPIO_MAX7219CS), LedMatrix_settings.modulesPerRow, LedMatrix_settings.modulesPerCol);
max2791Matrix_initDriver_done = true;
return MAX7291Matrix_init();
}
bool MAX7291Matrix_init(void)
{
int intensity = GetDisplayDimmer16(); // 0..15 int intensity = GetDisplayDimmer16(); // 0..15
max7219_Matrix->setIntensity(intensity); max7219_Matrix->setIntensity(intensity);
int orientation = Settings->display_rotate; int orientation = Settings->display_rotate;
max7219_Matrix->setOrientation((LedMatrix::ModuleOrientation)orientation ); max7219_Matrix->setOrientation((LedMatrix::ModuleOrientation)orientation );
AddLog(LOG_LEVEL_INFO, PSTR("DSP: MAX7291Matrix_init %dx%d modules, orientation: %d, intensity: %d"), modulesPerRow , modulesPerCol, orientation, intensity); AddLog(LOG_LEVEL_INFO, PSTR("MTX: MAX7291Matrix_init %dx%d modules, orientation: %d, intensity: %d"), LedMatrix_settings.modulesPerRow , LedMatrix_settings.modulesPerCol, orientation, intensity);
max2791Matrix_init_done = true;
max7219_Matrix->test(); //max7219_Matrix->test();
AddLog(LOG_LEVEL_INFO, PSTR("DSP: display test")); AddLog(LOG_LEVEL_INFO, PSTR("MTX: display test"));
return true;
}
bool MAX7291Matrix_clock(void)
{
LedMatrix_settings.show_clock = XdrvMailbox.payload;
if (ArgC() == 0)
XdrvMailbox.payload = 1;
if (XdrvMailbox.payload > 1)
{
LedMatrix_settings.timeFormat = "%H:%M";
if(LedMatrix_settings.modulesPerRow > 6)
{
LedMatrix_settings.timeFormat = "%H:%M:%S";
}
XdrvMailbox.payload = 2;
}
else
{
LedMatrix_settings.timeFormat = "%I:%M";
if(LedMatrix_settings.modulesPerRow > 6)
{
LedMatrix_settings.timeFormat = "%I:%M:%S";
}
XdrvMailbox.payload = 1;
}
AddLog(LOG_LEVEL_DEBUG, PSTR("MTX: LedMatrix_settings.show_clock %d, timeFormat %s"), LedMatrix_settings.show_clock, LedMatrix_settings.timeFormat);
//max7219_Matrix->clearDisplay();
MAX7291Matrix_showTime();
return true;
}
bool MAX7291Matrix_showTime()
{
time_t rawtime;
struct tm *timeinfo;
char timeStr[10];
time(&rawtime);
timeinfo = localtime(&rawtime);
strftime(timeStr, 10, LedMatrix_settings.timeFormat, timeinfo);
//AddLog(LOG_LEVEL_DEBUG, PSTR("MTX: showTime:%s"), timeStr);
max7219_Matrix->drawText(timeStr);
return true; return true;
} }
@ -179,14 +237,20 @@ bool Xdsp19(uint8_t function)
{ {
bool result = false; bool result = false;
if (FUNC_DISPLAY_INIT_DRIVER == function) if (FUNC_DISPLAY_INIT_DRIVER == function && !max2791Matrix_initDriver_done )
{ {
result = MAX7291Matrix_init(); result = MAX7291Matrix_initDriver();
} }
else if (max7219_Matrix && (XDSP_19 == Settings->display_model)) else if (max2791Matrix_initDriver_done && max7219_Matrix && (XDSP_19 == Settings->display_model))
{ {
switch (function) switch (function)
{ {
case FUNC_DISPLAY_INIT:
result = MAX7291Matrix_init();
break;
case FUNC_DISPLAY_POWER:
max7219_Matrix->power(disp_power!=0);
break;
case FUNC_DISPLAY_MODEL: case FUNC_DISPLAY_MODEL:
result = true; result = true;
break; break;
@ -196,6 +260,9 @@ bool Xdsp19(uint8_t function)
case FUNC_DISPLAY_DIM: case FUNC_DISPLAY_DIM:
result = max7219_Matrix->setIntensity(GetDisplayDimmer16()); result = max7219_Matrix->setIntensity(GetDisplayDimmer16());
break; break;
case FUNC_DISPLAY_CLOCK:
result = MAX7291Matrix_clock();
break;
case FUNC_DISPLAY_SEVENSEG_TEXT: case FUNC_DISPLAY_SEVENSEG_TEXT:
case FUNC_DISPLAY_SEVENSEG_TEXTNC: case FUNC_DISPLAY_SEVENSEG_TEXTNC:
case FUNC_DISPLAY_NUMBER: case FUNC_DISPLAY_NUMBER:
@ -205,12 +272,15 @@ bool Xdsp19(uint8_t function)
case FUNC_DISPLAY_RAW: case FUNC_DISPLAY_RAW:
case FUNC_DISPLAY_LEVEL: case FUNC_DISPLAY_LEVEL:
case FUNC_DISPLAY_SCROLLTEXT: case FUNC_DISPLAY_SCROLLTEXT:
case FUNC_DISPLAY_CLOCK:
case FUNC_DISPLAY_DRAW_STRING: case FUNC_DISPLAY_DRAW_STRING:
result = max7219_Matrix->drawText(dsp_str); result = max7219_Matrix->drawText(dsp_str);
break; break;
case FUNC_DISPLAY_EVERY_SECOND: case FUNC_DISPLAY_EVERY_SECOND:
//result = max7219_Matrix->scrollText(); if (LedMatrix_settings.show_clock)
{
result = MAX7291Matrix_showTime();
}
break; break;
case FUNC_DISPLAY_EVERY_50_MSECOND: case FUNC_DISPLAY_EVERY_50_MSECOND:
result = max7219_Matrix->scrollText(); result = max7219_Matrix->scrollText();