display dump

This commit is contained in:
gemu2015 2021-04-29 14:18:28 +02:00
parent cf4f1a964c
commit 3565eeb75d
10 changed files with 291 additions and 34 deletions

View File

@ -72,6 +72,8 @@ void Adafruit_SH1106::DisplayInit(int8_t p,int8_t size,int8_t rot,int8_t font) {
//fillScreen(BLACK); //fillScreen(BLACK);
fillScreen(BLACK); fillScreen(BLACK);
Updateframe(); Updateframe();
disp_bpp = -1;
//} //}
} }

View File

@ -604,6 +604,8 @@ void Adafruit_SSD1306::DisplayInit(int8_t p,int8_t size,int8_t rot,int8_t font)
setCursor(0,0); setCursor(0,0);
fillScreen(BLACK); fillScreen(BLACK);
Updateframe(); Updateframe();
disp_bpp = -1;
//} //}
} }

View File

@ -49,7 +49,7 @@ Adafruit_GFX(x, y) {
#ifdef USE_EPD_FONTS #ifdef USE_EPD_FONTS
selected_font = &Font12; selected_font = &Font12;
#endif #endif
disp_bpp = 16;
} }
uint16_t Renderer::GetColorFromIndex(uint8_t index) { uint16_t Renderer::GetColorFromIndex(uint8_t index) {

View File

@ -78,6 +78,7 @@ public:
pwr_cb pwr_cbp = 0; pwr_cb pwr_cbp = 0;
dim_cb dim_cbp = 0; dim_cb dim_cbp = 0;
LVGL_PARAMS lvgl_param; LVGL_PARAMS lvgl_param;
int8_t disp_bpp;
private: private:
void DrawCharAt(int16_t x, int16_t y, char ascii_char,int16_t colored); void DrawCharAt(int16_t x, int16_t y, char ascii_char,int16_t colored);
inline void drawFastVLineInternal(int16_t x, int16_t y, int16_t h, uint16_t color) __attribute__((always_inline)); inline void drawFastVLineInternal(int16_t x, int16_t y, int16_t h, uint16_t color) __attribute__((always_inline));

View File

@ -74,6 +74,8 @@ void Epd::DisplayInit(int8_t p,int8_t size,int8_t rot,int8_t font) {
setTextColor(WHITE,BLACK); setTextColor(WHITE,BLACK);
setCursor(0,0); setCursor(0,0);
fillScreen(BLACK); fillScreen(BLACK);
disp_bpp = 1;
} }
void Epd::Begin(int16_t cs,int16_t mosi,int16_t sclk) { void Epd::Begin(int16_t cs,int16_t mosi,int16_t sclk) {

View File

@ -86,6 +86,8 @@ void Epd42::DisplayInit(int8_t p,int8_t size,int8_t rot,int8_t font) {
setTextColor(WHITE,BLACK); setTextColor(WHITE,BLACK);
setCursor(0,0); setCursor(0,0);
fillScreen(BLACK); fillScreen(BLACK);
disp_bpp = 1;
} }
void Epd42::Begin(int16_t cs,int16_t mosi,int16_t sclk) { void Epd42::Begin(int16_t cs,int16_t mosi,int16_t sclk) {

View File

@ -122,7 +122,8 @@ uDisplay::uDisplay(char *lp) : Renderer(800, 600) {
setwidth(gxs); setwidth(gxs);
gys = next_val(&lp1); gys = next_val(&lp1);
setheight(gys); setheight(gys);
bpp = next_val(&lp1); disp_bpp = next_val(&lp1);
bpp = abs(disp_bpp);
if (bpp == 1) { if (bpp == 1) {
col_type = uCOLOR_BW; col_type = uCOLOR_BW;
} else { } else {
@ -373,15 +374,7 @@ uDisplay::uDisplay(char *lp) : Renderer(800, 600) {
Renderer *uDisplay::Init(void) { Renderer *uDisplay::Init(void) {
if (reset >= 0) {
pinMode(reset, OUTPUT);
digitalWrite(reset, HIGH);
delay(50);
digitalWrite(reset, LOW);
delay(50);
digitalWrite(reset, HIGH);
delay(200);
}
if (interface == _UDSP_I2C) { if (interface == _UDSP_I2C) {
if (wire_n == 0) { if (wire_n == 0) {
@ -486,6 +479,16 @@ Renderer *uDisplay::Init(void) {
} }
#endif // ESP32 #endif // ESP32
if (reset >= 0) {
pinMode(reset, OUTPUT);
digitalWrite(reset, HIGH);
delay(50);
digitalWrite(reset, LOW);
delay(50);
digitalWrite(reset, HIGH);
delay(200);
}
spiSettings = SPISettings((uint32_t)spi_speed*1000000, MSBFIRST, SPI_MODE3); spiSettings = SPISettings((uint32_t)spi_speed*1000000, MSBFIRST, SPI_MODE3);
uint16_t index = 0; uint16_t index = 0;

View File

@ -55,19 +55,20 @@ uint16_t Epd47::GetColorFromIndex(uint8_t index) {
Epd47::Epd47(int16_t dwidth, int16_t dheight) : Renderer(dwidth, dheight) { Epd47::Epd47(int16_t dwidth, int16_t dheight) : Renderer(dwidth, dheight) {
width = dwidth; width = dwidth;
height = dheight; height = dheight;
disp_bpp = 4;
} }
int32_t Epd47::Init(void) { int32_t Epd47::Init(void) {
epd_init(EPD_LUT_1K); epd_init(EPD_LUT_1K);
hl = epd_hl_init(WAVEFORM); hl = epd_hl_init(WAVEFORM);
epd47_buffer = epd_hl_get_framebuffer(&hl); epd47_buffer = epd_hl_get_framebuffer(&hl);
framebuffer = epd47_buffer;
lvgl_param.fluslines = 10; lvgl_param.fluslines = 10;
return 0; return 0;
} }
void Epd47::DisplayInit(int8_t p, int8_t size, int8_t rot, int8_t font) { void Epd47::DisplayInit(int8_t p, int8_t size, int8_t rot, int8_t font) {
if (p == DISPLAY_INIT_MODE) { if (p == DISPLAY_INIT_MODE) {
epd_poweron(); epd_poweron();
epd_clear(); epd_clear();

View File

@ -69,6 +69,9 @@ keywords if then else endif, or, and are better readable for beginners (others m
#define MAX_SARRAY_NUM 32 #define MAX_SARRAY_NUM 32
#endif #endif
#include <renderer.h>
extern Renderer *renderer;
uint32_t EncodeLightId(uint8_t relay_id); uint32_t EncodeLightId(uint8_t relay_id);
uint32_t DecodeLightId(uint32_t hue_id); uint32_t DecodeLightId(uint32_t hue_id);
@ -2352,7 +2355,7 @@ chknext:
goto exit; goto exit;
} }
if (!strncmp(vname, "fsm", 3)) { if (!strncmp(vname, "fsm", 3)) {
fvar=glob_script_mem.script_sd_found; fvar=(uint32_t)ufsp;
//card_init(); //card_init();
goto exit; goto exit;
} }
@ -3339,7 +3342,7 @@ chknext:
goto exit; goto exit;
} }
#endif // USE_TTGO_WATCH #endif // USE_TTGO_WATCH
#if defined(USE_FT5206) #if defined(USE_FT5206) || defined(USE_XPT2046) || defined(USE_LILYGO47)
if (!strncmp(vname, "wtch(", 5)) { if (!strncmp(vname, "wtch(", 5)) {
lp = GetNumericArgument(lp + 5, OPER_EQU, &fvar, gv); lp = GetNumericArgument(lp + 5, OPER_EQU, &fvar, gv);
fvar = Touch_Status(fvar); fvar = Touch_Status(fvar);
@ -5323,8 +5326,8 @@ void HandleScriptConfiguration(void) {
WSContentSend_P(HTTP_FORM_SCRIPT1b); WSContentSend_P(HTTP_FORM_SCRIPT1b);
#ifdef USE_SCRIPT_FATFS #ifdef USE_SCRIPT_FATFS
if (glob_script_mem.script_sd_found) { if (ufsp) {
WSContentSend_P(HTTP_FORM_SCRIPT1d); //WSContentSend_P(HTTP_FORM_SCRIPT1d);
if (glob_script_mem.flink[0][0]) WSContentSend_P(HTTP_FORM_SCRIPT1c, 1, glob_script_mem.flink[0]); if (glob_script_mem.flink[0][0]) WSContentSend_P(HTTP_FORM_SCRIPT1c, 1, glob_script_mem.flink[0]);
if (glob_script_mem.flink[1][0]) WSContentSend_P(HTTP_FORM_SCRIPT1c, 2, glob_script_mem.flink[1]); if (glob_script_mem.flink[1][0]) WSContentSend_P(HTTP_FORM_SCRIPT1c, 2, glob_script_mem.flink[1]);
} }
@ -6489,10 +6492,12 @@ char buff[512];
// screen copy // screen copy
#define fileHeaderSize 14 #define fileHeaderSize 14
#define infoHeaderSize 40 #define infoHeaderSize 40
if (buffer) {
uint8_t *bp = buffer; if (renderer && renderer->framebuffer) {
uint8_t *bp = renderer->framebuffer;
uint8_t *lbuf = (uint8_t*)special_malloc(Settings.display_width * 3 + 2); uint8_t *lbuf = (uint8_t*)special_malloc(Settings.display_width * 3 + 2);
if (!lbuf) return; if (!lbuf) return;
int8_t bpp = renderer->disp_bpp;
uint8_t *lbp; uint8_t *lbp;
uint8_t fileHeader[fileHeaderSize]; uint8_t fileHeader[fileHeaderSize];
createBitmapFileHeader(Settings.display_height , Settings.display_width , fileHeader); createBitmapFileHeader(Settings.display_height , Settings.display_width , fileHeader);
@ -6500,9 +6505,42 @@ char buff[512];
uint8_t infoHeader[infoHeaderSize]; uint8_t infoHeader[infoHeaderSize];
createBitmapInfoHeader(Settings.display_height, Settings.display_width, infoHeader ); createBitmapInfoHeader(Settings.display_height, Settings.display_width, infoHeader );
Webserver->client().write((uint8_t *)infoHeader, infoHeaderSize); Webserver->client().write((uint8_t *)infoHeader, infoHeaderSize);
if (bpp == -1) {
for (uint32_t lins = Settings.display_height - 1; lins >= 0 ; lins--) {
lbp = lbuf;
for (uint32_t cols = 0; cols < Settings.display_width; cols ++) {
uint8_t pixel = 0;
if (bp[cols + (lins / 8) * Settings.display_width] & (1 << (lins & 7))) {
pixel = 0xff;
}
*lbp++ = pixel;
*lbp++ = pixel;
*lbp++ = pixel;
}
Webserver->client().write((const char*)lbuf, Settings.display_width * 3);
}
} else {
for (uint32_t lins = 0; lins<Settings.display_height; lins++) { for (uint32_t lins = 0; lins<Settings.display_height; lins++) {
lbp = lbuf + (Settings.display_width * 3); lbp = lbuf + (Settings.display_width * 3);
for (uint32_t cols = 0; cols<Settings.display_width; cols += 8) { if (bpp == 4) {
for (uint32_t cols = 0; cols < Settings.display_width; cols += 2) {
uint8_t pixel;
for (uint32_t cnt = 0; cnt <= 1; cnt++) {
if (cnt & 1) {
pixel = *bp >> 4;
} else {
pixel = *bp & 0xf;
}
pixel *= 15;
*--lbp = pixel;
*--lbp = pixel;
*--lbp = pixel;
}
bp++;
}
} else {
for (uint32_t cols = 0; cols < Settings.display_width; cols += 8) {
uint8_t bits = 0x80; uint8_t bits = 0x80;
while (bits) { while (bits) {
if (!((*bp) & bits)) { if (!((*bp) & bits)) {
@ -6518,6 +6556,8 @@ char buff[512];
} }
bp++; bp++;
} }
}
}
Webserver->client().write((const char*)lbuf, Settings.display_width * 3); Webserver->client().write((const char*)lbuf, Settings.display_width * 3);
} }
if (lbuf) free(lbuf); if (lbuf) free(lbuf);

View File

@ -67,6 +67,11 @@ void EpdInitDriver47(void) {
bg_color = EPD47_WHITE; bg_color = EPD47_WHITE;
color_type = COLOR_COLOR; color_type = COLOR_COLOR;
#ifdef USE_TOUCH_BUTTONS
// start digitizer
EPD47_Touch_Init();
#endif // USE_TOUCH_BUTTONS
epd47_init_done = true; epd47_init_done = true;
AddLog(LOG_LEVEL_INFO, PSTR("DSP: E-Paper 4.7")); AddLog(LOG_LEVEL_INFO, PSTR("DSP: E-Paper 4.7"));
} }
@ -75,6 +80,198 @@ void EpdInitDriver47(void) {
/*********************************************************************************************/ /*********************************************************************************************/
#ifdef USE_TOUCH_BUTTONS
#define TOUCH_SLAVE_ADDRESS 0x5a
class TouchClass {
typedef struct {
uint8_t id;
uint8_t state;
uint16_t x;
uint16_t y;
} TouchData_t;
public:
bool begin(TwoWire &port = Wire, uint8_t addr = TOUCH_SLAVE_ADDRESS);
uint8_t scanPoint();
void getPoint(int16_t &x, int16_t &y, uint8_t index);
// void sleep(void);
// void wakeup(void);
TouchData_t data[5];
private:
void clearFlags(void);
void readBytes(uint8_t *data, uint8_t nbytes);
uint8_t _address;
bool initialization = false;
TwoWire *_i2cPort;
};
void TouchClass::readBytes(uint8_t *data, uint8_t nbytes) {
_i2cPort->beginTransmission(_address); // Initialize the Tx buffer
_i2cPort->write(data, 2); // Put data in Tx buffer
if (0 != _i2cPort->endTransmission()) {
Serial.println("readBytes error!");
}
uint8_t i = 0;
_i2cPort->requestFrom(_address, nbytes); // Read bytes from slave register address
while (_i2cPort->available()) {
data[i++] = _i2cPort->read();
}
}
void TouchClass::clearFlags(void) {
uint8_t buf[3] = {0xD0, 0X00, 0XAB};
_i2cPort->beginTransmission(_address);
_i2cPort->write(buf, 3);
_i2cPort->endTransmission();
}
bool TouchClass::begin(TwoWire &port, uint8_t addr) {
_i2cPort = &port;
_address = addr;
_i2cPort->beginTransmission(_address);
if (0 == _i2cPort->endTransmission()) {
// wakeup();
return true;
}
return false;
}
uint8_t TouchClass::scanPoint() {
uint8_t point = 0;
uint8_t buffer[40] = {0};
uint32_t sumL = 0, sumH = 0;
buffer[0] = 0xD0;
buffer[1] = 0x00;
readBytes(buffer, 7);
if (buffer[0] == 0xAB) {
clearFlags();
return 0;
}
point = buffer[5] & 0xF;
if (point == 1) {
buffer[5] = 0xD0;
buffer[6] = 0x07;
readBytes( &buffer[5], 2);
sumL = buffer[5] << 8 | buffer [6];
} else if (point > 1) {
buffer[5] = 0xD0;
buffer[6] = 0x07;
readBytes( &buffer[5], 5 * (point - 1) + 3);
sumL = buffer[5 * point + 1] << 8 | buffer[5 * point + 2];
}
clearFlags();
for (int i = 0 ; i < 5 * point; ++i) {
sumH += buffer[i];
}
if (sumH != sumL) {
point = 0;
}
if (point) {
uint8_t offset;
for (int i = 0; i < point; ++i) {
if (i == 0) {
offset = 0;
} else {
offset = 4;
}
data[i].id = (buffer[i * 5 + offset] >> 4) & 0x0F;
data[i].state = buffer[i * 5 + offset] & 0x0F;
if (data[i].state == 0x06) {
data[i].state = 0x07;
} else {
data[i].state = 0x06;
}
data[i].y = (uint16_t)((buffer[i * 5 + 1 + offset] << 4) | ((buffer[i * 5 + 3 + offset] >> 4) & 0x0F));
data[i].x = (uint16_t)((buffer[i * 5 + 2 + offset] << 4) | (buffer[i * 5 + 3 + offset] & 0x0F));
}
} else {
point = 1;
data[0].id = (buffer[0] >> 4) & 0x0F;
data[0].state = 0x06;
data[0].y = (uint16_t)((buffer[0 * 5 + 1] << 4) | ((buffer[0 * 5 + 3] >> 4) & 0x0F));
data[0].x = (uint16_t)((buffer[0 * 5 + 2] << 4) | (buffer[0 * 5 + 3] & 0x0F));
}
// Serial.printf("X:%d Y:%d\n", data[0].x, data[0].y);
return point;
}
void TouchClass::getPoint(int16_t &x, int16_t &y, uint8_t index) {
if (index >= 4)return;
x = data[index].x;
y = data[index].y;
}
//if (touch.scanPoint()) {
// touch.getPoint(x, y, 0);
#define EPD47_address 0x5A
TouchClass *EPD47_touchp;
void EPD47_Touch_Init(void) {
FT5206_found = false;
EPD47_touchp = new TouchClass();
if (EPD47_touchp->begin(Wire, EPD47_address)) {
I2cSetActiveFound(EPD47_address, "EPD47");
FT5206_found = true;
}
}
uint8_t EPD47_ctouch_counter = 0;
// no rotation support
void EPD47_RotConvert(int16_t *x, int16_t *y) {
int16_t temp;
if (renderer) {
uint8_t rot=renderer->getRotation();
switch (rot) {
case 0:
break;
case 1:
temp=*y;
*y=renderer->height()-*x;
*x=temp;
break;
case 2:
*x=renderer->width()-*x;
*y=renderer->height()-*y;
break;
case 3:
temp=*y;
*y=*x;
*x=renderer->width()-temp;
break;
}
}
}
// check digitizer hit
void EPD47_CheckTouch(void) {
EPD47_ctouch_counter++;
if (2 == EPD47_ctouch_counter) {
// every 100 ms should be enough
EPD47_ctouch_counter = 0;
touched = EPD47_touchp->scanPoint();
if (touched) {
EPD47_touchp->getPoint(touch_xp, touch_yp, 0);
EPD47_RotConvert(&touch_xp, &touch_yp);
}
//Touch_Check(EPD47_RotConvert);
}
}
#endif // USE_TOUCH_BUTTONS
/*********************************************************************************************\ /*********************************************************************************************\
* Interface * Interface
\*********************************************************************************************/ \*********************************************************************************************/
@ -91,6 +288,13 @@ bool Xdsp16(uint8_t function)
case FUNC_DISPLAY_MODEL: case FUNC_DISPLAY_MODEL:
result = true; result = true;
break; break;
#ifdef USE_TOUCH_BUTTONS
case FUNC_DISPLAY_EVERY_50_MSECOND:
if (FT5206_found) {
EPD47_CheckTouch();
}
break;
#endif // USE_TOUCH_BUTTONS
} }
} }
return result; return result;