【Tkinter系列02/5】界面初步和布局

本文是系列文章第二部分。前文见:【Tkinter系列01/5】界面初步和布局_无水先生的博客-CSDN博客

说明

        一般来说,界面开发中,如果不是大型的软件,就不必用QT之类的实现,用Tkinter已经足够,然而即便是Tkinter规模不大,也需要一个系统专业的学习过程,本篇将是对Tkinter系列介绍的一篇博文。

五. 标准属性

        在查看小部件之前,让我们先看一下它们的一些常见属性(例如大小、颜色和字体)是如何指定的。

  • 每个小部件都有一组影响其外观和行为的选项 ,例如字体、颜色、大小、文本标签等属性。

  • 您可以在使用关键字参数(例如text='PANIC!'或 )调用小部件的构造函数时指定选项height=20

  • 创建小部件后,您可以稍后使用小部件的.config()方法更改任何选项。您可以使用小部件的.cget() 方法检索任何选项的当前设置。有关这些方法的更多信息 ,请参阅第 26 节“通用小部件方法” 。

5.1. 方面

小部件的各种长度、宽度和其他尺寸可以用许多不同的单位来描述。

  • 如果将尺寸设置为整数,则假定以像素为单位。

  • 您可以通过将尺寸设置为包含数字的字符串来指定单位,后跟:

    表 3. 尺寸单位

    c厘米
    i英寸
    m毫米
    p打印机点(约1/72英寸)

 

5.2. 坐标系

与大多数现代显示系统一样,每个坐标系的原点位于其左上角,x坐标向右增加,y坐标向底部增加:

基本单位是像素,左上角像素的坐标为 (0,0)。您指定为整数的坐标始终以像素表示,但任何坐标都可以指定为有尺寸的数量;请参见第 5.1 节“尺寸”。

5.3. 颜色

在Tkinter 中有两种指定颜色的通用方法。

  • 您可以使用一个字符串以十六进制数字指定红色、绿色和蓝色的比例:

    #rgb每种颜色四位
    #rrggbb每种颜色八位
    #rrrgggbbb每种颜色十二位

    例如,'#fff'为白色、'#000000'为黑色、'#000fff000'为纯绿色、'#00ffff'为纯青色(绿色加蓝色)。

  • 您还可以使用任何本地定义的标准颜色名称。颜色 'white'、 'black'、 'red'、 'green'、 'blue'、 'cyan'、 'yellow'和 'magenta'将始终可用。其他名称也可能有效,具体取决于您的本地安装。

5.4. 输入字体

根据您的平台,最多可能有三种方法来指定类型样式。

  • 作为一个元组,其第一个元素是字体系列,后跟一个大小(如果为正,则以磅为单位,如果为负,则以像素为单位),可选地后跟一个包含一个或多个样式修饰符 、 、bolditalicunderline字符串overstrike

    示例:('Helvetica', '16')对于 16 点 Helvetica 常规字体;('Times', '24', 'bold italic')24 点 Times 粗体斜体。对于 20 像素 Times 粗体字体,请使用('Times', -20, 'bold').

  • tkFont您可以通过导入模块并使用其类构造函数 来创建“字体对象” Font

    import tkFontfont = tkFont.Font(option, ...)

    其中选项包括:

    family字符串形式的字体系列名称。
    size字体高度,以磅为单位的整数。要获得字体n像素高,请使用. -n
    weight'bold'对于粗体,'normal'对于常规粗细。
    slant'italic'对于斜体,'roman'对于不倾斜。
    underline1对于带下划线的文本,0对于普通文本。
    overstrike1对于重击文本,0对于正常。

    例如,要获得 36 点粗体 Helvetica 斜体字体:

        helv36 = tkFont.Font(family='Helvetica',size=36, weight='bold')
  • 如果您在 X Window 系统下运行,则可以使用任何 X 字体名称。例如,指定的字体'-*-lucidatypewriter-medium-r-*-*-*-140-*-*-*-*-*-*'是一种适合在屏幕上使用的良好固定宽度字体。使用xfontsel程序可以帮助您选择令人满意的字体。

要获取您平台上可用的所有字体系列的列表,请调用此函数:

 tkFont.families()

返回值是一个字符串列表。 注意:在调用此函数之前,您必须创建根窗口。

Font 这些方法在所有对象 上定义:

.actual(option=None)

如果您不传递任何参数,您将返回字体实际属性的字典,该字典可能与您请求的属性不同。要获取属性的值,请将其名称作为参数传递。

.cget(option)

返回给定的值option

