pi_miniweather/wetter_gui.py
2021-03-20 21:21:09 +01:00

200 lines
5.3 KiB
Python
Executable file

#!/usr/bin/env python3
import random
import time
import busio
import digitalio
import pulseio
from board import SCK, MOSI, MISO, D8, D24, D23, D18
from adafruit_rgb_display import color565
import adafruit_rgb_display.ili9341 as ili9341
#from raspyrfm import *
#import sensors
#from sensors import rawsensor
import sys
import threading
from PIL import Image, ImageDraw, ImageFont, ImageColor
import requests
class TextBox:
def __init__(self, pos, size, max_jitter, color, background, fitting_text):
self.color = color
self.background = background
self.pos = pos
self.bounds = (size[0]+1, size[1]+1)
font_size = 100
while (self.bounds[0] > size[0]-max_jitter) or (self.bounds[1] > size[1]-max_jitter):
font_size-=1
self.font = ImageFont.truetype("/usr/share/fonts/truetype/noto/NotoMono-Regular.ttf", font_size)
self.bounds = self.font.getsize(fitting_text)
self.size = size
self.img = Image.new("RGB", self.bounds)
self.draw = ImageDraw.Draw(self.img)
self.offset = (int((self.size[0]-self.bounds[0])/2), int((self.size[1]-self.bounds[1])/2))
def draw_text(self, display, text, jitter_pos):
self.draw.rectangle((0, 0, self.img.width-1, self.img.height-1), self.background, self.background, 1)
self.draw.text((jitter_pos[0],0), text, font=self.font, fill=self.color)
y=self.pos[0]+self.offset[0]
x=display.width-self.pos[1]-self.size[1]+self.offset[1]
display.image(self.img, x=x, y=y)
###
# CONFIGURATION
###
BAUDRATE = 1000000
DISPLAY_SIZE=(320,240)
CLOCK_FORMAT = "%H:%M"
TEMP_FORMAT = "% 3.1f°C"
BKGND_COLOR=(0,0,0)
LINE_COLOR=(255,255,255)
JITTER=5
DELAY=1
now_parts=time.localtime()
time_str = time.strftime(CLOCK_FORMAT, now_parts)
temp_str = TEMP_FORMAT % -10.0
clock_box=TextBox( (10,10), (300,120), JITTER, (255,255,255), BKGND_COLOR, time_str)
temp_box =TextBox( (120,180), (190,50), JITTER, (255,0,0), BKGND_COLOR, temp_str)
# Configuration for CS and DC pins:
CS_PIN = D8
DC_PIN = D24
RES_PIN = D23
BL_PIN = D18
# Setup SPI bus using hardware SPI:
spi = busio.SPI(clock=SCK, MOSI=MOSI, MISO=MISO)
# Create the ILI9341 display:
display = ili9341.ILI9341(spi,
cs=digitalio.DigitalInOut(CS_PIN),
dc=digitalio.DigitalInOut(DC_PIN),
rst=digitalio.DigitalInOut(RES_PIN),
baudrate=BAUDRATE,
width=DISPLAY_SIZE[1],
height=DISPLAY_SIZE[0],
rotation=270)
#backlight = pulseio.PWMOut(BL_PIN, duty_cycle=NIGHT_BRIGHT)
backlight = digitalio.DigitalInOut(BL_PIN)
backlight.direction = digitalio.Direction.OUTPUT
backlight.value = True
#if raspyrfm_test(5, RFM69):
# print("Found RaspyRFM mod")
# rfm = RaspyRFM(5, RFM69) #when using the RaspyRFM twin
#else:
# print("No RFM69 module found!")
# exit()
#rfm.set_params(
# Freq = 868.30, #MHz center frequency
# Datarate = 17.241, #kbit/s baudrate
# ModulationType = rfm69.FSK, #modulation
# Deviation = 30, #kHz frequency deviation
# SyncPattern = [0x2d, 0xd4], #syncword
# Bandwidth = 150, #kHz bandwidth
# RssiThresh = -105, #dBm RSSI threshold
#)
mean_temp = 0
shutdown = False
def update_temp():
global mean_temp
temps = []
while not shutdown:
data = rfm.receive(12)
if data:
obj = rawsensor.CreateSensor(data).GetData()
if 'ID' in obj and 'T' in obj:
temps.append(float(obj['T'][0]))
if len(temps)>20:
temps = temps[1:]
if temps:
mean_temp = sum(temps) / len(temps)
def fetch_temp(bridge, user, sensor):
r=requests.get(f"http://{bridge}/api/{user}/sensors/{str(sensor)}")
if r:
return r.json()["state"]["temperature"]/100
return None
#temp_thread = threading.Thread(target=update_temp, name="Temp Thread")
#temp_thread.start()
#display.vline(0,clock_box.size[1],1,color565(LINE_COLOR))
def jitter():
return (random.randint(0,JITTER), random.randint(0,JITTER))
# Main loop:
jitter_pos = jitter()
old_time=""
old_temp=""
display.fill(color565(BKGND_COLOR))
try:
while True:
cur_temp = fetch_temp("philips-hue", "GQ03rw1saUS0n88G5yj9j7-TsteFIE1yxtlBOgzD", 71)
if cur_temp:
mean_temp = cur_temp
#display.reset()
#time.sleep(0.5)
now = time.time()
now_parts = time.localtime(now)
time_str = time.strftime(CLOCK_FORMAT, now_parts)
temp_str = TEMP_FORMAT % mean_temp
# display.reset()
display.init()
# display.fill(color565(BKGND_COLOR))
if True: #time_str != old_time:
clock_box.draw_text(display, time_str, jitter_pos)
old_time = time_str
if now_parts.tm_sec == 0:
jitter_pos = jitter()
# if (now_parts.tm_min == 0) and (now_parts.tm_hour > 7 and now_parts.tm_hour < 19):
# backlight.duty_cycle = DAY_BRIGHT
# else:
# backlight.duty_cycle = NIGHT_BRIGHT
if True: #temp_str != old_temp:
time.sleep(0.1)
temp_box.draw_text(display, temp_str, jitter_pos)
old_temp = temp_str
while time.time() - now < DELAY:
time.sleep(0.1*DELAY)
except KeyboardInterrupt:
clock_box.draw_text(display, "off" ,(0,0))
# temp_box.draw_text(display,"",(0,0))
shutdown=True
# temp_thread.join()