@ -5,7 +5,6 @@
# pragma once
# pragma once
# include "Display_Mono.h"
# include "Display_Mono.h"
# include "../../utils/dbg.h"
class DisplayMono84X48 : public DisplayMono {
class DisplayMono84X48 : public DisplayMono {
public :
public :
@ -13,16 +12,45 @@ class DisplayMono84X48 : public DisplayMono {
mExtra = 0 ;
mExtra = 0 ;
}
}
void config ( bool enPowerSave , uint8_t screenSaver , uint8_t lum ) {
void config ( bool enPowerSave , uint8_t screenSaver , uint8_t lum , uint8_t graph_ratio , uint8_t graph_size ) {
mEnPowerSave = enPowerSave ;
mEnPowerSave = enPowerSave ;
mScreenSaver = screenSaver ;
mScreenSaver = screenSaver ;
mLuminance = lum ;
mLuminance = lum ;
mGraphRatio = graph_ratio ;
mGraphSize = graph_size ;
}
}
void init ( uint8_t type , uint8_t rotation , uint8_t cs , uint8_t dc , uint8_t reset , uint8_t clock , uint8_t data , DisplayData * displayData ) {
void init ( uint8_t type , uint8_t rotation , uint8_t cs , uint8_t dc , uint8_t reset , uint8_t clock , uint8_t data , DisplayData * displayData ) {
u8g2_cb_t * rot = ( u8g2_cb_t * ) ( ( rotation ! = 0x00 ) ? U8G2_R2 : U8G2_R0 ) ;
u8g2_cb_t * rot = ( u8g2_cb_t * ) ( ( rotation ! = 0x00 ) ? U8G2_R2 : U8G2_R0 ) ;
monoInit ( new U8G2_PCD8544_84X48_F_4W_SW_SPI ( rot , clock , data , cs , dc , reset ) , type , displayData ) ;
monoInit ( new U8G2_PCD8544_84X48_F_4W_SW_SPI ( rot , clock , data , cs , dc , reset ) , type , displayData ) ;
calcLinePositions ( ) ;
calcLinePositions ( ) ;
switch ( mGraphSize ) { // var opts2 = [[0, "Line 1 - 2"], [1, "Line 2 - 3"], [2, "Line 1 - 3"], [3, "Line 2 - 4"], [4, "Line 1 - 4"]];
case 0 :
graph_first_line = 1 ;
graph_last_line = 2 ;
break ;
case 1 :
graph_first_line = 2 ;
graph_last_line = 3 ;
break ;
case 2 :
graph_first_line = 1 ;
graph_last_line = 3 ;
break ;
case 3 :
graph_first_line = 2 ;
graph_last_line = 4 ;
break ;
case 4 :
default :
graph_first_line = 1 ;
graph_last_line = 4 ;
break ;
}
initPowerGraph ( mDispWidth - 16 , mLineYOffsets [ graph_last_line ] - mLineYOffsets [ graph_first_line - 1 ] - 2 ) ;
printText ( " Ahoy! " , l_Ahoy , 0xff ) ;
printText ( " Ahoy! " , l_Ahoy , 0xff ) ;
printText ( " ahoydtu.de " , l_Website , 0xff ) ;
printText ( " ahoydtu.de " , l_Website , 0xff ) ;
printText ( mDisplayData - > version , l_Version , 0xff ) ;
printText ( mDisplayData - > version , l_Version , 0xff ) ;
@ -45,22 +73,16 @@ class DisplayMono84X48 : public DisplayMono {
mDisplay - > drawPixel ( mDispWidth - 1 , mDispHeight - 1 ) ;
mDisplay - > drawPixel ( mDispWidth - 1 , mDispHeight - 1 ) ;
*/
*/
// print total power
// add new power data to power graph
if ( mDisplayData - > nrProducing > 0 ) {
if ( mDisplayData - > nrProducing > 0 ) {
if ( mDisplayData - > totalPower > 9999.0 )
addPowerGraphEntry ( mDisplayData - > totalPower ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f kW " , ( mDisplayData - > totalPower / 1000.0 ) ) ;
else
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f W " , mDisplayData - > totalPower ) ;
printText ( mFmtText , l_TotalPower , 0xff ) ;
} else {
printText ( " offline " , l_TotalPower , 0xff ) ;
}
}
// print Date and time
// print Date and time
if ( 0 ! = mDisplayData - > utcTs )
if ( 0 ! = mDisplayData - > utcTs )
printText ( ah : : getDateTimeStrShort ( gTimezone . toLocal ( mDisplayData - > utcTs ) ) . c_str ( ) , l_Time , 0xff ) ;
printText ( ah : : getDateTimeStrShort ( gTimezone . toLocal ( mDisplayData - > utcTs ) ) . c_str ( ) , l_Time , 0xff ) ;
if ( showLine ( l_Status ) ) {
// alternatively:
// alternatively:
// print ip address
// print ip address
if ( ! ( mExtra % 5 ) & & ( mDisplayData - > ipAddress ) ) {
if ( ! ( mExtra % 5 ) & & ( mDisplayData - > ipAddress ) ) {
@ -79,32 +101,57 @@ class DisplayMono84X48 : public DisplayMono {
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %d \x86 %d \x87 " , mDisplayData - > nrProducing , mDisplayData - > nrSleeping ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %d \x86 %d \x87 " , mDisplayData - > nrProducing , mDisplayData - > nrSleeping ) ;
printText ( mFmtText , l_Status , 0xff ) ;
printText ( mFmtText , l_Status , 0xff ) ;
}
}
}
// print yields
if ( showLine ( l_TotalPower ) ) {
printText ( " \x88 " , l_YieldDay , 10 ) ; // day symbol
// print total power
printText ( " \x83 " , l_YieldTotal , 10 ) ; // total symbol
if ( mDisplayData - > nrProducing > 0 ) {
if ( mDisplayData - > totalPower > 9999.0 )
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f kW " , ( mDisplayData - > totalPower / 1000.0 ) ) ;
else
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f W " , mDisplayData - > totalPower ) ;
printText ( mFmtText , l_TotalPower , 0xff ) ;
} else {
printText ( " offline " , l_TotalPower , 0xff ) ;
}
}
if ( showLine ( l_YieldDay ) ) {
// print day yield
printText ( " \x88 " , l_YieldDay , 10 ) ; // day symbol
if ( mDisplayData - > totalYieldDay > 9999.0 )
if ( mDisplayData - > totalYieldDay > 9999.0 )
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f kWh " , mDisplayData - > totalYieldDay / 1000.0 ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f kWh " , mDisplayData - > totalYieldDay / 1000.0 ) ;
else
else
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f Wh " , mDisplayData - > totalYieldDay ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f Wh " , mDisplayData - > totalYieldDay ) ;
printText ( mFmtText , l_YieldDay , 0xff ) ;
printText ( mFmtText , l_YieldDay , 0xff ) ;
}
if ( showLine ( l_YieldTotal ) ) {
// print total yield
printText ( " \x83 " , l_YieldTotal , 10 ) ; // total symbol
if ( mDisplayData - > totalYieldTotal > 9999.0 )
if ( mDisplayData - > totalYieldTotal > 9999.0 )
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f MWh " , mDisplayData - > totalYieldTotal / 1000.0 ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.2f MWh " , mDisplayData - > totalYieldTotal / 1000.0 ) ;
else
else
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f kWh " , mDisplayData - > totalYieldTotal ) ;
snprintf ( mFmtText , DISP_FMT_TEXT_LEN , " %.0f kWh " , mDisplayData - > totalYieldTotal ) ;
printText ( mFmtText , l_YieldTotal , 0xff ) ;
printText ( mFmtText , l_YieldTotal , 0xff ) ;
}
// draw dynamic Nokia RSSI bars
if ( mDispSwitchState = = d_POWER_GRAPH ) {
// plot power graph
plotPowerGraph ( 8 , mLineYOffsets [ graph_last_line ] - 1 ) ;
}
// draw dynamic RSSI bars
int rssi_bar_height = 7 ;
int rssi_bar_height = 7 ;
for ( int i = 0 ; i < 4 ; i + + ) {
for ( int i = 0 ; i < 4 ; i + + ) {
int radio_rssi_threshold = - 60 - i * 10 ; // radio rssi not yet tested in reality!
int radio_rssi_threshold = - 60 - i * 10 ;
int wifi_rssi_threshold = - 60 - i * 10 ;
int wifi_rssi_threshold = - 60 - i * 10 ;
uint8_t barwidth = std : : min ( 4 - i , 3 ) ;
if ( mDisplayData - > RadioRSSI > radio_rssi_threshold )
if ( mDisplayData - > RadioRSSI > radio_rssi_threshold )
mDisplay - > drawBox ( 0 , 8 + ( rssi_bar_height + 1 ) * i , 4 - i , rssi_bar_height ) ;
mDisplay - > drawBox ( 0 , 8 + ( rssi_bar_height + 1 ) * i , barwidth , rssi_bar_height ) ;
if ( mDisplayData - > WifiRSSI > wifi_rssi_threshold )
if ( mDisplayData - > WifiRSSI > wifi_rssi_threshold )
mDisplay - > drawBox ( mDispWidth - 4 + i , 8 + ( rssi_bar_height + 1 ) * i , 4 - i , rssi_bar_height ) ;
mDisplay - > drawBox ( mDispWidth - barwidth , 8 + ( rssi_bar_height + 1 ) * i , barwidth , rssi_bar_height ) ;
}
}
// draw dynamic antenna and WiFi symbols
// draw dynamic antenna and WiFi symbols
@ -139,6 +186,9 @@ class DisplayMono84X48 : public DisplayMono {
l_MAX_LINES = 5 ,
l_MAX_LINES = 5 ,
} ;
} ;
uint8_t graph_first_line ;
uint8_t graph_last_line ;
void calcLinePositions ( ) {
void calcLinePositions ( ) {
uint8_t yOff = 0 ;
uint8_t yOff = 0 ;
uint8_t i = 0 ;
uint8_t i = 0 ;
@ -150,7 +200,7 @@ class DisplayMono84X48 : public DisplayMono {
yOff + = asc ;
yOff + = asc ;
mLineYOffsets [ i ] = yOff ;
mLineYOffsets [ i ] = yOff ;
dsc = mDisplay - > getDescent ( ) ;
dsc = mDisplay - > getDescent ( ) ;
if ( l_TotalPower ! = i ) // power line needs no descent spacing
if ( l_TotalPower ! = i ) // power line needs no descent spacing
yOff - = dsc ;
yOff - = dsc ;
yOff + + ; // instead lets spend one pixel space between all lines
yOff + + ; // instead lets spend one pixel space between all lines
i + + ;
i + + ;
@ -158,7 +208,8 @@ class DisplayMono84X48 : public DisplayMono {
}
}
inline void setLineFont ( uint8_t line ) {
inline void setLineFont ( uint8_t line ) {
if ( ( line = = l_TotalPower ) | | ( line = = l_Ahoy ) )
if ( ( line = = l_TotalPower ) | |
( line = = l_Ahoy ) )
mDisplay - > setFont ( u8g2_font_logisoso16_tr ) ;
mDisplay - > setFont ( u8g2_font_logisoso16_tr ) ;
else
else
mDisplay - > setFont ( u8g2_font_5x8_symbols_ahoy ) ;
mDisplay - > setFont ( u8g2_font_5x8_symbols_ahoy ) ;
@ -174,6 +225,10 @@ class DisplayMono84X48 : public DisplayMono {
dispX = col ;
dispX = col ;
mDisplay - > drawStr ( dispX , mLineYOffsets [ line ] , text ) ;
mDisplay - > drawStr ( dispX , mLineYOffsets [ line ] , text ) ;
}
}
bool showLine ( uint8_t line ) {
return ( ( mDispSwitchState = = d_POWER_TEXT ) | | ( ( line < graph_first_line ) | | ( line > graph_last_line ) ) ) ;
}
} ;
} ;