当前位置:   article > 正文

谁说Python写GUI程序丑?那是你不会美化_python漂亮gui界面模板

python漂亮gui界面模板

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

页面布局

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

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

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

部分代码如下

  1. from tkinter import ttk
  2. from tkinter import *
  3. class Transform():
  4.     def __init__(self):
  5.         self.root = Tk()
  6.         self.root.title("进制转换工具")
  7.         self.root.geometry("600x280")
  8.         self.root.resizable(FalseFalse)
  9.         self.var = StringVar()
  10.         self.values = ['2''8''10''16''32''36''58''62']
  11.         self.myWidget()
  12.         self.myLayout()
  13.     def myWidget(self):
  14.         self.container = Frame(self.root)
  15.         # 转换设置区域
  16.         self.lf_group1 = LabelFrame(master=self.container, text="转换设置")
  17.         self.cb = Checkbutton(self.lf_group1, text="是否自动转换")
  18.         self.cb.invoke()
  19.         self.bt = Button(self.lf_group1, text='转换')
  20.         self.en = Entry(self.lf_group1, text='warning')
  21.         # 进制选择区域
  22.         self.lf_group2 = LabelFrame(master=self.container, text="进制选择")
  23.         self.lb1 = Label(self.lf_group2, text="请选择待转换的进制")
  24.         self.cbo1 = ttk.Combobox(
  25.             master=self.lf_group2,
  26.             values=self.values
  27.         )
  28.         self.cbo1.set(self.values[2])
  29.         self.lb2 = Label(self.lf_group2, text="请选择转换后的进制")
  30.         self.cbo2 = ttk.Combobox(
  31.             master=self.lf_group2,
  32.             values=self.values,
  33.         )
  34.         self.cbo2.set(self.values[0])
  35.         # 进制输出区域
  36.         self.txt = Text(master=self.container, height=5, width=50)
  37.     def myLayout(self):
  38.         self.container.pack(side=LEFT, fill=BOTH, expand=YES, padx=5)
  39.         self.lf_group1.pack(fill=X, side=TOP)
  40.         self.lf_group2.pack(fill=X, pady=10, side=TOP)
  41.         self.cb.pack(side=LEFT, expand=YES, padx=5, fill=X)
  42.         self.bt.pack(side=LEFT, expand=YES, padx=5, fill=X)
  43.         self.en.pack(side=LEFT, expand=YES, padx=5, fill=X)
  44.         self.lb1.pack(side=LEFT, expand=YES, padx=5)
  45.         self.cbo1.pack(side=LEFT, expand=YES, pady=5)
  46.         self.lb2.pack(side=LEFT, expand=YES, padx=5)
  47.         self.cbo2.pack(side=LEFT, expand=YES, pady=5)
  48.         self.txt.pack(side=LEFT, anchor=NW, pady=5, fill=BOTH, expand=YES)
  49.     def run(self):
  50.         self.container.mainloop()
  51. if __name__ == '__main__':
  52.     trans = Transform()
  53.     trans.run()

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

页面美化

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

首先我们设置背景颜色

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

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

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

  1. self.lf_group1.config(bg='#073642', fg="white")
  2. self.lf_group2.config(bg='#073642', fg="white")
  3. self.cb.config(bg='#073642', selectcolor='#073642', activebackground='#073642',
  4.                activeforeground='#073642', fg="white")
  5. self.bt.config(bg="azure3")
  6. self.en.config(highlightbackground="#0b5162", highlightcolor="#0b5162",
  7.                insertofftime=500, insertontime=500, fg="Gainsboro", insertbackground="Gainsboro",
  8.                bg="#073642", highlightthickness=2, relief="solid")
  9. self.lb1.config(bg='#073642', activebackground='#073642',
  10.                 activeforeground='#073642', fg="white")
  11. self.lb2.config(bg='#073642', activebackground='#073642',
  12.                 activeforeground='#073642', fg="white")
  13. self.txt.config(insertofftime=500, insertontime=500, fg="Gainsboro", insertbackground="Gainsboro",
  14.                 wrap="none", bg='#073642')

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

