pyqt5实现按钮添加背景图片以及背景图片的切换方法
作者:pursuit_zhangyu 时间:2023-01-11 05:15:32
简介
对与控件QPushButton中的可以使用setStyleSheet设置它背景图片。具体设置背景图片的方法有两种
self.button.setStyleSheet("QPushButton{background-image: url(img/1.png)}")
然而对于这种方法背景图片无法进行边框的自适应,可以使用下面的方法
self.button.setStyleSheet("QPushButton{border-image: url(img/1.png)}")
可以做到自适应边框。
代码
代码里面有两个图片需要使用,我放在下面了
代码1
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton
class Example(QWidget):
def __init__(self):
super().__init__()
self.initUI() # 界面绘制交给InitUi方法
def initUI(self):
# 设置窗口的位置和大小
self.setGeometry(300, 300, 300, 220)
# 设置窗口的标题
self.setWindowTitle('QPushButton')
#控件QPushButton的定义和设置
self.button = QPushButton(self)
self.button.setStyleSheet("QPushButton{border-image: url(img/1.png)}"
"QPushButton:hover{border-image: url(img/1_1.png)}"
"QPushButton:pressed{border-image: url(img/1_1.png)}")
#设置控件QPushButton的位置和大小
self.button.setGeometry(100, 100, 50, 50)
if __name__ == '__main__':
# 创建应用程序和对象
app = QApplication(sys.argv)
ex = Example()
ex.show()
sys.exit(app.exec_())
具体实现了按钮背景图片,以及鼠标划过按钮的背景切换,以及按下按钮的背景切换。
然而在按下按钮,我需要直接进行图片切换,且不回到原来的背景上。可以参考我的代码2。
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton
class Example(QWidget):
def __init__(self):
super().__init__()
self.initUI() # 界面绘制交给InitUi方法
self.slot_init()
def initUI(self):
# 设置窗口的位置和大小
self.setGeometry(300, 300, 300, 220)
# 设置窗口的标题
self.setWindowTitle('QPushButton')
#控件QPushButton的定义和设置
self.button = QPushButton(self)
self.button.setStyleSheet("QPushButton{border-image: url(img/1.png)}"
"QPushButton:hover{border-image: url(img/1_1.png)}")
# 设置控件QPushButton的位置和大小
self.button.setGeometry(100, 100, 50, 50)
def slot_init(self):
self.button.clicked.connect(self.button_change)
def button_change(self):
# 切换图标变亮
self.button.setStyleSheet('QPushButton{border-image:url(img/1_1.png)}')
if __name__ == '__main__':
# 创建应用程序和对象
app = QApplication(sys.argv)
ex = Example()
ex.show()
sys.exit(app.exec_())
如果需要来回的切换,可以定义一个计数器来解决这个问题。
来源:https://blog.csdn.net/pursuit_zhangyu/article/details/83213401
标签:pyqt5,按钮,背景图片,切换
0
投稿
猜你喜欢
python列表:开始、结束、步长值实例
2022-03-06 06:59:48
使用python爬取微博数据打造一颗“心”
2022-05-28 22:30:09
为非IE浏览器添加mouseenter,mouseleave事件的实现代码
2024-02-23 19:26:11
微信小程序与php 实现微信支付的简单实例
2023-11-14 15:22:07
Python安装xarray库读取.nc文件的详细步骤
2023-10-15 11:59:37
详解如何在Javascript中使用Object.freeze()
2024-04-10 16:10:17
Python图像处理之图像的灰度线性变换
2021-12-16 22:30:58
CodeIgniter分页类pagination使用方法示例
2023-11-24 10:33:05
Python映射类型之dict详解
2023-08-03 13:19:19
python numpy实现文件存取的示例代码
2022-01-11 07:14:58
公共Hooks封装报表导出useExportExcel实现详解
2024-04-28 09:21:36
Selenium元素的常用操作方法分析
2021-09-21 14:51:54
谈中国站长站的文章干扰码实现方法
2007-10-13 11:13:00
sublime text 3配置使用python操作方法
2023-01-21 20:30:14
Django基于ORM操作数据库的方法详解
2024-01-28 18:53:52
Oracle中大批量删除数据的方法
2010-07-21 13:05:00
Go 语言下基于Redis分布式锁的实现方式
2024-04-25 13:17:24
python遍历类中所有成员的方法
2022-11-16 22:29:00
Python中的字符串操作和编码Unicode详解
2021-02-24 18:37:11
Python OpenCV超详细讲解调整大小与图像操作的实现
2022-07-09 21:16:27