您现在的位置是:网站首页> 编程资料编程资料

Python GUI布局工具Tkinter入门之旅_python_

2023-05-25 304人已围观

简介 Python GUI布局工具Tkinter入门之旅_python_

图形用户界面 (GUI)

图形用户界面 (GUI) 只不过是一个桌面应用程序,可帮助我们与计算机进行交互

  • 像文本编辑器这样的 GUI 应用程序可以创建、读取、更新和删除不同类型的文件
  • 数独、国际象棋和纸牌等应用程序则是游戏版的GUI程序
  • 还有 Google Chrome、Firefox 和 Microsoft Edge 之类的 GUI 应用程序是用来浏览 Internet 的

这些都是我们日常在电脑上使用的一些不同类型的 GUI 应用程序,其实我们通过 Tkinter 也是可以构建简单的类似应用程序的

今天我们作为 GUI 的入门,将创建一个非常简单且漂亮的 GUI 应用程序

用于创建GUI的 Python 库

Python 有大量的第三方类库,对于 GUI 库,主要有以下几种:

  • Kivy
  • Python QT
  • wxPython
  • Tkinter

其中,Tkinter 是很多学习者和开发者的首选,因为它简单易用而且随 Python 安装自带

Tkinter 基础

下面的图片显示了应用程序是如何在 Tkinter 中实际执行

我们首先导入 Tkinter 模型,接着,我们创建主窗口,在这个窗口中,我们将要执行操作并显示一切视觉效果,接下来我们添加 Widgets,最后我们进入 Main Event Loop

这里有 2 个重要的关键字

  • Widgets
  • Main Event Loop

事件循环基本上是告诉代码继续显示窗口,直到我们手动关闭它,是在后台无限循环运行的

对于 Widgets 我们后面单独学习

下面一个代码例子,来深入理解下

import tkinter window = tkinter.Tk() # to rename the title of the window window.title("GUI") # pack is used to show the object in the window label = tkinter.Label(window, text = "Hello World!").pack() window.mainloop() 

我们导入 Tkinter 包并定义一个窗口,接着我们可以修改一个窗口标题,每当打开应用程序时,该标题都会显示在标题选项卡上

最后,我们还定义了一个标签,标签只不过是需要在窗口上显示的输出,在例子中是 hello world

Tkinter Widgets

那么到底什么是 Widgets 呢

Widgets 类似于 HTML 中的元素,我们可以在 Tkinter 中找到针对不同类型元素的不同类型的 Widgets

让我们看看 Tkinter 中所有这些 Widgets 的简要介绍

  • Canvas - Canvas 用于在 GUI 中绘制形状
  • Button – Button 用于在 Tkinter 中放置按钮
  • Checkbutton – Checkbutton 用于在应用程序中创建复选按钮
  • Entry - Entry 用于在 GUI 中创建输入字段
  • Frame – Frame 在 Tkinter 中用作容器
  • Label - Label 用于创建单行 Widgets,如文本、图像等
  • Menu - Menu 用于在 GUI 中创建菜单

下面让我们逐一看一下每个 Widgets 的用法

Label

标签用于创建文本和图像以及所有相关的,而且要注意的是,它只能是单行定义

l1 = Label(window, text="萝卜大杂烩!", font=("ArialBold", 50)) l1.grid(column=0, row=0) 

还有一个函数 geometry,它基本上用于更改窗口大小并根据我们的要求进行设置

l1 = Label(window, text="萝卜大杂烩!", font=("ArialBold", 50)) window.geometry('350x200') 

在这种情况下,我们将其设置为宽 350 像素和高 200 像素

接下来是 button

Button

按钮与标签非常相似,我们创建一个变量并使用 Widgets 语法来定义按钮要表达的内容

window.geometry('350x200') bt = Button(window, text="Enter") 

我们还可以更改按钮或任何其他 Widgets 的前景颜色,使用代码中所示的参数 FG。 同样,也可以使用 BG 属性更改背景颜色

bt = Button(window, text="Enter", bg="orange", fg="red") bt.grid(column=1, row=0) 

我们的前景是定义为红色的文本,背景为橙色

下面来看一下点击按钮的操作

def clicked(): l1.configure(text="按钮被点击了!!") bt = Button(window, text="Enter", bg="orange", fg="red", command=clicked) 

这个我们称之为点击事件,我们需要编写有关单击按钮或触发单击事件时应该发生什么的功能

我们定义了一个名为 clicked 的函数,可以显示一条文本消息,我们在按钮定义中添加一个名为 command 的参数,来调用点击事件

