点缀Tkinter画布小部件的最简单方法是什么?

时间:2011-01-29 09:45:06

标签: python canvas tkinter stipple

我有一个Tkinter画布小部件,我想在它上面创建一个点画图案。我知道我可以使用 create_line 方法手动完成。但是,我认为似乎有更好的方法。任何帮助将非常感激。

我目前正在与之合作。 (按Alt-F4退出程序)

import Tkinter, re

class StippleCanvas(Tkinter.Tk):
    def __init__(self, parent):
        Tkinter.Tk.__init__(self, parent)


        self.overrideredirect(1)
        self.resizable(False,False)
        self.wm_attributes("-topmost", 1)
        self.attributes("-alpha", 0.9)

        w = 90
        h = 90

        self.Ca = Tkinter.Canvas(self, width=w, height=h, highlightthickness=0, bd=0, bg='grey25')
        self.Ca.grid(column=0, row=0)
        self.bind('<Button-1>', self.relative_mouse_position)
        self.bind('<ButtonRelease-1>', self.wid_unbind)

        i0 = 0
        while i0 < w:
            i1 = 0
            while i1 < h:
                self.Ca.create_line(i1, i0, i1+1, i0, fill='grey20', width=1)
                i1 = i1 + 2
            i0 = i0 + 2

    def geom_grab (self):
        Cursorgfltr = re.compile(r"(\d+), (\d+)")
        CursorPos = self.winfo_pointerxy()
        CursorPosGr = Cursorgfltr.search(str(CursorPos))
        self.CursorX = int(CursorPosGr.group(1))
        self.CursorY = int(CursorPosGr.group(2))

        gfltr = re.compile(r"(\d+)?x?(\d+)?([+-])(\d+)([+-])(\d+)")

        gf = gfltr.search(self.wm_geometry())
        self.X = int(gf.group(4))
        self.Y = int(gf.group(6))

    def relative_mouse_position (self, event):
        self.geom_grab()

        RelX = self.CursorX - self.X
        RelY = self.CursorY - self.Y

        self.Ca.bind( "<Motion>", lambda event: self.wid_drag(event, RelX, RelY) )

    def wid_drag (self, event, RelX, RelY):


        self.geom_grab()

        X = self.CursorX - RelX
        Y = self.CursorY - RelY

        if X < 0:
            X = 0

        if Y < 0:
            Y = 0

        self.wm_geometry('+' + str(X) + '+' + str(Y))


    def wid_unbind (self, event):
        self.Ca.unbind("<Motion>")

def run():
    StippleCanvas(None).mainloop()
if __name__ == '__main__':
    run()

1 个答案:

答案 0 :(得分:0)

最简单的?这取决于你对“简单”的定义。一种方法是使用绘图程序为背景创建所需的图像,然后将其放在画布中。这假设您提前知道画布的大小。没有什么比将单个图像插入画布更简单了。

此主题的变体是创建一个小图块,并使用tkinter的图像处理来创建适当大小的新图像,并在新图像中平铺原始图像。每次调整画布大小时都可以执行此操作。可以在下面的链接中看到这方面的一些例子,虽然它们在Tcl而不是Python中(将它转换为python是非常直接的,所以不要让它吓到你):

http://wiki.tcl.tk/4389

坦率地说,对于一个简单的点画,你做的很好。我将点画图移动到一个函数,这样每当画布改变大小时它就可以重新运行(即:当它获得<Configure>事件时)。