PyQt5 QSpinBox – 为上升按钮添加皮肤
在这篇文章中,我们将看到如何为旋转盒的向上按钮设置不同状态的皮肤。旋转盒有两个子程序,一个是行编辑,另一个是向上和向下按钮。上升按钮用于增加旋转框的值,基本上有三种状态,一种是正常状态,第二种是悬停状态,即光标在上升按钮上时,第三种是被按下的状态。皮肤基本上是一个背景图像,它可以根据旋转框的大小来调整自己。
为了做到这一点,我们必须改变与旋转框相关的样式表,下面是样式表的代码
QSpinBox::up-button
{
border-image : url(image1.png);
}
QSpinBox::up-button:hover
{
border-image : url(image2.png);
}
QSpinBox::up-button:pressed
{
border-image : url(image3.png);
}
这将为向上按钮的每个状态添加三种不同的皮肤,还有一些额外的状态,如anti-hover(!hover)和anti-pressed(!pressed)这些分别是与hover和pressed状态相反。
下面是实现方法
# importing libraries
from PyQt5.QtWidgets import *
from PyQt5 import QtCore, QtGui
from PyQt5.QtGui import *
from PyQt5.QtCore import *
import sys
class Window(QMainWindow):
def __init__(self):
super().__init__()
# setting title
self.setWindowTitle("Python ")
# setting geometry
self.setGeometry(100, 100, 600, 400)
# calling method
self.UiComponents()
# showing all the widgets
self.show()
# method for widgets
def UiComponents(self):
# creating spin box
self.spin = QSpinBox(self)
# setting geometry to spin box
self.spin.setGeometry(100, 100, 250, 40)
# setting range to the spin box
self.spin.setRange(0, 9999)
# setting prefix to spin
self.spin.setPrefix("PREFIX ")
# setting suffix to spin
self.spin.setSuffix(" SUFFIX")
# setting style sheet
# adding skin to spin box's up-button
# adding skin to up button for hover and pressed state
self.spin.setStyleSheet("QSpinBox::up-button"
"{"
"border-image : url(image.png);"
"}"
"QSpinBox::up-button:hover"
"{"
"border-image : url(skin.png);"
"}"
"QSpinBox::up-button:pressed"
"{"
"border-image : url(logo.png);"
"}"
)
# create pyqt5 app
App = QApplication(sys.argv)
# create the instance of our Window
window = Window()
# start the app
sys.exit(App.exec())