-
Notifications
You must be signed in to change notification settings - Fork 203
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Draft support for M5PaperS3 #392
base: main
Are you sure you want to change the base?
Conversation
Looks very good for me. There can be always ghost here and there specially if the gray matrix (waveform) is not the one for this display. But even if it's the good one sometimes making multiple partial refreshes leaves some ghosting. |
This looks more like a slightly wrong VCOM value rather than waveform. Do they change if you turn them up or down a bit? |
I also see that poweron / off only drives display lines, do they just control the power through these control lines or is the display always powered? |
Thank you for the response. Not sure what you mean by "turn them up or down". If you meant the position of text on the screen, I wrote a simple code to test it, and I don't see any difference regardless of how I set const EpdFont* font = &FiraSans_20;
char text[64];
epd_init(&epd_board_m5papers3, &ED047TC2, EPD_LUT_64K);
epd_hl = epd_hl_init(EPD_BUILTIN_WAVEFORM);
epd_set_rotation(EPD_ROT_LANDSCAPE);
uint8_t* fb = epd_hl_get_framebuffer(&epd_hl);
int temperature = 21;
epd_poweron();
epd_clear();
vTaskDelay(500 / portTICK_PERIOD_MS);
epd_clear();
epd_poweroff();
int start_x = 20;
int start_y = 20;
// draw a line along the text
epd_draw_vline(start_x, start_y, 100, 0x00, fb);
int font_cursor_x = start_x + 50;
int font_cursor_y = start_y + 50;
EpdFontProperties font_props = epd_font_properties_default();
font_props.flags = EPD_DRAW_ALIGN_LEFT;
sprintf(text, "Testing 1 2 3 ... x: %d, y: %d", start_x, start_y);
epd_write_string(font, text, &font_cursor_x, &font_cursor_y, fb, &font_props);
epd_poweron();
checkError(epd_hl_update_screen(&epd_hl, MODE_GC16, temperature));
epd_poweroff(); If you meant to change the VCOM up and down - I'm not sure it is possible with this board. It is sealed and I can't get inside. And M5 did not implement setting vcom in their software. But maybe there is something possible based on the schematics ?
I'm not sure if I get the schematics right, but it seems the lines are drawn separately. The gpio_set_level(EPD_EN, 1);
vTaskDelay(1 / portTICK_PERIOD_MS);
gpio_set_level(BST_EN, 1);
vTaskDelay(1 / portTICK_PERIOD_MS);
gpio_set_level(EPD_SPV, 1);
gpio_set_level(EPD_SPV, 1); Oh, wait, my typo, there shouldn't be twice For some reason though, in gpio_set_level(BST_EN,0);
vTaskDelay(1 / portTICK_PERIOD_MS);
gpio_set_level(EPD_EN,0);
vTaskDelay(1 / portTICK_PERIOD_MS);
gpio_set_level(EPD_SPV,0); Please let me know if I can try anything else. |
Hello @jslawek ./src/board/epd_board_m5papers3.c:133:26: error: code should be clang-formatted [-Wclang-format-violations] I really don't have a clue why is like this but sadly don't want also to collect more Eink devices. Soon if my new board "v7 raw" works I will finally have a PCB to test this same display. |
OK @martinberlin, done, by the way fixed a typo and uncommented poweroff to the |
Hi guys I measure about -2.2 V on Thanks |
Thanks for the report @felmue. |
Hello @jslawek sorry, I need some additional info to build successfully. Using the latest ESP-IDF (e.g. v5.4) I get an error building examples/demo for target esp32s3.
Below are my steps:
Thanks |
Hi @felmue,
thanks for trying. |
Hello @jslawek I managed to build and run your code with an earlier esp-idf version (release/v4.4) and I can confirm that I get the same result on my M5PaperS3 as you posted. So I guess there is nothing wrong with your device. Thanks |
Good to know about the IDF issue. I hope I can look into it on the weekend! |
Is really annoying that the Espressif team has to change on every little upgrade from version 5 the LCD and RMT functions. At the end the code will need to have a lof of if def preprocessor conditionals on those peripherals |
I started working on a fix #401 , but for some reason I still get compile failures in CI that I don't get locally... it's strange. I'll need to continue another time :) |
Hi,
M5Stack has just released M5PaperS3: https://shop.m5stack.com/products/m5papers3-esp32s3-development-kit. Schematics: https://m5stack.oss-cn-shenzhen.aliyuncs.com/resource/docs/products/core/PaperS3/sch_papers3_V1.0.pdf.
It is based on ED047TC2 directly wired to ESP32S3.
I created a new board definition based on their implementation (M5GFX): https://github.com/m5stack/M5GFX/blob/master/src/M5GFX.cpp.
It works for me, but there are "ghost" afterimages - as visible in the "demo" example application below:
data:image/s3,"s3://crabby-images/e9a42/e9a4215304763dc68ca61647960142466bd06db0" alt="ghost_demo"
Please let me know if I can try anything to fix it.