[英]Change button images when you hover over them tkinter
将鼠标悬停在按钮上时如何更改图像? 我需要的是,当您在按钮 1 或 2 上使用 hover 时,图片会发生变化:
Photo1 = (file='Image\ProgrammingButton')
Photo2 = (file='Image\DesignButton')
But1 = (root, image=Photo1)
But2 = (root, image=Photo2)
在 hover
Photo1 = (file='Image\ActiveProgrammingButton')
Photo2 = (file='Image\ActiveDesignButton')
Tkinter 具有“进入”和“离开”事件,您必须将其绑定到某些 function 并且您可以使用config
方法更改图像。
这是一个演示:
from tkinter import *
from PIL import Image, ImageTk
def onEnter(event):
global img
img = ImageTk.PhotoImage(Image.open(r'img2'))
btn.config(image=img)
def onLeave(event):
global img
img = ImageTk.PhotoImage(Image.open(r'img1'))
btn.config(image=img)
root = Tk()
img = ImageTk.PhotoImage(Image.open(r'img1'))
btn = Button(root, image=img)
btn.pack()
btn.bind('<Enter>', onEnter)
btn.bind('<Leave>', onLeave)
root.mainloop()
如果您希望对许多按钮具有此效果。 我建议您创建自己的按钮,继承Button
class。
这是一个例子。
感谢@furas 的建议。 这是更新的 class
class Btn(Button):
def __init__(self, root, img1, img2, *args, **kwargs):
super().__init__(root, *args, **kwargs)
self.img = ImageTk.PhotoImage(Image.open(img1))
self.img2 = ImageTk.PhotoImage(Image.open(img2))
self['image'] = self.img
self.bind('<Enter>', self.enter)
self.bind('<Leave>', self.leave)
def enter(self, event):
self.config(image=self.img2)
def leave(self, event):
btn.config(image=self.img)
使用方法:在img1和img2参数中指定你的图片路径即可
这是一个例子:
img = r'path1'
img2 = r'path2'
btn = Btn(root, img1=img, img2=img2)
btn.pack()
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.