跳至主要内容

tkinter 练习之画笔(重置、撤销、还原)

import tkinter as tk
import sys
import os


class App(tk.Tk):
    b1 = "up"
    xold, yold = None, None
    color = "black"
    linesize = 2
    counter = 1  # keeps track of the current working line, is incremented as soon as line is finished
    undone = []  # keeps a list of coordinate lists on undone items

    def __init__(self):
        tk.Tk.__init__(self)
        self.drawing_area = tk.Canvas(self, width=600, height=600, background="white")
        self.drawing_area.pack()
        self.drawing_area.bind("<Motion>", self.motion)
        self.drawing_area.bind("<ButtonPress-1>", self.b1down)
        self.drawing_area.bind("<ButtonRelease-1>", self.b1up)

        self.button1 = tk.Button(self, text="Reset", command=self.blank_canvas, anchor=tk.N)
        self.button1.configure(width=3, background="#FFFFFF", relief=tk.FLAT)
        self.button1.pack(side="left")

        self.button2 = tk.Button(self, text="Undo", command=self.undo, anchor=tk.N)
        self.button2.configure(width=3, background="#FFFFFF", relief=tk.FLAT)
        self.button2.pack(side="left")

        self.button3 = tk.Button(self, text="Redo", command=self.redo, anchor=tk.N)
        self.button3.configure(width=3, background="#FFFFFF", relief=tk.FLAT)
        self.button3.pack(side="left")

    def blank_canvas(self):
        self.drawing_area.delete("line")

    def undo(self):
        self.counter -= 1  # decrements the counter to look at the previous item
        currentlist = []  # creates a list to store the coordinates in
        for item in self.drawing_area.find_withtag(
                "line" + str(self.counter)):  # find all sub lines from the previous line
            currentlist.append(self.drawing_area.coords(item))  # get and add the coordinates to the working list
        self.drawing_area.delete("line" + str(self.counter))  # delete all items of the current line
        self.undone.append(currentlist)  # add the working list to the stored list

    def redo(self):
        try:
            currentlist = self.undone.pop()  # fetch and remove last set of coordinates
            for coords in currentlist:  # for set of coordinates redraw subline
                self.drawing_area.create_line(coords, smooth=tk.TRUE, fill=self.color, width=self.linesize,
                                              tags=["line", "line" + str(self.counter)])
            self.counter += 1  # re increment counter
        except IndexError:
            pass  # occurs if list is empty

    def b1down(self, event):
        self.b1 = "down"

    def b1up(self, event):
        self.b1 = "up"
        self.xold = None
        self.yold = None
        self.counter += 1

    def motion(self, event):
        if self.b1 == "down":
            if self.xold is not None and self.yold is not None:
                event.widget.create_line(self.xold, self.yold, event.x, event.y, smooth=tk.TRUE, fill=self.color,
                                         width=self.linesize, tags=["line", "line" + str(self.counter)])
            self.xold = event.x
            self.yold = event.y


if __name__ == "__main__":
    app = App()
    app.mainloop()

评论

此博客中的热门博文

自动发送消息

  # https://pyperclip.readthedocs.io/en/latest/ import pyperclip while True :     # pyperclip.copy('Hello, world!')     # pyperclip.paste()     # pyperclip.waitForPaste()     print ( pyperclip. waitForNewPaste ( ) )     # 获取要输入新的坐标,也可以通过autohotkey import time import pyautogui  as pag import os   try :     while True :         print ( "Press Ctrl-C to end" )         x , y = pag. position ( )   # 返回鼠标的坐标         posStr = "Position:" + str ( x ) . rjust ( 4 ) + ',' + str ( y ) . rjust ( 4 )         print ( posStr )   # 打印坐标         time . sleep ( 0.2 )         os . system ( 'cls' )   # 清楚屏幕 except KeyboardInterrupt :     print ( 'end....' )     # 打印消息 import pyautogui import time import pyperclip   content = """   呼叫龙叔! 第二遍! 第三遍! 第四遍...

学习地址

清华大学计算机系课程攻略 https://github.com/PKUanonym/REKCARC-TSC-UHT 浙江大学课程攻略共享计划 https://github.com/QSCTech/zju-icicles https://home.unicode.org/ 世界上的每个人都应该能够在手机和电脑上使用自己的语言。 http://codecanyon.net   初次看到这个网站,小伙伴们表示都惊呆了。原来代码也可以放在网上卖的?!! 很多coder上传了各种代码,每个代码都明码标价。看了下销售排行,有的19刀的卖了3万多份,额di神啊。可以看到代码的演示效果,真的很漂亮。代码以php、wordpress主题、Javascript、css为主,偏前台。 https://www.lintcode.com/ 算法学习网站,上去每天刷两道算法题,走遍天下都不怕。 https://www.codecademy.com/ 包含在线编程练习和课程视频 https://www.reddit.com/ 包含有趣的编程挑战题,即使不会写,也可以查看他人的解决方法。 https://ideone.com/ 在线编译器,可运行,可查看代码示例。 http://it-ebooks.info/ 大型电子图书馆,可即时免费下载书籍。 刷题 https://github.com/jackfrued/Python-100-Days https://github.com/kenwoodjw/python_interview_question 面试问题 https://github.com/kenwoodjw/python_interview_question https://www.journaldev.com/15490/python-interview-questions#python-interpreter HTTP 身份验证 https://developer.mozilla.org/zh-CN/docs/Web/HTTP/Authentication RESTful 架构详解 https://www.runoob.com/w3cnote/restful-architecture.html https://www.rosettacode.org/wiki/Rosetta_C...

mysql 入门

资料 https://dinfratechsource.com/2018/11/10/how-to-install-latest-mysql-5-7-21-on-rhel-centos-7/ https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html https://www.runoob.com/mysql/mysql-create-database.html https://www.liquidweb.com/kb/install-java-8-on-centos-7/ 工具 https://www.heidisql.com/ HeidiSQL是免费软件,其目标是易于学习。 “ Heidi”使您可以从运行数据库系统MariaDB,MySQL,Microsoft SQL或PostgreSQL的计算机上查看和编辑数据和结构 MySQL 连接时尽量使用 127.0.0.1 而不是 localhost localhost 使用的 Linux socket,127.0.0.1 使用的是 tcp/ip 为什么我使用 localhost 一直没出问题 因为你的本机中只有一个 mysql 进程, 如果你有一个 node1 运行在 3306, 有一个 node2 运行在 3307 mysql -u root -h localhost -P 3306 mysql -u root -h localhost -P 3307 都会连接到同一个 mysql 进程, 因为 localhost 使用 Linux socket, 所以 -P 字段直接被忽略了, 等价于 mysql -u root -h localhost mysql -u root -h localhost 而 -h 默认是 localhost, 又等价于 mysql -u root mysql -u root 为了避免这种情况(比如你在本地开发只有一个 mysql 进程,线上或者 qa 环境有多个 mysql 进程)最好的方式就是使用 IP mysql -u root -h 127 .0 .0 .1 -P 3307 strac...