跳至主要内容

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()

评论

此博客中的热门博文

Mongo 入门

https://pymongo.readthedocs.io/en/stable/tutorial.html https://www.mongodb.com/languages/python https://zhuanlan.zhihu.com/p/51171906 https://www.runoob.com/python3/python-mongodb.html https://blog.baoshuo.ren/post/luogu-spider/ https://hub.docker.com/_/mongo 安装 MongoDB $ docker search mongo 启动一个mongo服务器实例 $ docker run --name some-mongo -d mongo:tag some-mongo是您要分配给容器的名称,tag是指定您想要的 MongoDB 版本的标签 MongoDB 的默认数据目录路径是/data/db 如下: $ docker run -it -v mongodata:/data/db -p 27017:27017 --name mongodb --restart unless-stopped -d mongo 你应该让 MongoDB 在端口 27017 上运行,并且可以通过localhostWindows 和 Ubuntu 20.04 上的URL访问 http://localhost:27017/ -p 是 HOST_PORT:CLIENT_PORT  -P 随机端口 -p 27017:27017 :将容器的27017 端口映射到主机的27017 端口 -v mongodata:/data/db :将主机中当前目录下的db挂载到容器的/data/db,作为mongo数据存储目录 从另一个 Docker 容器连接到 MongoDB 镜像中的 MongoDB 服务器侦听标准 MongoDB 端口27017,因此通过 Docker 网络连接将与连接到远程mongod. 以下示例启动另一个 MongoDB 容器实例,并mongo针对上述示例中的原始 MongoDB 容器运行命令行客户端,从而允许您针对数据库实例执行 MongoDB 语句: $ docker run -it --network some-network --...

MechanicalSoup

用于自动与网站交互的 Python 库。 MechanicalSoup 自动存储和发送 cookie,跟踪重定向,并且可以跟踪链接和提交表单。 它不执行 JavaScript。 https://github.com/MechanicalSoup/MechanicalSoup https://mechanicalsoup.readthedocs.io/en/stable/index.html https://realpython.com/python-web-scraping-practical-introduction/ pip show Mechanicalsoup 找到模块的安装位置 https://stackoverflow.com/questions/54352162/download-file-with-mechanicalsoup # Install dependencies # pip install requests # pip install BeautifulSoup4 # pip install MechanicalSoup # Import libraries import mechanicalsoup import urllib.request import requests from bs4 import BeautifulSoup import re # Create a browser object that can collect cookies browser = mechanicalsoup.StatefulBrowser() browser.open("https://www.ons.gov.uk/economy/grossdomesticproductgdp/timeseries/l2kq/qna") browser.download_link(link_text=".xls",file="D:/ONS_Data.xls" )

端口映射 公网访问内网

https://portforward.com/ Holer 通过安全隧道将位于NAT和防火墙之后的本地服务器暴露给公共Internet。 Holer是一个将原型中的应用映射到公网访问的端口映射软件,支持转发基于TCP协议的报文 https://github.com/wisdom-projects/holer 方式一:使用(公告)的holer映射或者开通holer服务,通过holer客户端软件经 holer服务器实现公网访问。 公开的holer映射详情如下: 访问密钥 访问域名 公网地址 本地地址 使用场景 HOLER_CLIENT-2F8D8B78B3C2A0AE holer65530.wdom.net holer.org:65530 127.0.0.1:8080 网页 HOLER_CLIENT-3C07CDFD1BF99BF2 holer65531.wdom.net holer.org:65531 127.0.0.1:8088 网页 HOLER_CLIENT-2A623FCB6E2A7D1D holer65532.wdom.net holer.org:65532 127.0.0.1:80 网页 HOLER_CLIENT-AF3E6391525F70E4 不适用 holer.org:65533 127.0.0.1:3389 远程桌面 HOLER_CLIENT-822404317F9D8ADD 不适用 holer.org:65534 127.0.0.1:22 SSH协议 HOLER_CLIENT-27DD1389DF1D4DBC 不适用 holer.org:65535 127.0.0.1:3306 数据库 使用Java版本的holer客户端 ①java 1.7或者更高版本 ②下载holer-client.zip 修改配置文件C:\holer-client\conf\holer.conf HOLER_ACCESS_KEY=HOLER_CLIENT-2A623FCB6E2A7D1D HOLER_SERVER_HOST=holer65532.wdom.net ③建议先双击运行C:\holer-client\bin\shutdown.bat,再双击运行C:\holer-client\bin\startup.bat...