Entry

它用于在 GUI 中创建输入字段以接收文本输入

txt = Entry(window, width=10) txt.grid(column=1, row=0) def clicked(): res = "Welcome to " + txt.get() l1.configure(text=res) bt = Button(window, text="Enter", bg="orange", fg="red", command=clicked) 

在这里,我们使用 Tkinter Entry 类创建一个文本框,grid 定义我们希望窗口小部件位于何处

同时 clicked 函数接收 Entry 的文本信息

Combobox

这是一个带有某些选项的下拉菜单

from tkinter.ttk import * combo = Combobox(window) combo['values']= (1, 2, 3, 4, 5, "Text") combo.current(3) combo.grid(column=0, row=0) 

这样一个下拉菜单就完成了

Checkbutton

复选按钮是非常常用的组件

chk_state = BooleanVar() chk_state.set (True) chk = Checkbutton(window, text="Select", var=chk_state) chk.grid(column=4, row=0) 

我们首先创建一个 booleanvar 类型的变量,这是一个 Tkinter 变量

默认情况下,我们将设置状态保持为 true,这代表按钮已经被选中 接下来,我们将 chk_state 传递给 checkbutton 类来为我们设置检查状态

Radio Button

单选按钮也是非常常用的

rad1 = Radiobutton(window, text=Python', value=1) rad2 = Radiobutton(window, text=Java', value=2) rad3 = Radiobutton(window, text=Scala', value=3) rad1.grid(column=0, row=0) rad2.grid(column=1, row=0) rad3.grid(column=2, row=0) 

在这里,我们使用了不同的参数值,1,2和3,如果它们相同,则会导致冲突并出现错误

它们的文本数据是可以相同,在这里,我们使用了 Python、Java 和 Scala

Scrolled Text

滚动文本组件

scro_txt = scrolledtext.ScrolledText(window, width=40,height=10) scro_txt.grid(column=0, row=4) 

我们指定了窗口的高和宽,否则默认会填充整个 Windiws 窗口

Message Box

消息组件可以方便的弹出提醒消息

def clicked(): messagebox.showinfo('Message title', 'Message content') btn = Button(window,text=‘ENTER', command=clicked) 

SpinBox

Spinbox 也是一个常见的组件,有两个选项卡,存在向上和向下滚动选项卡

pin = Spinbox(window, from_=0, to=100, width=5) 

有 3 个参数——from、to 和 width

  • From – 告诉我们范围的开始和默认值
  • to – 给我们范围的上限阈值
  • width 基本上是将 widget 的大小设置为5个字符的空格

Geometry

Tkinter 中的所有 Widgets 都会有一些位置信息,这些度量使得我们可以组织 Widgets 及其父框架、窗口等

Tkinter 具有以下三个布局方式

  • pack():- 它在块中组织 Widgets,这意味着它占据了整个可用宽度,这是在窗口中显示 Widgets 的标准方法
  • grid():- 它以类似表格的结构组织 Widgets
  • place():- 它将 Widgets 放置在我们想要的特定位置

组织布局

为了在窗口中安排布局,我们将使用 Frame 类

  • Frame -- 在窗口中创建分区,我们可以根据需要使用 pack() 方法的侧面参数对齐框架
  • Button -- 在窗口中创建一个按钮,需要传递几个参数,如文本(按钮的值)、fg(文本的颜色)、bg(背景颜色)

在下面的代码中,我们使用 window、top_frame、bottom_frame 来布局

import tkinter window = tkinter.Tk() window.title("GUI") # creating 2 frames TOP and BOTTOM top_frame = tkinter.Frame(window).pack() bottom_frame = tkinter.Frame(window).pack(side = "bottom") # now, create some widgets in the top_frame and bottom_frame btn1 = tkinter.Button(top_frame, text = "Button1", fg = "red").pack()# 'fg - foreground' is used to color the contents btn2 = tkinter.Button(top_frame, text = "Button2", fg = "green").pack()# 'text' is used to write the text on the Button btn3 = tkinter.Button(bottom_frame, text = "Button2", fg = "purple").pack(side = "left")# 'side' is used to align the widgets btn4 = tkinter.Button(bottom_frame, text = "Button2", fg = "orange").pack(side = "left") window.mainloop() 

再来看一个登录的小栗子

import tkinter window = tkinter.Tk() window.title("GUI") # creating 2 text labels and input labels tkinter.Label(window,
                
                

-六神源码网