This commit is contained in:
e2002
2025-08-03 21:36:48 +03:00
parent 8b1e0a3d25
commit 1c8e5077c0
6 changed files with 182 additions and 26 deletions

View File

@@ -67,6 +67,7 @@ https://aliexpress.com/item/32965676064.html
- or **ILI9486** (Testing mode) 3.5' 480x320 SPI https://aliexpress.com/item/1005001999296476.html?sku_id=12000018365356568 - or **ILI9486** (Testing mode) 3.5' 480x320 SPI https://aliexpress.com/item/1005001999296476.html?sku_id=12000018365356568
- or **SSD1322** 2.8' 256x64 SPI https://aliexpress.com/item/1005003480981568.html - or **SSD1322** 2.8' 256x64 SPI https://aliexpress.com/item/1005003480981568.html
- or **ST7920** 2.6' 128x64 SPI https://aliexpress.com/item/32699482638.html - or **ST7920** 2.6' 128x64 SPI https://aliexpress.com/item/32699482638.html
- or **ST7789** 2.25' 284x76 SPI https://aliexpress.ru/item/1005009016973081.html
(see [Wiki](https://github.com/e2002/yoradio/wiki/Available-display-models) for more details) (see [Wiki](https://github.com/e2002/yoradio/wiki/Available-display-models) for more details)
@@ -234,32 +235,36 @@ Work is in progress...
--- ---
## Version history ## Version history
### 0.9.561 #### v0.9.570
- added support for ST7789 284x76 2.25' SPI displays https://aliexpress.ru/item/1005009016973081.html \
note: the brightness pin of this display should be pulled up to GND
### v0.9.561
**!!! a [full update](#update-over-web-interface) with Sketch data upload is required !!!**\ **!!! a [full update](#update-over-web-interface) with Sketch data upload is required !!!**\
or-> just upload `yoRadio/data/www/script.js.gz` to Webboard Uploader http://radioipaddr/webboard\ or-> just upload `yoRadio/data/www/script.js.gz` to Webboard Uploader http://radioipaddr/webboard \
After updating please clear browser cache. After updating please clear browser cache.
- fixed error when switching to SD Card mode - fixed error when switching to SD Card mode
- fixed issue causing random reboots - fixed issue causing random reboots
- fixed preview playback bug in Playlist Editor - fixed preview playback bug in Playlist Editor
### 0.9.555 ### v0.9.555
- fixed error "assert failed: udp_new_ip_type /IDF/components/lwip/lwip/src/core/udp.c:1278 (Required to lock TCPIP core functionality!)"\ - fixed error "assert failed: udp_new_ip_type /IDF/components/lwip/lwip/src/core/udp.c:1278 (Required to lock TCPIP core functionality!)"\
part #2 part #2
- weather synchronization code rewritten - weather synchronization code rewritten
### 0.9.553 ### v0.9.553
- fix "No 'Access-Control-Allow-Origin' header is present on the requested resource" on saving playlist\ - fix "No 'Access-Control-Allow-Origin' header is present on the requested resource" on saving playlist\
just reupload the file `script.js.gz` with Webboard uploader just reupload the file `script.js.gz` with Webboard uploader
- fixed error "assert failed: udp_new_ip_type /IDF/components/lwip/lwip/src/core/udp.c:1278 (Required to lock TCPIP core functionality!)" - fixed error "assert failed: udp_new_ip_type /IDF/components/lwip/lwip/src/core/udp.c:1278 (Required to lock TCPIP core functionality!)"
- fixed error "Exception in status_listener when handling msg" in HA component - fixed error "Exception in status_listener when handling msg" in HA component
### 0.9.552 ### v0.9.552
- fixed compilation error for ESP cores version below 3.0.0\ - fixed compilation error for ESP cores version below 3.0.0\
Thanks to @salawalas ! https://github.com/e2002/yoradio/pull/197/ Thanks to @salawalas ! https://github.com/e2002/yoradio/pull/197/
- disabled websocket reconnection on all pages except the start page "/"\ - disabled websocket reconnection on all pages except the start page "/"\
just reupload the file `script.js.gz` just reupload the file `script.js.gz`
### 0.9.550 ### v0.9.550
**!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!**\ **!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!**\
or-> just upload all files from data/www (11 pcs) to Webboard Uploader http://radioipaddr/webboard or-> just upload all files from data/www (11 pcs) to Webboard Uploader http://radioipaddr/webboard
- fixed the issue with selecting all rows in the playlist editor - fixed the issue with selecting all rows in the playlist editor
@@ -276,12 +281,12 @@ or-> just upload all files from data/www (11 pcs) to Webboard Uploader http://ra
- settings for time and weather synchronization intervals have been added to the web interface - settings for time and weather synchronization intervals have been added to the web interface
- bug fixes, optimization - bug fixes, optimization
### 0.9.533 ### v0.9.533
- fixed compilation error for esp32 core version lower than 3.0.0 - fixed compilation error for esp32 core version lower than 3.0.0
- fixed error setting display brightness to 1 - fixed error setting display brightness to 1
- fixed error setting IR tolerance value (upload a new file `options.html.gz` via WEB Board Uploader and press Ctrl+F5 on the settings page) - fixed error setting IR tolerance value (upload a new file `options.html.gz` via WEB Board Uploader and press Ctrl+F5 on the settings page)
### 0.9.530 ### v0.9.530
- optimization of webserver/socket code in netserver.cpp, part#1 - optimization of webserver/socket code in netserver.cpp, part#1
- added support for ArduinoOTA (OTA update from Arduino IDE) (disabled by default)\ - added support for ArduinoOTA (OTA update from Arduino IDE) (disabled by default)\
to enable you need to add to myoptions.h: `#define USE_OTA true`\ to enable you need to add to myoptions.h: `#define USE_OTA true`\
@@ -294,13 +299,13 @@ or-> just upload all files from data/www (11 pcs) to Webboard Uploader http://ra
- added config (sys.config) telnet command that displays the same information usually shown over serial at boot. - added config (sys.config) telnet command that displays the same information usually shown over serial at boot.
- bug fixes 🪲 - bug fixes 🪲
### 0.9.515 ### v0.9.515
- fixed a bug with resetting all parameters when resetting only one section of parameters - fixed a bug with resetting all parameters when resetting only one section of parameters
### 0.9.512 ### v0.9.512
- fixed bug with saving ntp server #1 value - fixed bug with saving ntp server #1 value
### 0.9.511 ### v0.9.511
In this version, the contents of the data/www directory have changed, so that the first time you flash it, you will be greeted by WEB Board Uploader. Just upload all the files from data/www (11 pcs) to it\ In this version, the contents of the data/www directory have changed, so that the first time you flash it, you will be greeted by WEB Board Uploader. Just upload all the files from data/www (11 pcs) to it\
or -> **!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!** or -> **!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!**
- fixed a bug with saving smartstart mode - fixed a bug with saving smartstart mode
@@ -314,7 +319,7 @@ or -> **!!! a [full update](#update-over-web-interface) with Sketch data upload
- buttons reboot (reboot) format (spiffs format) and reset (reset settings to default) have been added to the settings - buttons reboot (reboot) format (spiffs format) and reset (reset settings to default) have been added to the settings
- the beginnings of theming (theme.css) (just a list of global colors that can be changed, and then uploaded to theme.css via WB uploader) - the beginnings of theming (theme.css) (just a list of global colors that can be changed, and then uploaded to theme.css via WB uploader)
### 0.9.434 ### v0.9.434
- fixed the issue with exiting Screensaver Blank Screen mode via button presses and IR commands. - fixed the issue with exiting Screensaver Blank Screen mode via button presses and IR commands.
- reduced the minimum frequency for tone control on I2S modules to 80Hz. - reduced the minimum frequency for tone control on I2S modules to 80Hz.
- increased the display update task delay to 10 TICKS. - increased the display update task delay to 10 TICKS.
@@ -322,13 +327,13 @@ or -> **!!! a [full update](#update-over-web-interface) with Sketch data upload
- when ENCODER2 is connected, the UP and DOWN buttons now work as PREV and NEXT (single click). - when ENCODER2 is connected, the UP and DOWN buttons now work as PREV and NEXT (single click).
- implemented backlight off in Screensaver Blank Screen mode. - implemented backlight off in Screensaver Blank Screen mode.
### 0.9.428 ### v0.9.428
- fixed freezing after SD scanning during playback - fixed freezing after SD scanning during playback
- AsyncWebSocket queue increased to 128 - AsyncWebSocket queue increased to 128
- fixed VU meter overlapping the clock on displays - fixed VU meter overlapping the clock on displays
- fixed Guru Meditation error when loading in SD mode with SD card removed - fixed Guru Meditation error when loading in SD mode with SD card removed
### 0.9.420 ### v0.9.420
**!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!** **!!! a [full update](#update-over-web-interface) with Sketch data upload is required. After updating please press CTRL+F5 in browser !!!**
- added screensaver mode during playback, configurable via the web interface, pull request[#129](https://github.com/e2002/yoradio/pull/129) - added screensaver mode during playback, configurable via the web interface, pull request[#129](https://github.com/e2002/yoradio/pull/129)
- added blank screen mode to screensaver, configurable via the web interface, pull request[#129](https://github.com/e2002/yoradio/pull/129) - added blank screen mode to screensaver, configurable via the web interface, pull request[#129](https://github.com/e2002/yoradio/pull/129)

View File

@@ -50,6 +50,7 @@ The connection tables are located here https://github.com/e2002/yoradio#connecti
#define DSP_ILI9486 22 // (Testing mode) 480x320 3.5' https://aliexpress.com/item/1005001999296476.html?sku_id=12000018365356568 #define DSP_ILI9486 22 // (Testing mode) 480x320 3.5' https://aliexpress.com/item/1005001999296476.html?sku_id=12000018365356568
#define DSP_SSD1322 23 // 256x64 2.8' https://aliexpress.com/item/1005003480981568.html #define DSP_SSD1322 23 // 256x64 2.8' https://aliexpress.com/item/1005003480981568.html
#define DSP_ST7920 24 // 128x64 2.6' https://aliexpress.com/item/32699482638.html #define DSP_ST7920 24 // 128x64 2.6' https://aliexpress.com/item/32699482638.html
#define DSP_ST7789_76 25 // 284x76 2.25' https://aliexpress.ru/item/1005009016973081.html
#define DSP_CUSTOM 101 // your display #define DSP_CUSTOM 101 // your display
#ifndef DSP_MODEL #ifndef DSP_MODEL

View File

@@ -0,0 +1,71 @@
/*************************************************************************************
SSD1305 265x64 displays configuration file.
Copy this file to yoRadio/src/displays/conf/displaySSD1322conf_custom.h
and modify it
More info on https://github.com/e2002/yoradio/wiki/Widgets#widgets-description
*************************************************************************************/
#ifndef displayST778976conf_h
#define displayST778976conf_h
#define DSP_WIDTH 284
#define DSP_HEIGHT 76
#define TFT_FRAMEWDT 2
#define MAX_WIDTH DSP_WIDTH-TFT_FRAMEWDT*2
#define HIDE_HEAPBAR
#define HIDE_VOL
//#define HIDE_VU
//#define HIDE_TITLE2
#define bootLogoTop 68
/* SROLLS */ /* {{ left, top, fontsize, align }, buffsize, uppercase, width, scrolldelay, scrolldelta, scrolltime } */
const ScrollConfig metaConf PROGMEM = {{ TFT_FRAMEWDT+1, TFT_FRAMEWDT+1, 2, WA_LEFT }, 140, true, MAX_WIDTH-2, 5000, 2, 25 };
const ScrollConfig title1Conf PROGMEM = {{ TFT_FRAMEWDT, 21, 1, WA_LEFT }, 140, true, DSP_WIDTH/2+18, 5000, 2, 25 };
const ScrollConfig title2Conf PROGMEM = {{ TFT_FRAMEWDT, 30, 1, WA_LEFT }, 140, true, DSP_WIDTH/2+18, 5000, 2, 25 };
const ScrollConfig playlistConf PROGMEM = {{ TFT_FRAMEWDT, 30, 1, WA_LEFT }, 140, true, MAX_WIDTH, 500, 2, 25 };
const ScrollConfig apTitleConf PROGMEM = {{ TFT_FRAMEWDT+1, TFT_FRAMEWDT+1, 1, WA_CENTER }, 140, false, MAX_WIDTH-2, 0, 2, 25 };
const ScrollConfig apSettConf PROGMEM = {{ TFT_FRAMEWDT, 64-7, 1, WA_LEFT }, 140, false, MAX_WIDTH, 0, 2, 25 };
const ScrollConfig weatherConf PROGMEM = {{ TFT_FRAMEWDT, 64-12, 1, WA_LEFT }, 140, true, DSP_WIDTH/2+18, 0, 2, 25 }; // ПОГОДА!!
/* BACKGROUNDS */ /* {{ left, top, fontsize, align }, width, height, outlined } */
const FillConfig metaBGConf PROGMEM = {{ 0, 0, 0, WA_LEFT }, DSP_WIDTH, 19, false };
const FillConfig volbarConf PROGMEM = {{ TFT_FRAMEWDT, DSP_HEIGHT-4, 0, WA_LEFT }, DSP_WIDTH-TFT_FRAMEWDT*2, 3, true };
const FillConfig playlBGConf PROGMEM = {{ 0, 26, 0, WA_LEFT }, DSP_WIDTH, 12, false };
const FillConfig heapbarConf PROGMEM = {{ 0, 63, 0, WA_LEFT }, DSP_WIDTH, 1, false };
/* WIDGETS */ /* { left, top, fontsize, align } */
const WidgetConfig bootstrConf PROGMEM = { 0, DSP_HEIGHT-10, 1, WA_CENTER };
const WidgetConfig bitrateConf PROGMEM = { TFT_FRAMEWDT+20, 64-11-10, 1, WA_LEFT };
//const WidgetConfig voltxtConf PROGMEM = { 32, 108, 1, WA_RIGHT };
const WidgetConfig iptxtConf PROGMEM = { TFT_FRAMEWDT, 64-12, 1, WA_LEFT };
const WidgetConfig rssiConf PROGMEM = { TFT_FRAMEWDT, 64-11-10, 1, WA_LEFT };
const WidgetConfig numConf PROGMEM = { TFT_FRAMEWDT, 57, 35, WA_CENTER };
const WidgetConfig apNameConf PROGMEM = { 0, 18, 1, WA_CENTER };
const WidgetConfig apName2Conf PROGMEM = { 0, 26, 1, WA_CENTER };
const WidgetConfig apPassConf PROGMEM = { 0, 37, 1, WA_CENTER };
const WidgetConfig apPass2Conf PROGMEM = { 0, 45, 1, WA_CENTER };
//const WidgetConfig clockConf PROGMEM = { 6, 34, 2, WA_CENTER };
const WidgetConfig clockConf PROGMEM = { 0, 57, 35, WA_RIGHT }; /* 35 is a fixed font size. do not change */
const WidgetConfig vuConf PROGMEM = { 2, DSP_HEIGHT-14, 1, WA_CENTER };
const WidgetConfig bootWdtConf PROGMEM = { 0, DSP_HEIGHT-8*2-5, 1, WA_CENTER };
const ProgressConfig bootPrgConf PROGMEM = { 90, 10, 4 };
/* BANDS */ /* { onebandwidth, onebandheight, bandsHspace, bandsVspace, numofbands, fadespeed } */
const VUBandsConfig bandsConf PROGMEM = { DSP_WIDTH/2-TFT_FRAMEWDT*2-2, 7, TFT_FRAMEWDT*2+4, 1, 17, 2 };
/* STRINGS */
const char numtxtFmt[] PROGMEM = "%d";
const char rssiFmt[] PROGMEM = "%d";
const char iptxtFmt[] PROGMEM = "%s";
//const char voltxtFmt[] PROGMEM = "%d";
const char bitrateFmt[] PROGMEM = "%d kBs";
/* MOVES */ /* { left, top, width } */
const MoveConfig clockMove PROGMEM = { 0, 0, -1 };
const MoveConfig weatherMove PROGMEM = { 0, 0, -1 };
const MoveConfig weatherMoveVU PROGMEM = { 0, 0, -1 };
#endif

View File

@@ -1,9 +1,14 @@
#include "../core/options.h" #include "../core/options.h"
#if DSP_MODEL==DSP_ST7789 || DSP_MODEL==DSP_ST7789_240 #if DSP_MODEL==DSP_ST7789 || DSP_MODEL==DSP_ST7789_240 || DSP_MODEL==DSP_ST7789_76
#include "displayST7789.h" #include "displayST7789.h"
//#include <SPI.h> //#include <SPI.h>
#if DSP_MODEL==DSP_ST7789_76
#include "fonts/bootlogo40.h"
#else
#include "fonts/bootlogo.h" #include "fonts/bootlogo.h"
#endif
#include "../core/config.h" #include "../core/config.h"
#include "../core/network.h" #include "../core/network.h"
@@ -20,7 +25,11 @@ DspCore::DspCore(): Adafruit_ST7789(TFT_CS, TFT_DC, TFT_RST) {}
#include "tools/utf8RusGFX.h" #include "tools/utf8RusGFX.h"
void DspCore::initDisplay() { void DspCore::initDisplay() {
if(DSP_MODEL==DSP_ST7789_76){
init(76,284);
}else{
init(240,(DSP_MODEL==DSP_ST7789)?320:240); init(240,(DSP_MODEL==DSP_ST7789)?320:240);
}
if(DEF_SPI_FREQ > 0) setSPISpeed(DEF_SPI_FREQ); if(DEF_SPI_FREQ > 0) setSPISpeed(DEF_SPI_FREQ);
invert(); invert();
cp437(true); cp437(true);
@@ -36,8 +45,14 @@ void DspCore::initDisplay() {
plYStart = (height() / 2 - plItemHeight / 2) - plItemHeight * (plTtemsCount - 1) / 2 + playlistConf.widget.textsize*2; plYStart = (height() / 2 - plItemHeight / 2) - plItemHeight * (plTtemsCount - 1) / 2 + playlistConf.widget.textsize*2;
} }
#if DSP_MODEL==DSP_ST7789_76
void DspCore::drawLogo(uint16_t top) {
//drawBitmap( (width() - LOGO_WIDTH ) / 2, 8, logo, LOGO_WIDTH, LOGO_HEIGHT, 1);
drawRGBBitmap((width() - 62) / 2, 8, bootlogo40, 62, 40);
}
#else
void DspCore::drawLogo(uint16_t top) { drawRGBBitmap((width() - 99) / 2, top, bootlogo2, 99, 64); } void DspCore::drawLogo(uint16_t top) { drawRGBBitmap((width() - 99) / 2, top, bootlogo2, 99, 64); }
#endif
void DspCore::printPLitem(uint8_t pos, const char* item, ScrollWidget& current){ void DspCore::printPLitem(uint8_t pos, const char* item, ScrollWidget& current){
setTextSize(playlistConf.widget.textsize); setTextSize(playlistConf.widget.textsize);
@@ -66,7 +81,11 @@ GFXglyph *pgm_read_glyph_ptr(const GFXfont *gfxFont, uint8_t c) {
} }
uint8_t DspCore::_charWidth(unsigned char c){ uint8_t DspCore::_charWidth(unsigned char c){
#if DSP_MODEL==DSP_ST7789_76
GFXglyph *glyph = pgm_read_glyph_ptr(&DS_DIGI28pt7b, c - 0x20);
#else
GFXglyph *glyph = pgm_read_glyph_ptr(&DS_DIGI42pt7b, c - 0x20); GFXglyph *glyph = pgm_read_glyph_ptr(&DS_DIGI42pt7b, c - 0x20);
#endif
return pgm_read_byte(&glyph->xAdvance); return pgm_read_byte(&glyph->xAdvance);
} }
@@ -82,15 +101,61 @@ void DspCore::_getTimeBounds() {
strftime(buf, 4, "%H", &network.timeinfo); strftime(buf, 4, "%H", &network.timeinfo);
_dotsLeft=textWidth(buf); _dotsLeft=textWidth(buf);
} }
#if DSP_MODEL==DSP_ST7789_76
void DspCore::_clockSeconds(){
setTextSize(1);
setFont(&DS_DIGI28pt7b);
setTextColor((network.timeinfo.tm_sec % 2 == 0) ? config.theme.clock : (CLOCKFONT_MONO?config.theme.clockbg:config.theme.background), config.theme.background);
setCursor(_timeleft+_dotsLeft, clockTop);
print(":");
setFont();
}
void DspCore::_clockDate(){ }
void DspCore::_clockTime(){
if(_oldtimeleft>0 && !CLOCKFONT_MONO) dsp.fillRect(_oldtimeleft, clockTop-clockTimeHeight+1, _oldtimewidth+CHARWIDTH*2+2, clockTimeHeight, config.theme.background);
_timeleft = (width()/*/2*/ - _timewidth/*/2*/)-clockRightSpace;
setTextSize(1);
setFont(&DS_DIGI28pt7b);
if(CLOCKFONT_MONO) {
setCursor(_timeleft, clockTop);
setTextColor(config.theme.clockbg, config.theme.background);
print("88:88");
}
setTextColor(config.theme.clock, config.theme.background);
setCursor(_timeleft, clockTop);
print(_timeBuf);
setFont();
strlcpy(_oldTimeBuf, _timeBuf, sizeof(_timeBuf));
_oldtimewidth = _timewidth;
_oldtimeleft = _timeleft;
}
void DspCore::printClock(uint16_t top, uint16_t rightspace, uint16_t timeheight, bool redraw){
clockTop = top;
clockRightSpace = rightspace;
clockTimeHeight = timeheight;
strftime(_timeBuf, sizeof(_timeBuf), "%H:%M", &network.timeinfo);
if(strcmp(_oldTimeBuf, _timeBuf)!=0 || redraw){
_getTimeBounds();
_clockTime();
}
_clockSeconds();
}
void DspCore::clearClock(){
dsp.fillRect(_timeleft, clockTop-clockTimeHeight, _timewidth+2, clockTimeHeight+1, config.theme.background);
}
#else
void DspCore::_clockSeconds(){ void DspCore::_clockSeconds(){
setTextSize(3); setTextSize(3);
setTextColor(config.theme.seconds, config.theme.background); setTextColor(config.theme.seconds, config.theme.background);
setCursor(width() - 8 - clockRightSpace - CHARWIDTH*3*2, clockTop-clockTimeHeight+1); setCursor(width() - 8 - clockRightSpace - CHARWIDTH*3*2, clockTop-clockTimeHeight+1);
sprintf(_bufforseconds, "%02d", network.timeinfo.tm_sec); sprintf(_bufforseconds, "%02d", network.timeinfo.tm_sec);
if(!config.isScreensaver) print(_bufforseconds); /* print seconds */ if(!config.isScreensaver) print(_bufforseconds); /* print seconds */
setTextSize(1); setNumFont();
setFont(&DS_DIGI42pt7b);
setTextColor((network.timeinfo.tm_sec % 2 == 0) ? config.theme.clock : (CLOCKFONT_MONO?config.theme.clockbg:config.theme.background), config.theme.background); setTextColor((network.timeinfo.tm_sec % 2 == 0) ? config.theme.clock : (CLOCKFONT_MONO?config.theme.clockbg:config.theme.background), config.theme.background);
setCursor(_timeleft+_dotsLeft, clockTop); setCursor(_timeleft+_dotsLeft, clockTop);
print(":"); /* print dots */ print(":"); /* print dots */
@@ -115,8 +180,7 @@ void DspCore::_clockDate(){
void DspCore::_clockTime(){ void DspCore::_clockTime(){
if(_oldtimeleft>0 && !CLOCKFONT_MONO) dsp.fillRect(_oldtimeleft, clockTop-clockTimeHeight+1, _oldtimewidth, clockTimeHeight, config.theme.background); if(_oldtimeleft>0 && !CLOCKFONT_MONO) dsp.fillRect(_oldtimeleft, clockTop-clockTimeHeight+1, _oldtimewidth, clockTimeHeight, config.theme.background);
_timeleft = width()-clockRightSpace-CHARWIDTH*3*2-24-_timewidth; _timeleft = width()-clockRightSpace-CHARWIDTH*3*2-24-_timewidth;
setTextSize(1); setNumFont();
setFont(&DS_DIGI42pt7b);
if(CLOCKFONT_MONO) { if(CLOCKFONT_MONO) {
setCursor(_timeleft, clockTop); setCursor(_timeleft, clockTop);
@@ -155,6 +219,7 @@ void DspCore::printClock(uint16_t top, uint16_t rightspace, uint16_t timeheight,
void DspCore::clearClock(){ void DspCore::clearClock(){
dsp.fillRect(_timeleft, clockTop-clockTimeHeight, _timewidth+CHARWIDTH*3*2+24, clockTimeHeight+10+CHARHEIGHT, config.theme.background); dsp.fillRect(_timeleft, clockTop-clockTimeHeight, _timewidth+CHARWIDTH*3*2+24, clockTimeHeight+10+CHARHEIGHT, config.theme.background);
} }
#endif
void DspCore::startWrite(void) { void DspCore::startWrite(void) {
Adafruit_ST7789::startWrite(); Adafruit_ST7789::startWrite();
@@ -178,7 +243,7 @@ void DspCore::setTextSize(uint8_t s){
} }
void DspCore::flip(){ void DspCore::flip(){
#if DSP_MODEL==DSP_ST7789 #if DSP_MODEL==DSP_ST7789 || DSP_MODEL==DSP_ST7789_76
setRotation(config.store.flipscreen?3:1); setRotation(config.store.flipscreen?3:1);
#endif #endif
#if DSP_MODEL==DSP_ST7789_240 #if DSP_MODEL==DSP_ST7789_240
@@ -226,7 +291,11 @@ void DspCore::clearClipping(){
} }
void DspCore::setNumFont(){ void DspCore::setNumFont(){
#if DSP_MODEL==DSP_ST7789_76
setFont(&DS_DIGI28pt7b);
#else
setFont(&DS_DIGI42pt7b); setFont(&DS_DIGI42pt7b);
#endif
setTextSize(1); setTextSize(1);
} }
#endif #endif

View File

@@ -6,10 +6,18 @@
#include <Adafruit_GFX.h> #include <Adafruit_GFX.h>
#include <Adafruit_ST7789.h> #include <Adafruit_ST7789.h>
#if CLOCKFONT_MONO #if DSP_MODEL==DSP_ST7789_76
#include "fonts/DS_DIGI42pt7b_mono.h" // https://tchapi.github.io/Adafruit-GFX-Font-Customiser/ #if CLOCKFONT_MONO
#include "fonts/DS_DIGI28pt7b_mono.h" // https://tchapi.github.io/Adafruit-GFX-Font-Customiser/
#else
#include "fonts/DS_DIGI28pt7b.h"
#endif
#else #else
#if CLOCKFONT_MONO
#include "fonts/DS_DIGI42pt7b_mono.h" // https://tchapi.github.io/Adafruit-GFX-Font-Customiser/
#else
#include "fonts/DS_DIGI42pt7b.h" #include "fonts/DS_DIGI42pt7b.h"
#endif
#endif #endif
#include "tools/l10n.h" #include "tools/l10n.h"
@@ -25,6 +33,8 @@ typedef GFXcanvas16 Canvas;
#else #else
#if DSP_MODEL==DSP_ST7789 #if DSP_MODEL==DSP_ST7789
#include "conf/displayST7789conf.h" #include "conf/displayST7789conf.h"
#elif DSP_MODEL==DSP_ST7789_76
#include "conf/displayST7789_76conf.h"
#else #else
#include "conf/displayST7789_240conf.h" #include "conf/displayST7789_240conf.h"
#endif #endif

View File

@@ -12,7 +12,7 @@
#include "displaySSD1306.h" #include "displaySSD1306.h"
#elif DSP_MODEL==DSP_NOKIA5110 #elif DSP_MODEL==DSP_NOKIA5110
#include "displayN5110.h" #include "displayN5110.h"
#elif DSP_MODEL==DSP_ST7789 || DSP_MODEL==DSP_ST7789_240 #elif DSP_MODEL==DSP_ST7789 || DSP_MODEL==DSP_ST7789_240 || DSP_MODEL==DSP_ST7789_76
#include "displayST7789.h" #include "displayST7789.h"
#elif DSP_MODEL==DSP_SH1106 #elif DSP_MODEL==DSP_SH1106
#include "displaySH1106.h" #include "displaySH1106.h"