我有一個名為self.canvas_input_frame的畫布,其中的畫布名為self.canvas_input_image. self.canvas_input_image是實際顯示圖像的位置。我已將子元素垂直和水平滾動條附加到self.canvas_input_frame. 我的 GUI 如下圖所示:水平滾動條不完全從西向東延伸。如何解決?下面是我的代碼: def open_file_dialog(self): self.filename = filedialog.askopenfilename(initialdir = "C:/Users/alyss/AppData/Local/Programs/Python/Python36/Damaged Text Document Virtual Restoration", title = "Select A File", filetype = (("png", "*.png"),("jpeg", "*.jpg"), ("pdf", "*.pdf"), )) #Create Canvas Frame for Input Document self.canvas_input_frame = tk.Canvas(self.main_canvas, bg = "blue") self.canvas_input_frame.configure(width=456, height=470) self.canvas_input_frame.pack(side="left", padx=10,pady = 10) #Load Input Image load = Image.open(self.filename) render = ImageTk.PhotoImage(load) self.width, self.height = load.size self.canvas_input_image = tk.Canvas(self.canvas_input_frame,bg = "green") # how to render image in canvas self.canvas_input_image.configure(width=390, height=470) self.canvas_input_image.image = render self.canvas_input_image.create_image(0,0,anchor="nw",image=self.canvas_input_image.image) self.canvas_input_image.pack(side="left") self.vsb_canvas_input_frame = tk.Scrollbar( self.canvas_input_frame, orient="vertical", command=self.canvas_input_image.yview) self.hsb_canvas_input_frame = tk.Scrollbar( self.canvas_input_frame, orient="horizontal", command=self.canvas_input_image.xview) self.canvas_input_image.config(yscrollcommand=self.vsb_canvas_input_frame.set,xscrollcommand=self.hsb_canvas_input_frame.set) self.vsb_canvas_input_frame.pack(side = "right", fill = "y") self.hsb_canvas_input_frame.pack(side = "bottom", fill = "x") self.canvas_input_image.config(scrollregion = self.canvas_input_image.bbox("all"))
1 回答

暮色呼如
TA貢獻1853條經驗 獲得超9個贊
這里的問題是包裝小部件的順序。如果您更改包裝元素的順序,如下所示,那么它可以獲得您預期的視圖。
self.vsb_canvas_input_frame.pack(side = "right", fill = "y")
self.hsb_canvas_input_frame.pack(side = "bottom", fill = "x")
self.canvas_input_image.pack(side="left")
理解pack方法的一種方法是,如果您將 widget1 包裝在“左”中,則任何其他元素只能放在其“右”的另一側(而不是左、上或下)。類似的邏輯也適用于其他方面。
添加回答
舉報
0/150
提交
取消