It works if you change it like so:

from tkinter import *
class ShowList(Frame):
        def __init__(self, root):
                Frame.__init__(self, root)
                self.grid()
                self.draw_widgets()
        def draw_widgets(self):
                cframe = Frame(self)
                cframe.grid(row=1, sticky=N+S+E+W)
                canv = Canvas(cframe)
                canv.grid(row=0, column=0, sticky=N+S+E+W)
                vscroll = Scrollbar(cframe, orient=VERTICAL, command=canv.yview)
                hscroll = Scrollbar(cframe, orient=HORIZONTAL, 
command=canv.xview)
                vscroll.grid(row=0, column=1, sticky=N+S)
                hscroll.grid(row=1, column=0, sticky=E+W)
                canv["xscrollcommand"] = hscroll.set
                canv["yscrollcommand"] = vscroll.set
                aframe = Frame(canv)
                id = canv.create_window(0,0,window=aframe, anchor=N+W)
                for i in range(0,100):
                        Label(aframe, text=str(i), anchor=N+W).grid(row=i, 
column=0)
                aframe.update_idletasks()
                canv["scrollregion"]=canv.bbox(ALL)
root  = Tk()
m=ShowList(root)
root.mainloop()

You need to do the update_idletasks to force the canvas to be mapped before you 
figure out the bounding box.  Until the canvas is mapped to the screen, the 
bounding box is (0,0,1,1) so there no scrolling possible.  (You can call 
update_ideltasks through any widget.)

That said, I wonder why you're putting widgets in the frame instead of putting 
objects directly on the canvas.  The way you're doing it you can't use tags, 
which are what really give the canvas its power.

Saul

   
-- 
http://mail.python.org/mailman/listinfo/python-list

Reply via email to