This commit is contained in:
e2002
2022-03-18 18:03:00 +03:00
parent 5fd0a1b98c
commit ec05da1f21
5 changed files with 91 additions and 25 deletions

View File

@@ -31,8 +31,9 @@ https://aliexpress.com/item/32965676064.html
#### Optional: #### Optional:
##### Displays ##### Displays
- **ST7735** 1.8' or 1.44' https://aliexpress.com/item/1005002822797745.html - **ST7735** 1.8' or 1.44' https://aliexpress.com/item/1005002822797745.html
- or **SSD1306** 0.96' I2C https://aliexpress.com/item/1005001621806398.html - or **SSD1306** 0.96' 128x64 I2C https://aliexpress.com/item/1005001621806398.html
- or **Nokia5110** 84x48 SPI https://aliexpress.com/item/1005001621837569.htmlz - or **SSD1306** 0,91' 128x32 I2C https://aliexpress.com/item/32798439084.html
- or **Nokia5110** 84x48 SPI https://aliexpress.com/item/1005001621837569.html
- or **ST7789** 320x240 SPI https://aliexpress.com/item/32960241206.html - or **ST7789** 320x240 SPI https://aliexpress.com/item/32960241206.html
- or **SH1106** 128x64 I2C https://aliexpress.com/item/32683094040.html - or **SH1106** 128x64 I2C https://aliexpress.com/item/32683094040.html
- or **1602** 16x2 I2C https://aliexpress.com/item/32305776560.html - or **1602** 16x2 I2C https://aliexpress.com/item/32305776560.html
@@ -242,6 +243,9 @@ download _http://\<yoradioip\>/data/playlist.csv_ and _http://\<yoradioip\>/data
--- ---
## Version history ## Version history
#### v0.5.020
- added support for SSD1306 128x32 I2C displays
#### v0.5.010 #### v0.5.010
- added support for ST7789 320x240 SPI displays - added support for ST7789 320x240 SPI displays
- added support for SH1106 I2C displays - added support for SH1106 I2C displays

View File

