使用 Tkinter 制作一个进制转换工具,好用!

在平时工作学习当中,我们经常会编写一些简单的 Python GUI 工具,以此来完成各种各样的自动化任务,比如批量处理文件,批量处理图片等等。当我们进行这些工具的编写之时,往往只关注了功能的实现,而忽略了页面的美化,这也使得在人们的眼中,Python 构建的 GUI 程序都是比较 low 的,今天我们先忽略掉功能,着眼于页面的美化,来看看纯 Python 的编写的 GUI 程序也可以很美观!

页面布局

我们首先完成一个基本的 GUI 布局

假设我们想要做一个进制转换的工具,那么大致的布局可以入下图

上图是完全通过 Python 自带的 GUI 库 tkinter 来编写的

部分代码如下

from tkinter import ttk
from tkinter import *

class Transform():
    def __init__(self):
        self.root = Tk()
        self.root.title("进制转换工具")
        self.root.geometry("600x280")
        self.root.resizable(False, False)
        self.var = StringVar()
        self.values = ['2', '8', '10', '16', '32', '36', '58', '62']
        self.myWidget()
        self.myLayout()

    def myWidget(self):
        self.container = Frame(self.root)
        # 转换设置区域
        self.lf_group1 = LabelFrame(master=self.container, text="转换设置")
        self.cb = Checkbutton(self.lf_group1, text="是否自动转换")
        self.cb.invoke()
        self.bt = Button(self.lf_group1, text='转换')
        self.en = Entry(self.lf_group1, text='warning')
        # 进制选择区域
        self.lf_group2 = LabelFrame(master=self.container, text="进制选择")
        self.lb1 = Label(self.lf_group2, text="请选择待转换的进制")
        self.cbo1 = ttk.Combobox(
            master=self.lf_group2,
            values=self.values
        )
        self.cbo1.set(self.values[2])
        self.lb2 = Label(self.lf_group2, text="请选择转换后的进制")
        self.cbo2 = ttk.Combobox(
            master=self.lf_group2,
            values=self.values,
        )
        self.cbo2.set(self.values[0])
        # 进制输出区域
        self.txt = Text(master=self.container, height=5, width=50)

    def myLayout(self):
        self.container.pack(side=LEFT, fill=BOTH, expand=YES, padx=5)
        self.lf_group1.pack(fill=X, side=TOP)
        self.lf_group2.pack(fill=X, pady=10, side=TOP)
        self.cb.pack(side=LEFT, expand=YES, padx=5, fill=X)
        self.bt.pack(side=LEFT, expand=YES, padx=5, fill=X)
        self.en.pack(side=LEFT, expand=YES, padx=5, fill=X)
        self.lb1.pack(side=LEFT, expand=YES, padx=5)
        self.cbo1.pack(side=LEFT, expand=YES, pady=5)
        self.lb2.pack(side=LEFT, expand=YES, padx=5)
        self.cbo2.pack(side=LEFT, expand=YES, pady=5)
        self.txt.pack(side=LEFT, anchor=NW, pady=5, fill=BOTH, expand=YES)

    def run(self):
        self.container.mainloop()


if __name__ == '__main__':
    trans = Transform()
    trans.run()

代码并不复杂,布局也是使用的最基本的 pack 方式,整个 GUI 程序虽然看起来比较整齐,但是颜色单调,各个组件也不是十分美观,下面我们就来进行美化

页面美化

我们首先通过手工设置 CSS 的方式来美化页面,这里主要用到了 tkonter 库的 config 属性

首先我们设置背景颜色

self.container.config(bg='#073642')

对于整体 container 容器,我们设置背景色为#073642

接下来再分别设置各个组件的样式

self.lf_group1.config(bg='#073642', fg="white")
self.lf_group2.config(bg='#073642', fg="white")
self.cb.config(bg='#073642', selectcolor='#073642', activebackground='#073642',
               activeforeground='#073642', fg="white")
