tkinterでクラス化しているのですが、ウィンドウを閉じるときに応答なしになってしまいます。
クラスはまだ完全ではありませんが、ウィジェットとコントローラーの2種類に分けようと思っています。
過去の質問の回答を参考に作ってみたのですが、異なる動作結果になってしまいます。
該当のソースコード
(controller.pyから実行)
controller.py
Python
1from datetime import datetime 2import time 3import tkinter as tk 4import queue 5import threading 6 7import create 8 9def run(): 10 win = tk.Tk() 11 app = create.Application(win) 12 time_flag = True 13 message_queue = queue.Queue() 14 thread1 = threading.Thread(target=lambda:time_print(time_flag, message_queue)) 15 thread1.start() 16 win.after(0, lambda:check_queue(win, app, message_queue)) 17 win.protocol("WM_DELETE_WINDOW", lambda:on_closing(win, time_flag, thread1)) 18 win.mainloop() 19 20def time_print(time_flag, message_queue): 21 while time_flag: 22 now = datetime.now() 23 d = "{0:%Y/%m/%d}".format(now) 24 t = "{0:%H:%M:%S}".format(now) 25 message_queue.put(d + t) 26 time.sleep(0.01) 27 28# Queueを確認してラベルを更新 29def check_queue(win, app, message_queue): 30 try: 31 msg = message_queue.get(0) 32 app.label["text"] = msg 33 except queue.Empty: 34 pass 35 36 #5ms後に再度この関数を呼ぶ(main thread上で動作) 37 win.after(5, lambda:check_queue(win, app, message_queue)) 38 39def on_closing(win, time_flag, thread1): 40 time_flag = False 41 thread1.join() 42 win.destroy() 43 44if __name__ == "__main__": 45 run()
create.py
Python
1import tkinter as tk 2 3class Application: 4 def __init__(self, win): 5 self.win = win 6 self.widget_add() 7 8 def widget_add(self): 9 self.label = tk.Label(self.win, text="") 10 self.label.grid() 11 12if __name__ == "__main__": 13 pass
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/03/25 03:50