Browse Source

improve display layout for Nokia5110

(cherry picked from commit 24bb14656a9d491c887b5a2a9556d783fa66650b)
pull/1093/head
Wusaweki 1 year ago
parent
commit
3e1949775d
  1. 86
      src/plugins/Display/Display_Mono_84X48.h
  2. 11
      src/utils/helper.cpp
  3. 1
      src/utils/helper.h

86
src/plugins/Display/Display_Mono_84X48.h

@ -17,6 +17,7 @@ class DisplayMono84X48 : public DisplayMono {
mTimeout = DISP_DEFAULT_TIMEOUT; // interval at which to power save (milliseconds) mTimeout = DISP_DEFAULT_TIMEOUT; // interval at which to power save (milliseconds)
mUtcTs = NULL; mUtcTs = NULL;
mType = 0; mType = 0;
mDispWidth = 0;
} }
void init(uint8_t type, uint8_t rotation, uint8_t cs, uint8_t dc, uint8_t reset, uint8_t clock, uint8_t data, uint32_t *utcTs, const char *version) { void init(uint8_t type, uint8_t rotation, uint8_t cs, uint8_t dc, uint8_t reset, uint8_t clock, uint8_t data, uint32_t *utcTs, const char *version) {
@ -28,14 +29,15 @@ class DisplayMono84X48 : public DisplayMono {
mUtcTs = utcTs; mUtcTs = utcTs;
mDisplay->begin(); mDisplay->begin();
mDispWidth = mDisplay->getDisplayWidth();
calcLinePositions(); calcLinePositions();
mDisplay->clearBuffer(); mDisplay->clearBuffer();
mDisplay->setContrast(mLuminance); mDisplay->setContrast(mLuminance);
printText("AHOY!", 0); printText("AHOY!", l_Ahoy);
printText("ahoydtu.de", 2); printText("ahoydtu.de", l_Website);
printText(version, 3); printText(version, l_Version);
mDisplay->sendBuffer(); mDisplay->sendBuffer();
} }
@ -63,32 +65,33 @@ class DisplayMono84X48 : public DisplayMono {
mDisplay->setPowerSave(false); mDisplay->setPowerSave(false);
if (totalPower > 999) if (totalPower > 999)
snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%2.2f kW", (totalPower / 1000)); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%.2f kW", (totalPower / 1000));
else else
snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%3.0f W", totalPower); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%.0f W", totalPower);
printText(mFmtText, 0); printText(mFmtText, l_TotalPower);
} else { } else {
printText("offline", 0); printText("offline", l_TotalPower);
// check if it's time to enter power saving mode // check if it's time to enter power saving mode
if (mTimeout == 0) if (mTimeout == 0)
mDisplay->setPowerSave(mEnPowerSafe); mDisplay->setPowerSave(mEnPowerSafe);
} }
snprintf(mFmtText, DISP_FMT_TEXT_LEN, "today: %4.0f Wh", totalYieldDay); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "Today: %4.0f Wh", totalYieldDay);
printText(mFmtText, 1); printText(mFmtText, l_YieldDay);
snprintf(mFmtText, DISP_FMT_TEXT_LEN, "total: %.1f kWh", totalYieldTotal); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "Total: %.1f kWh", totalYieldTotal);
printText(mFmtText, 2); printText(mFmtText, l_YieldTotal);
if (NULL != mUtcTs)
printText(ah::getDateTimeStrShort(gTimezone.toLocal(*mUtcTs)).c_str(), l_Time);
IPAddress ip = WiFi.localIP(); IPAddress ip = WiFi.localIP();
if (!(mExtra % 10) && (ip)) if (!(mExtra % 5) && (ip))
printText(ip.toString().c_str(), 3); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%s", ip.toString().c_str());
else if (!(mExtra % 5)) { else
snprintf(mFmtText, DISP_FMT_TEXT_LEN, "%d Inverter on", isprod); snprintf(mFmtText, DISP_FMT_TEXT_LEN, "Inv.On: %d", isprod);
printText(mFmtText, 3); printText(mFmtText, l_Status);
} else if (NULL != mUtcTs)
printText(ah::getTimeStr(gTimezone.toLocal(*mUtcTs)).c_str(), 3);
mDisplay->sendBuffer(); mDisplay->sendBuffer();
@ -96,33 +99,52 @@ class DisplayMono84X48 : public DisplayMono {
} }
private: private:
uint16_t mDispWidth;
enum _dispLine
{
// start page
l_Website = 0,
l_Ahoy = 2,
l_Version = 4,
// run page
l_Time = 0,
l_Status = 1,
l_TotalPower = 2,
l_YieldDay = 3,
l_YieldTotal = 4,
// End
l_MAX_LINES = 5,
};
void calcLinePositions() { void calcLinePositions() {
uint8_t yOff = 0; uint8_t yOff = 0;
for (uint8_t i = 0; i < 4; i++) { uint8_t i = 0;
uint8_t asc, dsc;
do {
setFont(i); setFont(i);
yOff += (mDisplay->getMaxCharHeight()); asc = mDisplay->getAscent();
yOff += asc;
mLineYOffsets[i] = yOff; mLineYOffsets[i] = yOff;
} dsc = mDisplay->getDescent();
if (l_TotalPower!=i) // power line needs no descent spacing
yOff -= dsc;
yOff++; // instead lets spend one pixel space between all lines
i++;
} while(l_MAX_LINES>i);
} }
inline void setFont(uint8_t line) { inline void setFont(uint8_t line) {
switch (line) { if ((line == l_TotalPower) || (line == l_Ahoy))
case 0:
mDisplay->setFont(u8g2_font_logisoso16_tr); mDisplay->setFont(u8g2_font_logisoso16_tr);
break; else
case 3:
mDisplay->setFont(u8g2_font_5x8_tr);
break;
default:
mDisplay->setFont(u8g2_font_5x8_tr); mDisplay->setFont(u8g2_font_5x8_tr);
break;
}
} }
void printText(const char *text, uint8_t line) { void printText(const char *text, uint8_t line) {
uint8_t dispX = (line == 0) ? 10 : 5; uint8_t dispX;
setFont(line); setFont(line);
dispX = (mDispWidth - mDisplay->getStrWidth(text)) / 2; // center text
dispX += (mEnScreenSaver) ? (mExtra % 7) : 0; dispX += (mEnScreenSaver) ? (mExtra % 7) : 0;
mDisplay->drawStr(dispX, mLineYOffsets[line], text); mDisplay->drawStr(dispX, mLineYOffsets[line], text);
} }

11
src/utils/helper.cpp

@ -50,6 +50,17 @@ namespace ah {
return String(str); return String(str);
} }
String getDateTimeStrShort(time_t t) {
char str[20];
if(0 == t)
sprintf(str, "n/a");
else {
sprintf(str, "%3s ", dayShortStr(dayOfWeek(t)));
sprintf(str+4, "%2d.%3s %02d:%02d", day(t), monthShortStr(month(t)), hour(t), minute(t));
}
return String(str);
}
String getTimeStr(time_t t) { String getTimeStr(time_t t) {
char str[9]; char str[9];
if(0 == t) if(0 == t)

1
src/utils/helper.h

@ -41,6 +41,7 @@ namespace ah {
void ip2Char(uint8_t ip[], char *str); void ip2Char(uint8_t ip[], char *str);
double round3(double value); double round3(double value);
String getDateTimeStr(time_t t); String getDateTimeStr(time_t t);
String getDateTimeStrShort(time_t t);
String getDateTimeStrFile(time_t t); String getDateTimeStrFile(time_t t);
String getTimeStr(time_t t); String getTimeStr(time_t t);
uint64_t Serial2u64(const char *val); uint64_t Serial2u64(const char *val);

Loading…
Cancel
Save