self.bt.config(bg="azure3")
self.en.config(highlightbackground="#0b5162", highlightcolor="#0b5162",
               insertofftime=500, insertontime=500, fg="Gainsboro", insertbackground="Gainsboro",
               bg="#073642", highlightthickness=2, relief="solid")
self.lb1.config(bg='#073642', activebackground='#073642',
                activeforeground='#073642', fg="white")
self.lb2.config(bg='#073642', activebackground='#073642',
                activeforeground='#073642', fg="white")
self.txt.config(insertofftime=500, insertontime=500, fg="Gainsboro", insertbackground="Gainsboro",
                wrap="none", bg='#073642')

都是通过 config 来设置,对于颜色的选择,可以通过在线的颜色选择器来选择

https://tools.kalvinbg.cn/dev/colorPicker

接下来我们进行下拉框样式的设置,对于下拉框组件,还是有些特殊的

该组件属于 ttk 组件,所以设置样式需要通过主题来进行,代码如下

combostyle = ttk.Style()
combostyle.theme_create('combostyle', parent='alt',
                        settings={'TCombobox':
                            {'configure':
                                {
                                    'foreground': 'white',
                                    'selectbackground': '#073642',  # 选择后的背景颜色
                                    'fieldbackground': '#073642',  # 下拉框颜色
                                    'background': '#073642',  # 下拉按钮背景颜色
                                    "font": 10,  # 字体大小
                                }}}
                        )
combostyle.theme_use('combostyle')

这样我们整体 GUI 程序的样式就设置完成了,来看下最终的效果

可以明显看出,颜值那是提升了好几个档次!

使用 ttkbootstrap 美化页面

当然我们还有更加简单有效的美化方法,就是使用 ttkbootstrap 库来进行页面美化

首先通过 pip 安装 ttkbootstrap 库

pip install ttkbootstrap

然后在项目中引用该库

import ttkbootstrap as ttk
from ttkbootstrap.constants import *


class MainCreator(ttk.Window):
    def __init__(self):
        super().__init__("进制转换工具", themename="solar", resizable=(False, False))  # 设置一个主题

此时当我们完成组件的布局的时候,页面整体风格也就变成了主题solar的样式了,当然我们还是可以为不同的组件添加bootstyle属性来达到更多样式效果

def create_frame(self):
    """Create all the frame widgets"""
    container = ttk.Frame(self)
    container.pack(side=LEFT, fill=BOTH, expand=YES, padx=5)

    color_group = ttk.Labelframe(
        master=container, text="转换设置", padding=10
    )
    color_group.pack(fill=X, side=TOP)
    self.cb = ttk.Checkbutton(color_group, text="是否自动转换", variable=self.cbvar)
    self.cb.invoke()
    self.bt = ttk.Button(color_group, text='转换', bootstyle='success')
    self.en = ttk.Entry(color_group, text='warning', bootstyle='warning')
    self.cb.pack(side=LEFT, expand=YES, padx=5, fill=X)
    self.bt.pack(side=LEFT, expand=YES, padx=5, fill=X)
    self.en.pack(side=LEFT, expand=YES, padx=5, fill=X)

    cr_group = ttk.Labelframe(
        master=container, text="进制选择", padding=10
    )
    cr_group.pack(fill=X, pady=10, side=TOP)
    values = ['2', '8', '10', '16', '32', '36', '58', '62']
    cr3 = ttk.Label(cr_group, text="请选择待转换的进制")
    cr3.pack(side=LEFT, expand=YES, padx=5)
    self.cbo1 = ttk.Combobox(
        master=cr_group,
        values=values,
    )
    self.cbo1.pack(side=LEFT, expand=YES, pady=5)
    self.cbo1.set(values[2])

    cr5 = ttk.Label(cr_group, text="请选择转换后的进制")
    cr5.pack(side=LEFT, expand=YES, padx=5)
    self.cbo2 = ttk.Combobox(
        master=cr_group,
        values=values,
    )
    self.cbo2.pack(side=LEFT, expand=YES, pady=5)
    self.cbo2.set(values[0])

    self.txt = ttk.Text(master=container, height=5, width=50, wrap="none")
    self.txt.pack(side=LEFT, anchor=NW, pady=5, fill=BOTH, expand=YES)

