当前位置:首页 >> 教育
教育

谁说Python撰写GUI程序丑?那是你不会美化

2025-08-16 12:19

p>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 来增设,对于红色的必需,可以通过离线的红色必需器来必需

再一我们顺利进行下拉框外形上的增设,对于下拉框配件,还是有些特殊的

该配件属于 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脚注("进位制转化工具", theme, 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 外形上要越来越加耐用,同时也越来越加便捷!

杭州比较好的白癜风医院
江苏皮肤病检查多少钱
西安妇科医院哪家最好
揭阳白癜风医院地址
青岛中医医院排行

上一篇: 有望通过 Flyme 实现手机与汽车信息相伴?魅族 19 主理人最新调研出炉

下一篇: 全速出击 Kingston FURY叛逆者(Renegade)前传DDR5内存

友情链接