python使用tkinter和ttkbootstrap制作UI界面(一)

2024-04-19 15:28

本文主要是介绍python使用tkinter和ttkbootstrap制作UI界面(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

标题使用python制作UI界面,可以选用tkinter库和ttkbootstrap库编写,首先主题框架如下:

在这里插入图片描述
新建ui_test.py文件编写主体界面,新建test_one.py和test_two.py编写分界面,以下先进行主体界面编写,代码如下:

主体框架

import ttkbootstrap
from tkinter import Frameclass UiTest(object):def __init__(self):self.window = ttkbootstrap.Window()def main_interface(self):"""测试主界面"""# 设置标题self.window.title('测试UI界面')# 屏幕的尺寸大小sw = self.window.winfo_screenwidth()sh = self.window.winfo_screenheight()# 设置UI界面的高度和宽度ww = 1000wh = 700# 窗口居中设置x = (sw - ww) / 2y = (sh - wh) / 2self.window.geometry("%dx%d+%d+%d" % (ww, wh, x, y))# 设置窗口是否可以变化长宽,默认可变self.window.resizable(width=False, height=False)def run_main(self):self.main_interface()self.window.mainloop()if __name__ == '__main__':ui_test = UiTest()ui_test.run_main()

运行界面如下:
在这里插入图片描述

Notebook组件应用

        """多窗口设置"""all_notebook = ttkbootstrap.Notebook(self.window)all_notebook.pack(padx=10, pady=5, fill=ttkbootstrap.BOTH, expand=True)self.frame_one = Frame(all_notebook)self.frame_two = Frame(all_notebook)all_notebook.add(self.frame_one, text='测试界面一')all_notebook.add(self.frame_two, text='测试界面二')

效果如下:
在这里插入图片描述

Labelframe组件应用

        """Labelframe组件"""argument_info = ttkbootstrap.Labelframe(self.frame_one, text="参数信息", width=960, height=640, labelanchor="n")argument_info.place(x=10, y=10)

效果如下:
在这里插入图片描述

Label组件应用

        """Label组件"""tk.Label(argument_info, text="文字输入:", font=("微软雅黑", 12)).place(x=10, y=10)

效果如下:
在这里插入图片描述

Entry组件应用

        """Entry组件"""project_code = tk.Entry(argument_info, font=('微软雅黑', 12), width=35)project_code.place(x=110, y=10)

效果如下:
在这里插入图片描述

Button组件应用

        """Button组件"""select_button = ttkbootstrap.Button(argument_info, text="按键", bootstyle="success")select_button.place(x=600, y=10)

效果如下:

在这里插入图片描述

Radiobutton组件应用

        """Radiobutton组件"""select_cell = tk.StringVar()select_cell.set("单选建")select_all_channel_test = ttkbootstrap.Radiobutton(argument_info, text="单选建", variable=select_cell,value="单选建", bootstyle="success-round-toggle")select_all_channel_test.place(x=10, y=100)

效果如下:
在这里插入图片描述

Checkbutton组件

        """Checkbutton组件"""# 适合单个多选键或少量多选键global select_switchselect_switch = IntVar()select_switch.set(0)select_switch_checkbutton = ttk.Checkbutton(argument_info, text="多选键", variable=select_switch,offvalue=0, onvalue=1)select_switch_checkbutton.place(x=100, y=100)# 大量多选键global switch_list_front_oneswitch_list_front_one = [int(x) for x in range(1, 5)]for i in range(1, 5):switch_list_front_one[i - 1] = StringVar()ttk.Checkbutton(argument_info, text=i, variable=switch_list_front_one[i - 1], offvalue=f"关闭{i}",onvalue=f"开启{i}").place(x=10 + 50 * (i - 1), y=150)

效果如下:
在这里插入图片描述
ui_test.py中写入主界面代码,代码如下:

import ttkbootstrap
from tkinter import Framefrom ui_show.test_one import UiTestOneclass UiTest(object):def __init__(self):self.window = ttkbootstrap.Window()self.frame_one = Frame()self.frame_two = Frame()def main_interface(self):"""测试主界面"""# 设置标题self.window.title('测试UI界面')# 屏幕的尺寸大小sw = self.window.winfo_screenwidth()sh = self.window.winfo_screenheight()# 设置UI界面的高度和宽度ww = 1000wh = 700# 窗口居中设置x = (sw - ww) / 2y = (sh - wh) / 2self.window.geometry("%dx%d+%d+%d" % (ww, wh, x, y))# 设置窗口是否可以变化长宽,默认可变self.window.resizable(width=False, height=False)"""多窗口设置"""all_notebook = ttkbootstrap.Notebook(self.window)all_notebook.pack(padx=10, pady=5, fill=ttkbootstrap.BOTH, expand=True)self.frame_one = Frame(all_notebook)self.frame_two = Frame(all_notebook)all_notebook.add(self.frame_one, text='测试界面一')all_notebook.add(self.frame_two, text='测试界面二')def run_main(self):self.main_interface()ui_test_one = UiTestOne(self.frame_one)ui_test_one.show_interface()self.window.mainloop()if __name__ == '__main__':ui_test = UiTest()ui_test.run_main()

test_one.py中写入界面一代码,代码如下:

import ttkbootstrap
import tkinter as tkfrom tkinter import ttk
from tkinter import IntVar, StringVarclass UiTestOne(object):def __init__(self, window):self.frame_one = windowdef show_interface(self):"""Labelframe组件"""argument_info = ttkbootstrap.Labelframe(self.frame_one, text="参数信息", width=960, height=640, labelanchor="n")argument_info.place(x=10, y=10)"""Label组件"""tk.Label(argument_info, text="文字输入:", font=("微软雅黑", 12)).place(x=10, y=10)"""Entry组件"""project_code = tk.Entry(argument_info, font=('微软雅黑', 12), width=35)project_code.place(x=110, y=10)"""Button组件"""select_button = ttkbootstrap.Button(argument_info, text="按键", bootstyle="success")select_button.place(x=600, y=10)"""Radiobutton组件"""select_cell = tk.StringVar()select_cell.set("单选建")select_all_channel_test = ttkbootstrap.Radiobutton(argument_info, text="单选建", variable=select_cell,value="单选建", bootstyle="success-round-toggle")select_all_channel_test.place(x=10, y=100)"""Checkbutton组件"""# 适合单个多选键或少量多选键global select_switchselect_switch = IntVar()select_switch.set(0)select_switch_checkbutton = ttk.Checkbutton(argument_info, text="多选键", variable=select_switch,offvalue=0, onvalue=1)select_switch_checkbutton.place(x=100, y=100)# 大量多选键global switch_list_front_oneswitch_list_front_one = [int(x) for x in range(1, 5)]for i in range(1, 5):switch_list_front_one[i - 1] = StringVar()ttk.Checkbutton(argument_info, text=i, variable=switch_list_front_one[i - 1], offvalue=f"关闭{i}",onvalue=f"开启{i}").place(x=10 + 50 * (i - 1), y=150)

篇幅有限,界面二会更新更多组件的编写方式,有疑问欢迎找博主进行答疑,我是活动的笑脸,希望大家积极点赞,本篇到此结束。

这篇关于python使用tkinter和ttkbootstrap制作UI界面(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917929

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos