Подтвердить что ты не робот

Как получить холст tkinter для динамического изменения размера окна?

Мне нужно получить холст в tkinter, чтобы установить его ширину в ширину окна, а затем динамически изменить размер холста, когда пользователь делает окно меньше/больше.

Есть ли способ сделать это (легко)?

4b9b3361

Ответ 1

Я думал, что добавлю дополнительный код, чтобы расширить ответ на @fredtantini, так как он не занимается обновлением формы виджетов, нарисованных на Canvas.

Для этого вам нужно использовать метод scale и пометить все виджеты. Ниже приведен полный пример.

from Tkinter import *

# a subclass of Canvas for dealing with resizing of windows
class ResizingCanvas(Canvas):
    def __init__(self,parent,**kwargs):
        Canvas.__init__(self,parent,**kwargs)
        self.bind("<Configure>", self.on_resize)
        self.height = self.winfo_reqheight()
        self.width = self.winfo_reqwidth()

    def on_resize(self,event):
        # determine the ratio of old width/height to new width/height
        wscale = float(event.width)/self.width
        hscale = float(event.height)/self.height
        self.width = event.width
        self.height = event.height
        # resize the canvas 
        self.config(width=self.width, height=self.height)
        # rescale all the objects tagged with the "all" tag
        self.scale("all",0,0,wscale,hscale)

def main():
    root = Tk()
    myframe = Frame(root)
    myframe.pack(fill=BOTH, expand=YES)
    mycanvas = ResizingCanvas(myframe,width=850, height=400, bg="red", highlightthickness=0)
    mycanvas.pack(fill=BOTH, expand=YES)

    # add some widgets to the canvas
    mycanvas.create_line(0, 0, 200, 100)
    mycanvas.create_line(0, 100, 200, 0, fill="red", dash=(4, 4))
    mycanvas.create_rectangle(50, 25, 150, 75, fill="blue")

    # tag all of the drawn widgets
    mycanvas.addtag_all("all")
    root.mainloop()

if __name__ == "__main__":
    main()

Ответ 2

Вы можете использовать диспетчер геометрии .pack:

self.c=Canvas(…)
self.c.pack(fill=BOTH, expand=YES)

должен сделать трюк. Если ваш холст находится внутри фрейма, сделайте то же самое для фрейма:

self.r = root
self.f = Frame(self.r)
self.f.pack(fill=BOTH, expand=YES)
self.c = Canvas(…)
self.c.pack(fill=BOTH, expand=YES)

Подробнее см. effbot.

Изменить: если вы не хотите "полноразмерного" холста, вы можете привязать свой холст к функции:

self.c.bind('<Configure>', self.resize)

def resize(self, event):
    w,h = event.width-100, event.height-100
    self.c.config(width=w, height=h)

Смотрите effbot снова для событий и привязок