.configure(option, ...)

使用此方法可以更改字体的一个或多个选项。例如,如果您有一个Font名为 的对象titleFont,那么如果您调用titleFont.configure(family='times', size=18),该字体将更改为 18pt Times,并且使用该字体的任何小部件也会更改。

.copy()

返回对象的副本Font

.measure(text)

向此方法传递一个字符串,它将返回该字符串在字体中所占的宽度像素数。警告:一些倾斜的字符可能会延伸到该区域之外。

.metrics(option)

如果您不带参数调用此方法,它将返回所有字体规格 的字典。您可以通过将一个指标的名称作为参数传递来检索该指标的值。指标包括:

ascent基线与最高上升部分顶部之间的高度像素数。
descent基线与最低上升部分底部之间的高度像素数。
fixed该值0适用于可变宽度字体和1 等宽字体。
linespace总高度的像素数。这是给定字体中设置为实心的类型的前导。

 

5.5. 锚

        Tkinter 模块定义了许多锚点常量,您可以使用它们来控制项目相对于其上下文的位置。例如,当框架大于小部件时,锚点可以指定小部件在框架内的位置。

        这些常数以罗盘点的形式给出,其中北在上,西在左。我们为这种北半球沙文主义向南半球读者致歉。

        锚常数如下图所示:

        例如,如果您在大框架内创建一个小部件并使用该anchor=tk.SE选项,则该部件将被放置在框架的右下角。如果您anchor=tk.N改为使用,则小部件将沿顶部边缘居中。

        锚点还用于定义文本相对于参考点的位置。例如,如果用作 tk.CENTER文本锚点,文本将围绕参考点水平和垂直居中。锚点tk.NW将定位文本,以便参考点与包含文本的框的西北(左上角)角重合。锚点 tk.W将使文本围绕参考点垂直居中,文本框的左边缘穿过该点,依此类推。

 

5.6. 浮雕样式

        小部件的浮雕样式是指小部件外部周围的某些模拟 3D 效果。这是一排按钮的屏幕截图,展示了所有可能的浮雕样式:

        这些边框的宽度取决于borderwidth小部件的选项。上图显示了带有 5 像素边框的它们的样子;默认边框宽度为 2。

 

5.7. 位图

对于bitmap小部件中的选项,这些位图保证可用:

上图显示了Button 带有标准位图的小部件。从左到右分别是'error'、 'gray75'、 'gray50'、 'gray25'、 'gray12'、 'hourglass'、 'info'、 'questhead'、 'question'、 和 'warning'

您可以使用自己的位图。任何 .xbm(X 位图)格式的文件都可以使用。使用后跟'@'文件路径名 的字符串来代替标准位图名称.xbm

5.8. 光标

有很多不同的鼠标光标可用。他们的名字和图形显示在这里。确切的图形可能会根据您的操作系统而有所不同。

表 4.cursor选项的值

arrow

man

based_arrow_down

middlebutton

based_arrow_up

mouse

boat

pencil

bogosity

pirate

bottom_left_corner

plus

bottom_right_corner

question_arrow

bottom_side

right_ptr

bottom_tee

right_side

box_spiral

right_tee

center_ptr

rightbutton

circle

rtl_logo

clock

sailboat

coffee_mug

sb_down_arrow

cross

sb_h_double_arrow

cross_reverse

sb_left_arrow

crosshair

sb_right_arrow

diamond_cross

sb_up_arrow

dot

sb_v_double_arrow

dotbox

shuttle

double_arrow

sizing

draft_large

spider

draft_small

spraycan

draped_box

star

exchange

target

fleur

tcross

gobbler

top_left_arrow

gumby

top_left_corner

hand1

top_right_corner

hand2

top_side

heart

top_tee

icon

trek

iron_cross

ul_angle

left_ptr

umbrella

left_side

ur_angle

left_tee

watch

leftbutton

xterm

ll_angle

X_cursor

lr_angle  

5.9. 显示图片

在Tkinter应用程序 中显示图形图像有三种常用方法。

  • 要以该格式显示位图(双色)图像.xbm,请参阅第 5.9.1 节“BitmapImage类”。

  • .gif要以、.pgm、 或.ppm 格式 显示全彩图像,请参见第 5.9.2 节 “PhotoImage类”。

  • Python 图像库 (PIL) 支持更多种格式的图像。它的ImageTk类是专门为在Tkinter应用程序中显示图像而设计的。有关 PIL 文档,请参阅作者的配套文档:Python Imaging Library (PIL) 快速参考。

5.9.1.  BitmapImage_类

        要以该格式显示双色图像.xbm ,您将需要以下构造函数:

 tk.BitmapImage(file=f[, background=b][, foreground=c])

        其中f是图像文件的名称.xbm

        通常,图像中的前景 (1) 位将显示为黑色像素,图像中的背景 (0) 位将显示为透明。要更改此行为,请使用可选 选项将背景设置为 color ,并使用可选选项将前景设置为 color 。有关颜色规范,请参见第 5.3 节“颜色”。 background=bbforeground=cc

        此构造函数返回一个可以在Tkinter需要图像的任何地方使用的值。例如,要将图像显示为标签,请使用Label 小部件(请参阅第 12 节“Label小部件”)并提供 BitmapImage对象作为选项的值 image

    logo = tk.BitmapImage('logo.xbm', foreground='red')Label(image=logo).grid()

5.9.2. PhotoImage_类

.gif要以、.pgm、 或格式 显示彩色图像.ppm,您将需要以下构造函数:

 tk.PhotoImage(file=f)

其中f是图像文件的名称。构造函数返回一个可以在Tkinter需要图像的任何地方使用的值。

5.10. 几何字符串

几何字符串是描述桌面上顶级窗口的大小和位置的标准方法。

几何字符串具有以下一般形式:

 ' wx h± x± y'

在哪里:

  • 和 部分给出了以像素为单位w 的h窗口宽度和高度。它们由字符分开'x'

  • 如果下一部分的形式为,则它指定窗口的左侧应该是距离桌面左侧的像素。如果它的形式为,则窗口的右侧距桌面右侧的像素数。 +xx-xx

  • 如果下一部分具有形式,则它指定窗口顶部应低于桌面顶部的像素。如果它具有形式,则窗口底部将位于桌面底部边缘上方的像素处。 +yy-yy

例如,使用创建的窗口geometry='120x50-0+20'为 120 像素宽 x 50 像素高,其右上角将沿着桌面的右边缘,且距上边缘下方 20 像素。

 

5.11. 窗口名称

术语“窗口”描述了桌面上的矩形区域。

  • 顶层 窗口或 窗口是在窗口管理器下独立存在的窗口。它用窗口管理器的装饰进行装饰,并且可以独立移动和调整大小。您的应用程序可以使用任意数量的顶级窗口。

  • 术语“窗口”也适用于属于顶级窗口一部分的任何小部件。

Tkinter使用分层 窗口路径名来命名所有这些窗口。

  • 根窗口的名称是'.'

  • 子窗口的名称格式为,其中是字符串形式的某个整数。例如,名为的窗口是根窗口 ( ) 的子窗口。 '.n'n'.135932060''.'

  • 子窗口中的子窗口具有以下形式的名称,其中是父窗口的名称,并且是某个整数。例如,名为的窗口有父窗口 ,因此它是根窗口的孙子窗口。 'p.n'pn'.135932060.137304468''.135932060'

  • 窗口的相对名称 是'.'路径名称中最后一个之后的部分。继续前面的示例,孙窗口有一个相对名称'137304468'

        要获取小部件的路径名w,请使用。 str(w)

        另请参阅第 26 节“通用小部件方法”,了解可用于操作窗口名称的方法,尤其是.winfo_name、 .winfo_parent和.winfo_pathname方法。

5.12. 端盖和连接样式

        为了令人愉快且有效地渲染图表,有时注意 cap 和 join 样式是个好主意。

  • 线的帽样式是线末端的形状。款式有:

    • tk.BUTT:线的末端在通过端点的线处被切断。

    • tk.PROJECTING:线的末端被切成方形,但切割线超出端点的距离等于线宽度的一半。

    • tk.ROUND:末端描述以端点为中心的半圆。

  • 连接样式描述了两条线段以一定角度相交的形状。

    • tk.ROUND:连接是以相邻线段相交点为中心的圆。

    • tk.BEVEL:以相邻线的角度之间的中间角度绘制平面。

    • tk.MITER:相邻线段的边缘继续在尖点处相交。

        此图显示了Tkinter的 cap 和 join 选项如何处理由两个连接的线段组成的线。小红色圆圈显示定义这条线的点的位置。

 

 

5.13。破折号图案

        许多小部件允许您指定虚线轮廓。和dash选项dashoffset使您可以精细控制破折号的确切模式。

dash

        该选项被指定为整数元组。第一个整数指定应绘制多少像素。第二个整数指定在再次开始绘制之前应跳过多少像素,依此类推。当元组中的所有整数都用完时,它们会以相同的顺序重复使用,直到边界完成。

        例如,dash=(3,5)生成由 5 像素间隙分隔的交替 3 像素虚线。值会dash=(7,1,1,1) 生成点划线图案,其中划线的长度是点或点周围间隙的七倍长。值dash=(5,) 会产生交替的五像素虚线和五像素间隙。

dashoff

        要在循环的不同点而不是在开头开始虚线图案,请使用 选项 ,其中是在图案开始处要跳过的像素数。 dashoff=nn

        例如,对于选项dash=(5, 1, 2, 1)dashoff=3,生成的第一个模式将是:2 on、1 off、2 on 和 1 off。后续模式将为 5 开、1 关、2 开和 1 关。以下是使用此选项组合绘制的线条的屏幕截图:

 

5.14。匹配点画图案

这似乎是一个非常挑剔的风格点,但如果您绘制的图形包含两个带有点画图案的对象,真正的专业人士将确保图案沿其边界对齐。

这是一个例子。左侧的屏幕截图显示两个相邻的 100×100 正方形,上面有“ gray12”图案,但右侧的正方形垂直偏移了一个像素。图形中心的黑色短线是沿着两个图形的边界绘制的。

未对齐的点画。

正确对齐点画。

第二个屏幕截图是相同的,只是两个 100×100 的正方形的点画图案是对齐的。

实际上,这种情况会在两种情况下出现。大点画区域的对齐由名为 的选项控制offset。对于具有点画轮廓的图形,该outlineoffset 选项控制它们的对齐方式。这两个选项都具有以下形式之一的值:

  • 'x,y':相对于顶级窗口或画布的原点, 将点画图案偏移此值x和值。y

  • '#x,y':对于画布上的对象,使用偏移量xy相对于顶级窗口。

  • tk.NE、 tk.SE、 tk.SW、 tk.NW:将点画图案的一角与包含对象的相应角对齐。例如,tk.NE表示点画图案的左上角与要点画的区域的左上角重合。

  • tk.N、 tk.E、 tk.S、 tk.W:将点画图案与包含对象一侧的中心对齐。例如,tk.E表示点画图案的中心将与要点画的区域右侧的中心重合。

  • tk.CENTER:将点画图案的中心与包含对象的中心对齐。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/55933.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

spring boot 项目整合 websocket

1.业务背景 负责的项目有一个搜索功能,搜索的范围几乎是全表扫,且数据源类型贼多。目前对搜索的数据量量级未知,但肯定不会太少,不仅需要搜索还得点击下载文件。 关于搜索这块类型 众多,未了避免有个别极大数据源影响整…

linux操作系统的权限的深入学习(未完)

1.Linux权限的概念 Linux下有两种用户:超级用户(root)、普通用户。 超级用户:可以再linux系统下做任何事情,不受限制 普通用户:在linux下做有限的事情。 超级用户的命令提示符是“#”,普通用户…

Spring Authorization Server入门 (十六) Spring Cloud Gateway对接认证服务

前言 之前虽然单独讲过Security Client和Resource Server的对接,但是都是基于Spring webmvc的,Gateway这种非阻塞式的网关是基于webflux的,对于集成Security相关内容略有不同,且涉及到代理其它微服务,所以会稍微比较麻…

Prometheus 监控系统

常用的监控系统有哪些? 老牌传统 Zabbix Nagios Cacti 新一代的 Prometheus 夜莺 Zabbix 和 Prometheus 的区别?如何选择?【重中之重】 Zabbix 更适用于传统业务架构的物理机、虚拟机环境的监控,对容器环境的支持较差&#xf…

战略形成是权力妥协的过程,江湖,政治是常态

战略权力派:战略形成是各种权力妥协的过程【安志强趣讲270期】 趣讲大白话:有人的地方就有政治 **************************** 有人的地方就有江湖 有组织的地方就有政治 公司的战略是各种人的权力博弈的产物 围观权力:就是组织内部 宏观权力…

MyCAT命令行监控

9066端口 ,用mysql命令行连接 Mysql –utest –ptest –P9066 show help 可显示所有相关管理命令 显示后端物理库连接信息,包括当前连接数,端口 Show backend Show connection 显示当前前端客户端连接情况,已经网络流量信息、…

Tomcat 部署时 war 和 war exploded区别

在 Tomcat 调试部署的时候,我们通常会看到有下面 2 个选项。 是选择war还是war exploded 这里首先看一下他们两个的区别: war 模式:将WEB工程以包的形式上传到服务器 ;war exploded 模式:将WEB工程以当前文件夹的位置…

【Go 基础篇】Go语言数组遍历:探索多种遍历数组的方式

数组作为一种基本的数据结构,在Go语言中扮演着重要角色。而数组的遍历是使用数组的基础,它涉及到如何按顺序访问数组中的每个元素。在本文中,我们将深入探讨Go语言中多种数组遍历的方式,为你展示如何高效地处理数组数据。 前言 …

2023年高教社杯 国赛数学建模思路 - 复盘:光照强度计算的优化模型

文章目录 0 赛题思路1 问题要求2 假设约定3 符号约定4 建立模型5 模型求解6 实现代码 建模资料 0 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 1 问题要求 现在已知一个教室长为15米,宽为12米&…

YOLO目标检测——肺炎分类数据集下载分享

肺炎分类数据集总共21000图片,可应用于:肺炎检测、疾病诊断、疾病预测和预警等等。 数据集点击下载:YOLO肺炎分类数据集21000图片.rar

如何深入理解 Node.js 中的流(Streams)

Node.js是一个强大的允许开发人员构建可扩展和高效的应用程序。Node.js的一个关键特性是其内置对流的支持。流是Node.js中的一个基本概念,它能够实现高效的数据处理,特别是在处理大量信息或实时处理数据时。 在本文中,我们将探讨Node.js中的流…

腾讯云服务器地域和可用区详细介绍_选择攻略

腾讯云服务器地域有什么区别?怎么选择比较好?地域选择就近原则,距离地域越近网络延迟越低,速度越快。关于地域的选择还有很多因素,地域节点选择还要考虑到网络延迟速度方面、内网连接、是否需要备案、不同地域价格因素…

微服务dubbo

微服务是一种软件开发架构风格,它将一个应用程序拆分成一组小型、独立的服务,每个服务都可以独立部署、管理和扩展。每个服务都可以通过轻量级的通信机制(通常是 HTTP/REST 或消息队列)相互通信。微服务架构追求高内聚、低耦合&am…

Cookie for Mac:隐私保护工具保护您的在线隐私

随着互联网的发展,我们每天都会浏览各种网站,享受在线购物、社交娱乐和学习资料等各种便利。然而,您是否曾经遇到过需要频繁输入用户名和密码的情况?或者不方便访问您常用的网站?如果是这样,那么Cookie for…

pytest

1.安装 pip install pytestpytest官网:https://docs.pytest.org/en/stable/ 2.编写规则 1.测试文件已test开头(或以test结尾) 2.测试类以Test开头,并且不能带有init方法 3.测试函数以test开头 4.断言使用基本的assert即可 3.p…

基于树莓派设计的酒店房间号智能识别系统(图像识别)

基于树莓派4B设计的酒店房间号智能识别系统(图像识别) 一、设计需求 酒店房间识别系统的主要目的是:通过图像处理技术,以机器视觉的方式识别光学传感器传回的酒店房间图像中的数字,该系统可以以非接触的方式,以图像的方式获得需要的酒店房间读数,这能极大提高老式的酒店房…

Matlab图像处理-乘法运算

乘法运算 两幅图像进行乘法运算主要实现两个功能: 一是可以实现掩模操作,即屏蔽图像的某些部分; 二是如果一幅图像乘以一个常数因子,如果常数因子大于1,将增强图像的亮度,如果因子小于1则会使图像变暗。…

NGINX相关配置

NGINX相关配置 NGINX配置信息 nginx 官方帮助文档:http://nginx.org/en/docs/Nginx的配置文件的组成部分: 主配置文件:/conf/nginx.conf(/nginx/conf/nginx.conf) 子配置文件: include conf.d/*.conf#事件驱动相关的配置 同步 event { wo…

MySQL表的增删改查

文章目录 MySQL表的增删改查1. Create1.1 单行数据插入1.2 多行数据插入1.3 插入否则更新1.4 替换 2. Retrieve2.1 SELECT 列2.1.1 全列查询2.1.2 指定列查询2.1.3 查询字段为表达式2.1.4 为查询结果指定别名2.1.5 结果去重 2.2 WHERE 条件2.2.1 英语不及格的同学及英语成绩(&l…

〔017〕Stable Diffusion 之 常用模型推荐 篇

✨ 目录 🎈 模型网站🎈 仿真系列🎈 国风系列🎈 卡通动漫系列🎈 3D系列🎈 一些好用的lora模型 🎈 模型网站 由于现在大模型超级多,导致每种画风的模型太多,那么如何选择最…