2022-10-18 20:38:02 +00:00
|
|
|
#!/usr/bin/python
|
|
|
|
# -*- coding:utf-8 -*-
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
picdir = os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), 'pic')
|
|
|
|
libdir = os.path.join(os.path.dirname(os.path.dirname(os.path.realpath(__file__))), 'lib')
|
|
|
|
if os.path.exists(libdir):
|
|
|
|
sys.path.append(libdir)
|
|
|
|
|
|
|
|
import logging
|
2022-10-19 18:00:22 +00:00
|
|
|
from waveshare_epd import epd2in13b_V3
|
2022-10-18 20:38:02 +00:00
|
|
|
import time
|
|
|
|
from PIL import Image,ImageDraw,ImageFont
|
|
|
|
import traceback
|
|
|
|
from paho.mqtt import client as mqtt_client
|
2022-10-19 06:40:32 +00:00
|
|
|
import paho.mqtt.client as paho
|
2022-10-18 20:38:02 +00:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
|
2022-10-19 14:46:39 +00:00
|
|
|
Connected = False #global variable for the state of the connection
|
|
|
|
|
|
|
|
broker = "192.168.99.224"
|
|
|
|
port = 1883
|
|
|
|
topic_wHouseConsumption = "openWB/global/WHouseConsumption"
|
|
|
|
topic_pvProduction = "openWB/pv/W"
|
|
|
|
topic_energyImportExport = "openWB/evu/W"
|
|
|
|
topic_houseBatterySoC = "openWB/housebattery/%Soc"
|
|
|
|
topic_houseBatteryLoadUnload = "openWB/housebattery/W"
|
|
|
|
|
|
|
|
username = "mqtt-user"
|
|
|
|
pw = "phio6yiR9ohs1veeghu4WaeGhaiRi8he4EiWasheev4faeku8tohdiuthah7zahP"
|
|
|
|
client_id = "solarmonitor"
|
|
|
|
|
2022-10-19 07:21:28 +00:00
|
|
|
try:
|
2022-10-19 18:00:22 +00:00
|
|
|
epd = epd2in13b_V3.EPD()
|
2022-10-19 07:21:28 +00:00
|
|
|
logging.info("init and Clear")
|
2022-10-19 11:19:34 +00:00
|
|
|
epd.init()
|
|
|
|
epd.Clear()
|
2022-10-19 17:41:05 +00:00
|
|
|
time.sleep(1)
|
2022-10-19 07:21:28 +00:00
|
|
|
|
|
|
|
except IOError as e:
|
|
|
|
logging.info(e)
|
|
|
|
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
logging.info("ctrl + c:")
|
2022-10-19 18:00:22 +00:00
|
|
|
epd2in13b_V3.epdconfig.module_exit()
|
2022-10-19 07:21:28 +00:00
|
|
|
exit()
|
|
|
|
|
2022-10-18 21:02:28 +00:00
|
|
|
def on_connect(client, userdata, flags, rc):
|
|
|
|
if rc == 0:
|
|
|
|
print("Connected to MQTT Broker!")
|
2022-10-18 20:38:02 +00:00
|
|
|
|
2022-10-18 21:02:28 +00:00
|
|
|
global Connected #Use global variable
|
|
|
|
Connected = True #Signal connection
|
|
|
|
else:
|
|
|
|
print("Failed to connect, return code %d\n", rc)
|
2022-10-18 20:38:02 +00:00
|
|
|
|
2022-10-18 21:00:28 +00:00
|
|
|
def on_message(client, userdata, msg):
|
2022-10-19 15:49:14 +00:00
|
|
|
global value_pvProduction
|
|
|
|
global value_wHouseConsumption
|
|
|
|
global value_energyImportExport
|
|
|
|
global value_houseBatterySoC
|
|
|
|
global value_houseBatteryLoadUnload
|
2022-10-19 15:40:16 +00:00
|
|
|
|
2022-10-19 08:48:51 +00:00
|
|
|
if msg.topic == "openWB/pv/W":
|
2022-10-19 15:35:43 +00:00
|
|
|
value_pvProduction = ""+msg.payload.decode()
|
2022-10-19 08:48:51 +00:00
|
|
|
elif msg.topic == "openWB/global/WHouseConsumption":
|
2022-10-19 15:35:43 +00:00
|
|
|
value_wHouseConsumption = ""+msg.payload.decode()
|
2022-10-19 08:48:51 +00:00
|
|
|
elif msg.topic == "openWB/evu/W":
|
2022-10-19 15:35:43 +00:00
|
|
|
value_energyImportExport = ""+msg.payload.decode()
|
2022-10-19 08:48:51 +00:00
|
|
|
elif msg.topic == "openWB/housebattery/%Soc":
|
2022-10-19 15:38:02 +00:00
|
|
|
value_houseBatterySoC = ""+msg.payload.decode()
|
2022-10-19 14:41:11 +00:00
|
|
|
elif msg.topic == "openWB/housebattery/W":
|
2022-10-19 15:38:02 +00:00
|
|
|
value_houseBatteryLoadUnload = ""+msg.payload.decode()
|
2022-10-18 21:00:28 +00:00
|
|
|
|
2022-10-19 06:40:32 +00:00
|
|
|
client = mqtt_client.Client(client_id, protocol=paho.MQTTv31)
|
|
|
|
client.username_pw_set(username, password=pw)
|
2022-10-18 21:00:28 +00:00
|
|
|
client.on_connect = on_connect
|
2022-10-19 15:46:36 +00:00
|
|
|
|
2022-10-19 15:54:40 +00:00
|
|
|
value_pvProduction = ""
|
|
|
|
value_wHouseConsumption = ""
|
|
|
|
value_energyImportExport = ""
|
2022-10-19 15:55:33 +00:00
|
|
|
value_houseBatterySoC = ""
|
|
|
|
value_houseBatteryLoadUnload = ""
|
2022-10-19 15:54:40 +00:00
|
|
|
|
2022-10-18 21:00:28 +00:00
|
|
|
client.on_message = on_message
|
2022-10-19 14:44:00 +00:00
|
|
|
|
2022-10-19 06:40:32 +00:00
|
|
|
client.connect(broker, port=port)
|
2022-10-18 20:38:02 +00:00
|
|
|
|
2022-10-18 21:00:28 +00:00
|
|
|
client.loop_start() #start the loop
|
|
|
|
|
|
|
|
while Connected != True: #Wait for connection
|
2022-10-19 06:44:21 +00:00
|
|
|
time.sleep(1)
|
2022-10-18 20:38:02 +00:00
|
|
|
|
2022-10-19 07:07:32 +00:00
|
|
|
client.subscribe(topic_wHouseConsumption)
|
|
|
|
client.subscribe(topic_pvProduction)
|
|
|
|
client.subscribe(topic_energyImportExport)
|
|
|
|
client.subscribe(topic_houseBatterySoC)
|
2022-10-19 07:08:47 +00:00
|
|
|
client.subscribe(topic_houseBatteryLoadUnload)
|
|
|
|
|
2022-10-18 20:38:02 +00:00
|
|
|
|
2022-10-18 21:00:28 +00:00
|
|
|
try:
|
|
|
|
while True:
|
2022-10-19 17:51:26 +00:00
|
|
|
# Drawing on the image
|
|
|
|
logging.info("Drawing")
|
|
|
|
font10 = ImageFont.truetype(os.path.join(picdir, 'Font.ttc'), 12)
|
|
|
|
|
|
|
|
# Drawing on the Horizontal image
|
|
|
|
logging.info("1.Drawing on the Horizontal image...")
|
|
|
|
HBlackimage = Image.new('1', (epd.height, epd.width), 255) # 298*126
|
|
|
|
HRedimage = Image.new('1', (epd.height, epd.width), 255) # 298*126 ryimage: red or yellow image
|
|
|
|
drawblack = ImageDraw.Draw(HBlackimage)
|
|
|
|
drawred = ImageDraw.Draw(HRedimage)
|
|
|
|
drawblack.text((5, 0), 'PV Produktion', font = font10, fill = 0)
|
|
|
|
drawblack.text((5, 15), 'Hausverbrauch', font = font10, fill = 0)
|
2022-10-19 19:04:43 +00:00
|
|
|
if value_energyImportExport > 0:
|
|
|
|
drawred.text((5, 30), 'Strom Import', font = font10, fill = 0)
|
|
|
|
else:
|
|
|
|
drawblack.text((5, 30), 'Strom Export', font = font10, fill = 0)
|
|
|
|
|
2022-10-19 17:51:26 +00:00
|
|
|
drawblack.text((5, 45), 'Batterie %', font = font10, fill = 0)
|
|
|
|
drawblack.text((5, 60), 'Batterie Laden/Entladen', font = font10, fill = 0)
|
2022-10-19 17:52:24 +00:00
|
|
|
#epd.display(epd.getbuffer(HBlackimage), epd.getbuffer(HRedimage))
|
2022-10-19 17:51:26 +00:00
|
|
|
#epd.display(epd.getbuffer(HBlackimage))
|
|
|
|
|
2022-10-19 07:11:48 +00:00
|
|
|
print("-----")
|
2022-10-19 14:44:00 +00:00
|
|
|
logging.info("test")
|
2022-10-19 17:30:44 +00:00
|
|
|
logging.info("PvP: "+value_pvProduction)
|
|
|
|
logging.info("Hou: "+value_wHouseConsumption)
|
|
|
|
logging.info("I/E: "+value_energyImportExport)
|
|
|
|
logging.info("SoC: "+value_houseBatterySoC)
|
|
|
|
logging.info("Bio: "+value_houseBatteryLoadUnload)
|
2022-10-19 17:51:26 +00:00
|
|
|
#drawblack.rectangle((150, 0, 220, 50), fill = 255)
|
2022-10-19 15:44:50 +00:00
|
|
|
drawblack.text((150, 0), value_pvProduction, font = font10, fill = 0)
|
2022-10-19 17:51:26 +00:00
|
|
|
#drawblack.rectangle((150, 15, 220, 50), fill = 255)
|
2022-10-19 15:44:50 +00:00
|
|
|
drawblack.text((150, 15), value_wHouseConsumption, font = font10, fill = 0)
|
2022-10-19 17:51:26 +00:00
|
|
|
#drawblack.rectangle((150, 30, 220, 50), fill = 255)
|
2022-10-19 19:04:43 +00:00
|
|
|
if value_energyImportExport > 0:
|
|
|
|
drawred.text((150, 30), value_energyImportExport, font = font10, fill = 0)
|
|
|
|
else:
|
|
|
|
drawblack.text((150, 30), value_energyImportExport, font = font10, fill = 0)
|
2022-10-19 17:51:26 +00:00
|
|
|
#drawblack.rectangle((150, 45, 220, 50), fill = 255)
|
2022-10-19 17:55:28 +00:00
|
|
|
drawblack.text((150, 45), value_houseBatterySoC, font = font10, fill = 0)
|
2022-10-19 17:51:26 +00:00
|
|
|
#drawblack.rectangle((150, 60, 220, 50), fill = 255)
|
2022-10-19 15:44:50 +00:00
|
|
|
drawblack.text((150, 60), value_houseBatteryLoadUnload, font = font10, fill = 0)
|
|
|
|
|
2022-10-19 17:43:32 +00:00
|
|
|
epd.display(epd.getbuffer(HBlackimage), epd.getbuffer(HRedimage))
|
2022-10-19 17:52:24 +00:00
|
|
|
|
2022-10-19 17:51:26 +00:00
|
|
|
time.sleep(10)
|
2022-10-18 21:00:28 +00:00
|
|
|
|
|
|
|
except KeyboardInterrupt:
|
2022-10-18 21:01:15 +00:00
|
|
|
print("exiting")
|
2022-10-18 21:00:28 +00:00
|
|
|
client.disconnect()
|
|
|
|
client.loop_stop()
|