v0.5.020
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
@@ -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);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user