没有内置的方法可以做到这一点,但您可以尝试使用事件绑定来解决它。
下面的示例将使用一些绑定来尝试管理菜单的位置。
我们需要一个Toplevel() 窗口来容纳菜单。
接下来我们需要去掉它的按钮(-、[]和X)。这可以通过overidedirect(True) 完成。
现在我们无法手动移动Toplevel() 窗口,我们需要将<Configure> 事件绑定到将顶层定位在主窗口最右侧的函数。
这是绑定:
win.bind("<Configure>", lambda x: win.after(0, move_menu(x)))
函数如下:
def move_menu(event):
x = (win.winfo_width() - menu_frame.winfo_width())
z = (win.winfo_x(), win.winfo_y())
xx = menu_frame.winfo_width()
menu_frame.geometry('%dx%d+%d+%d' % ((xx), 0, (z[0]+x+8), (z[1]+30)))
接下来,我们需要强制菜单或顶层窗口停留在主窗口的顶部。这可以通过menu_frame.attributes('-topmost', True) 完成。但是,当您在 man 窗口之外单击时,我们会遇到一个问题,即顶级菜单窗口位于 tkinter 应用程序之外的所有程序之上。
为了管理这种行为,我们需要另外 2 个绑定。一个用于事件'<Enter>',一个用于事件'<Leave>'。这将允许我们在鼠标进入和离开根窗口时切换overrideredirect() 方法。
这里是绑定:
win.bind("<Enter>", lambda x: win.after(0, manage_top_attr(x, True)))
win.bind("<Leave>", lambda x: win.after(0, manage_top_attr(x, False)))
函数如下:
def manage_top_attr(event, tf):
menu_frame.attributes('-topmost', tf)
将所有内容添加到程序中后,我们可以在屏幕右侧有一个菜单。
代码示例:
import tkinter as tk
win = tk.Tk()
win.minsize(200, 200)
win.geometry("250x200")
menu_frame = tk.Toplevel(win)
menu_frame.overrideredirect(True)
menu_frame.attributes('-topmost', True)
tk.Label(win, text="").grid(row=0, column=0)
main_window_frame = tk.Frame(win)
main_window_frame.grid(row=1, column=0, sticky="nsew")
def manage_top_attr(event, tf):
menu_frame.attributes('-topmost', tf)
def move_menu(event):
print (event)
x = (win.winfo_width() - menu_frame.winfo_width())
z = (win.winfo_x(), win.winfo_y())
xx = menu_frame.winfo_width()
menu_frame.geometry('%dx%d+%d+%d' % ((xx), 0, (z[0]+x+8), (z[1]+30)))
win.bind("<Configure>", lambda x: win.after(0, move_menu(x)))
win.bind("<Enter>", lambda x: win.after(0, manage_top_attr(x, True)))
win.bind("<Leave>", lambda x: win.after(0, manage_top_attr(x, False)))
tk.Label(main_window_frame, text="Main window").grid(row=0, column=0)
menuBar = tk.Menu(menu_frame)
menu_frame.config(menu=menuBar)
fileMenu = tk.Menu(menuBar, tearoff=0)
menuBar.add_cascade(label="File", menu=fileMenu)
fileMenu.add_command(label="New")
menuBar.add_cascade(label="Edit", menu=fileMenu)
menuBar.add_cascade(label="Options", menu=fileMenu)
menuBar.add_cascade(label="Help", menu=fileMenu)
win.mainloop()
结果:
调整窗口大小后:
现在它的行为并不完美,可能需要做一些工作,但这是一个开始。