J'ai besoin d'obtenir un canevas dans tkinter pour définir sa largeur à la largeur de la fenêtre, puis redimensionner dynamiquement le canevas lorsque l'utilisateur rend la fenêtre plus petite/plus grande.
Y a-t-il un moyen de le faire (facilement)?
J'ai pensé que j'ajouterais du code supplémentaire pour développer réponse de @ fredtantini , car cela ne traite pas de la façon de mettre à jour la forme des widgets dessinés sur le Canvas
.
Pour ce faire, vous devez utiliser la méthode scale
et baliser tous les widgets. Un exemple complet est ci-dessous.
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()
Vous pouvez utiliser le .pack
gestionnaire de géométrie:
self.c=Canvas(…)
self.c.pack(fill="both", expand=True)
devrait faire l'affaire. Si votre toile est à l'intérieur d'un cadre, faites de même pour le cadre:
self.r = root
self.f = Frame(self.r)
self.f.pack(fill="both", expand=True)
self.c = Canvas(…)
self.c.pack(fill="both", expand=True)
Voir effbot pour plus d'informations.
Edit: si vous ne voulez pas d'un canevas "pleine taille", vous pouvez lier votre canevas à une fonction:
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)
Voir effbot à nouveau pour les événements et les liaisons