我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python GUI之tkinter详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python GUI之tkinter详解

展示

在这里插入图片描述


import tkinter
 if __name__ == '__main__':
    win = tkinter.Tk()
     #设置标题
    win.title("我的世界")
     #设置宽和高
    win.geometry('800x600')
     #创建画布,设置背景色,高,宽
    canvas = tkinter.Canvas(win,bg='#EBEBEB',width=800,height=1200,xscrollincrement = 1,
                yscrollincrement = 1)
    x0,y0 = 100,100
    # 创建一个圆,填充红色,轮廓白色
    oval = canvas.create_oval(x0-5,y0-5,x0+5,y0+5,fill='#ff0000',outline="#000000",tags="node")
    canvas.create_text(x0,y0-10,text='('+str(x0) +','+str(y0)+')',fill='black',tags="text")
    p1 = (x0,y0)
     x0, y0 = 120,170
    oval = canvas.create_oval(x0 - 5, y0 - 5, x0 + 5, y0 + 5, fill='#ff0000', outline="#000000", tags="node")
    canvas.create_text(x0, y0 - 10, text='(' + str(x0) + ',' + str(y0) + ')', fill='black',tags="text")
    p2 = (x0, y0)
     #连线
    canvas.create_line(p1, p2, fill='#000000', tags="line")
     canvas.pack(expand = tkinter.YES, fill = tkinter.BOTH)
     #删除tags = "text"
    # canvas.delete("text")
     win.mainloop()

在这里插入图片描述


from tkinter import *
import random
if __name__ == '__main__':
    win = Tk()
     #设置标题
    win.title("我的世界")
     #设置宽和高
    win.geometry('800x600')
    frame = Frame(win)
     #创建画布,设置背景色,高,宽
    canvas = Canvas(frame,bg='#EBEBEB',width=800,height=800,scrollregion=(0,0,2000,1200))
    pos = [[565.0,575.0],[25.0,185.0],[345.0,750.0],[945.0,685.0],[845.0,655.0],
                        [880.0,660.0],[25.0,230.0],[525.0,1000.0],[580.0,1175.0],[650.0,1130.0],
                        [1605.0,620.0],[1220.0,580.0],[1465.0,200.0],[1530.0,  5.0],[845.0,680.0],
                        [725.0,370.0],[145.0,665.0],[415.0,635.0],[510.0,875.0],[560.0,365.0],
                        [300.0,465.0],[520.0,585.0],[480.0,415.0],[835.0,625.0],[975.0,580.0],
                        [1215.0,245.0],[1320.0,315.0],[1250.0,400.0],[660.0,180.0],[410.0,250.0],
                        [420.0,555.0],[575.0,665.0],[1150.0,1160.0],[700.0,580.0],[685.0,595.0],
                        [685.0,610.0],[770.0,610.0],[795.0,645.0],[720.0,635.0],[760.0,650.0],
                        [475.0,960.0],[95.0,260.0],[875.0,920.0],[700.0,500.0],[555.0,815.0],
                        [830.0,485.0],[1170.0, 65.0],[830.0,610.0],[605.0,625.0],[595.0,360.0],
                        [1340.0,725.0],[1740.0,245.0]]
    for x,y in pos:
        canvas.create_oval(x - 5, y - 5, x + 5, y + 5, fill='#ff0000', outline="#000000", tags="node")
        canvas.create_text(x, y - 10, text='(' + str(x) + ',' + str(y) + ')', fill='black', tags="text")
     length = len(pos)
    path = [x for x in range(length)]
    random.shuffle(path)
     for i in range(length-1):
        canvas.create_line(pos[i], pos[i+1], fill='#000000', tags="line")
     hbar = Scrollbar(frame,orient=HORIZONTAL)  # 定义水平滚动条
    hbar.pack(side=BOTTOM, fill=X)  # 放置水平滚动条在最下侧,占满X轴
    hbar.config(command=canvas.xview)# 设置水平滚动条的函数与画布的X轴滚动条事件绑定
    vbar = Scrollbar(frame,orient=VERTICAL)  # 定义垂直滚动条
    vbar.pack(side=RIGHT, fill=Y)  # 放置垂直滚动条在最右侧,占满Y轴
    vbar.config(command=canvas.yview)# 设置垂直滚动条的函数与画布的Y轴滚动条事件绑定
     canvas.config(xscrollcommand=hbar.set, yscrollcommand=vbar.set) # 设置画布的X,Y轴滚动条函数与垂直滚动条绑定
    canvas.pack(expand=True, fill=BOTH)
    frame.pack(expand=True, fill=BOTH)
    #删除tags = "text"
    # canvas.delete("text")
     win.mainloop()
 

多线程

在这里插入图片描述


