繁体   English   中英

如何在Python Tkinter中将这些按钮覆盖在图像的背景上

[英]How do I overlay these buttons on top of an image for a background in Python Tkinter

目前,我正在尝试使用Tkinter作为简单的GUI为游戏创建简单的主菜单,因为它是简单的RPG游戏和Python,但是图像在所有情况下都覆盖按钮。

我尝试过使用其他解决方案,例如放置它们或创建窗口,但我都找不到如何做到的直接答案。

import tkinter
from tkinter import *
from PIL import ImageTk, Image 
(PIL is from when I was using a JPG before.)   

root = Tk()
content = ttk.Frame(root)
root.geometry("600x600")

background = ImageTk.PhotoImage(Image.open("bred.png"))
canvas = tkinter.Canvas(root, width=580, height=600)

content.grid(column=0, row=0)

Btn1 = Button(content, text="Play", width=5, height=1)
Btn2 = Button(content, text="Kill me", width=7, height=1, command = 
root.quit)

backgroundlabel = tkinter.Label(root, image=background)
backgroundlabel.image = background

backgroundlabel.place(x=0, y=0, relwidth=1, relheight=1)

Btn1.grid(row=1, column=2, padx=(130))
Btn1.columnconfigure(1, weight=1)
Btn1.rowconfigure(1, weight=1)

Btn2.grid(row=1, column=3, pady=(130))
Btn2.columnconfigure(3, weight=1)
Btn2.rowconfigure(1, weight=1)

root.mainloop()

当前,背景的母版设置为root而按钮设置为框架。 您需要做的第一件事是将两者都设置为同一母版,即将背景母版更改为content

backgroundlabel = tk.Label(content, image=background)

接下来,您需要处理堆叠顺序。 您可以调用widget.lift()将按钮升至顶部:

Btn1.grid(row=1, column=2, padx=(130))
...
Btn1.lift()

Btn2.grid(row=1, column=3, pady=(130))
...
Btn2.lift()

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM