【问题标题】:Tkinter: Change the menu bar and title bar colorsTkinter:更改菜单栏和标题栏颜色
【发布时间】:2020-11-17 02:14:39
【问题描述】:

我想更改菜单栏和标题的颜色。

这是我想要的示例。

有可能吗?

【问题讨论】:

标签: python tkinter


【解决方案1】:

举例说明你想做什么:

import tkinter as tk
from tkinter import ttk

class App(tk.Tk):
    def __init__(self):
        super().__init__()
        self.geometry("400x200")
        self.configure(background='black')
        self.overrideredirect(1)
        self.attributes("-topmost", True)
        
    def startMove(self,event):
        self.x = event.x
        self.y = event.y

    def stopMove(self,event):
        self.x = None
        self.y = None

    def moving(self,event):
        x = (event.x_root - self.x)
        y = (event.y_root - self.y)
        self.geometry("+%s+%s" % (x, y))

    def exit(self):
        self.destroy()


def save():
    print ('save')
    return None
def add():
    print('add')
    return None

  

class MenuBar(tk.Frame):
    def __init__(self, master=None):
        tk.Frame.__init__(self, master, bd=1, relief='raised')
        self.master=master
        self.configure(background='black',
                       cursor='hand2')

        file = tk.Menubutton(self, text='File',
                             background='black',
                             foreground='white',
                             activeforeground='black',
                             activebackground='white'
                             )
        file_menu = tk.Menu(file,tearoff=0)
        file_menu.add_command(label='save', command=save,
                              background='black',
                              foreground='white',
                              activeforeground='black',
                              activebackground='white'
                              )
        
        file.config(menu=file_menu)
        file.pack(side='left')

        edit = tk.Menubutton(self, text='Edit',
                             background='black',
                             foreground='white',
                             activeforeground='black',
                             activebackground='white'
                             )
        edit_menu = tk.Menu(edit,tearoff=0)
        edit_menu.add_command(label='add', command=add,
                              background='black',
                              foreground='white',
                              activeforeground='black',
                              activebackground='white'
                              )

        edit.config(menu=edit_menu)
        edit.pack(side='left')

        close = tk.Button(self, text='X', command=lambda:root.exit(),
                          background='black',
                          foreground='white')
        close.pack(side='right')

def show():
    print('show')
    return None
def ex_it():
    print('exit')
    return None

class MainFrame(tk.LabelFrame):
    def __init__(self, master=None):
        tk.LabelFrame.__init__(self, master, bd=1, relief='raised', text='MainFrame', background='black', foreground='white')
        self.master=master
        self.note = tk.Label(self, text='Your typed chars appear here:',
                             background='black',
                             foreground='white',
                             )
        self.note.grid(column=0, row=0, columnspan=2, sticky='w')
        self.entry = ttk.Entry(self, style='My.TEntry')
        self.entry.grid(column=0,row=1,columnspan=3, sticky='ew')
        self.columnconfigure(0, weight=1)
        self.b_frame=tk.Frame(self, bg='black')
        self.b_frame.grid(column=0,row=2,sticky='w')
        self.sh_b = tk.Button(self.b_frame, text='Show', command=show)
        self.ex_b = tk.Button(self.b_frame, text='Exit', command=ex_it)
        self.sh_b.grid(column=0, row=0, sticky='w')
        self.ex_b.grid(column=1, row=0, sticky='w', padx=5)

root = App()

menubar = MenuBar(root)
menubar.pack(side='top', fill='x')

mainframe = MainFrame(root)
mainframe.pack(fill='both', expand=1)

menubar.bind("<Button-1>", root.startMove)
menubar.bind("<ButtonRelease-1>", root.stopMove)
menubar.bind("<B1-Motion>", root.moving)

style = ttk.Style(root)
style.element_create("plain.field", "from", "clam")
style.layout("My.TEntry",
             [('Entry.plain.field', {'children': [(
                 'Entry.background', {'children': [(
                     'Entry.padding', {'children': [(
                         'Entry.textarea', {'sticky': 'nswe'})],
                                       'sticky': 'nswe'})], 'sticky': 'nswe'})],
                                     'border':'2', 'sticky': 'nswe'})])
style.configure("My.TEntry",
                 foreground="white",
                 fieldbackground="grey")

root.mainloop()

玩得开心!

说明

首先,我使用类创建了 3 个对象,它们看起来像这样:

应用程序lication / 我们从 Tk() 获取的窗口

class App(tk.Tk):
    def __init__(self):
        super().__init__()

然后是从 Frame 中获取的菜单栏,如下所示:

class MenuBar(tk.Frame):
    def __init__(self, master=None):
        tk.Frame.__init__(self, master, bd=1, relief='raised')

以及从 tkinter 的 LabeFrame 类中继承的 MainFrame:

class MainFrame(tk.LabelFrame):
    def __init__(self, master=None):
        tk.LabelFrame.__init__(self, master, bd=1, relief='raised', text='MainFrame', background='black', foreground='white')

了解更多关于类和init方法[click] 理解语法self.[click]

让我们仔细看看应用程序:


self.geometry("400x200")
self.configure(background='black')
self.overrideredirect(1)
self.attributes("-topmost", True)
  • 使用the geometry method,我们以像素为单位定义width=400height=200
  • 然后我们用一行来配置背景:

self.configure(background='black')

设置或获取覆盖重定向标志。如果非零,这可以防止 窗口管理器从装饰窗口。换句话说, 窗口将没有标题或边框,并且不能移动或 通过普通方式关闭。

  • 我们最终将attributes method 用于Toplevels,并将参数topmost 设置为true:

(Windows) 如果设置,则此窗口始终位于其他窗口之上 视窗。请注意,在此版本中,此属性必须为 “-topmost”。


使用 overrideredirect 后最大的问题是你不能再移动你的窗口了,因为窗口管理器没有边框/标题或菜单栏了。所以我们需要自己携带,使用这段代码:

def startMove(self,event):
    self.x = event.x
    self.y = event.y

def stopMove(self,event):
    self.x = None
    self.y = None

def moving(self,event):
    x = (event.x_root - self.x)
    y = (event.y_root - self.y)
    self.geometry("+%s+%s" % (x, y))

这段代码的作用是通过单击/Button-1 和event manger 来获取当前鼠标位置

event.x 或 event.y 表示:

当前鼠标位置,以像素为单位。

event.x_root 或 event.y_root 表示:

当前鼠标相对于左上角的位置 屏幕,以像素为单位。

通过从另一个中减去一个,我们得到偏移量,这是我们将geometry method 需要的偏移量到“移动”


【讨论】:

  • 您的代码有效。但是我还是适应不了。我有个问题。你能给我显示标题的代码吗,把菜单栏设置为黑色,其余的设置为白色?对不起,我是初学者
  • 我会尽快写一个解释。但首先你应该知道已经没有“正常”的菜单栏了,我已经删除了系统的菜单栏并在菜单栏类中编写了我自己的菜单栏。删除App类中的self.configure(background='black')这一行,看看能不能解决你的问题。
  • @LucySmith 已更新为有效点。我希望这会有所帮助
  • 谢谢你,你帮了我很多。但我还是做不到。我在这里发布了我的一些代码。 pastebin.com/Wn2rMK6t
  • @LucySmith 这与我编写的代码没有太大关系,我真的不想经历这一切。但是你可以尝试在应用类中使用 self.configure(bg='color_of_your_choice') 看看是否有效。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-11-02
  • 1970-01-01
  • 1970-01-01
  • 2013-01-30
  • 2013-04-20
相关资源
最近更新 更多