mirror of
https://github.com/lumapu/ahoy.git
synced 2025-08-06 01:48:19 +02:00
- rework "hiding Pins" to easier configure pins for new displays (using a pin map, remove hard-coded if-statements)
- rework display type handling: remove uneeded checks because defined context from which functions are called - default initialize "mMono" pointer (potential illegal memory access) - define EXACTLY one display type for ePaper display (type 10). There is no need to use ranges and distinguish oled from epaper display. Simply one switch/case - correct type handling for display type (javascript). Event handler gives a string instead of number (display type)
This commit is contained in:
parent
47d5531d05
commit
c99851364a
3 changed files with 46 additions and 48 deletions
|
@ -26,37 +26,29 @@ class Display {
|
||||||
mLoopCnt = 0;
|
mLoopCnt = 0;
|
||||||
mVersion = version;
|
mVersion = version;
|
||||||
|
|
||||||
if (mCfg->type == 0)
|
switch (mCfg->type) {
|
||||||
return;
|
case 0: mMono = NULL; break;
|
||||||
|
case 1: // fall-through
|
||||||
|
case 2: mMono = new DisplayMono128X64(); break;
|
||||||
|
case 3: mMono = new DisplayMono84X48(); break;
|
||||||
|
case 4: mMono = new DisplayMono128X32(); break;
|
||||||
|
case 5: mMono = new DisplayMono64X48(); break;
|
||||||
|
|
||||||
if ((0 < mCfg->type) && (mCfg->type < 10)) {
|
#if defined(ESP32)
|
||||||
switch (mCfg->type) {
|
case 10:
|
||||||
case 1: // fall-through
|
mMono = NULL; // ePaper does not use this
|
||||||
case 2:
|
mRefreshCycle = 0;
|
||||||
mMono = new DisplayMono128X64();
|
mEpaper.config(mCfg->rot, mCfg->pwrSaveAtIvOffline);
|
||||||
break;
|
mEpaper.init(mCfg->type, mCfg->disp_cs, mCfg->disp_dc, mCfg->disp_reset, mCfg->disp_busy, mCfg->disp_clk, mCfg->disp_data, mUtcTs, mVersion);
|
||||||
case 3:
|
break;
|
||||||
mMono = new DisplayMono84X48();
|
#endif
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
mMono = new DisplayMono128X32();
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
mMono = new DisplayMono64X48();
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default: mMono = NULL; break;
|
||||||
mMono = new DisplayMono128X64();
|
}
|
||||||
break;
|
if(mMono)
|
||||||
}
|
{
|
||||||
mMono->config(mCfg->pwrSaveAtIvOffline, mCfg->pxShift, mCfg->contrast);
|
mMono->config(mCfg->pwrSaveAtIvOffline, mCfg->pxShift, mCfg->contrast);
|
||||||
mMono->init(mCfg->type, mCfg->rot, mCfg->disp_cs, mCfg->disp_dc, 0xff, mCfg->disp_clk, mCfg->disp_data, mUtcTs, mVersion);
|
mMono->init(mCfg->type, mCfg->rot, mCfg->disp_cs, mCfg->disp_dc, 0xff, mCfg->disp_clk, mCfg->disp_data, mUtcTs, mVersion);
|
||||||
} else if (mCfg->type >= 10) {
|
|
||||||
#if defined(ESP32)
|
|
||||||
mRefreshCycle = 0;
|
|
||||||
mEpaper.config(mCfg->rot, mCfg->pwrSaveAtIvOffline);
|
|
||||||
mEpaper.init(mCfg->type, mCfg->disp_cs, mCfg->disp_dc, mCfg->disp_reset, mCfg->disp_busy, mCfg->disp_clk, mCfg->disp_data, mUtcTs, mVersion);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,14 +96,16 @@ class Display {
|
||||||
totalYieldTotal += iv->getChannelFieldValue(CH0, FLD_YT, rec);
|
totalYieldTotal += iv->getChannelFieldValue(CH0, FLD_YT, rec);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((0 < mCfg->type) && (mCfg->type < 10) && (mMono != NULL)) {
|
if (mMono ) {
|
||||||
mMono->disp(totalPower, totalYieldDay, totalYieldTotal, isprod);
|
mMono->disp(totalPower, totalYieldDay, totalYieldTotal, isprod);
|
||||||
} else if (mCfg->type >= 10) {
|
}
|
||||||
#if defined(ESP32)
|
#if defined(ESP32)
|
||||||
|
else if (mCfg->type == 10) {
|
||||||
|
|
||||||
mEpaper.loop(totalPower, totalYieldDay, totalYieldTotal, isprod);
|
mEpaper.loop(totalPower, totalYieldDay, totalYieldTotal, isprod);
|
||||||
mRefreshCycle++;
|
mRefreshCycle++;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(ESP32)
|
#if defined(ESP32)
|
||||||
if (mRefreshCycle > 480) {
|
if (mRefreshCycle > 480) {
|
||||||
|
@ -133,7 +127,7 @@ class Display {
|
||||||
#if defined(ESP32)
|
#if defined(ESP32)
|
||||||
DisplayEPaper mEpaper;
|
DisplayEPaper mEpaper;
|
||||||
#endif
|
#endif
|
||||||
DisplayMono *mMono;
|
DisplayMono *mMono = NULL; //default !!!
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /*__DISPLAY__*/
|
#endif /*__DISPLAY__*/
|
||||||
|
|
|
@ -26,7 +26,7 @@ DisplayEPaper::DisplayEPaper() {
|
||||||
void DisplayEPaper::init(uint8_t type, uint8_t _CS, uint8_t _DC, uint8_t _RST, uint8_t _BUSY, uint8_t _SCK, uint8_t _MOSI, uint32_t *utcTs, const char *version) {
|
void DisplayEPaper::init(uint8_t type, uint8_t _CS, uint8_t _DC, uint8_t _RST, uint8_t _BUSY, uint8_t _SCK, uint8_t _MOSI, uint32_t *utcTs, const char *version) {
|
||||||
mUtcTs = utcTs;
|
mUtcTs = utcTs;
|
||||||
|
|
||||||
if (type > 9) {
|
if (type == 10) {
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
_display = new GxEPD2_BW<GxEPD2_150_BN, GxEPD2_150_BN::HEIGHT>(GxEPD2_150_BN(_CS, _DC, _RST, _BUSY));
|
_display = new GxEPD2_BW<GxEPD2_150_BN, GxEPD2_150_BN::HEIGHT>(GxEPD2_150_BN(_CS, _DC, _RST, _BUSY));
|
||||||
hspi.begin(_SCK, _BUSY, _MOSI, _CS);
|
hspi.begin(_SCK, _BUSY, _MOSI, _CS);
|
||||||
|
|
|
@ -791,6 +791,7 @@
|
||||||
document.getElementsByName(i)[0].checked = obj[i];
|
document.getElementsByName(i)[0].checked = obj[i];
|
||||||
|
|
||||||
var e = document.getElementById("dispPins");
|
var e = document.getElementById("dispPins");
|
||||||
|
//KEEP this order !!!
|
||||||
var pins = [['clock', 'disp_clk'], ['data', 'disp_data'], ['cs', 'disp_cs'], ['dc', 'disp_dc'], ['reset', 'disp_rst']];
|
var pins = [['clock', 'disp_clk'], ['data', 'disp_data'], ['cs', 'disp_cs'], ['dc', 'disp_dc'], ['reset', 'disp_rst']];
|
||||||
if("ESP32" == type)
|
if("ESP32" == type)
|
||||||
pins.push(['busy', 'disp_bsy']);
|
pins.push(['busy', 'disp_bsy']);
|
||||||
|
@ -806,7 +807,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
// keep display types grouped
|
// keep display types grouped
|
||||||
var opts = [[0, "None"], [2, "SH1106 1.3\" 128X64"], [5, "SSD1306 0.66\" 64X48"], [4, "SSD1306 0.91\" 128X32"], [1, "SSD1306 0.96\" 128X64"], [3, "Nokia5110"]];
|
var opts = [[0, "None"], [2, "SH1106 1.3\" 128X64"], [5, "SSD1306 0.66\" 64X48 (Wemos OLED Shield)"], [4, "SSD1306 0.91\" 128X32"], [1, "SSD1306 0.96\" 128X64"], [3, "Nokia5110"]];
|
||||||
if("ESP32" == type)
|
if("ESP32" == type)
|
||||||
opts.push([10, "ePaper"]);
|
opts.push([10, "ePaper"]);
|
||||||
var dispType = sel("disp_typ", opts, obj["disp_typ"]);
|
var dispType = sel("disp_typ", opts, obj["disp_typ"]);
|
||||||
|
@ -817,7 +818,7 @@
|
||||||
])
|
])
|
||||||
);
|
);
|
||||||
dispType.addEventListener('change', (e) => {
|
dispType.addEventListener('change', (e) => {
|
||||||
hideDispPins(pins, e.target.value)
|
hideDispPins(pins, parseInt(e.target.value))
|
||||||
});
|
});
|
||||||
|
|
||||||
opts = [[0, "0°"], [2, "180°"]];
|
opts = [[0, "0°"], [2, "180°"]];
|
||||||
|
@ -837,23 +838,26 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
function hideDispPins(pins, dispType) {
|
function hideDispPins(pins, dispType) {
|
||||||
|
// create pin map for each display type.
|
||||||
|
// It depends on fix pin array (see var pins)
|
||||||
|
// var pins = [['clock', 'disp_clk'], ['data', 'disp_data'], ['cs', 'disp_cs'], ['dc', 'disp_dc'], ['reset', 'disp_rst']];
|
||||||
|
const pinMap = new Map([
|
||||||
|
[0, [0,0,0,0,0]], //none
|
||||||
|
[1, [1,1,0,0,0]], //SSD1306_128X64
|
||||||
|
[2, [1,1,0,0,0]], //SH1106_128X64
|
||||||
|
[3, [1,1,1,1,0]], //PCD8544_84X48 /nokia5110
|
||||||
|
[4, [1,1,0,0,0]], //SSD1306_128X32
|
||||||
|
[5, [1,1,0,0,0]], //SSD1306_64X48
|
||||||
|
[10, [1,1,1,1,1]] //ePaper
|
||||||
|
])
|
||||||
for(var i = 0; i < pins.length; i++) {
|
for(var i = 0; i < pins.length; i++) {
|
||||||
var cl = document.getElementById("row_" + pins[i][1]).classList;
|
var cl = document.getElementById("row_" + pins[i][1]).classList;
|
||||||
|
if(pinMap.get(dispType)[i]) {
|
||||||
if(0 == dispType)
|
|
||||||
cl.add("hide");
|
|
||||||
else if(dispType <= 2 || dispType == 4) { // OLED
|
|
||||||
if(i < 2)
|
|
||||||
cl.remove("hide");
|
|
||||||
else
|
|
||||||
cl.add("hide");
|
|
||||||
} else if(dispType == 3) { // Nokia
|
|
||||||
if(i < 4)
|
|
||||||
cl.remove("hide");
|
|
||||||
else
|
|
||||||
cl.add("hide");
|
|
||||||
} else // ePaper
|
|
||||||
cl.remove("hide");
|
cl.remove("hide");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
cl.add("hide");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue