上帝为你开了一扇窗之Tkinter常用函数详解


Posted in Python onJune 02, 2021

第一步:导入模块,无需安装

import tkinter

第二步:实现一个窗口

import tkinter
tk=tkinter.Tk()
tk.mainloop()

 上帝为你开了一扇窗之Tkinter常用函数详解

这样,我们应该基本的gui窗口就搞定了。接下来,我们给它加点东西,让它看起来更加独特。

第三步:修改窗口名称

tk.title("窗口")

上帝为你开了一扇窗之Tkinter常用函数详解

第四步:设置窗口大小

tk.geometry("300x150+700+300")

参数:width x height+x+y,

分别对应,窗口 宽,高,以及窗口出现的坐标,

桌面的坐标系:以桌面左上角为(0,0)向右为x轴正半轴,向下为y轴正半轴

设置固定大小:

tk.minsize(560, 545) # 最小尺寸
 
tk.maxsize(560, 545) # 最大尺寸

设置全屏模式:

tk.attributes("-fullscreen", True)#全屏模式:True 全屏;False 正常显示
注:全屏模式没有退出按钮,关闭可使用win+D最小化才能关闭

上帝为你开了一扇窗之Tkinter常用函数详解

第五步:获取当前桌面的尺寸

有时候我们需要获取到当前屏幕的大小,来决定我们窗口的大小,那就需要获取当前屏幕的宽高,如何获取呢?

w = tk.winfo_screenwidth()#获取屏幕宽
h = tk.winfo_screenheight()#获取屏幕高

上帝为你开了一扇窗之Tkinter常用函数详解

第六步:设置窗口图标

tk.iconbitmap('favicon.ico')#设置窗口图标,将ico放在同级目录下。

上帝为你开了一扇窗之Tkinter常用函数详解

第七步:设置窗口背景颜色

tk["background"] ="#7AC5CD"# 采用16色,或者"blue",颜色名称

上帝为你开了一扇窗之Tkinter常用函数详解

这里,我为大家准备一个网站,供大家选择颜色。

https://tool.oschina.net/commons?type=3

上帝为你开了一扇窗之Tkinter常用函数详解

第八步:设置窗口透明度

tk.attributes("-alpha", 0.6)#设置窗口透明度,透明度的值是:0~1 可以是小数点,0:全透明;1:全不透明

上帝为你开了一扇窗之Tkinter常用函数详解

第九步:设置顶部工具栏样式

tk.attributes("-toolwindow", True)#有退出,可以移动

工具样式:True 只有退出按钮,也没有图标; False 正常的窗体样式

上帝为你开了一扇窗之Tkinter常用函数详解

如果要将退出按钮都隐藏呢?

tk.overrideredirect(True)#无退出,不能移动,无工具栏

第十步:设置窗口置顶

tk.attributes("-topmost", True)
窗体置顶:True 所有窗口中处于最顶层;False 正常显示

使用场景,比如:桌面便签,需要显示在最顶层,又不妨碍其他软件使用。

上帝为你开了一扇窗之Tkinter常用函数详解

第十一步:获取tk窗体信息

# 获取屏幕的大小;
height = tk.winfo_height()
width = tk.winfo_width()
# 获取窗体的位置
x = tk.winfo_x()
y = tk.winfo_y()
通常结合.update()使用,获取窗口改变之后的数据。
我们可以用bind来记录。
tk.bind("", update_test)#绑定事件
def update_test(e):
    tk.update()
    # 获取屏幕的大小;
    height = tk.winfo_height()
    width = tk.winfo_width()
    # 获取窗体的位置
    x = tk.winfo_x()
    y = tk.winfo_y()
    print(width, height, x, y)
tk.bind("", update_test)

第十二步:添加标签

tkinter.Label(tk,text='标签1(0,0)').grid(column=0,row=0)#column表示x,row表示y
那如何来理解这个参数呢?
grid中参数,依然可以把他看做是x,y,当两个标签中间没有数据时,就会自然缩进。
如图2,其中没有2,所以就会自动将2省去。
如图三中,坐标就是确定这些小方格。设置标签样式:
tkinter.Label(tk,text='标签1(0,0)',background='red',font=30,).grid(column=0,row=0)#x,y
tkinter.Label(tk,text='标签1(1,1)',foreground='red').grid(column=1,row=1)#x,y
background='red'#标签背景颜色
font=30#字体大小
foreground='red'#字体颜色

第十三步:调用事件

button=Button(tk, text="事件调用", fg="blue",bd=2,width=8,command=update_test).grid(column=1,row=5)

每点击一次,就调用对应的函数。

上帝为你开了一扇窗之Tkinter常用函数详解

第十四步:插入图片

photo = tkinter.PhotoImage(file="图片.png")#file:t图片路径
imgLabel = tkinter.Label(tk,image=photo).grid(column=1,row=6)#把图片整合到标签类中

 上帝为你开了一扇窗之Tkinter常用函数详解

完整代码

import tkinter
from tkinter import *
tk=tkinter.Tk()
tk.title("窗口")#设置窗口名称
tk.geometry("300x150+700+300")
"""width x height+x+y,分别对应,窗口 宽,高,以及窗口出现的坐标
    桌面的坐标系:以桌面左上角为(0,0)向右为x轴正半轴,向下为y轴正半轴"""
w = tk.winfo_screenwidth()#获取屏幕宽
h = tk.winfo_screenheight()#获取屏幕高
print(w,h)
tk.iconbitmap('favicon.ico')#设置窗口图标,将ico放在同级目录下。
# 设置背景色,以“蓝色”为例
tk["background"] ="#7AC5CD"# "blue"
tk.attributes("-alpha",1)#设置窗口透明度,透明度的值是:0~1 可以是小数点,0:全透明;1:全不透明
tk.attributes("-toolwindow", True)#有退出,可以移动,工具样式:True 只有退出按钮,也没有图标; False 正常的窗体样式
#tk.overrideredirect(True)#无退出,不能移动,无工具栏
#tk.attributes("-fullscreen", True)#全屏模式:True 全屏;False 正常显示
tk.attributes("-topmost", True)#窗体置顶:True 所有窗口中处于最顶层;False 正常显示
# 获取屏幕的大小;
height = tk.winfo_height()
width = tk.winfo_width()
# 获取窗体的位置
x = tk.winfo_x()
y = tk.winfo_y()
print(width,height,x,y)
def update_test():
    tk.update()
    # 获取屏幕的大小;
    height = tk.winfo_height()
    width = tk.winfo_width()
    # 获取窗体的位置
    x = tk.winfo_x()
    y = tk.winfo_y()
    print(width, height, x, y)
# tk.bind("<Configure>", update_test)#绑定事件,窗体的改变事件
tkinter.Label(tk,text='标签1(0,0)',background='red',font=30,).grid(column=0,row=0)#x,y,设置标签,grid设置位置
tkinter.Label(tk,text='标签1(1,1)',foreground='red').grid(column=1,row=1)#x,y
tkinter.Label(tk,text='标签2').grid(column=4,row=3)
tkinter.Label(tk,text='标签3').grid(column=3,row=4)
 
button=Button(tk, text="事件调用", fg="blue",bd=2,width=8,command=update_test).grid(column=1,row=5)#按钮,添加按钮事件
 
photo = tkinter.PhotoImage(file="Figure_1.png")#file:t图片路径
imgLabel = tkinter.Label(tk,image=photo).grid(column=1,row=6)#把图片整合到标签类中
tk.mainloop()