import time
from tkinter import *
import random
import threading
pos = [[565.0,575.0],[25.0,185.0],[345.0,750.0],[945.0,685.0],[845.0,655.0],
                        [880.0,660.0],[25.0,230.0],[525.0,1000.0],[580.0,1175.0],[650.0,1130.0],
                        [1605.0,620.0],[1220.0,580.0],[1465.0,200.0],[1530.0,  5.0],[845.0,680.0],
                        [725.0,370.0],[145.0,665.0],[415.0,635.0],[510.0,875.0],[560.0,365.0],
                        [300.0,465.0],[520.0,585.0],[480.0,415.0],[835.0,625.0],[975.0,580.0],
                        [1215.0,245.0],[1320.0,315.0],[1250.0,400.0],[660.0,180.0],[410.0,250.0],
                        [420.0,555.0],[575.0,665.0],[1150.0,1160.0],[700.0,580.0],[685.0,595.0],
                        [685.0,610.0],[770.0,610.0],[795.0,645.0],[720.0,635.0],[760.0,650.0],
                        [475.0,960.0],[95.0,260.0],[875.0,920.0],[700.0,500.0],[555.0,815.0],
                        [830.0,485.0],[1170.0, 65.0],[830.0,610.0],[605.0,625.0],[595.0,360.0],
                        [1340.0,725.0],[1740.0,245.0]]
 win = Tk()
 #设置标题
win.title("我的世界")
 #设置宽和高
win.geometry('800x600')
frame = Frame(win)
 #创建画布,设置背景色,高,宽
canvas = Canvas(frame,bg='#EBEBEB',width=800,height=800,scrollregion=(0,0,2000,1200))
 for x,y in pos:
    canvas.create_oval(x - 5, y - 5, x + 5, y + 5, fill='#ff0000', outline="#000000", tags="node")
    canvas.create_text(x, y - 10, text='(' + str(x) + ',' + str(y) + ')', fill='black', tags="text")
 hbar = Scrollbar(frame,orient=HORIZONTAL)  # 定义水平滚动条
hbar.pack(side=BOTTOM, fill=X)  # 放置水平滚动条在最下侧,占满X轴
hbar.config(command=canvas.xview)# 设置水平滚动条的函数与画布的X轴滚动条事件绑定
vbar = Scrollbar(frame,orient=VERTICAL)  # 定义垂直滚动条
vbar.pack(side=RIGHT, fill=Y)  # 放置垂直滚动条在最右侧,占满Y轴
vbar.config(command=canvas.yview)# 设置垂直滚动条的函数与画布的Y轴滚动条事件绑定
 canvas.config(xscrollcommand=hbar.set, yscrollcommand=vbar.set) # 设置画布的X,Y轴滚动条函数与垂直滚动条绑定
canvas.pack(expand=True, fill=BOTH)
frame.pack(expand=True, fill=BOTH)
def run():
    length = len(pos)
    path = [x for x in range(length)]
    random.shuffle(path)
    time.sleep(1)
     for i in range(length - 1):
        canvas.create_line(pos[i], pos[i + 1], fill='#000000', tags="line", arrow=LAST, width=1)
        time.sleep(1)
if __name__ == '__main__':
     #删除tags = "text"
    # canvas.delete("text")
     t = threading.Thread(target=run)
    t.start()
     win.mainloop()
 

暂定版本

个人知识还是不够,里面还有很多小bug,容我再思考思考

在这里插入图片描述


