I am deploying a couple of Pis running Screenly OSE connected to normal LCD flat TVs used as monitors via their HDMI inputs. The displayed content is needed only during the working hours, (it is a social project in a community building I do for free), and I need to turn off the TVs when not used to save electric power for the hosting organization, the Pis can remain on and online the whole time.
My first idea is to cut-off the power to the TV set via a relay board that is connected to the Pi’s io ports.
I have made several such iot gadgets already, I use MQTT for the remote control, no problem with this part…
The problem is that no TV I know of ‘autoboot’ after reconnected to the power line, they need a separate turn-on signal sent from their remotes. This a problem also when an accidental power outage causes the TV to turn off, even after the power is restored, the TV needs to be turned on manually. In new models there is also a dead-man’s function that would automatically turn-off the TV after x hours of operation of not overruled manually, I hope this could be disabled (?)
Sending a ‘turn-on’ IR signal to the TV with my add-on board is an option, and it could also regularly reselect the HDMI input source on the TV set for being safe. (i could stick small plastic cover with an IR led inside on the TV’s IR sensor directly, this would also serve as blocking any outside IR signal of somebody messing with a remote), but the whole thing is getting too much complicated and my main concern is that how could I make this not depending on a particular TV model and manufacturer.
Do you guys have any advice how it could be done reliably, professionally?
I managed to find an easy solution using HDMI CEC signaling, luckily the Raspberry has the hardware for it already, and almost all modern TV sets also have CEC interface in their HDMI inputs.
Hi @matrix - glad you found a solution. Yes, we have some documentation for that here.
Your approach with CEC is probably the best approach for consumer grade monitors. Commercial monitors usually provide an RS232 interface for controlling the monitor. This is however rare in consumer grade monitors.
Do however note that if the power is off on the monitor when the Raspberry Pi reboots/boots, it will likely detect the wrong resolution.
Hi @vpetersson - I was able to setup a crontab to turn on and off my monitors. I have three screenly instances running and they are all supposed turn on and off at the same time, however, some days that is not the case. Two may fire up and one doesn’t. Sometimes one and two don’t. What do you think could be the reason for this?
@vpetersson - Also, I’m using balena.io to serve my deployment. Currently I had to individually add the cronjob onto each device. Is there a way I can add the cronjob into my build, so any future device I deploy from Balena.io will have the cronjob?
Cronjobs is not something that belongs in a Docker container (as it isn’t compatible with the dockerized world). As of the recent versions, we have introduced Celery, which is a worker. The proper way to implement this would be to add a Celery task that turns on/off the monitors.
Most of the Celery work in Screenly OSE can be found in this PR.
(tl;dr in a dockerized workload, you only run one process per container. Cron is designed for a traditional system. The “modern” way to replace Cron is to use a pub/sub-style system where you schedule a task (e.g. turn tv off) from a web interface or a timer and a “worker” picks up on this and issues the actual command)
Hi, I’m just getting back on this - I’m still new to Docker, please could you show me how to how to use Celery in setting up the task of turning on and off the TVs.