Skip to content

Instantly share code, notes, and snippets.

@cryptogun
Created October 22, 2017 07:28
Show Gist options
  • Save cryptogun/791b5bf7898114ec44e66d97fb8a7a7c to your computer and use it in GitHub Desktop.
Save cryptogun/791b5bf7898114ec44e66d97fb8a7a7c to your computer and use it in GitHub Desktop.
MVC example in Python
try:
import Tkinter as tk
except ImportError:
import tkinter as tk
class Observable:
def __init__(self, initialValue=None):
self.data = initialValue
self.callbacks = {}
def addCallback(self, func):
self.callbacks[func] = 1
def delCallback(self, func):
del self.callback[func]
def _docallbacks(self):
for func in self.callbacks:
func(self.data)
def set(self, data):
self.data = data
self._docallbacks()
def get(self):
return self.data
def unset(self):
self.data = None
class Model:
def __init__(self):
self.myMoney = Observable(0)
def addMoney(self, value):
self.myMoney.set(self.myMoney.get() + value)
def removeMoney(self, value):
self.myMoney.set(self.myMoney.get() - value)
class View(tk.Toplevel):
def __init__(self, master):
tk.Toplevel.__init__(self, master)
self.protocol('WM_DELETE_WINDOW', self.master.destroy)
tk.Label(self, text='My Money').pack(side='left')
self.moneyCtrl = tk.Entry(self, width=8)
self.moneyCtrl.pack(side='left')
def SetMoney(self, money):
self.moneyCtrl.delete(0, 'end')
self.moneyCtrl.insert('end', str(money))
class ChangerWidget(tk.Toplevel):
def __init__(self, master):
tk.Toplevel.__init__(self, master)
self.addButton = tk.Button(self, text='Add', width=8)
self.addButton.pack(side='left')
self.removeButton = tk.Button(self, text='Remove', width=8)
self.removeButton.pack(side='left')
class Controller:
def __init__(self, root):
self.model = Model()
self.model.myMoney.addCallback(self.MoneyChanged)
self.view1 = View(root)
self.view2 = ChangerWidget(self.view1)
self.view2.addButton.config(command=self.AddMoney)
self.view2.removeButton.config(command=self.RemoveMoney)
self.MoneyChanged(self.model.myMoney.get())
def AddMoney(self):
self.model.addMoney(10)
def RemoveMoney(self):
self.model.removeMoney(10)
def MoneyChanged(self, money):
self.view1.SetMoney(money)
if __name__ == '__main__':
root = tk.Tk()
root.withdraw()
app = Controller(root)
root.mainloop()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment