Close
0%
0%

Raspberry Pi Wall Panel

A wall panel style case for a Raspberry Pi including presence sensing and touch input

Similar projects worth following

After finally setting up Homeassistant, I figured I needed a wall terminal, but couldn't really find what I wanted as an off the shelf product. So I created this...

Key features are:

  • Modern but neutral design
  • Easy 3D printing and able to be finished to look like a home appliance
  • Presence sensing to automatically turn screen on and off
  • Support for a camera for video conferencing
  • Touch sensors for input in addition to touch screen
  • Support for PoE for permanent wiring (still in progress)

There are still some elements in progress, but the 3D files are now available in the Github link below

View all 10 components

  • Autostart, Labwc, project completion*, and what's next

    Tobias11/09/2024 at 05:12 0 comments

    Huzzah! I've finally worked out how to start all of the browser window I want, and have them automatically placed in different workspaces. If you've seen the previous logs you'll have seen how you can then tab through the different workspaces using the touch sensors to show all the different apps or HomeAssistant dashboards.

    This took a huge amount of banging my head against the Wayfire (the window manager) documentation, and I'm honestly still not sure what an app_id or a window "title" is... But, it works! Huzzah!

    You can see all of the instructions in the readme in the GitHub repo here: https://github.com/tsnoad/rpi_wall_case

    But then Hackaday put out this article about how Raspberry Pi OS has now abandoned Wayfire and has moved to something called Labwc for window management: RASPBERRY PI OS’S WAYLAND TRANSITION COMPLETED WITH SWITCH TO LABWC

    So yeah, there are a bunch of questions I don't have the answer to:

    • From what version will Labwc be the default? No idea, the announcement is completely vague
    • If I apt-upgrade will Labwc be set as the default? No idea
    • Is there any documentation for Labwc? Ha, no

    So at some point the autostart script will stop working, so I guess I'll find out when that happens. This will likely affect the autostart settings that automatically open the defined browser windows, as well as the way the touch sensors are used to change workspace. I don't believe it will affect the presence sensor and the automatic backlight dimming (but who really knows...)

    There isn't really any good documentation for Labwc, so I don't have any plans to update the script to use it, at least until this thing on my wall breaks, and I'm forced to do something about it. Sigh...

    Anyway, setting all of that crap aside, this project is now pretty much complete. There are a few things that I still want to do, specifically:

    • Reprint the case now that I've solved the z-wobble on my 3d printer
    • Redesign the case so that a light sensor can be included, as well as making the sensor brackets more modular. This might include a mounting position for a microphone board that could be used by Rhasspy or other voice assistants
    • Redesign how the face is mounted. I'm not a huge fan of how the screws are visible on the front, and I really don't like the bed texture on the front of the faceplate. I do want to redesign it to be attached with magnets which could solve both of these issues

    But, I don't have a timeframe for any of that, and I wouldn't expect it anytime soon.

    So with that said, thanks everyone for the views and likes. If anyone has printed their own version of this, I'd love to see it, and until next we meet, have a good one!

  • Button inputs, Wayfire, autostart, and what's next

    Tobias10/18/2024 at 09:15 0 comments

    After leaving the front panel buttons unimplemented for a while, a really helpful comment from @ryan-worrell got me thinking about how they could be set up. The way I decided to go was to use the buttons to switch back and forth between a few different browser-based apps. In my case this was Homeassistant, and Klipper for my 3D printer. Here's what it looks like in action:

    And while we're looking at animations, here's what it looks like when the presence sensor detects that I've walked away, and slowly turns of the screen backlight:

    Instead of reading the touch sensor buttons in a Python script, it was easier to use a dti_overlay to tell the RPi to treat the GPIO input like a keyboard press - so that when the sensor is pressed, it is just like pressing the KEY_NEXTSONG key on a keyboard. The next step was configuring Wayfire to know that it should switch workspaces when this key is pressed.

    Another really important feature I wanted is for all of my desired apps/browsers/windows to open automatically when the RPi boots up. Ideally this would also include the apps being set up in the right workspace, but so far that has proved challenging, and something I'm still working on.

    So, how is all of this set up? I've added all of the steps to the README on the GitHub page, which you can find here: https://github.com/tsnoad/rpi_wall_case

    So, what's next? To be honest, I'm really not happy with how the front panel looks when it's 3D printed, mainly because of the printer bed texture. At some point I want to redesign the 3D files, which could also include adding a ambient light sensor, but don't expect this soon. With the exception of getting the autostart script to put the windows where I want them, this project is pretty much complete.

    Finally, @ryan-worrell asked how the presence and touch sensors are wired to the GPIO pins, and unfortunately this isn't really something I've documented yet. Here's a (not very useful) picture of the wiring, as well as a (hopefully more useful) table of the pin connections:

    RPi 4 GPIO Pin #Pin DescConnected to
    13.3VVCC pin of LD2410C-P presence sensor
    3GPIO 2Not used
    5GPIO 3Not used
    7GPIO 4OUT pin of LD2410C-P presence sensor
    9GNDGND pin of LD2410C-P presence sensor
    11GPIO 17Not used
    13GPIO 27Not used
    15GPIO 22Not used
    173.3VVCC pin of both TP223 touch sensors
    19GPIO 10I/O pin of right TP223 touch sensor
    21GPIO 9I/O pin of left TP223 touch sensor
    23GPIO 11Not used
    25GNDGND pin of both TP223 touch sensors

  • Presence Sensing

    Tobias09/23/2024 at 07:17 0 comments

    Presence sensing was always a key feature for this project, with the goal to have the screen turn on when someone approaches, and then automatically turn off when not in use.

    Thankfully the presence sensing is really easy to achieve using an LD2410C-P sensor. As far as I understand it, this awesome sensor uses radar to essentially measure the amount water it can see, meaning that it's not affected by motion, sunlight, etc, and only triggers when a big sack of water is standing in front of it - ie a human being. The best part is that it outputs a simple low/high IO signal based on presence being detected. So far, the sensor has worked fantastically and flawlessly.

    The sensor is mounted behind the faceplate which doesn't seem to change the way it performs at all. The datasheet has more information about radomes, but 0.4mm of PLA seems to work fine.


    The biggest challenge was getting the screen to turn off and on. I'll blame a lot of this on the change from X to Wayland in RPi OS, but I've found that almost any internet article or forum post before 2023 no longer applies (and yes, I understand the security reason for the change). I think this is just something that will just improve over time.

    Anyway, after a lot of trying and failing with Xrandr, WL-randr and DDCUtil, I found the correct version of Waveshare's RPi-USB-Brightness library. Unfortunately it seems to be completely closed source, but from what I understand it controls the backlight by serial communication over the USB port, and so far it works adequately. The alternative is to solder a wire to the screen's backlight PWM port, and then send a PWM signal from the RPi.

    So, to bring it all together, I created a Python script to read the GPIO pin, and turn the screen off and on as necessary with a nice fade-in effect. You can view and download this script from the Github repo here: https://github.com/tsnoad/rpi_wall_case/blob/main/kiosk.py. This script will also be used to read input from the touch-sensitive buttons, but this isn't implemented yet, partially because I don't know if the buttons will actually be useful.

    At present the script has to be run manually after startup (so does the browser that points to Homeassistant). At some point I will set this up as a daemon, but at the moment I just have it set up as a RPi OS menu item so that a keyboard is not needed.


    That's all for now, but still on the to-do list are:

    • Project log about getting Power over Ethernet working
    • Project log about painting, sanding and finishing the case

  • The RT9460, RPi PoE, and a slow descent into madness...

    Tobias09/02/2024 at 07:17 0 comments

    So, while the procrastinator in me was happy to have a USB cable running up the wall, the perfectionist in me could only stand that for a couple of weeks. Thankfully it's fairly easy to run a cable through my walls, and at first I had a 4 meter cable running to a 5 volt power supply. Of course, it didn't take long to find out just how much resistance there is in 22AWG cable at low voltage.

    The plan was always to switch to PoE, and in my inveterate browsing of Aliexpress, I came across the RT9400/RT9460 PoE module. The official RPi PoE module might be a better option, but the RT9460 has the advantage of fitting into my tight space constraints, and it's nice that it's a fair bit cheaper. I've also seen people using the common DC-DC modules to power a Raspberry Pi, and at the end of the day this really is just a DC-DC converter. It does, however, have an isolation transformer, and it's designed to operate at 48V, which I think is on the high end for most of the cheap DC-DC converter modules.

    The real problem is that there isn't any good information on how to use it to power a Raspberry Pi. Adafruit sell a PoE module with a different part number, but which looks the same and has the same pinout, but I had absolutely no luck trying their suggested wiring.

    So, with all of that said, I'll show you how I wired a RT9460 PoE module to supply power to my Raspberry Pi. But first, an important note: I'm using a RPi 4, and I can't tell you if these instructions will also work for an RPi 3, 5, or anything else (oh, and in case it needs saying, I can't guarantee that if you try this you won't set fire to your RPi, workbench, ethernet cable, fingers, house, or anything else - playing with cheap Aliexpress electronics can be a dangerous game).

    First we must ask... what is the PoE connector? Essentially it's a direct connection to the ethernet pins in the RJ45 jack. More accurately, it's a direct connection to the centre taps of the coupling transformers for each ethernet pair, which is good, cause that's what we need to the power from the power over ethernet.

    So now we just need to work out which pins are which on the Raspberry Pi 4 PoE header. A quick bit of poking with a multimeter let me work out which PoE header pin corresponded to which ethernet pins:

    My PoE switch provides +48V DC on pins 4&5, and negative on pins 7&8, which according to wikipedia is Mode B PoE. A bit more poking with the multimeter (watch out for arcs at this voltage!) confirms the pinout which, is nice.

    Now we just need to hook up the RT9460 PoE module, but here we run into the next challenge. The data sheet for the RT9460 is clear about which ethernet pin needs to be connected to which RT9460 pin, but then provides wiring diagrams for 100M and 1000M ethernet that have conflicting wiring. Specifically, the data sheet says for 100M, VA1 and VA2 of the RT9460 should be connected to ethernet pins 1,2 respectively. for 1000M, VA1 and VA2 of the RT9460 should be connected to ethernet pins 7,8 and 4,5. So which should we use?

    At this point it's probably worth noting that I don't have any idea how PoE works, and I'm just prodding things until they work. But, according to the data sheet, the RT9460 is not polarity sensitive, in getting this to work I tried just about every combination, and the module didn't fry...

    So, at last we get to the good stuff, an actual wiring guide. Here's what worked:

    • RPi PoE header (ethernet pin 4,5) - to - RT9460 VA1 (pin 1)
    • RPi PoE header (ethernet pin 7,8) - to - RT9460 VA2 (pin 2)
    • RPi PoE header (ethernet pin 1,2) - to - RT9460 VB1 (pin 3)
    • RPi PoE header (ethernet pin 3,6) - to - RT9460 VB2 (pin 4)


    And here's what it looks like in practice. Important not, the color of these wires means nothing - I soldered them on before I double checked the pins (sigh):

    And here's the overall view:

    Thanks for coming along on this alarmingly long journey, and leave you with some last notes:

    • breadboard hookup jumper wires worked great for the 48V input...
    Read more »

  • Assembly and Todo

    Tobias07/22/2024 at 15:31 0 comments

    Here's a quick animation of how all the components fit together.


    There are still a few items to do:

    • clearance on the mounting bosses for the wall need to be adjusted
    • Need to design a mount for a PoE board (still waiting for parts to arrive)
    • Need to clean up and comment OpenSCAD file
    • Need to complete Python script that deals with the presence and touch sensors
    • Need to work out how daemons work in Rasbian Bookworm (yeah, I know why it's important, but at this stage I'm really starting to hate Wayland...)

View all 5 project logs

Enjoy this project?

Share

Discussions

Tobias wrote 10/14/2024 at 06:27 point

Oh no, you're definitely going to send me down an ADHD-fueled rabbit hole researching open-source voice assistants...

Re the camera, I would definitely encourage you to alter the design to make it compatible with a V3 camera. You might have figured this out already, but all you would need to adjust is the camera_co module on line 946 of the scad file. If you're so inclined you could also add something like camera_v3_co() and send a pull request in GitHub and. I should also take a moment and apologise for my spaghetti code - it really needs a good refactoring.

Re wiring the sensors, I would like to post a bit more detail at some point, but really it's incredibly easy: both the touch and presence sensors just need 3.3V and ground, and then then the sensor outputs (which are just digital low/high signals) go to one of the RPi GPIO pins.

You're right that I haven't implemented the touch sensors which the python script looks for on pin 19. I worked out how to use a dti_overlay to get the GPIO inputs to behave as a keyboard input, and then use Wayland to switch workspace on that keyboard press. I'll post this as soon as I can

Thanks again, and good luck!

  Are you sure? yes | no

Ryan Worrell wrote 09/26/2024 at 12:35 point

Awesome project! What is the cutout at the top for? RPi camera for video calling? 

I'm not sure what is the best solution for video calling on the Pis but it would be really neat if you could call from one room to another room like an intercom but with optional video support. If there was a way to keep it fully local/offline that would be when better. Maybe a touch sensor could pop up a menu list of rooms to ring? 

Another potential use for a touch button could be scrolling through a pre-set list of Lovelace HA dashboards. 

Have you considered making these also function as voice assistants in HA? It would need something like a ReSpeaker for audio and far field mics but it would run great on the Pi already there.

  Are you sure? yes | no

Tobias wrote 10/01/2024 at 00:27 point

Hi Ryan, thanks for the comment! You're absolutely right, the top cutout is for a camera. The case is designed to fit one of the Raspberry Pi V2 camera modules. When I designed the case I though videoconferencing would be nice add-on, but to be honest it's mainly there because I already had a camera, and if I didn't put it in I would totally just lose it.

Re video calling, I have been able to get WhatsApp running in LineageOS, but it was a bit of a painful process. If I ever use the camera it will probably be with Zoom or Skype and in the browser.

The biggest pain is that the 3.5mm jack doesn't have audio in, and I gave up trying to get any of my USB audio adapters to work. I'm sure it's a solvable problem, but it's one that would affect a voice assistant device as well. I think voice assistant devices (and video calling hardware) have a lot of engineering in their microphone setup, so I suspect if I tried to do this the audio quality would just be terrible.

Great suggestion on the buttons, and after a bit of digging I think I've found a way to do this in Bookworm/Wayfire without too much pain - hopefully I'll have a post in the next couple of days. Thanks again!

  Are you sure? yes | no

Ryan Worrell wrote 10/01/2024 at 14:49 point

Hey Tobias. Thanks for you reply and thanks for this project! I've struggled with sluggish wall tablets for years and I think this approach is great and I've started building one of these myself. That makes sense on the camera and explains why my v3 modules would not fit haha.  I will try and design an alternate mounting bracket for v3. And you are absolutely right regarding the audio in/out. The soundcard on the Pi alone is not suitable for a voice assistant. The overall design would have to incorporate something like a "ReSpeaker 2-Mics Pi HAT" or similar which includes far field microphones that many like myself use for Rhasspy satellites. I have one of these and the matching speaker laying around. I will put some thought into possible ways to remix the current design to maybe include them without changing too much. Do you have any more photos or details available on how you wired in the radar and touch sensors? I noticed you are using GPIO 7 and 19 in your scripts, I am guessing the second touch button maybe just isn't implemented or mentioned in the code just yet? Also, just wanted to note that the GeeekPi PoE HAT fits pretty much perfectly in your standard Mk2 frame. Thanks again for your work and sharing this project. I look forward to your next post!

  Are you sure? yes | no

Similar Projects

Does this project spark your interest?

Become a member to follow this project and never miss any updates