2017-05-08 46 views
0

我想在GUI中使用多個幀,其中頁面根據點擊按鈕切換。我知道已經有幾條線索了,我一直在尋找this one。 但是,對於我的頁面,我需要在每個框架的畫布上使用不同的圖像,這樣,當我豎起一個不同的框架時,它會在畫布上出現新的畫布和新的圖像。我嘗試了很多,但我不知道如何讓它起作用,以便畫布出現在他們的圖像中。Tkinter多幀/'頁面:使用畫布圖像

這裏是我到目前爲止,大部分來自上面的鏈接複製:

import tkinter as tk # python3 

TITLE_FONT = ("Helvetica", 18, "bold") 

class SampleApp(tk.Tk): 

    def __init__(self, *args, **kwargs): 
     tk.Tk.__init__(self, *args, **kwargs) 

     # the container is where we'll stack a bunch of frames 
     # on top of each other, then the one we want visible 
     # will be raised above the others 
     container = tk.Frame(self) 
     container.pack(side="top", fill="both", expand=True) 
     container.grid_rowconfigure(0, weight=1) 
     container.grid_columnconfigure(0, weight=1) 

     self.frames = {} 
     self.frames["StartPage"] = StartPage(parent=container, controller=self) 
     self.frames["PageOne"] = PageOne(parent=container, controller=self) 
     self.frames["PageTwo"] = PageTwo(parent=container, controller=self) 

     self.frames["StartPage"].grid(row=0, column=0, sticky="nsew") 
     self.frames["PageOne"].grid(row=0, column=0, sticky="nsew") 
     self.frames["PageTwo"].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 __init__(self, parent, controller): 
     tk.Frame.__init__(self, parent) 
     self.controller = controller 

     self._canvas = tk.Canvas(parent, bg='white', width=900, height=3517, scrollregion=(0, 2800, 100, 800)) 
     self._photo = tk.PhotoImage(file='images/homegraphic.gif') 
     self._canvas.create_image(0, 0, image=self._photo, anchor='nw') 

     label = tk.Label(self, text="This is the start page", font=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): 

    def __init__(self, parent, controller): 
     tk.Frame.__init__(self, parent) 
     self.controller = controller 
     label = tk.Label(self, text="This is page 1", font=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=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() 

如何獲得畫布形象出現?我花了很長時間試圖弄清楚這一點,並會感謝任何幫助!

+0

忘了補充,當我做網格類的起始頁畫布,窗口彈出的大小合適,但說明不了什麼,只是正常的灰色Tkinter的背景與文本和頂部的按鈕。 – amrungwaew

+0

您的畫布需要將當前框架本身用作主框架,而不是父框架,就像您的按鈕一樣:'self._canvas = tk.Canvas(self,bg ='white',width = 900,height = 3517,scrollregion = (0,2800,100,800))'。然後你需要使用'pack'進行佈局,因爲StartPage是由包管理的。 – Novel

回答

0

的問題是在這裏:一個頁面內

self._canvas = tk.Canvas(parent, ...) 

一切都需要在頁面的子或它的後代之一。

它必須是這樣的:

self._canvas = tk.Canvas(self, ...)