Tkinter

Tkinter是Python的一款功能强大且全面、操作简易的GUI编程模块。今天,我们将使用tkinter制作一款简易画图软件。加油吧!

最终效果如下:


下载模块

我们将使用Python 3.10为编译器,使用 pip 下载所需模块:

pip install tkinter
pip install PIL

导入模块

这里,我们将导入所有所需的模块。

import time
import tkinter
import tkinter.simpledialog
import tkinter.colorchooser
import tkinter.filedialog
from PIL import Image, ImageTk, ImageGrab

设置主窗口

设置所有接下来所需的元素,并初始化。

def center_window(w, h):app.winfo_screenwidth()app.winfo_screenheight()app.geometry('%dx%d' % (w, h))app = tkinter.Tk()
app.title('轩氏画图')
x = 1200
y = 800
center_window(x, y)yesno = tkinter.IntVar(value=0)
what = tkinter.IntVar(value=1)
X = tkinter.IntVar(value=0)
Y = tkinter.IntVar(value=0)foreColor = '#000000'
backColor = '#FFFFFF'image = tkinter.PhotoImage()
canvas = tkinter.Canvas(app, bg='white', width=x, height=y)
canvas.create_image(x, y, image=image)lastDraw = 0
end = [0]
size = "20"

基本画图运算逻辑

重点来了!我们使用鼠标左键按下等动作探测,绘制曲线:


def getter(widget):time.sleep(0.5)x = app.winfo_x() + widget.winfo_x()y = app.winfo_y() + widget.winfo_y()if app.winfo_x() < 0:x = 0if app.winfo_y() < 0:y = 0x1 = x + widget.winfo_width() + 200y1 = y + widget.winfo_height() + 200filename = tkinter.filedialog.asksaveasfilename(filetypes=[('.jpg', 'JPG')],initialdir='C:\\Users\\lin042\\Desktop\\')ImageGrab.grab().crop((x, y, x1, y1)).save(filename)def onLeftButtonDown(event):yesno.set(1)X.set(event.x)Y.set(event.y)if what.get() == 4:canvas.create_text(event.x, event.y, font=("等线", int(size)), text=text, fill=foreColor)what.set(1)def onLeftButtonMove(event):global lastDrawif yesno.get() == 0:returnif what.get() == 1:lastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y,fill=foreColor)X.set(event.x)Y.set(event.y)elif what.get() == 2:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y,fill=foreColor)elif what.get() == 3:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_rectangle(X.get(), Y.get(), event.x, event.y,outline=foreColor)elif what.get() == 5:lastDraw = canvas.create_rectangle(event.x - 10, event.y - 10, event.x + 10, event.y + 10,outline=backColor)elif what.get() == 6:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_oval(X.get(), Y.get(), event.x, event.y,fill=backColor, outline=foreColor)def onLeftButtonUp(event):global lastDrawif what.get() == 2:lastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y, fill=foreColor)elif what.get() == 3:lastDraw = canvas.create_rectangle(X.get(), Y.get(), event.x, event.y, outline=foreColor)elif what.get() == 6:lastDraw = canvas.create_oval(X.get(), Y.get(), event.x, event.y, outline=foreColor)yesno.set(0)end.append(lastDraw)def onRightButtonUp(event):menu.post(event.x_root, event.y_root)

最后通过bind来移动画笔:

canvas.bind('<Button-1>', onLeftButtonDown)
canvas.bind('<B1-Motion>', onLeftButtonMove)
canvas.bind('<ButtonRelease-1>', onLeftButtonUp)
canvas.bind('<ButtonRelease-3>', onRightButtonUp)
canvas.pack(fill=tkinter.BOTH, expand=tkinter.YES)

顶部主菜单

设置主菜单功能及运算函数。目前包括以下五个选项:导入、保存、撤销、清屏和工具栏。

