Я некоторое время работал над небольшим проектом в PyQt5, и я хотел попытаться сделать его немного лучше, используя таблицу стилей. Для тестирования я скопировал пример из W3Schools в новый проект, чтобы посмотреть, сработает ли он. Примером является кнопка, где фон исчезает с белого на зеленый. Все работает, кроме того, что вместо исчезновения, переход происходит мгновенно. Мои вопросы, как я могу получить этот эффект исчезновения? Мне также любопытно, как я могу получить такой же эффект перехода, но с другими аспектами кнопки, такими как размер или форма.
Я провел большой поиск, но все релевантное, что я нашел немного вне моей сферы знаний. Что я знаю, так это то, что мне, вероятно, придется кодировать его вместо использования таблицы стилей, но я не совсем уверен, как это сделать. Я думал, что смогу сделать функцию для постоянного изменения цвета, но я также думаю, что, вероятно, есть лучший способ сделать это.
Это код, который генерируется, когда я конвертирую файл .ui.
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_Dialog(object):
def setupUi(self, Dialog):
Dialog.setObjectName("Dialog")
Dialog.resize(400, 300)
self.pushButton = QtWidgets.QPushButton(Dialog)
self.pushButton.setGeometry(QtCore.QRect(10, 10, 381, 281))
self.pushButton.setMouseTracking(False)
self.pushButton.setAutoFillBackground(False)
self.pushButton.setStyleSheet(".QPushButton{\n"
"background-color: #4CAF50;\n"
"border: none;\n"
"color: white;\n"
"padding: 16px 32px;\n"
"text-align: center;\n"
"text-decoration: none;\n"
"display: inline-block;\n"
"font-size: 16px;\n"
"margin: 4px 2px;\n"
"transition-duration: 0.4s;\n"
"cursor: pointer;\n"
"}\n"
"\n"
"#pushButton{\n"
"background-color: white;\n"
"color: black;\n"
"border: 2px solid #4CAF50;\n"
"}\n"
"\n"
"#pushButton:hover{\n"
"background-color: #4CAF50;\n"
"color: white;\n"
"}")
self.pushButton.setObjectName("pushButton")
self.retranslateUi(Dialog)
QtCore.QMetaObject.connectSlotsByName(Dialog)
def retranslateUi(self, Dialog):
_translate = QtCore.QCoreApplication.translate
Dialog.setWindowTitle(_translate("Dialog", "Dialog"))
self.pushButton.setText(_translate("Dialog", "Click Here"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
Dialog = QtWidgets.QDialog()
ui = Ui_Dialog()
ui.setupUi(Dialog)
Dialog.show()
sys.exit(app.exec_())
Это то, что находится в таблице стилей, но более читабельно.
.QPushButton{
background-color: #4CAF50;
border: none;
color: white;
padding: 16px 32px;
text-align: center;
text-decoration: none;
display: inline-block;
font-size: 16px;
margin: 4px 2px;
transition-duration: 0.4s;
cursor: pointer;
}
#pushButton{
background-color: white;
color: black;
border: 2px solid #4CAF50;
}
#pushButton:hover{
background-color: #4CAF50;
color: white;
}
Вот изображение кнопки.
Перед наведением
и после