Also these 7" displays will work.
What I’m about to say shows just how little experience I have working with this kind of project. I never even thought about the idea of using another board as a display driver. I’ve done work with Pis before and never needed a display driver, since everything I found was all in a box and easily connectable to a Pi.
I’ve been looking at doing this with ESPHome, since I know I can make ESPHome work on its own and easily integrate it with Home Assistant. I’ve considered using a Pi, but I can’t get clear answers on running something on a Pi that connects with ESPHome devices (other than through REST APIs) and with Home Assistant. (I know you can run Home Assistant as a hub on a Pi, but I’m having trouble getting answers about running a “device” that would be controlled by Home Assistant and, as you can tell how easy it was for people here to find things I didn’t find, my Google-fu doesn’t always do well.)
So I’ve been looking at this from two angles: Use ESPHome and get the connectivity I need easily, but then have to work out what to do for a display, or use a Pi with a display and work out what to do for connectivity to my ESPHome devices and Home Assistant system. It looks like, if I go with ESPHome, I need a special board (like the Waveshare) or some kind of display adaptor, but if I do that, it opens up some good possibilities.
Why are you didn’t talking about Pi’s? No one suggested that.
I’m saying that this is one route I’m looking at to do what I want (using an ESP32), but that I’m also considering another route, using a Pi. I wasn’t going to mention the Pi possibility, but since so many displays are designed for the Pi, I figured it might be relevant. Also, I’ve found that sometimes when I bring up something like that (another possible solution), people with more experience sometimes tell me, “Oh, that’d be much easier.”
Ok I thought you might be confused by suggestions of pi compatible screens.
It really depends what you want to do. Esphome is tightly linked to HA.
Yes, and this is one of those things that, if I had a lot more experience working with ESPHome, HA, and displays, I’m sure I could have made a decision by now. I have a lot of data to sort through. Basically I want to make a sign. In my case, for a limited use, but I hate design or programming something for one use, when, with more info, I could make it work for other things, too.
I think a lot of the config will be easier with ESPHome, and I know ESPHome devices can communicate without HA. (That’s critical, since 1-2 times a year I updated HA and the update breaks something that can take 2-5 days to fix. That’s not acceptable for what I’m working on now: It has to work if HA is down. But if I could also communicate with HA, that would open up a lot of options for other uses.
So it boils down to using ESPHome and solving the display issue or using a Pi and solving the communications issue - and solving it in a way that does not require massive config work on each new display I make.
I’d give esphome a try if I were you. What are you hoping to show on the sign?
Mainly simple text messages, like, “CNC in use, do not enter without safety goggles,” or, “Laser in use. Wear orange safety goggles.” But if it would be possible to include some graphic screens to throw up on the display, that would be cool. It’s not dynamic text, like a crawl or a news ticker or anything like that.
Okay, after looking things over more, I think the thread linked to above (Esphome Stream Deck Replacement) looks like a good option. It’s an all-in-one device, except for a case, and I was figuring on having to print a case anyway. The link to it on Ali Express is also provided. (Interesting that Ali Express can apparently get it to me, from overseas) 1-2 weeks faster than Amazon - if their shipping estimate is correct. (I’ve ordered from them before and, after the order, the shipping date was suddenly 2-3 weeks later than in the item listing.)
I’m trying to absorb a lot of information on this project. I am getting a bit confused - mainly in trying to keep straight what display or project had what features or problems.
So he’s running ESPHome on this setup, which is good. That means there’s a display I can use with an ESP32 and ESPHome, so that solves the display problem.
It’s hard for me to get a feel for something like running a display on an ESP32 without actually doing it - so a few questions, if it’s not to tiresome, before I place my order, so I can be sure I’m getting something that’ll work. (And if it works, I can see getting a few more of these for various uses.)
1 - This is used as a touch screen control system. Is it easy to either disable a touch screen or just not respond to input? (I’m thinking I don’t really need it, but then again, it also might work as a “doorbell,” where, if someone touches it, would activate something to work like a doorbell.)
2 - Just how hard is it to setup and use a display like this? It looks like it’s self-contained in terms of hardware, so it would be an issue of coding and configuration. Is there more involved?
3 - This is working with a specific setup for a control panel. How hard is it to pick the background color and text color and just write some text to the screen?
4 - Is it possible to store images that can be displayed on the screen?
5 - (Close to #4) More of an ESPHome ability than a screen issue, but would it be possible to set a URL to, say, a web server on my LAN, so it could display whatever image is at that URL?
How are you intending to tell it what message to display?
As for the numbered questions
-
Yes you don’t have to configure the touch component at all.
-
The coding will take a bit of patience. Esphome has recently gained the LVGL component which introduces some nice graphics.
-
Easy.
4 and 5. Both possible.
I’m not 100% sure, yet. I’m thinking I’d like to use 2 ways for this to communicate: Through Home Assistant, and using the REST API with other ESPHome devices. I still have to check on what I can do with Home Assistant. I don’t know just how open device configuration is on that.
For the direct ESPHome to ESPHome setup, I was thinking of using a web interface to specify the text message (or an image) to be used when another device is in a specified state. (For instance, if a switch on another ESPHome device is turned on, the message would be, “WEAR SAFETY GOGGLES. (Laser is on.)” If the laser is off, but the system is on, it might ready, “CNC and laser are active.”
For Home Assistant, I don’t know yet if I can do what I want, or how I’d have to modify things, but I’d like to set up an automation so when a specified device is in a specified state, a message is sent to this device and it would display that message on the screen. Again, since I haven’t studied just what I can do with that yet, I don’t know just what I can do with that.
All of this is do-able. If I were you, I would work on one element of this at a time.
I am probably being a bit vague, but when you get down to it, I can point out some components etc.
Exactly!
As I mentioned, often I miss something in Google. (Odd - I spent years having to find really obscure things that could a couple days to track down, but I’m not that good at finding what is obvious to most people.) I realized, from the start, that I’d have to handle a number of elements, and each one would take time to research. I didn’t want to get through, say, 4 out of 7 steps, only to find a dead end and that I’d have to use something else to do the job (like, say, using a Pi instead of ESPHome).
So this is part of my, “Can I do this all on ESPHome and can I do it both without HA, and incorporated with HA?” research. At my speed, checking out all the elements might have taken me the better part of a week before I was sure I could do it that way. So your help has saved me a lot of time.
Now I can focus on ESPHome and do my research there. I already have one ESPHome device on my HA system, to control a vent fan (needed to vent smoke from the laser). But that was a simple PWM system and didn’t need a lot of research to do. Since I know this can be done, I have no problem now diving into ESPHome and finding out just what it can do. I have a sense it’s a pretty powerful little system and I’m looking forward to the next few days of research, starting with configurations and automations.
I’ve also ordered the 7" TFT touch screen I mentioned. It’s on AliExpress, but I found it on Amazon. It’s about $8 more on Amazon, but that includes shipping, so the prices are pretty close, and I get it in 2 days instead of 2 weeks.
So, first, configuration on the control box, then getting that to work with HA (that should be easy). After that, I can work on the sign. I’ll probably work on the display first, then work on the communication with both HA and the control box using ESPHome.
All stuff I’m sure I can do - just didn’t want to spend a long time researching it, only to find one part of it was not doable.
Let’s keep the thread going then. Let us know how you are going.
Will do. This could be a helpful guide when I’m done.
Adding a note - I’ll do this to cover stumbling blocks along the way.
I’ve received the screen, a Waveshare 7" ESP32-S3-Touch-LCD-7 (link is to the Waveshare Wiki). It’s not a bad little screen, with the ESP32-S3 attached. No papers, manual, or any other info with it. A few wires and plugs to use for connecting other devices are included. It’s 800x480 resolution, 65k colors (16 bit color). They’re on AliExpress, but also on Amazon, so, depending on your location, one source may be preferable than the other. Be aware that there is also another small screen version (I think about 3.5"), so be sure, when ordering, that you’re ordering the 7" screen.
I use a Mac for my primary computer. I plugged a USB-C cable from my Mac into the board on the back of the screen and it didn’t boot up immediately. I had to disconnect it and try again and it booted completely on the 2nd time. It needs a driver on the Mac (and, apparently, on Windows and Linux, too). Before I installed the driver, the ESPHome web installer connected to it, but couldn’t install ESPHome. Once I installed the driver, ESPHome installed without immediate issue. If plugging the USB-C cable from your computer into the jack labelled USB doesn’t work, plug it into UART1.
After installing, I tried to set it up to use my wifi. It gave me error messages at first and was sometime after 2 minutes after the install when I could finally setup wifi on it.
Once I reached that point, it was business as usual to get ESPHome running on it.
There is a sample config for this board here; note that this uses UART0 for logging so you should use the UART port, not the USB port. With the board as delivered (factory firmware) the USB port was not usable for flashing. After flashing ESPHome once that port started working.
Are you saying logging is sent through UART1 (well, it’s labeled 1 on the board - I saw UART1 and UART2 and the USB-C, didn’t see a UART0 on the board labels)? So if I want to read logs on a console, I need to use UART1 to read them?
I’d like some clarification with this. I did have a problem communicating with the board when I set it up and found the UART1 worked when the USB connection did not.
The board has two USB-C connectors, labelled “USB” and “UART1”. Within ESPHome these correspond to logger serial ports USB_SERIAL_JTAG
and UART0
respectively.
The ESPHome default for logging on an ESP32-S3 is USB_SERIAL_JTAG
so if you don’t configure a hardware serial port in the logger
config that is what will be used and you will need to be plugged into the “USB” connector to see those logs.
If you set hardware_uart: UART0
then you will be able to read logs from the “UART1” serial connector. This is what is in the sample yaml I linked to.
You can flash the board using either connector, but unless your logger config matches the connector you use, you won’t see any logs past the first few lines that come from the hardware bootloader.
BUT… to complicate matters the board has a multiplexer that can switch the USB signal lines D+ and D- between the “USB” connector, and the CAN bus connector. The power-on default is to switch to the USB connector, but it appears that the factory firmware switches it to the CAN bus, so with the factory firmware loaded the “USB” connector isn’t usable for flashing. Once you have flashed ESPHome the first time, the “USB” connector will operate as expected.
Updating this.
I used @clydebarrow’s work on GitHub, with some modifications to the config file (mainly things like my network ID and password info). I’m used to using the Arduino framework and had to use the Esp-idf framework. I ran into an error/warning message and problems, so I had to comment out platform_version and version for it to work. Once I did that, compiling took 20 minutes, since it downloaded a lot of libraries and had to compile their object code.
Also, I did not make the wiring change for the display light (using GPIO13). That’s for later. Right now I just wanted to see if I could make things work.
It started right up and I got the LVGL startup page, which is a Hello World page with some sample widgets to test out both the display and the touch screen.
So I have a simple display that’s working now.
Next steps:
- Print text to screen (and position it, use fonts and variations like bold or italic)
- Communicate with this ESP32 from Home Assistant and display messages from HA on the screen.
- Use fonts and effects from HA messages for display
- Use images in the display.
- Turn the display on and off.
- Not necessary, but it’d be nice if I could create something like a screensaver, so when warning messages are not displayed on the screen, it might have some kind of moving image or text floating around on it, so it’s not just a dark screen. If I do this, I might want it to do this only for a few hours after it has been in use. (Or it could cycle through images stored on the LAN for it to load and display.)
- Another thought for a feature might be to add a doorbell feature, so if someone is outside the door and sees the warning about goggles, can push a button that chimes in the workshop to let me know someone wants to get in and is waiting for me to turn off the laser.
I don’t know yet if I have to use full screen images or if I can put up some text on the screen and an image as well (and maybe format the text so it goes around the image). I’d like to make it easy to specify, from Home Assistant, all the text and images to use on the screen. One example might be text saying, “Laser in use. Do not enter without safety googles,” then include an image of the goggles or maybe something showing a laser being blocked by safety goggles.
At this point I know almost nothing about what I can do with LVGL or what I can do from Home Assistant to send formatted text. So, if anyone out there is looking for a guide for a newbie on how to set up something like this, by the time I’m done, I should have all the details here.
One thought about images: I do know that they aren’t stored on this device - that it has to read them from a server somewhere. I’m hoping I can store images on my Samba share on the Raspberry Pi I use for Home Assistant. That would keep the images on the HA system (and available if I use it for other HA uses), and not require an extra server somewhere on my LAN.