读取串行输入并打印到Tkinter GUI

莫滕·尼索夫(Morten Nissov)

我正在尝试为Arduino打印传感器值创建基于Tkinter的GUI并响应用户输入。

我试图用来消除while循环的代码是这样的,它不会打印任何传感器信息,唯一的输出是“ Trying ... / dev / ttyACM0”,然后打开tkinter窗口。从Tkinter导入导入序列导入时间*

connected = False
write_to_file_path = "output.txt"
output_file = open(write_to_file_path, "w+")

locations=['/dev/ttyACM0','/dev/ttyACM1','/dev/ttyACM2','/dev/ttyACM3']

for device in locations:
    try:
        print "Trying...",device
        ser = serial.Serial(device, 9600)
        break
    except:
        print "Failed to connect on",device

## loop until the arduino tells us it is ready
while not connected:
    serin = ser.read()
    connected = True

time.sleep(0.1)
ser.flushInput()
time.sleep(1)

def serialRead():
    if ser.inWaiting():
        line = ser.readline()
        data = line.decode("utf-8").split('\t')
        print(data)
        output_file.write(line)
        root.after(1000, serialRead)



root = Tk()
root.title("Temperature Control")
serialRead()
root.mainloop()

另一方面,除了没有tkinter窗口外,这非常有效。但是它会从缓冲区中删除旧输入,并读入新输入。

import serial
import time

connected = False
write_to_file_path = "output.txt"
output_file = open(write_to_file_path, "w+")

serial_port = '/dev/ttyACM0'
baud_rate = 9600
ser = serial.Serial(serial_port, baud_rate, timeout=5)
time.sleep(0.1)
ser.flushInput()
time.sleep(1)

while True:
    if ser.inWaiting():
        line = ser.readline()
        data = line.decode("utf-8").split('\t') #ser.readline returns a binary, convert to string
        print data[0] + '\t' + data[1]
        output_file.write(line)

这是由一段时间前不同的stackoverflow帖子启发的:在Tkinter的背景中运行无限循环

我已经看到了一些使用线程的示例,但是我对python和线程不了解太多,所以我真的很想让它与root.after()一起使用。我还使用root.after尝试了该示例,所有这些都与我链接的示例非常相似,但我无法使它们正常工作。我是否在做任何明显错误的事情,或者以比需要做的事情难得多的方式做事?如果有人能指出正确的方向,我将不胜感激。

Jtwilson

我在TK中创建了一个UI,用于从GPS接收器读取数据,但是我很难让root.mainloop()运行,所以我在TK应用程序中放置了一个回调,最终调用了root.update()而不是mainloop。

代码看起来像这样:

class App:

def __init__(self, master):
    self.sats = tk.StringVar()
    self.satsnum = tk.Label(self.frame, textvariable=self.sats, bg="blue")
    self.satsnum.pack()

def update_display(self, master):

    while source:

        self.sats.set(n_sats)

        if n_sats < 10:
            satsbgcolor = 'red'
        else:
            satsbgcolor = 'green'
        self.satsnum.configure(bg = satsbgcolor)

        master.update()
        time.sleep(1)


with serial_link.get_base_args_driver(args) as driver:
    with Handler(Framer(driver.read, driver.write, verbose=True)) as source:
        root = tk.Tk()
        app = App(root)
        app.update_display(root)

注意,在MacOS上,time.sleep(1)是必需的,因为如果调用更新太快,tk.update()将会泄漏内存。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章