'''主菜单及其关联的函数'''
menu = tkinter.Menu(app, bg="red")
app.config(menu=menu)def Open():filename = tkinter.filedialog.askopenfilename(title='导入图片',filetypes=[('image', '*.jpg *.png *.gif')])if filename:global imageimage = Image.open(filename)image = image.resize((800, 600), Image.ANTIALIAS)image = ImageTk.PhotoImage(image)canvas.create_image(400, 300, image=image)menu.add_command(label='导入', command=Open)def Save():getter(canvas)menu.add_command(label='保存', command=Save)def Clear():global lastDraw, endfor item in canvas.find_all():canvas.delete(item)end = [0]lastDraw = 0menu.add_command(label='清屏', command=Clear)def Back():global endtry:for i in range(end[-2], end[-1] + 1):canvas.delete(i)end.pop()except:end = [0]menu.add_command(label='撤销', command=Back)menu.add_separator()

工具栏子菜单

设置“工具栏”下子菜单函数和内容,运算逻辑前面已经定义过了,这里我们只需要调用并绑定按钮即可。

'''子菜单及其关联的函数'''
menuType = tkinter.Menu(menu, tearoff=0)def drawCurve():what.set(1)menuType.add_command(label='铅笔', command=drawCurve)def drawLine():what.set(2)menuType.add_command(label='直线', command=drawLine)def drawRectangle():what.set(3)menuType.add_command(label='矩形', command=drawRectangle)def drawCircle():what.set(6)menuType.add_command(label='圆形', command=drawCircle)def drawText():global text, sizetext = tkinter.simpledialog.askstring(title='输入文本', prompt='')if text is not None:size = tkinter.simpledialog.askinteger('输入字号', prompt='', initialvalue=20)if size is None:size = "20"what.set(4)menuType.add_command(label='文本', command=drawText)def onErase():what.set(5)menuType.add_command(label='橡皮擦', command=onErase)
menuType.add_separator()def chooseForeColor():global foreColorforeColor = tkinter.colorchooser.askcolor()[1]menuType.add_command(label='选择前景色', command=chooseForeColor)def chooseBackColor():global backColorbackColor = tkinter.colorchooser.askcolor()[1]menuType.add_command(label='选择背景色', command=chooseBackColor)menu.add_cascade(label='工具栏', menu=menuType)

进入窗口循环

最后,使用mainloop进入窗口循环。

app.mainloop()

效果展示

最终效果展示:


完整代码

完整代码如下:

