My forked version of GeekyTim's PiClock project to help make it more turnkey, add features, and make it more extendable by others.
- The code is pretty well written and is fairly clear to understand. It can get tricky in places, but a few well placed logging statements helped me get over some of my mental hurdles. I liked that the way it was structured actually helped me learn a few things about python as well.
- I think doing this project with threading was a great choice. It helps with the separation of functions and I think will be a potentially good launching off point for considering how to extend this project.
- There were just a few places with hardcoding, but for the most part, the code had clear avenues for customizing via configurable variables.
- Fix some of the problems I had with directly using the code such as removing hardcoded temperature units, and the interesting, but unneeded PIR feature.
- Separate out the parts that require individual configuration such as the Open Weather Map key, the users location, and the preferred units into its own python module. Also have the LED matrix configuration separated out as well. The goal will be for another user to ONLY have to change parameters in a specific configuration module that is separate from the code implementation.
- Simplify the temperature display to just show the current temp instead of the min/max temp.
- Add instructions and help for enabling the display at boot. Optionally add something (code, instructions, etc.) to assist the user in adding a switch for soft Raspberry Pi shutdown.
- Have logging flush to output regularly so someone can monitor the logs while the project is running. Additionally include some checks to manage log file size to prevent overrunning the file system.
- Add the ability to extend the display to include other data pulled from RestAPIs, screen scraping or other types of data. Two examples I'm planning on including:
- A rolling display of ongoing Instructables contests (https://www.instructables.com/contest/)
- A "days until" declaration for events of interest to the user (e.g. "23 days until your birthday" or "4 weeks until Halloween").
- Provide some kind of support for displaying multiple text lines in a given bounding area.
What is below is from GeekyTim's project. I'm just getting started in making modifications and updates.
The PiClock is a weather display made with:
- A Raspberry Pi model 2 B
- Two AdaFruit 64x32 RGB displays (https://makersify.com/collections/leds/products/adafruit-64x32-rgb-led-matrix-3mm-pitch)
- One Adafruit RGB Matrix HAT + RTC (https://makersify.com/products/adafruit-rgb-matrix-hat-rtc-for-raspberry-pi-mini-kit?variant=1054962589)
- A 30A 5V power supply (Model AD0530-150W)
- A small (10mm) PIR
- A custom designed case (laser cut Perspex and 3D printed parts - files supplied)
Software Required:
- Adafruit's RGB Matrix HAT + RTC library (see https://learn.adafruit.com/adafruit-rgb-matrix-plus-real-time-clock-hat-for-raspberry-pi)
Having organised about 18+ Raspberry Jams in the guise of CamJam (http://camjam.me), including two PiWars (http://piwars.org), two birthday parties on behalf of the Raspberry Pi Foundation and a number of Potton Pi and Pints, and having designed and written the worksheets for the three CamJam EduKits (http://camjam.me/EduKit), I decided it was time finally get round to my own project using the Raspberry Pi. Having about 75 of them in the house, being used for my 3D printer server, Audio Amp (IQaudIO - http://www.iqaudio.co.uk/), a Plex media server, numerous robots (inc. Diddyborg Metal Edition - https://www.piborg.org/diddyborg/metaledition), Pimoroni Picade (https://shop.pimoroni.com/products/picade), and PiTop (https://www.pi-top.com/) and the ones beloging to CamJam, I needed to build something for myself!
This clock had been in planning for about a year, but with so much going on with CamJam and the Foundation, I just did not get time to do anything. So I decided to take a break and finish this project. The main reason was for me to learn Python in more depth that I used for the EduKits. And Wow, has it been a good learning experience.
This project has taught me the following Python concepts:
- Tuples
- Dictionaries
- Reading files from the Internet
- Converting JSON into Python lists
- Classes and Methods
- Coding and wine/beer doesn't always mix
- Nor does coding and watching Game of Thrones etc.
- Logging
- Threading
All the above is self taught (as is most of my IT experience!), and as it is my first adventure into Object Orientated Programming (having developed software since the last century!), I have still got lots to learn, including:
- Best Class and Method naming conventions
- Using external files to populate Python dictionaries
- Coding and wine/beer doesn't always mix
- Nor does coding and watching Game of Thrones etc.
I welcome comments on the code, especially improvements to proper Class standards. Please tweet me at @Geeky_Tim or leave a message on GitHub.
If you want to run the code, you need to get the rgbmatrix.so from Adafruit (linked above) and put it in the same directory as PiClock.py. You also need the other files in the images directory.
##What are the Files This repository includes the following files:
- PiClock.py - the clock code
- RunClock.sh - A shell script I uses to start the clock
- StopClock.sh - Used to stop all clock threads The 'images' directory contains images multiple images that I address individually using dictionaries (explained at a later date):
- clockfont.png - All the characters used in the time part of the clock.
- clocktimes8.png - The 3 hour period the weather is being displayed for (to be explained)
- datefont.png - The font used for the date numbers
- DoW.png - The Days of the Week
- months.png - The months of the year
- smallfont.png - A font used in the clock The PiClock Case directory contaus the files I used for creating the case.
- *.svg for the Perspex case
- *.stl for the various 3d printed parts
Eventually I will write up what is happening in the code - this is just the first upload for those interested. It has been written so I can redefine what appears on the clock just be redefining the dictionaries.Much of the code could be used to repurpose the 'clock' to display anything required.
If any magazine (e.g. MagPi) is interested in an article and photos, please contact me! ;-)
This weekend I added in some logging because I wanted to know whether the clock was turning off and when. However, this appears to cause issues to both the PIR and network - the clock appears to disconnet from both. Turning off logging (and currently PIR), I'm able to connect via ssh. More time needed...