added simple traffic light example
This commit is contained in:
parent
c934c858d3
commit
247c2fd109
84
tk_first_steps/traffic_light_simple_mvc.py
Normal file
84
tk_first_steps/traffic_light_simple_mvc.py
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
|
from tkinter import *
|
||||||
|
from tkinter import ttk
|
||||||
|
|
||||||
|
# --------------------------
|
||||||
|
# Model
|
||||||
|
# --------------------------
|
||||||
|
|
||||||
|
class TLight:
|
||||||
|
def __init__(self):
|
||||||
|
self.colors = {0: "red", 1: "yellow", 2: "green", 3: "yellow"}
|
||||||
|
self.status = 0
|
||||||
|
|
||||||
|
def switch(self):
|
||||||
|
if self.status < max(self.colors.keys()):
|
||||||
|
self.status += 1
|
||||||
|
else:
|
||||||
|
self.status = 0
|
||||||
|
|
||||||
|
def print_color(self):
|
||||||
|
print(self.colors[self.status])
|
||||||
|
|
||||||
|
def get_color(self):
|
||||||
|
return self.colors[self.status]
|
||||||
|
|
||||||
|
# --------------------------
|
||||||
|
# Controller
|
||||||
|
# --------------------------
|
||||||
|
|
||||||
|
class TLightController:
|
||||||
|
def __init__(self, app):
|
||||||
|
self.app = app
|
||||||
|
self.tlight = TLight()
|
||||||
|
|
||||||
|
def change_light(self, event=None):
|
||||||
|
self.tlight.switch()
|
||||||
|
self.update_view()
|
||||||
|
|
||||||
|
def update_view(self):
|
||||||
|
color = self.tlight.get_color()
|
||||||
|
self.app.change_light_display(color)
|
||||||
|
|
||||||
|
|
||||||
|
# --------------------------
|
||||||
|
# View / Main Application
|
||||||
|
# --------------------------
|
||||||
|
|
||||||
|
class TLightApp(Tk):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.controller = TLightController(self)
|
||||||
|
|
||||||
|
self.create_widgets()
|
||||||
|
self.create_light()
|
||||||
|
self.bind_events()
|
||||||
|
|
||||||
|
def create_widgets(self):
|
||||||
|
mainframe = ttk.Frame(self, padding="3 3 3 3")
|
||||||
|
mainframe.grid(column=0, row=0, sticky=N+W+S+E)
|
||||||
|
self.columnconfigure(0, weight=1)
|
||||||
|
self.rowconfigure(0, weight=1)
|
||||||
|
|
||||||
|
button_switch = ttk.Button(mainframe, text="Schalte um", command=self.controller.change_light)
|
||||||
|
button_switch.grid(column=0, row=0, sticky=W)
|
||||||
|
light_canvas = Canvas(mainframe, width=50, height=50, background="black")
|
||||||
|
light_canvas.grid(column=1, row=0, sticky=W)
|
||||||
|
self.lc = light_canvas
|
||||||
|
|
||||||
|
def create_light(self, color="red"):
|
||||||
|
self.light = self.lc.create_oval(10,10,40,40,fill=color)
|
||||||
|
|
||||||
|
def bind_events(self):
|
||||||
|
self.bind("<Return>", self.controller.change_light)
|
||||||
|
|
||||||
|
def change_light_display(self, color):
|
||||||
|
self.lc.itemconfigure(self.light, fill=color)
|
||||||
|
|
||||||
|
# --------------------------
|
||||||
|
# Execution
|
||||||
|
# --------------------------
|
||||||
|
if __name__ == "__main__":
|
||||||
|
app = TLightApp()
|
||||||
|
app.mainloop()
|
Loading…
Reference in New Issue
Block a user