import time
import tkinter
import tkinter.simpledialog
import tkinter.colorchooser
import tkinter.filedialog
from PIL import Image, ImageTk, ImageGrabdef center_window(w, h):app.winfo_screenwidth()app.winfo_screenheight()app.geometry('%dx%d' % (w, h))app = tkinter.Tk()
app.title('轩氏画图')
x = 1200
y = 800
center_window(x, y)yesno = tkinter.IntVar(value=0)
what = tkinter.IntVar(value=1)
X = tkinter.IntVar(value=0)
Y = tkinter.IntVar(value=0)foreColor = '#000000'
backColor = '#FFFFFF'image = tkinter.PhotoImage()
canvas = tkinter.Canvas(app, bg='white', width=x, height=y)
canvas.create_image(x, y, image=image)lastDraw = 0
end = [0]
size = "20"def getter(widget):time.sleep(0.5)x = app.winfo_x() + widget.winfo_x()y = app.winfo_y() + widget.winfo_y()if app.winfo_x() < 0:x = 0if app.winfo_y() < 0:y = 0x1 = x + widget.winfo_width() + 200y1 = y + widget.winfo_height() + 200filename = tkinter.filedialog.asksaveasfilename(filetypes=[('.jpg', 'JPG')],initialdir='C:\\Users\\lin042\\Desktop\\')ImageGrab.grab().crop((x, y, x1, y1)).save(filename)def onLeftButtonDown(event):yesno.set(1)X.set(event.x)Y.set(event.y)if what.get() == 4:canvas.create_text(event.x, event.y, font=("等线", int(size)), text=text, fill=foreColor)what.set(1)def onLeftButtonMove(event):global lastDrawif yesno.get() == 0:returnif what.get() == 1:lastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y,fill=foreColor)X.set(event.x)Y.set(event.y)elif what.get() == 2:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y,fill=foreColor)elif what.get() == 3:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_rectangle(X.get(), Y.get(), event.x, event.y,outline=foreColor)elif what.get() == 5:lastDraw = canvas.create_rectangle(event.x - 10, event.y - 10, event.x + 10, event.y + 10,outline=backColor)elif what.get() == 6:try:canvas.delete(lastDraw)except Exception:passlastDraw = canvas.create_oval(X.get(), Y.get(), event.x, event.y,fill=backColor, outline=foreColor)def onLeftButtonUp(event):global lastDrawif what.get() == 2:lastDraw = canvas.create_line(X.get(), Y.get(), event.x, event.y, fill=foreColor)elif what.get() == 3:lastDraw = canvas.create_rectangle(X.get(), Y.get(), event.x, event.y, outline=foreColor)elif what.get() == 6:lastDraw = canvas.create_oval(X.get(), Y.get(), event.x, event.y, outline=foreColor)yesno.set(0)end.append(lastDraw)def onRightButtonUp(event):menu.post(event.x_root, event.y_root)canvas.bind('<Button-1>', onLeftButtonDown)
canvas.bind('<B1-Motion>', onLeftButtonMove)
canvas.bind('<ButtonRelease-1>', onLeftButtonUp)
canvas.bind('<ButtonRelease-3>', onRightButtonUp)
canvas.pack(fill=tkinter.BOTH, expand=tkinter.YES)'''主菜单及其关联的函数'''
menu = tkinter.Menu(app, bg="red")
app.config(menu=menu)def Open():filename = tkinter.filedialog.askopenfilename(title='导入图片',filetypes=[('image', '*.jpg *.png *.gif')])if filename:global imageimage = Image.open(filename)image = image.resize((800, 600), Image.ANTIALIAS)image = ImageTk.PhotoImage(image)canvas.create_image(400, 300, image=image)menu.add_command(label='导入', command=Open)def Save():getter(canvas)menu.add_command(label='保存', command=Save)def Clear():global lastDraw, endfor item in canvas.find_all():canvas.delete(item)end = [0]lastDraw = 0menu.add_command(label='清屏', command=Clear)def Back():global endtry:for i in range(end[-2], end[-1] + 1):canvas.delete(i)end.pop()except:end = [0]menu.add_command(label='撤销', command=Back)menu.add_separator()'''子菜单及其关联的函数'''
menuType = tkinter.Menu(menu, tearoff=0)def drawCurve():what.set(1)menuType.add_command(label='铅笔', command=drawCurve)def drawLine():what.set(2)menuType.add_command(label='直线', command=drawLine)def drawRectangle():what.set(3)menuType.add_command(label='矩形', command=drawRectangle)def drawCircle():what.set(6)menuType.add_command(label='圆形', command=drawCircle)def drawText():global text, sizetext = tkinter.simpledialog.askstring(title='输入文本', prompt='')if text is not None:size = tkinter.simpledialog.askinteger('输入字号', prompt='', initialvalue=20)if size is None:size = "20"what.set(4)menuType.add_command(label='文本', command=drawText)def onErase():what.set(5)menuType.add_command(label='橡皮擦', command=onErase)
menuType.add_separator()def chooseForeColor():global foreColorforeColor = tkinter.colorchooser.askcolor()[1]menuType.add_command(label='选择前景色', command=chooseForeColor)def chooseBackColor():global backColorbackColor = tkinter.colorchooser.askcolor()[1]menuType.add_command(label='选择背景色', command=chooseBackColor)menu.add_cascade(label='工具栏', menu=menuType)app.mainloop()

喜欢就点个赞,收藏一下吧~

我是轩哥啊哈,下期我们不见不散~

Python tkinter库:简易画板(笔、直线、矩形、圆形和橡皮擦工具+导入、保存、撤销、清屏功能)相关推荐

  1. python tkinter库 密码实时显示_python tkinter库实现气泡屏保和锁屏

    本文实例为大家分享了python tkinter库实现气泡屏保和锁屏的具体代码,供大家参考,具体内容如下 显示效果如下: 代码: import random import tkinter import ...

  2. python tkinter库实现华氏温度摄氏温度转换

    python tkinter库实现华氏温度摄氏温度转换 功能要求 创建GUI窗口 创建文本标签 创建可输入文本 按钮控件 创建显示文本框 温度转换函数-g 总程序 结束啦 功能要求 创建一个图形窗口, ...

  3. 使用python+Tkinter库构建GUI应用工具 - 个性签名工具

    使用python+Tkinter库构建GUI应用工具 - 个性签名工具 安装Tkinter及pillow库 pip install tkinter # 安装tkinter库 pip install p ...

  4. python如何设置清屏功能_Python的IDEL增加清屏功能实例

    为idle增加一个清屏的扩展ClearWindow就可以了(在http://bugs.python.org/issue6143中可以看到这个扩展的说明). 下面我说安装使用的方法.首先下载clearw ...

  5. python tkinter库、添加gui界面_使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二)...

    使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二),创建一个,界面,布局,文件,路径 使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二) ...

  6. python tkinter库 pack布局方法调用

    python的tkinter库pack布局方法调用 这个布局简单 tkinter.Label(window,text='今晚去庆祝',bg="back",fg='white').p ...

  7. Python+tkinter库实现简单图书管理系统

    文章目录 前言 一.MySQL是什么? 二.Tkinter库 三.Code步骤 1.引入库 2.使用tkinter搭建系统 3.定义函数(发送消息,操作mysql数据库) 总结 前言 使用mysql数 ...

  8. 树回归--python Tkinter库创建GUI(2)

    简单的Tkinter库创建GUI的例子可参考: http://blog.csdn.net/lilong117194/article/details/78456376 下面是代码: # -*- codi ...

  9. Python IDLE 如何设置清屏功能(清屏快捷键,亲测可用)

    前言   在使用 Python IDLE 时,我时常想有没有像命令提示符环境中的 cls 那样的清屏命令,一下子删除交互模式中所有已执行的命令,毕竟每次都关掉再重新打开 IDLE 有点麻烦,于是在网上 ...

最新文章

  1. Ubuntu 系统 卸载OpenJDK 8
  2. 基于Smiles2vec预测化合物物理性质
  3. 「SAP技术」SAP 如何看序列号被包在哪些HU里?
  4. 放心,GPT-3不会“杀死”编程
  5. Linux内核分析 - 网络[六]:网桥
  6. 关于对Enum的理解
  7. HarmonyOS应用开发者门户,HarmonyOS 手机应用开发者 Beta 版到来,对开发者意味着什么...
  8. Python 装饰器学习以及实际使用场景实践
  9. pandaboard 安装_linux fb设备(pandaboard) | 学步园
  10. 苹果发布会邀请函被玩坏:神似桂林西瓜霜
  11. 一文了解H5照片上传过程
  12. 摩拜服务器维护,摩拜的后台是云服务器
  13. android游戏开发框架libgdx环境搭建
  14. Android 在Android手机上获取其他应用的包名及版本号
  15. 纯新手DSP编程--5.31--DSP/BIOS中的数据交换
  16. NGN学习笔记2——软交换技术
  17. JavaMail之发送邮件+接收邮件
  18. 互联网运营工作需要做什么?
  19. bh1750采集流程图_多路BH1750光强检测系统的设计
  20. xp 启动linux系统安装,Linux网络安装Centos/windows 2003/xp 并且启动winpe系统

热门文章

  1. 聚焦品牌化 Morketing2018第二届跨境出口电商营销峰会成功举办
  2. 机器学习集成学习与模型融合
  3. 计算机动画制作有什么软件,电脑绘画和动画制作,要用什么软件?
  4. DeepFunc:一种深度学习框架,可根据蛋白质序列和相互作用准确预测蛋白质功能
  5. 「UG/NX」NX2212手动安装方法教程
  6. PMP考试计算专题——网络图
  7. 三元运算符(三目运算符)
  8. linux分区表mbr改gtp,免重装系统 手把手教你MBR转GPT分区表
  9. 高晓松《晓说》为何这么红?
  10. 关于【你们数据仓库是怎么设计的】如何回答?