import time
from tkinter import *
import random
import sys
import threading
class TSP(object):
    def __init__(self,root,cities:list[list]):
        self.__root = root
        self.__root.geometry('800x600')
        self.__root.title("TSP蚁群算法(n:初始化 e:开始搜索 s:停止搜索 c:继续搜索 q:退出程序)")
        self.__frame = Frame(root)
        self.__canvas = Canvas(self.__frame,bg='#EBEBEB',width=800,height=800,scrollregion=(0,0,2000,1200))
         hbar = Scrollbar(self.__frame, orient=HORIZONTAL)  # 定义水平滚动条
        hbar.pack(side=BOTTOM, fill=X)  # 放置水平滚动条在最下侧,占满X轴
        hbar.config(command=self.__canvas.xview)  # 设置水平滚动条的函数与画布的X轴滚动条事件绑定
        vbar = Scrollbar(self.__frame, orient=VERTICAL)  # 定义垂直滚动条
        vbar.pack(side=RIGHT, fill=Y)  # 放置垂直滚动条在最右侧,占满Y轴
        vbar.config(command=self.__canvas.yview)  # 设置垂直滚动条的函数与画布的Y轴滚动条事件绑定
         self.__canvas.config(xscrollcommand=hbar.set, yscrollcommand=vbar.set)  # 设置画布的X,Y轴滚动条函数与垂直滚动条绑定
        self.__canvas.pack(expand=True, fill=BOTH)
        self.__frame.pack(expand=True, fill=BOTH)
        self.setCity(cities)
         self.__lock = threading.RLock()  # 线程锁
        self.__bindEvents()
         self.__new()
     def setCity(self,cities:list[list]):
        self.__cities = cities
    def sefPathsAndValues(self,paths:[list],values:list):
        self.__paths = paths
        self.__values = values
     # 按键响应程序
    def __bindEvents(self):
        self.__root.bind("q", self.__quite)  # 退出程序
        self.__root.bind("n", self.__new)  # 初始化
        self.__root.bind("e", self.__search_path)  # 开始搜索
        self.__root.bind("s", self.__stop)  # 停止搜索
        self.__root.bind("c", self.__continue)  # 继续搜索
     #初始化
    def __new(self,event=None):
        self.__lock.acquire()       #上锁
        self.__running = False      #标志位
        self.__lock.release()       #释放锁
         for x, y in self.__cities:
            self.__canvas.create_oval(x - 5, y - 5, x + 5, y + 5, fill='#ff0000', outline="#000000", tags="node")
            self.__canvas.create_text(x, y - 10, text='(' + str(x) + ',' + str(y) + ')', fill='black', tags="text")
    def __quite(self,event=None):
        self.__lock.acquire()  # 上锁
        self.__running = False  # 标志位
        self.__lock.release()  # 释放锁
        self.__root.destroy()
        print(u"\n程序已退出...")
        sys.exit()
        # 停止搜索
     def __stop(self,event=None):
        self.__lock.acquire()  # 上锁
        self.__running = False  # 标志位
        self.__lock.release()  # 释放锁
    def __line(self,path:list):
        self.__canvas.delete("line")
        i = 0
        while self.__running:
            if i == len(self.__cities) -1:
                break
            p1, p2 = self.__cities[path[i]], self.__cities[path[i + 1]]
            self.__canvas.create_line(p1, p2, fill='#000000', tags="line",
                                      arrow=LAST, width=1)
            self.__canvas.update()
            self.__canvas.after(500)
            i = i+1
     # 开始搜索
    def __search_path(self,event=None):
        self.__lock.acquire()  # 上锁
        self.__running = True  # 标志位
        self.__lock.release()  # 释放锁
         while self.__running:
            x = random.randint(10,100)
            label = Label(self.__canvas,text="最佳路径总距离:"+str(x)).place(x=10,y=30)
            self.__canvas.update()
            path = [x for x in range(len(self.__cities))]
            random.shuffle(path)
            self.__line(path)
     def __continue(self,event=None):
        self.__lock.acquire()  # 上锁
        self.__running = True  # 标志位
        self.__lock.release()  # 释放锁
    def mainloop(self):
        self.__root.mainloop()
if __name__ == '__main__':
     tsp = TSP(Tk(),cities)
    tsp.mainloop()

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程网的更多内容!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python GUI之tkinter详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python学习之GUI(Tkinter

button按钮的生成:import Tkinter as tkwindow=tk.Tk()def buttonClick():    print "Beep!"button=tk.Button(window,text="Click me!
2023-01-31

Python Tkinter GUI

一,Tkinter介绍Tkinter是一个python模块,是一个调用Tcl/Tk的接口,它是一个跨平台的脚本图形界面接口。Tkinter不是唯一的python图形编程接口,但是是其中比较流行的一个。最大的特点是跨平台,缺点是性能不太好,执
2023-01-31

Python GUI(Tkinter)初

Python version: 3.7.0效果:代码:import tkinter as tkdef openPath():    print("aaa")frm = tk.Tk()frm.title('Auto Rename File T
2023-01-31

python--GUI编程--Tkinter

Tkinter: Tkinter 模块(Tk 接口)是 Python 的标准 Tk GUI 工具包的接口 .Tk 和 Tkinter 可以在大多数的 Unix 平台下使用,同样可以应用在 Windows 和 Macintosh 系统里。Tk
2023-01-30

Python GUI之如何使用tkinter控件

目录一、功能按钮二、文本框三、练习一四、练习二:计算器一、功能按钮 格式:Button(父对象,options,…) 父对象:表示当前按钮建立在哪一个窗口下。 options:下面总结一部常用的。 1.bg或者background:背景色
2022-06-02

Python tkinter GUI动态改变图像

问题内容我来自java,只想创建一个带有图片的图形用户界面,但是图片正在动态变化,我不知道它将是哪张图片......但它不起作用,我只能创建一个图像并且无法在 root.mainloop() 之外更改它并收到大量错误消息...有人知道如
Python tkinter GUI动态改变图像
2024-02-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录