到此这篇关于上帝给你开了一个窗口之Tkinter常用函数详解的文章就介绍到这了,更多相关Tkinter常用函数内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
使用Python脚本和ADB命令实现卸载App
Feb 10 Python
利用Python查看目录中的文件示例详解
Aug 28 Python
对Python subprocess.Popen子进程管道阻塞详解
Oct 29 Python
元组列表字典(莫烦python基础)
Apr 03 Python
ubuntu 16.04下python版本切换的方法
Jun 14 Python
python3.8下载及安装步骤详解
Jan 15 Python
关于torch.optim的灵活使用详解(包括重写SGD,加上L1正则)
Feb 20 Python
Python导入模块包原理及相关注意事项
Mar 25 Python
pandas数据分组groupby()和统计函数agg()的使用
Mar 04 Python
图文详解matlab原始处理图像几何变换
Jul 09 Python
OpenCV实现常见的四种图像几何变换
Apr 01 Python
python画条形图的具体代码
Apr 20 Python
只用20行Python代码实现屏幕录制功能
TensorFlow中tf.batch_matmul()的用法
Jun 02 #Python
pytorch 运行一段时间后出现GPU OOM的问题
Jun 02 #Python
python flask开发的简单基金查询工具
python爬取网页版QQ空间,生成各类图表
Python爬虫实战之爬取携程评论
Pytorch DataLoader shuffle验证方式
You might like
现磨咖啡骗局!现磨咖啡=新鲜咖啡?现磨咖啡背后的猫腻你不懂!
2019/03/28 冲泡冲煮
php使用Jpgraph绘制3D饼状图的方法
2015/06/10 PHP
完美解决thinkphp唯一索引重复时出错的问题
2017/03/31 PHP
Laravel5.1 框架Request请求操作常见用法实例分析
2020/01/04 PHP
图片自动缩小 点击放大
2008/07/07 Javascript
5个最佳的Javascript日期处理类库分享
2012/04/15 Javascript
jquery创建并行对象或者合并对象的实现代码
2012/10/10 Javascript
ajax与302响应代码测试
2013/10/23 Javascript
JavaScript中的单引号和双引号报错的解决方法
2014/09/01 Javascript
排序算法的javascript实现与讲解(99js手记)
2014/09/28 Javascript
快速获取/设置iframe内对象元素的几种js实现方法
2016/05/20 Javascript
详谈Angular路由与Nodejs路由的区别
2017/03/05 NodeJs
js和jQuery以及easyui实现对下拉框的指定赋值方法
2018/01/23 jQuery
vue的常用组件操作方法应用分析
2018/04/13 Javascript
react脚手架如何配置less和ant按需加载的方法步骤
2018/11/28 Javascript
vue-cli3.0+element-ui上传组件el-upload的使用
2018/12/03 Javascript
JS/HTML5游戏常用算法之路径搜索算法 随机迷宫算法详解【普里姆算法】
2018/12/13 Javascript
你不可不知的Vue.js列表渲染详解
2019/10/01 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
2020/10/29 Javascript
原生JavaScript实现轮播图
2021/01/10 Javascript
[00:35]DOTA2上海特级锦标赛 VP战队宣传片
2016/03/04 DOTA
Python中列表、字典、元组、集合数据结构整理
2014/11/20 Python
利用Python获取操作系统信息实例
2016/09/02 Python
TensorFlow安装及jupyter notebook配置方法
2017/09/08 Python
python版简单工厂模式
2017/10/16 Python
python之DataFrame实现excel合并单元格
2021/02/22 Python
HTML5 解析规则分析
2009/08/14 HTML / CSS
mui几种页面跳转方式对比总结概括
2017/08/18 HTML / CSS
万宝龙英国官网:Montblanc手表、书写工具、皮革和珠宝
2018/10/16 全球购物
英国折扣零售连锁店:QD Stores
2018/12/08 全球购物
后勤人员自我评价怎么写
2013/09/19 职场文书
工商管理专业应届生求职信
2013/11/04 职场文书
厨师长岗位职责
2014/03/02 职场文书
办公室个人总结
2015/02/28 职场文书
导游词之上海东方明珠塔
2019/09/25 职场文书
vue+elementUI实现表格列的显示与隐藏
2022/04/13 Vue.js