最终效果如下:

可以看出,使用该库的整体效果还是要比我们手工添加 CSS 样式要更加美观,同时也更加便捷!

好了,这就是今天分享的全部内容,我们下次再见~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Android 跨进程之间通信(IPC)方式之ContentProvider

Android 跨进程之间通信 Android 跨进程之间通信(IPC)方式之BroadcastReceiverAndroid 跨进程之间通信(IPC)方式之ContentProvider 文章目录 Android 跨进程之间通信前言一、ContentProvider 是什么?二、如何利用ContentProvider跨进程通信1.创建自定义ContentProv…

伺服电机:原点复位

一、原点复位概念 原点复位指的是,在驱动器使能时,触发原点复位功能后,电机将主动查找零点,完成定位功能。 那么问题来了,什么是原点,什么是零点? 原点:即机械原点,可…

面向对象知识点

类和对象知识点梳理 1. 类和对象的概念 类是对一类事物的描述,是抽象的、概念上的定义。Java 中定义类的关键字是:class。 具有相同特征和行为的对象抽象成类,类描述了这一类对象的属性和方法: 属性(成员变量&#x…

分布式技术之数据复制技术

文章目录 什么是数据复制技术?数据复制技术原理及应用同步复制技术原理及应用异步复制技术原理及应用半同步复制技术原理及应用三种数据复制技术对比 什么是数据复制技术? 数据复制是一种实现数据备份的技术。数据复制技术,可以保证存储在不…

3D目标检测(教程+代码)

随着计算机视觉技术的不断发展,3D目标检测成为了一个备受关注的研究领域。与传统的2D目标检测相比,3D目标检测可以在三维空间中对物体进行定位和识别,具有更高的准确性和适用性。本文将介绍3D目标检测的相关概念、方法和代码实现。 一、3D目…

回溯法寻找元素之和等于目标值的子集

这是一个回溯法的算法,可以用来寻找所有元素之和等于目标值的子集. 整个算法中最重要的是:在递归之后"恢复现场" 也就是: t[cnt]0; cnt--; 完整代码(注释部分打印信息可以用来辅助理解递归过程)&#xff1a; #include<iostream> #include<cstring> …

RFC7636-PKCE

前言 PKCE &#xff08;RFC 7636&#xff09; 是授权代码流的扩展&#xff0c;用于防止 CSRF 和授权代码注入攻击。 PKCE 不是客户端身份验证的一种形式&#xff0c;PKCE 不能替代客户端密码或其他客户端身份验证。即使客户端使用客户端密码或其他形式的客户端身份验证&#…

oracle物化视图

物化视图定义 视图是一个虚拟表&#xff08;也可以认为是一条语句&#xff09;&#xff0c;基于它创建时指定的查询语句返回的结果集&#xff0c;每次访问它都会导致这个查询语句被执行一次&#xff0c;为了避免每次访问都执行这个查询&#xff0c;可以将这个查询结果集存储到…

【STM32】STM32学习笔记-输入捕获测频率和占空比(18)

00. 目录 文章目录 00. 目录01. 预留02. 输入捕获测频率接线图03. 输入捕获测频率示例04. 输入捕获测频率和占空比接线图05. 输入捕获测频率和占空比示例06. 示例程序下载07. 附录 01. 预留 02. 输入捕获测频率接线图 03. 输入捕获测频率示例 pwm.h #ifndef __PWM_H #define…

从入门到精通UNet: 让你快速掌握图像分割算法

文章目录 一、UNet 算法简介1.1 什么是 UNet 算法1.2 UNet 的优缺点1.3 UNet 在图像分割领域的应用 二、准备工作2.1 Python 环境配置2.2 相关库的安装 三、数据处理3.1 数据的获取与预处理3.2 数据的可视化与分析 四、网络结构五、训练模型5.1 模型训练流程5.2 模型评估指标5.…

【JS逆向】逆向案例之 ----- 安某客滑块

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 安某客滑块小结 1. 初步分析 总共分为两步&#xff0c; 获取滑块图片信息检查滑块移动是否正确 整体框架如下&#xff1a; 1.1 getinfoTp 获取图片信息…

Plantuml之JSON数据语法介绍(二十五)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

Nx市工业数据洞察:Flask、MySQL、Echarts的可视化之旅

Nx市工业数据洞察&#xff1a;Flask、MySQL、Echarts的可视化之旅 背景数据集来源技术选型功能介绍创新点总结 背景 随着工业化的不断发展&#xff0c;Nx市工业数据的收集和分析变得愈发重要。本博客将介绍如何利用Flask、MySQL和Echarts等技术&#xff0c;从统计局获取的数据…

【Java进阶篇】JDK新版本中的新特性都有哪些

JDK新版本中的新特性都有哪些 ✔️经典解析✔️拓展知识仓✔️本地变量类型推断✔️Switch 表达式✔️Text Blocks✔️Records✔️封装类✔️instanceof 模式匹配✔️switch 模式匹配 ✅✔️虚拟线程 ✔️经典解析 JDK 8中推出了Lambda表达式、Stream、Optional、新的日期API等…

Halcon闭运算closing

Halcon闭运算 文章目录 Halcon闭运算 闭运算的计算步骤&#xff0c;为先膨胀&#xff0c;后腐蚀。这两步操作能将看起来很接近的元素&#xff0c;如区域内部的空洞或外部孤立的点连接成一体&#xff0c;区域的外观和面积也不会有明显的改变。通俗地说&#xff0c;就是类似于“填…

echarts 折线图根据x轴时间渲染不同颜色的折线

footIm 如上图所示一条折线多种颜色 后端数据返回"data": [ { “dateTime”: “2023-10-11 00:02:10”, “pos”: 6, “curr”: 104.6 }, { “dateTime”: “2023-10-11 00:02:39”, “pos”: 7, “curr”: 104.6 }&#xff0c; …] 我们拿到后端返回的res.data传递给…

mysql原理--Explain详解

1.概述 一条查询语句在经过 MySQL 查询优化器的各种基于成本和规则的优化会后生成一个所谓的 执行计划 &#xff0c;这个执行计划展示了接下来具体执行查询的方式&#xff0c;比如多表连接的顺序是什么&#xff0c;对于每个表采用什么访问方法来具体执行查询等等。设计 MySQL 的…

Java EE Servlet之Cookie 和 Session

文章目录 1. Cookie 和 Session1.1 Cookie1.2 理解会话机制 (Session)1.2.1 核心方法 2. 用户登录2.1 准备工作2.2 登录页面2.3 写一个 Servlet 处理上述登录请求2.4 实现登录后的主页 3. 总结 1. Cookie 和 Session 1.1 Cookie cookie 是 http 请求 header 中的一个属性 浏…

【微服务】2.创建多个服务器

vmware有克隆功能直接拷贝以及设置好的虚拟机 如果要自己设置IP地址&#xff0c;修改/etc/sysconfig/network-scripts/ 编辑ifcfg-ens33需改ip地址 #开机加载网络配置启动网络服务 ONBOOT"yes" #分配ip的协议 none static :不自动分配&#xff0c;手动设置ip / dhcp…

Iterator(迭代器) 和 list

Iterator&#xff08;迭代器&#xff09; 和 list 文章目录 一、Iterator&#xff08;迭代器&#xff09;二、list 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、Iterator&#xff08;迭代器&#xff09; 对 collection 进行迭代的迭代器。迭代器…