update
This commit is contained in:
		
							parent
							
								
									7fa199db64
								
							
						
					
					
						commit
						58f6c81562
					
				| @ -1,6 +1,7 @@ | |||||||
| from UIModell import * | from UIModell import * | ||||||
| import UIViewTKinter as viewTkinter | import UIViewTKinter as viewTkinter | ||||||
| import UIViewPySide as viewPySide | import UIViewPySide as viewPySide | ||||||
|  | from threading import Thread | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class Controller(): | class Controller(): | ||||||
| @ -16,9 +17,18 @@ class Controller(): | |||||||
|             "test": self.test |             "test": self.test | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         self.pages = { | ||||||
|  |             "stop": "StartPage", | ||||||
|  |             "copySpelling": "WorkingPage", | ||||||
|  |             "freeSpelling": "WorkingPage", | ||||||
|  |             "test": "WorkingPage" | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|         self.view.mainloop() |         self.view.mainloop() | ||||||
|      |      | ||||||
|     def actionPerformed(self, action): |     def actionPerformed(self, action): | ||||||
|  |         self.view.changeFrame(self.pages.get(action)) | ||||||
|         func = self.commands.get(action) |         func = self.commands.get(action) | ||||||
|         if(func is not None): |         if(func is not None): | ||||||
|             func() |             func() | ||||||
| @ -26,8 +36,11 @@ class Controller(): | |||||||
|             print("Kommado existiert nicht") |             print("Kommado existiert nicht") | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|     def test(self): |     def test(self): | ||||||
|         self.model.trainXDawn() |         self.thread = Thread(target=self.model.trainXDawn) | ||||||
|  |         self.thread.start() | ||||||
|  |         #self.model.trainXDawn() | ||||||
| 
 | 
 | ||||||
|     def commandoCopySpelling(self): |     def commandoCopySpelling(self): | ||||||
|         self.model.startCopySpelling() |         self.model.startCopySpelling() | ||||||
| @ -39,5 +52,6 @@ class Controller(): | |||||||
| 
 | 
 | ||||||
|     def commandStop(self): |     def commandStop(self): | ||||||
|         self.model.killProzess() |         self.model.killProzess() | ||||||
|  |         self.thread.join() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
										
											Binary file not shown.
										
									
								
							| @ -97,3 +97,6 @@ class Modell(): | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         print("killed openvibe-designer") |         print("killed openvibe-designer") | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -5,22 +5,48 @@ except ImportError: | |||||||
| 
 | 
 | ||||||
| from UIController import * | from UIController import * | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| class View(Tk): | class View(Tk): | ||||||
|     def __init__(self, c, *args, **kwargs): |     def __init__(self, c, *args, **kwargs): | ||||||
|         Tk.__init__(self, *args, **kwargs) |         Tk.__init__(self, *args, **kwargs) | ||||||
|         self.controller = c |         self.controller = c | ||||||
|         self.title("Taktiles Spelling") |         self.title("Taktiles Spelling") | ||||||
|  |         self.h = 400 | ||||||
|  |         self.w = 500 | ||||||
|  |         self.faktor = [(0.125),(0.625), (0.25)] | ||||||
|         #self.resizable(height=False, width= False) |         #self.resizable(height=False, width= False) | ||||||
|         self.geometry('500x400') |         self.geometry('{}x{}'.format(self.w,self.h)) | ||||||
|         #self.configure(bg="blue") |  | ||||||
| 
 | 
 | ||||||
|         self.createTopFrame() |         self.createTopFrame() | ||||||
|         self.createMainFrame() |         self.createMainFrame() | ||||||
|         self.createBottomFrame() |         self.createBottomFrame() | ||||||
| 
 | 
 | ||||||
|  |         self.bind("<Configure>", self.adjustSize) | ||||||
|         self.protocol("WM_DELETE_WINDOW", self.onClosing) |         self.protocol("WM_DELETE_WINDOW", self.onClosing) | ||||||
|      |      | ||||||
|        |        | ||||||
|  |     def changeFrame(self, pageName): | ||||||
|  |         frame = self.frames[pageName] | ||||||
|  |         frame.tkraise() | ||||||
|  | 
 | ||||||
|  |     def adjustSize(self, event): | ||||||
|  |         if(str(event.widget) =="."): | ||||||
|  |             self.h = event.height | ||||||
|  |             self.w = event.width | ||||||
|  |             self.topFrame.configure(height=(self.h*self.faktor[0]), width=self.w) | ||||||
|  |             self.mainFrame.configure(height=(self.h*self.faktor[1]), width=self.w) | ||||||
|  |             self.bottomFrame.configure(height=(self.h*self.faktor[2]), width=self.w) | ||||||
|  |             self.container.configure(height=(self.h*self.faktor[1]), width=self.w) | ||||||
|  |             for f in self.frames: | ||||||
|  |                 self.frames[f].configure(height=(self.h*self.faktor[1]), width=self.w) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def onClosing(self): | ||||||
|  |         print("closing") | ||||||
|  |         self.destroy() | ||||||
|  |          | ||||||
|  |      | ||||||
|     def createTopFrame(self): |     def createTopFrame(self): | ||||||
|         self.topFrame = Frame(self, bg="blue", height=50, width=500) #, padx=460, pady=10) |         self.topFrame = Frame(self, bg="blue", height=50, width=500) #, padx=460, pady=10) | ||||||
|         l = Label(self.topFrame, text="taktilles Buchstabieren") |         l = Label(self.topFrame, text="taktilles Buchstabieren") | ||||||
| @ -36,48 +62,28 @@ class View(Tk): | |||||||
|         self.mainFrame.grid(column=0, row=1) |         self.mainFrame.grid(column=0, row=1) | ||||||
|         self.mainFrame.pack_propagate(0) |         self.mainFrame.pack_propagate(0) | ||||||
|          |          | ||||||
|         container = Frame(self.mainFrame, bg="cyan", height=250, width=500) |         self.container = Frame(self.mainFrame, bg="cyan", height=250, width=500) | ||||||
|         container.pack(side="top", fill="both", expand = True) |         self.container.pack(side="top", fill="both", expand = True) | ||||||
|         container.pack_propagate(0) |         self.container.pack_propagate(0) | ||||||
|         container.grid_propagate(0) |         self.container.grid_propagate(0) | ||||||
|          |          | ||||||
|         self.frames = {} |         self.frames = {} | ||||||
|         for F in (StartPage, WorkingPage): |         for F in (StartPage, WorkingPage): | ||||||
|             page_name = F.__name__ |             page_name = F.__name__ | ||||||
|             frame = F(parent=container, controller=self) |             frame = F(parent=self.container, controller=self.controller) | ||||||
|             self.frames[page_name] = frame |             self.frames[page_name] = frame | ||||||
| 
 |  | ||||||
|             # put all of the pages in the same location; |  | ||||||
|             # the one on the top of the stacking order |  | ||||||
|             # will be the one that is visible. |  | ||||||
|             frame.grid(row=0, column=0, sticky="nsew") |             frame.grid(row=0, column=0, sticky="nsew") | ||||||
|          |          | ||||||
|         self.changeFrame("StartPage") |         self.changeFrame("StartPage") | ||||||
|            |            | ||||||
|     def changeFrame(self, pageName): |  | ||||||
|         frame = self.frames[pageName] |  | ||||||
|         frame.tkraise() |  | ||||||
| 
 |  | ||||||
|         #testBtn = Button(self.mainFrame, text="test", command=lambda: self.controller.actionPerformed("test"), height=6, width = 10) |  | ||||||
|         #testBtn.grid(row=0, column=0) |  | ||||||
| 
 |  | ||||||
|         #stopBtn = Button(self.mainFrame, text="stop", command=lambda: self.controller.actionPerformed("stop"), height=6, width = 10) |  | ||||||
|         #stopBtn.grid(row=0, column=1) |  | ||||||
| 
 |  | ||||||
|          |  | ||||||
|     def createBottomFrame(self): |     def createBottomFrame(self): | ||||||
|         self.bottomFrame = Frame(self, bg="green", height=250, width=500) |         self.bottomFrame = Frame(self, bg="green", height=100, width=500) | ||||||
|         self.bottomFrame.grid(column=0, row=2) |         self.bottomFrame.grid(column=0, row=2) | ||||||
|         self.bottomFrame.pack_propagate(0) |         self.bottomFrame.pack_propagate(0) | ||||||
| 
 | 
 | ||||||
|         label = Label(self.bottomFrame, text="Hier stehen Infos") |         label = Label(self.bottomFrame, text="Hier stehen Infos") | ||||||
|         label.pack()    |         label.pack()    | ||||||
| 
 | 
 | ||||||
|     def onClosing(self): |  | ||||||
|         print("closing") |  | ||||||
|         self.destroy() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| class StartPage(Frame): | class StartPage(Frame): | ||||||
|     def __init__(self, parent, controller): |     def __init__(self, parent, controller): | ||||||
| @ -85,22 +91,16 @@ class StartPage(Frame): | |||||||
|         self.grid_propagate(0) |         self.grid_propagate(0) | ||||||
|         self.pack_propagate(0) |         self.pack_propagate(0) | ||||||
|         self.controller = controller |         self.controller = controller | ||||||
|         label = Label(self, text="This is the start page") |  | ||||||
|         label.pack(side="top", fill="x", pady=10) |  | ||||||
| 
 | 
 | ||||||
|         button1 = Button(self, text="Go to Page One", |         testBtn = Button(self, text="test", command=lambda: self.controller.actionPerformed("test"), height=6, width = 10) | ||||||
|                             command=lambda: controller.changeFrame("WorkingPage")) |         testBtn.grid(row=0, column=0) | ||||||
|         button2 = Button(self, text="Go to Page Two", | 
 | ||||||
|                             command=lambda: controller.changeFrame("WorkingPage")) |         freeSpellingBtn = Button(self, text="freeSpelling", command=lambda: self.controller.actionPerformed("freeSpelling"), height=6, width = 10) | ||||||
|         button1.pack() |         freeSpellingBtn.grid(row=0, column=1) | ||||||
|         button2.pack() |  | ||||||
| 
 | 
 | ||||||
| class WorkingPage(Frame): | class WorkingPage(Frame): | ||||||
|     def __init__(self, parent, controller): |     def __init__(self, parent, controller): | ||||||
|         Frame.__init__(self, parent) |         Frame.__init__(self, parent) | ||||||
|         self.controller = controller |         self.controller = controller | ||||||
|         label = Label(self, text="This is page 1") |         stopBtn = Button(self, text="stop", command=lambda: self.controller.actionPerformed("stop"), height=6, width = 10) | ||||||
|         label.pack(side="top", fill="x", pady=10) |         stopBtn.pack() | ||||||
|         button = Button(self, text="Go to the start page", |  | ||||||
|                            command=lambda: controller.changeFrame("StartPage")) |  | ||||||
|         button.pack() |  | ||||||
|  | |||||||
										
											Binary file not shown.
										
									
								
							| @ -1,84 +1,42 @@ | |||||||
| try: | from threading import Thread | ||||||
|     import tkinter as tk                # python 3 | import time | ||||||
|     from tkinter import font as tkfont  # python 3 | from itertools import count  | ||||||
| except ImportError: |  | ||||||
|     import Tkinter as tk     # python 2 |  | ||||||
|     import tkFont as tkfont  # python 2 |  | ||||||
| 
 | 
 | ||||||
| class SampleApp(tk.Tk): | class Modell(Thread): | ||||||
|  |     def __init__(self): | ||||||
|  |         Thread.__init__(self) | ||||||
|  |         self.running = True | ||||||
|          |          | ||||||
|     def __init__(self, *args, **kwargs): |     def stop(self): | ||||||
|         tk.Tk.__init__(self, *args, **kwargs) |         self.running = False | ||||||
| 
 | 
 | ||||||
|         self.title_font = tkfont.Font(family='Helvetica', size=18, weight="bold", slant="italic") |     def setFunktion(self, func, args=None, kwargs=None): | ||||||
|  |         self.func = func | ||||||
|  |         self.args = args or [] | ||||||
|  |         self.kwargs = kwargs or {} | ||||||
|      |      | ||||||
|         # the container is where we'll stack a bunch of frames |     def run(self):  | ||||||
|         # on top of each other, then the one we want visible |         t = Thread(target=self.func, args=self.args, kwargs=self.kwargs) | ||||||
|         # will be raised above the others |         t.setDaemon(True) | ||||||
|         container = tk.Frame(self) |         t.start() | ||||||
|         container.pack(side="top", fill="both", expand=True) |  | ||||||
|         container.grid_rowconfigure(0, weight=1) |  | ||||||
|         container.grid_columnconfigure(0, weight=1) |  | ||||||
|          |          | ||||||
|         self.frames = {} |         while self.running: | ||||||
|         for F in (StartPage, PageOne, PageTwo): |             time.sleep(0.1) | ||||||
|             page_name = F.__name__ |  | ||||||
|             frame = F(parent=container, controller=self) |  | ||||||
|             self.frames[page_name] = frame |  | ||||||
| 
 |  | ||||||
|             # put all of the pages in the same location; |  | ||||||
|             # the one on the top of the stacking order |  | ||||||
|             # will be the one that is visible. |  | ||||||
|             frame.grid(row=0, column=0, sticky="nsew") |  | ||||||
| 
 |  | ||||||
|         self.show_frame("StartPage") |  | ||||||
| 
 |  | ||||||
|     def show_frame(self, page_name): |  | ||||||
|         '''Show a frame for the given page name''' |  | ||||||
|         frame = self.frames[page_name] |  | ||||||
|         frame.tkraise() |  | ||||||
|      |      | ||||||
| 
 | 
 | ||||||
| class StartPage(tk.Frame): |     def worker(self): | ||||||
|  |         i= 0 | ||||||
|  |         while True: | ||||||
|  |             i = i+1 | ||||||
|  |             print(i) | ||||||
|  |             time.sleep(0.05) | ||||||
|      |      | ||||||
|     def __init__(self, parent, controller): | c = Modell() | ||||||
|         tk.Frame.__init__(self, parent) | c.setFunktion(c.worker) | ||||||
|         self.controller = controller | c.start() | ||||||
|         label = tk.Label(self, text="This is the start page", font=controller.title_font) |  | ||||||
|         label.pack(side="top", fill="x", pady=10) |  | ||||||
| 
 |  | ||||||
|         button1 = tk.Button(self, text="Go to Page One", |  | ||||||
|                             command=lambda: controller.show_frame("PageOne")) |  | ||||||
|         button2 = tk.Button(self, text="Go to Page Two", |  | ||||||
|                             command=lambda: controller.show_frame("PageTwo")) |  | ||||||
|         button1.pack() |  | ||||||
|         button2.pack() |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class PageOne(tk.Frame): | t = time.time() | ||||||
|  | time.sleep(3) | ||||||
| 
 | 
 | ||||||
|     def __init__(self, parent, controller): | c.stop() | ||||||
|         tk.Frame.__init__(self, parent) |  | ||||||
|         self.controller = controller |  | ||||||
|         label = tk.Label(self, text="This is page 1", font=controller.title_font) |  | ||||||
|         label.pack(side="top", fill="x", pady=10) |  | ||||||
|         button = tk.Button(self, text="Go to the start page", |  | ||||||
|                            command=lambda: controller.show_frame("StartPage")) |  | ||||||
|         button.pack() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| class PageTwo(tk.Frame): |  | ||||||
| 
 |  | ||||||
|     def __init__(self, parent, controller): |  | ||||||
|         tk.Frame.__init__(self, parent) |  | ||||||
|         self.controller = controller |  | ||||||
|         label = tk.Label(self, text="This is page 2", font=controller.title_font) |  | ||||||
|         label.pack(side="top", fill="x", pady=10) |  | ||||||
|         button = tk.Button(self, text="Go to the start page", |  | ||||||
|                            command=lambda: controller.show_frame("StartPage")) |  | ||||||
|         button.pack() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| if __name__ == "__main__": |  | ||||||
|     app = SampleApp() |  | ||||||
|     app.mainloop() |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user