如何在python ttk中获得平面浮雕条目小部件?

Rai*_*ers 1 python user-interface tkinter ttk

我正在用 python ttk 编写一个 GUI FTP 客户端应用程序。我似乎无法按照我想要的方式获取文本条目。在此输入图像描述

文本条目具有“SUNKEN”效果。我想调整高度并使文本条目具有“平面”外观,更像这个程序:

在此输入图像描述
我让按钮从这里看起来平坦,我正在努力让条目看起来平坦。
如何使条目看起来平坦?

我不需要 tk 解决方案,我知道如何在 tk 中设置救济平坦。

Com*_*nse 7

琐事:

ttk 小部件的外观很大程度上取决于使用的主题和/或平台。在 Windows 上,我可以使用主题重现这种压抑的灰色风格classic,所以让我们假设正在使用这个主题。如果您想知道,您可以在这里找到主题列表(请注意'clam'主题,它与您的愿望最相似)。

下一站,我们layout的,或者换句话说,小部件主题的结构。您可以轻松打印此结构以查看可用选项。话不多说,让我们尝试一下小部件的结构ttk.Entry

>>> print(s.layout('TEntry'))

#   formatted result, actual result is one-line string
[('Entry.highlight', {
    'sticky': 'nswe',
    'children': [(
        'Entry.field', {
            'sticky': 'nswe',
            'children': [(
                'Entry.padding', {
                    'sticky': 'nswe',
                    'children': [(
                        'Entry.textarea', {
                            'sticky': 'nswe'})]
                })],
            'border': '1'})]
})]
Run Code Online (Sandbox Code Playgroud)

正如您所看到的,结构元素都没有relief选项,因此relief='flat'对我们的条目没有影响!

>>> print(s.element_options('Entry.field'))
('-bordercolor', '-lightcolor', '-darkcolor', '-fieldbackground')
Run Code Online (Sandbox Code Playgroud)

解决方法:

但是,我们可以编辑所需小部件的布局,并将一个元素替换为另一个元素,从而能够识别一个relief选项(注意removed Entry.field,替换为an Entry.border)。

所以尝试一下这个小片段:

try:
    import tkinter as tk
    import tkinter.ttk as ttk
except ImportError:
    import Tkinter as tk
    import ttk

#   root
root = tk.Tk()

#   declare style variable
s = ttk.Style()
#   assume that classic theme in use
s.theme_use('classic')

#   configure relief
s.configure('SOExample.TEntry', relief='flat')

#   lets try to change this structure
s.layout('SOExample.TEntry', [
    ('Entry.highlight', {
        'sticky': 'nswe',
        'children':
            [('Entry.border', {
                'border': '1',
                'sticky': 'nswe',
                'children':
                    [('Entry.padding', {
                        'sticky': 'nswe',
                        'children':
                            [('Entry.textarea',
                              {'sticky': 'nswe'})]
                    })]
            })]
    })])

#   let's find some differences between this two
print(s.layout('SOExample.TEntry'))
print(s.layout('TEntry'))

#    packing
frame1 = tk.Frame(root)
label1 = tk.Label(frame1, text='Flat Entry')
entry1 = ttk.Entry(frame1, style='SOExample.TEntry')
label1.pack()
entry1.pack()
frame1.pack(side='left')

frame2 = tk.Frame(root)
label2 = tk.Label(frame2, text='Default Entry')
entry2 = ttk.Entry(frame2)
label2.pack()
entry2.pack()
frame2.pack(side='right')

#   mainloop
root.mainloop()
Run Code Online (Sandbox Code Playgroud)

...最终的外观是:

不活跃积极的

另外,在我的机器上默认主题是vista,我什至无法识别条目: 远景

而且 an 的结构也Entry取决于主题,因此vista

#   formatted result, actual result is one-line string
[('Entry.field', {
    'sticky': 'nswe',
    'children': [(
        'Entry.background', {
            'sticky': 'nswe',
            'children': [(
                'Entry.padding', {
                    'sticky': 'nswe',
                    'children': [(
                        'Entry.textarea', {
                            'sticky': 'nswe'})]
                })]
        })]
})]
Run Code Online (Sandbox Code Playgroud)

...如果我们用此结构中的元素替换 a fieldborder则外观非常接近您的要求(groove在这种情况下也尝试缓解):

远景

结论:

不幸的是,这个小部件将缺少字段和边框颜色的选项,因此另一个选项是为此目的创建自己的元素,但这是另一个问题。

因此,基本上我试图回答的不是“如何解决这个问题”,而是“为什么救济对条目没有影响”,无论如何,正如您所看到的,条目的平坦救济是可以实现的。