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

相关文章

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2