|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# 00infoLCDTK.py
|
|
|
|
#
|
|
|
|
# called by #
|
|
|
|
# /home/pi/autostart.sh
|
|
|
|
# dev/test/run with:
|
|
|
|
# sudo -i -u pi DISPLAY=:0.0 /usr/bin/python3 /home/admin/00infoLCDTK.py
|
|
|
|
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import json
|
|
|
|
import logging
|
|
|
|
import logging.config
|
|
|
|
import tkinter as tk
|
|
|
|
|
|
|
|
COLOR = "black"
|
|
|
|
WINFO = None
|
|
|
|
|
|
|
|
log = logging.getLogger()
|
|
|
|
|
|
|
|
|
|
|
|
def setup_logging(default_path='00infoLCDw.json'):
|
|
|
|
"""Setup logging configuration"""
|
|
|
|
path = default_path
|
|
|
|
if os.path.exists(path):
|
|
|
|
with open(path, 'rt') as f:
|
|
|
|
config = json.load(f)
|
|
|
|
logging.config.dictConfig(config)
|
|
|
|
else: # if $default_path does not exist use the following default log setup
|
|
|
|
default_config_as_json = """
|
|
|
|
{
|
|
|
|
"version": 1,
|
|
|
|
"disable_existing_loggers": false,
|
|
|
|
"formatters": {
|
|
|
|
"simple": {
|
|
|
|
"format": "%(asctime)s - %(levelname)s - %(message)s"
|
|
|
|
},
|
|
|
|
"extended": {
|
|
|
|
"format": "%(asctime)s - %(name)s - %(levelname)s - %(module)s:%(lineno)d - %(message)s"
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
"handlers": {
|
|
|
|
"console": {
|
|
|
|
"class": "logging.StreamHandler",
|
|
|
|
"level": "INFO",
|
|
|
|
"formatter": "simple",
|
|
|
|
"stream": "ext://sys.stdout"
|
|
|
|
},
|
|
|
|
|
|
|
|
"file_handler": {
|
|
|
|
"class": "logging.handlers.RotatingFileHandler",
|
|
|
|
"level": "DEBUG",
|
|
|
|
"formatter": "extended",
|
|
|
|
"filename": "00infoLCDTK.log",
|
|
|
|
"maxBytes": 10485760,
|
|
|
|
"backupCount": 0,
|
|
|
|
"encoding": "utf8"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"loggers": {
|
|
|
|
"infoblitz": {
|
|
|
|
"level": "INFO",
|
|
|
|
"handlers": ["console", "file_handler"],
|
|
|
|
"propagate": "no"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
"root": {
|
|
|
|
"level": "INFO",
|
|
|
|
"handlers": ["console", "file_handler"]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
config = json.loads(default_config_as_json)
|
|
|
|
logging.config.dictConfig(config)
|
|
|
|
|
|
|
|
|
|
|
|
def callback_b1():
|
|
|
|
global WINFO
|
|
|
|
log.info("clicked b1")
|
|
|
|
if sys.platform != "win32":
|
|
|
|
os.system("xterm -fn fixed -into %d +sb -hold /home/admin/00infoLCD.sh &" % WINFO)
|
|
|
|
|
|
|
|
|
|
|
|
def callback_b2():
|
|
|
|
global WINFO
|
|
|
|
log.info("clicked b2")
|
|
|
|
if sys.platform != "win32":
|
|
|
|
os.system("xterm -fn fixed -into %d +sb -hold /home/admin/XXbutton2.sh &" % WINFO)
|
|
|
|
|
|
|
|
|
|
|
|
def callback_b4():
|
|
|
|
global WINFO
|
|
|
|
log.info("clicked b4")
|
|
|
|
if sys.platform != "win32":
|
|
|
|
os.system("xterm -fn fixed -into %d +sb -hold /home/admin/XXshutdown.sh &" % WINFO)
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
global WINFO
|
|
|
|
setup_logging()
|
|
|
|
log.info("Starting 00infoLCDTK.py")
|
|
|
|
|
|
|
|
# LCD root
|
|
|
|
root = tk.Tk()
|
|
|
|
root.config(bg=COLOR)
|
|
|
|
root.overrideredirect(1)
|
|
|
|
root.geometry("480x320+0+0")
|
|
|
|
root.title("RaspiBlitz")
|
|
|
|
|
|
|
|
# but LCD on canvas
|
|
|
|
entry = tk.Entry(root)
|
|
|
|
entry.config(bg=COLOR, highlightbackground=COLOR)
|
|
|
|
entry.pack(side="bottom", fill="x")
|
|
|
|
|
|
|
|
# button frame
|
|
|
|
frame1 = tk.Frame(entry, width=80, background="black")
|
|
|
|
frame1.pack(side="left", fill="both", expand=True)
|
|
|
|
|
|
|
|
# button 1
|
|
|
|
button1 = tk.Button(frame1, text='\u0397', fg='black', command=callback_b1)
|
|
|
|
button1.pack(pady=24)
|
|
|
|
|
|
|
|
# button 2
|
|
|
|
button2 = tk.Button(frame1, text='\u0399', fg='black', command=callback_b2)
|
|
|
|
button2.pack(pady=24)
|
|
|
|
|
|
|
|
# button 3
|
|
|
|
label3 = tk.Label(frame1, text='1.3', bg=COLOR, fg='white')
|
|
|
|
label3.pack(pady=24)
|
|
|
|
|
|
|
|
# button 4
|
|
|
|
button4 = tk.Button(frame1, text='\N{BLACK CIRCLE}', fg='red', command=callback_b4)
|
|
|
|
button4.pack(pady=24)
|
|
|
|
|
|
|
|
# content frame
|
|
|
|
frame2 = tk.Frame(entry, width=400, background="grey")
|
|
|
|
frame2.pack(side="right", fill="both", expand=True)
|
|
|
|
|
|
|
|
# run terminal in
|
|
|
|
WINFO = frame2.winfo_id()
|
|
|
|
if sys.platform != "win32":
|
|
|
|
os.system("xterm -fn fixed -into %d +sb -hold /home/admin/00infoLCD.sh &" % WINFO)
|
|
|
|
|
|
|
|
# run
|
|
|
|
root.mainloop()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|