@@ -14,7 +14,7 @@ DisplayDummy dsp;
#elif DSP_MODEL==DSP_ST7735 #elif DSP_MODEL==DSP_ST7735
#include "src/displays/displayST7735.h" #include "src/displays/displayST7735.h"
DisplayST7735 dsp; DisplayST7735 dsp;
#elif DSP_MODEL==DSP_SSD1306 #elif DSP_MODEL==DSP_SSD1306 || DSP_MODEL==DSP_SSD1306x32
#include "src/displays/displaySSD1306.h" #include "src/displays/displaySSD1306.h"
DisplaySSD1306 dsp; DisplaySSD1306 dsp;
#elif DSP_MODEL==DSP_NOKIA5110 #elif DSP_MODEL==DSP_NOKIA5110
@@ -255,6 +255,8 @@ void Display::swichMode(displayMode_e newmode) {
time(true); time(true);
#ifdef CLOCK_SPACE // if set space for clock in 1602 displays #ifdef CLOCK_SPACE // if set space for clock in 1602 displays
dsp.fillSpaces=true; dsp.fillSpaces=true;
ip();
rssi();
volume(); volume();
#endif #endif
} else { } else {

View File

@@ -1,7 +1,7 @@
#ifndef options_h #ifndef options_h
#define options_h #define options_h
#define VERSION "0.5.010" #define VERSION "0.5.020"
/******************************************************* /*******************************************************
DO NOT EDIT THIS FILE. DO NOT EDIT THIS FILE.
@@ -26,6 +26,7 @@ The connection tables are located here https://github.com/e2002/yoradio#connecti
#define DSP_ST7789 4 // use it with the [#define TFT_INVERT false] option https://aliexpress.com/item/32960241206.html #define DSP_ST7789 4 // use it with the [#define TFT_INVERT false] option https://aliexpress.com/item/32960241206.html
#define DSP_SH1106 5 // https://aliexpress.com/item/32683094040.html #define DSP_SH1106 5 // https://aliexpress.com/item/32683094040.html
#define DSP_1602I2C 6 // https://aliexpress.com/item/32305776560.html #define DSP_1602I2C 6 // https://aliexpress.com/item/32305776560.html
#define DSP_SSD1306x32 7 // https://aliexpress.com/item/32798439084.html
#ifndef DSP_MODEL #ifndef DSP_MODEL
#define DSP_MODEL DSP_DUMMY #define DSP_MODEL DSP_DUMMY

View File

@@ -1,5 +1,5 @@
#include "../../options.h" #include "../../options.h"
#if DSP_MODEL==2 #if DSP_MODEL==DSP_SSD1306 || DSP_MODEL==DSP_SSD1306x32
#include "displaySSD1306.h" #include "displaySSD1306.h"
#include <Wire.h> #include <Wire.h>
@@ -11,9 +11,10 @@
#define SCREEN_ADDRESS 0x3C ///< See datasheet for Address; 0x3D for 128x64, 0x3C for 128x32 or scan it https://create.arduino.cc/projecthub/abdularbi17/how-to-scan-i2c-address-in-arduino-eaadda #define SCREEN_ADDRESS 0x3C ///< See datasheet for Address; 0x3D for 128x64, 0x3C for 128x32 or scan it https://create.arduino.cc/projecthub/abdularbi17/how-to-scan-i2c-address-in-arduino-eaadda
#endif #endif
#if DSP_MODEL==DSP_SSD1306
#define LOGO_WIDTH 21 #define LOGO_WIDTH 21
#define LOGO_HEIGHT 32 #define LOGO_HEIGHT 32
const unsigned char logo [] PROGMEM= const unsigned char logo [] PROGMEM=
{ {
0x06, 0x03, 0x00, 0x0f, 0x07, 0x80, 0x1f, 0x8f, 0xc0, 0x1f, 0x8f, 0xc0, 0x06, 0x03, 0x00, 0x0f, 0x07, 0x80, 0x1f, 0x8f, 0xc0, 0x1f, 0x8f, 0xc0,
@@ -25,10 +26,11 @@ const unsigned char logo [] PROGMEM=
0x7e, 0x00, 0x00, 0x7f, 0x00, 0x00, 0x3f, 0xc0, 0xe0, 0x3f, 0xff, 0xe0, 0x7e, 0x00, 0x00, 0x7f, 0x00, 0x00, 0x3f, 0xc0, 0xe0, 0x3f, 0xff, 0xe0,
0x1f, 0xff, 0xe0, 0x0f, 0xff, 0xe0, 0x03, 0xff, 0xc0, 0x00, 0xfe, 0x00 0x1f, 0xff, 0xe0, 0x0f, 0xff, 0xe0, 0x03, 0xff, 0xc0, 0x00, 0xfe, 0x00
}; };
#endif
TwoWire I2CSSD1306 = TwoWire(0); TwoWire I2CSSD1306 = TwoWire(0);
DisplaySSD1306::DisplaySSD1306(): Adafruit_SSD1306(128, 64, &I2CSSD1306, I2C_RST) { DisplaySSD1306::DisplaySSD1306(): Adafruit_SSD1306(128, ((DSP_MODEL==DSP_SSD1306)?64:32), &I2CSSD1306, I2C_RST) {
} }
@@ -109,15 +111,17 @@ char* DisplaySSD1306::utf8Rus(const char* str, bool uppercase) {
void DisplaySSD1306::apScreen() { void DisplaySSD1306::apScreen() {
setTextSize(1); setTextSize(1);
setTextColor(TFT_FG, TFT_BG); setTextColor(TFT_FG, TFT_BG);
setCursor(TFT_FRAMEWDT, TFT_FRAMEWDT + 2 * TFT_LINEHGHT); setCursor(TFT_FRAMEWDT, TFT_FRAMEWDT + ((DSP_MODEL==DSP_SSD1306)?2:1) * TFT_LINEHGHT);
print("AP NAME: "); print("AP NAME: ");
print(apSsid); print(apSsid);
setCursor(TFT_FRAMEWDT, TFT_FRAMEWDT + 3 * TFT_LINEHGHT); setCursor(TFT_FRAMEWDT, TFT_FRAMEWDT + ((DSP_MODEL==DSP_SSD1306)?3:2) * TFT_LINEHGHT);
print("PASSWORD: "); print("PASSWORD: ");
print(apPassword); print(apPassword);
setTextColor(SILVER, TFT_BG); setTextColor(SILVER, TFT_BG);
#if DSP_MODEL==DSP_SSD1306
setCursor(TFT_FRAMEWDT, sheight - TFT_LINEHGHT * 2); setCursor(TFT_FRAMEWDT, sheight - TFT_LINEHGHT * 2);
print("SETTINGS PAGE ON: "); print("SETTINGS PAGE ON: ");
#endif
setCursor(TFT_FRAMEWDT, sheight - TFT_LINEHGHT); setCursor(TFT_FRAMEWDT, sheight - TFT_LINEHGHT);
print("http://"); print("http://");
print(WiFi.softAPIP().toString().c_str()); print(WiFi.softAPIP().toString().c_str());
@@ -132,20 +136,30 @@ void DisplaySSD1306::initD(uint16_t &screenwidth, uint16_t &screenheight) {
} }
cp437(true); cp437(true);
fillScreen(TFT_BG); fillScreen(TFT_BG);
setRotation(TFT_ROTATE); byte tftRotate = TFT_ROTATE;
if(tftRotate>2) tftRotate=2;
if(tftRotate==1) tftRotate=0;
setRotation(tftRotate);
setTextWrap(false); setTextWrap(false);
screenwidth = width(); screenwidth = width();
screenheight = height(); screenheight = height();
swidth = screenwidth; swidth = screenwidth;
sheight = screenheight; sheight = screenheight;
fillSpaces = true;
} }
void DisplaySSD1306::drawLogo() { void DisplaySSD1306::drawLogo() {
clearDisplay(); clearDisplay();
#if DSP_MODEL==DSP_SSD1306
drawBitmap( drawBitmap(
(width() - LOGO_WIDTH ) / 2, (width() - LOGO_WIDTH ) / 2,
8, 8,
logo, LOGO_WIDTH, LOGO_HEIGHT, 1); logo, LOGO_WIDTH, LOGO_HEIGHT, 1);
#else
setTextSize(2);
centerText(utf8Rus("ёRadio", false), 0, TFT_FG, TFT_BG);
setTextSize(1);
#endif
display(); display();
} }
@@ -153,13 +167,13 @@ void DisplaySSD1306::drawPlaylist(uint16_t currentItem, char* currentItemText) {
for (byte i = 0; i < PLMITEMS; i++) { for (byte i = 0; i < PLMITEMS; i++) {
plMenu[i][0] = '\0'; plMenu[i][0] = '\0';
} }
config.fillPlMenu(plMenu, currentItem - 3, PLMITEMS); config.fillPlMenu(plMenu, currentItem - ((DSP_MODEL==DSP_SSD1306)?3:2), PLMITEMS);
setTextSize(1); setTextSize(1);
int yStart = (sheight / 2 - PLMITEMHEIGHT / 2) - PLMITEMHEIGHT * (PLMITEMS - 1) / 2 + 3; int yStart = (sheight / 2 - PLMITEMHEIGHT / 2) - PLMITEMHEIGHT * (PLMITEMS - 1) / 2 + 3;
fillRect(0, (sheight / 2 - PLMITEMHEIGHT / 2) + 1, swidth, PLMITEMHEIGHT, TFT_LOGO); fillRect(0, (sheight / 2 - PLMITEMHEIGHT / 2) + 1, swidth, PLMITEMHEIGHT, TFT_LOGO);
setTextColor(TFT_FG, TFT_BG); setTextColor(TFT_FG, TFT_BG);
for (byte i = 0; i < PLMITEMS; i++) { for (byte i = 0; i < PLMITEMS; i++) {
if (i == 3) { if (i == ((DSP_MODEL==DSP_SSD1306)?3:2)) {
strlcpy(currentItemText, plMenu[i], PLMITEMLENGHT - 1); strlcpy(currentItemText, plMenu[i], PLMITEMLENGHT - 1);
} else { } else {
setCursor(TFT_FRAMEWDT, yStart + i * PLMITEMHEIGHT); setCursor(TFT_FRAMEWDT, yStart + i * PLMITEMHEIGHT);
@@ -199,8 +213,6 @@ void DisplaySSD1306::centerText(const char* text, byte y, uint16_t fg, uint16_t
const char* txt = text; const char* txt = text;
getTextBounds(txt, 0, 0, &x1, &y1, &w, &h); getTextBounds(txt, 0, 0, &x1, &y1, &w, &h);
setTextColor(fg); setTextColor(fg);
if(y==90) y=sheight-TFT_LINEHGHT*2-5;
if(y==110) y=sheight-TFT_LINEHGHT;
setCursor((swidth - w) / 2, y); setCursor((swidth - w) / 2, y);
fillRect(0, y, swidth, h, bg); fillRect(0, y, swidth, h, bg);
print(txt); print(txt);
@@ -212,7 +224,7 @@ void DisplaySSD1306::rightText(const char* text, byte y, uint16_t fg, uint16_t b
getTextBounds(text, 0, 0, &x1, &y1, &w, &h); getTextBounds(text, 0, 0, &x1, &y1, &w, &h);
setTextColor(fg); setTextColor(fg);
setCursor(swidth - w - TFT_FRAMEWDT, y); setCursor(swidth - w - TFT_FRAMEWDT, y);
fillRect(swidth - w - TFT_FRAMEWDT, y, w, h, bg); fillRect(swidth - w - TFT_FRAMEWDT-((DSP_MODEL==DSP_SSD1306)?0:2), y, w+((DSP_MODEL==DSP_SSD1306)?0:2), h, bg);
print(text); print(text);
} }
@@ -221,18 +233,37 @@ void DisplaySSD1306::displayHeapForDebug() {
} }
void DisplaySSD1306::printClock(const char* timestr) { void DisplaySSD1306::printClock(const char* timestr) {
#if DSP_MODEL==DSP_SSD1306
setTextSize(2); setTextSize(2);
centerText(timestr, 34, TFT_FG, TFT_BG); centerText(timestr, 34, TFT_FG, TFT_BG);
setTextSize(1); setTextSize(1);
#else
setTextSize(1);
rightText(timestr, 0, TFT_FG, TFT_BG);
#endif
}
void DisplaySSD1306::printClock(struct tm timeinfo, bool dots, bool redraw) {
#if DSP_MODEL==DSP_SSD1306x32
strftime(insideClc, sizeof(insideClc), dots?" %H %M":" %H:%M", &timeinfo);
#endif
} }
void DisplaySSD1306::drawVolumeBar(bool withNumber) { void DisplaySSD1306::drawVolumeBar(bool withNumber) {
int16_t vTop = sheight - 4; int16_t vTop = sheight - 4;
int16_t vWidth = swidth; int16_t vWidth = swidth-TFT_FRAMEWDT*2;
#if DSP_MODEL==DSP_SSD1306
uint8_t ww = map(config.store.volume, 0, 254, 0, vWidth - 2); uint8_t ww = map(config.store.volume, 0, 254, 0, vWidth - 2);
fillRect(TFT_FRAMEWDT, vTop, vWidth, 3, TFT_BG); fillRect(TFT_FRAMEWDT, vTop, vWidth, 3, TFT_BG);
drawRect(TFT_FRAMEWDT, vTop, vWidth, 3, TFT_LOGO); drawRect(TFT_FRAMEWDT, vTop, vWidth, 3, TFT_LOGO);
fillRect(TFT_FRAMEWDT + 1, vTop + 1, ww, 1, TFT_LOGO); fillRect(TFT_FRAMEWDT + 1, vTop + 1, ww, 1, TFT_LOGO);
#else
uint8_t ww = map(config.store.volume, 0, 254, 0, vWidth);
if(fillSpaces) {
drawFastHLine(TFT_FRAMEWDT, sheight-1, swidth-TFT_FRAMEWDT*2, TFT_BG);
drawFastHLine(TFT_FRAMEWDT, sheight-1, ww, TFT_LOGO);
}
#endif
if (withNumber) { if (withNumber) {
setTextSize(2); setTextSize(2);
setTextColor(TFT_FG); setTextColor(TFT_FG);
@@ -241,8 +272,8 @@ void DisplaySSD1306::drawVolumeBar(bool withNumber) {
int16_t x1, y1; int16_t x1, y1;
sprintf(volstr, "%d", config.store.volume); sprintf(volstr, "%d", config.store.volume);
getTextBounds(volstr, 0, 0, &x1, &y1, &wv, &hv); getTextBounds(volstr, 0, 0, &x1, &y1, &wv, &hv);
fillRect(TFT_FRAMEWDT, 24, swidth - TFT_FRAMEWDT / 2, hv + 3, TFT_BG); fillRect(TFT_FRAMEWDT, VOL_TOP, swidth - TFT_FRAMEWDT / 2, hv + 3, TFT_BG);
setCursor((swidth - wv) / 2, 24); setCursor((swidth - wv) / 2, VOL_TOP);
print(volstr); print(volstr);
} }
} }
@@ -255,26 +286,28 @@ void DisplaySSD1306::drawNextStationNum(uint16_t num) {
int16_t x1, y1; int16_t x1, y1;
sprintf(numstr, "%d", num); sprintf(numstr, "%d", num);
getTextBounds(numstr, 0, 0, &x1, &y1, &wv, &hv); getTextBounds(numstr, 0, 0, &x1, &y1, &wv, &hv);
fillRect(TFT_FRAMEWDT, 24, swidth - TFT_FRAMEWDT / 2, hv + 3, TFT_BG); fillRect(TFT_FRAMEWDT, VOL_TOP, swidth - TFT_FRAMEWDT / 2, hv + 3, TFT_BG);
setCursor((swidth - wv) / 2, 24); setCursor((swidth - wv) / 2, VOL_TOP);
print(numstr); print(numstr);
} }
void DisplaySSD1306::frameTitle(const char* str) { void DisplaySSD1306::frameTitle(const char* str) {
setTextSize(2); setTextSize((DSP_MODEL==DSP_SSD1306?2:1));
centerText(str, TFT_FRAMEWDT, TFT_LOGO, TFT_BG); centerText(str, TFT_FRAMEWDT, TFT_LOGO, TFT_BG);
} }
void DisplaySSD1306::rssi(const char* str) { void DisplaySSD1306::rssi(const char* str) {
if(!fillSpaces && DSP_MODEL==DSP_SSD1306x32) return;
char buf[4]; char buf[4];
strlcpy(buf, str, strlen(str)-2); strlcpy(buf, str, strlen(str)-2);
int16_t vTop = sheight - TFT_LINEHGHT - 4; int16_t vTop = sheight - TFT_LINEHGHT - ((DSP_MODEL==DSP_SSD1306)?4:2);
setTextSize(1); setTextSize(1);
rightText(buf, vTop, SILVER, TFT_BG); rightText(buf, vTop, SILVER, TFT_BG);
} }
void DisplaySSD1306::ip(const char* str) { void DisplaySSD1306::ip(const char* str) {
int16_t vTop = sheight - TFT_LINEHGHT - 4; if(!fillSpaces && DSP_MODEL==DSP_SSD1306x32) return;
int16_t vTop = sheight - TFT_LINEHGHT - ((DSP_MODEL==DSP_SSD1306)?4:2);
setTextSize(1); setTextSize(1);
setTextColor(SILVER, TFT_BG); setTextColor(SILVER, TFT_BG);
setCursor(0, vTop); setCursor(0, vTop);
@@ -299,6 +332,9 @@ void DisplaySSD1306::printText(const char* txt) {
void DisplaySSD1306::loop() { void DisplaySSD1306::loop() {
if (checkdelay(83, loopdelay)) { if (checkdelay(83, loopdelay)) {
#if DSP_MODEL==DSP_SSD1306x32
if(fillSpaces) printClock(insideClc);
#endif
display(); display();
} }
yield(); yield();

View File

@@ -7,15 +7,36 @@
#define TFT_LINEHGHT 8 #define TFT_LINEHGHT 8
#define TFT_FRAMEWDT 0 #define TFT_FRAMEWDT 0
#define PLMITEMS 7
#define PLMITEMLENGHT 40 #define PLMITEMLENGHT 40
#if DSP_MODEL==DSP_SSD1306
#define PLMITEMS 7
#define PLMITEMHEIGHT 9 #define PLMITEMHEIGHT 9
#define TITLE_TOP2 TFT_FRAMEWDT + 3 * TFT_LINEHGHT #define TITLE_TOP2 TFT_FRAMEWDT + 3 * TFT_LINEHGHT
#define PLCURRENT_SIZE 1 #define PLCURRENT_SIZE 1
#define BOOTSTR_TOP1 64-TFT_LINEHGHT*2-5
#define BOOTSTR_TOP2 64-TFT_LINEHGHT
#define VOL_TOP 24
#else
#define PLMITEMS 5
#define PLMITEMHEIGHT 10
#define TITLE_TOP2 TFT_FRAMEWDT + 2 * TFT_LINEHGHT
#define PLCURRENT_SIZE 1
#define META_SIZE 1
#define TITLE_SIZE2 0
#define TITLE_TOP1 TFT_FRAMEWDT + META_SIZE * TFT_LINEHGHT + 3
#define TFT_FULLTIME 1
#define BOOTSTR_TOP1 14
#define BOOTSTR_TOP2 24
#define CLOCK_SPACE 38
#define VOL_SPACE 0
#define VOL_TOP 16
#endif
class DisplaySSD1306: public Adafruit_SSD1306 { class DisplaySSD1306: public Adafruit_SSD1306 {
public: public:
bool fillSpaces;
DisplaySSD1306(); DisplaySSD1306();
char plMenu[PLMITEMS][PLMITEMLENGHT]; char plMenu[PLMITEMS][PLMITEMLENGHT];
uint16_t clockY; uint16_t clockY;
@@ -30,6 +51,7 @@ class DisplaySSD1306: public Adafruit_SSD1306 {
void set_Cursor(int16_t x, int16_t y); void set_Cursor(int16_t x, int16_t y);
void printText(const char* txt); void printText(const char* txt);
void printClock(const char* timestr); void printClock(const char* timestr);
void printClock(struct tm timeinfo, bool dots, bool redraw = false);
void displayHeapForDebug(); void displayHeapForDebug();
void drawVolumeBar(bool withNumber); void drawVolumeBar(bool withNumber);
void drawNextStationNum(uint16_t num); void drawNextStationNum(uint16_t num);
@@ -45,6 +67,7 @@ class DisplaySSD1306: public Adafruit_SSD1306 {
private: private:
uint16_t swidth, sheight; uint16_t swidth, sheight;
unsigned long loopdelay; unsigned long loopdelay;
char insideClc[10];
boolean checkdelay(int m, unsigned long &tstamp); boolean checkdelay(int m, unsigned long &tstamp);
}; };