https://tools.kalvinbg.cn/dev/colorPicker 接下来我们进行下拉框样式的设置,对于下拉框组件,还是有些特殊的

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

  1. combostyle = ttk.Style()
  2. combostyle.theme_create('combostyle', parent='alt',
  3.                         settings={'TCombobox':
  4.                             {'configure':
  5.                                 {
  6.                                     'foreground''white',
  7.                                     'selectbackground''#073642',  # 选择后的背景颜色
  8.                                     'fieldbackground''#073642',  # 下拉框颜色
  9.                                     'background''#073642',  # 下拉按钮背景颜色
  10.                                     "font"10,  # 字体大小
  11.                                 }}}
  12.                         )
  13. combostyle.theme_use('combostyle')

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

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

使用 ttkbootstrap 美化页面

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

首先通过 pip 安装 ttkbootstrap 库

pip install ttkbootstrap

然后在项目中引用该库

  1. import ttkbootstrap as ttk
  2. from ttkbootstrap.constants import *
  3. class MainCreator(ttk.Window):
  4.     def __init__(self):
  5.         super().__init__("进制转换工具", themename="solar", resizable=(FalseFalse))  # 设置一个主题

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

  1. def create_frame(self):
  2.     """Create all the frame widgets"""
  3.     container = ttk.Frame(self)
  4.     container.pack(side=LEFT, fill=BOTH, expand=YES, padx=5)
  5.     color_group = ttk.Labelframe(
  6.         master=container, text="转换设置", padding=10
  7.     )
  8.     color_group.pack(fill=X, side=TOP)
  9.     self.cb = ttk.Checkbutton(color_group, text="是否自动转换", variable=self.cbvar)
  10.     self.cb.invoke()
  11.     self.bt = ttk.Button(color_group, text='转换', bootstyle='success')
  12.     self.en = ttk.Entry(color_group, text='warning', bootstyle='warning')
  13.     self.cb.pack(side=LEFT, expand=YES, padx=5, fill=X)
  14.     self.bt.pack(side=LEFT, expand=YES, padx=5, fill=X)
  15.     self.en.pack(side=LEFT, expand=YES, padx=5, fill=X)
  16.     cr_group = ttk.Labelframe(
  17.         master=container, text="进制选择", padding=10
  18.     )
  19.     cr_group.pack(fill=X, pady=10, side=TOP)
  20.     values = ['2''8''10''16''32''36''58''62']
  21.     cr3 = ttk.Label(cr_group, text="请选择待转换的进制")
  22.     cr3.pack(side=LEFT, expand=YES, padx=5)
  23.     self.cbo1 = ttk.Combobox(
  24.         master=cr_group,
  25.         values=values,
  26.     )
  27.     self.cbo1.pack(side=LEFT, expand=YES, pady=5)
  28.     self.cbo1.set(values[2])
  29.     cr5 = ttk.Label(cr_group, text="请选择转换后的进制")
  30.     cr5.pack(side=LEFT, expand=YES, padx=5)
  31.     self.cbo2 = ttk.Combobox(
  32.         master=cr_group,
  33.         values=values,
  34.     )
  35.     self.cbo2.pack(side=LEFT, expand=YES, pady=5)
  36.     self.cbo2.set(values[0])
  37.     self.txt = ttk.Text(master=container, height=5, width=50, wrap="none")
  38.     self.txt.pack(side=LEFT, anchor=NW, pady=5, fill=BOTH, expand=YES)

最终效果如下:

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

以上就是本次分享的所有内容,如果你觉得文章还不错,欢迎关注公众号:Python编程学习圈,每日干货分享,发送“J”还可领取大量学习资料,内容覆盖Python电子书、教程、数据库编程、Django,爬虫,云计算等等。或是前往编程学习网,了解更多编程技术知识。

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/724460
推荐阅读
相关标签
  

闽ICP备14008679号