איך משנים צבע לBUTTON בPYQT כשהעכבר עובר עליו?
קדם ‹ Forums ‹ הייטק ‹ Programming Languages ‹ איך משנים צבע לBUTTON בPYQT כשהעכבר עובר עליו?
-
איך משנים צבע לBUTTON בPYQT כשהעכבר עובר עליו?
פורסם ע"י michal029022 חברה on 16/01/2020 ב12:36 pmאני רוצה לשנות את הצבע של הBUTTON כשהעכבר עובר עליו(MOUSE HOVER ) (בצורה הדרגתית (לאט ניסיתי עם אנימציות וטרנזישןס, אבל לא כ”כ ידעתי איך לכתוב את זה בפייתון או בpyqt מישהי יכולה לעזור לי אולי?
הדר צמח הגיבה לפני 4 שנים, 11 חודשים 2 חברות · 16 תגובות -
16 תגובות
-
000חברה חדשה
היי
אולי זה יעזור לך:
https://stackoverflow.com/questions/34496675/change-the-background-color-of-a-qpushbutton-progressively-and-in-a-time-duratio
זה לא בפייתון, אבל אפשר להמיר יחסית בקלות -
000חברה חדשה
תודה, אבל איך אני מפעילה את הenter-event? ניסיתי לשלב את הקוד הזה בקוד שלי אבל שום דבר לא קרה!
-
000חברה חדשה
הנה הקוד בתוספת כמה שינויים שעבדו לי:
: import קודם כל מוסיפה את ה from PyQt4 import QtCore from PyQt4.QtCore import QPropertyAnimation, Qt from PyQt4.QtGui import QPushButton, QColor זה המימוש של הclass, הוספתי ל init שיקבל פרמטר “אבא” (החלון הראשי, או מי שאמור להחזיק אותו) וה enterEvent זוהי פונקציה מובנת של הכפתור, שאנו דורסים וממשים בצורה אחרת (האנימציה של הצבעים)
class MyButton(QPushButton): def __init__(self, parent=None): super(MyButton, self).__init__(parent) self.setMinimumSize(80,50) self.setText(‘QPushButton’) def getColor(self): return Qt.black def setColor(self, color): self.setStyleSheet(“background-color: rgb({0}, {1}, {2});border:none;”.format(color.red(), color.green(), color.blue())) color=QtCore.pyqtProperty(QColor, getColor, setColor) def enterEvent(self, event): global anim anim=QPropertyAnimation(self, “color”) anim.setDuration(200) anim.setStartValue(QColor(216, 140, 230)) anim.setEndValue(QColor(230, 230, 230)) anim.start() def leaveEvent(self, event): self.setStyleSheet(“background:none;”) וכמובן לא לשכוח בקוד שלך, ליצור כפתור מסוג myButton: self.mybutton = MyButton(self) מקווה שעזרתי אם יש עוד שאלות, בשמחה! -
000חברה חדשה
ואם רוצים להוסיף כזה כפתור דרך ה qtdesigner
יש ליצור קובץ עם ה class
ודרך ה gui, לחיצה ימנית על הכפתור -> promote to יפתח חלון כזה: ולהכניס את המידע בהתאמה לשים לב שאפילו שהקובץ של הclass הוא בפייתון, כאן יש להכניס אותו עם סיומת .h בהצלחה! -
000חברה חדשה
וואו, תודה. עשיתי את זה, והאנימציה לא עושה כלום, זאת אומרת – כשאני עוזבת עם העכבר – הוא פועל מצוין, אבל כשאני עוברת עם העכבר – הוא לא עושה כלום. אני מצרפת את הקוד: class MyButton(QtWidgets.QPushButton):
def __init__(self, parent=”none”):
super(MyButton, self).__init__(parent)self.setMinimumSize(80, 50)
self.setText(‘QPushButton’)
self.setStyleSheet(
“border: 1px solid white;border-radius:15px;background-color: white;”)def enterEvent(self, event):
global animanim = QPropertyAnimation(self, b’background-color’)
anim.setDuration(200)
anim.setStartValue(QColor(255, 255, 255))
anim.setEndValue(QColor(0, 170, 0))
anim.start()
def leaveEvent(self, event):
self.setStyleSheet(
“border: 1px solid white;border-radius:15px;background-color: white;”) -
000חברה חדשה
סליחה, לא הסברתי את עצמי טוב הevent מתרחש בשתיהם האנימציה לא פועלת. (עשיתי הדפסות וראיתי שהוא נכנס לפונקציות( רק האנימציה לא פועלת.
-
000חברה חדשה
אוקי, זה מה שקרה גם אצלי עם הקוד שלך
וקיבלתי הודעה כזאת: QPropertyAnimation: you’re trying to animate a non-existing property background_color of your QObject זה בגלל שכאן מצפים לקבל משתנה של המחלקה: anim = QPropertyAnimation(self, b’background-color’) ואין לך משתנה בשם background-color לכן צריך להוסיף את ההגדרה שלו כמו בדוגמא שכתבתי, עם הset ו get (אני לא מספיק מתמצאת כדי לדעת אם אפשר להיפטר מהם ואיך)
פשוט תוסיפי לקוד שלך את הקוד הזה: def getColor(self): return Qt.black def setColor(self, color): self.setStyleSheet(“background-color: rgb({0}, {1}, {2});border:none;border: 1px solid white;border-radius:15px;”.format(color.red(), color.green(), color.blue())) background_color=QtCore.pyqtProperty(QColor, getColor, setColor) שימי לב שאי אפשר לתת שם למשתנה עם קו אמצעי – לכן קראתי עם קו תחתון background_color
וגם שיניתי בהתאמה בשורה:
anim=QPropertyAnimation(self, “background_color”) (ואת יכולה לקרוא לו בכל שם שתרצי, זה לא משנה) הנה הקוד המלא ליתר ביטחון: class MyButton(QPushButton):
def __init__(self, parent=None):
super(MyButton, self).__init__(parent)
self.setMinimumSize(80,50)
self.setText(‘QPushButton’)
self.setStyleSheet(
“border: 1px solid white;border-radius:15px;background-color: white;”)def getColor(self):
return Qt.blackdef setColor(self, color):
self.setStyleSheet(“background-color: rgb({0}, {1}, {2});border:none;border: 1px solid white;border-radius:15px;”.format(color.red(), color.green(), color.blue()))background_color=QtCore.pyqtProperty(QColor, getColor, setColor)
def enterEvent(self, event):
global anim
anim=QPropertyAnimation(self, “background_color”)
anim.setDuration(200)
anim.setStartValue(QColor(255, 255, 255))
anim.setEndValue(QColor(0, 170, 0))
anim.start()def leaveEvent(self, event):
self.setStyleSheet(“background:white;border: 1px solid white;border-radius:15px;”) ועוד משהו קטן, בפונקציה איניט את צריכה לאתחל את האבא לNone ולא “none” -
000חברה חדשה
את יכולה להעלות פה את כל הקוד? כולל יצירת הכפתור?
-
000חברה חדשה
from PyQt5 import QtCore, QtGui, QtWidgets,QtQuick
from PyQt5.QtCore import QPropertyAnimation, Qt,QTimer
from PyQt5.QtGui import QColorclass Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName(“MainWindow”)
MainWindow.resize(800, 600)
MainWindow.setAutoFillBackground(False)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName(“centralwidget”)self.pushButton = MyButton(self.centralwidget)
self.pushButton.setGeometry(QtCore.QRect(290, 110, 201, 331))
self.pushButton.setMouseTracking(True)
self.pushButton.setAutoFillBackground(True)self.pushButton.setAutoRepeat(False)
self.pushButton.setAutoExclusive(False)
self.pushButton.setObjectName(“pushButton”)
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtWidgets.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
self.menubar.setObjectName(“menubar”)
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName(“statusbar”)
MainWindow.setStatusBar(self.statusbar)self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate(“MainWindow”, “MainWindow”))
self.pushButton.setText(_translate(“MainWindow”, “PushButton”))class MyButton(QtWidgets.QPushButton):
def __init__(self, parent=”None”):
super(MyButton, self).__init__(parent)self.setMinimumSize(80, 50)
self.setText(‘QPushButton’)
self.setStyleSheet(
“border: 1px solid white;border-radius:15px;background-color: white”)def getColor(self):
return Qt.blackdef setColor(self, color):
self.setStyleSheet(
“background-color: rgb({0}, {1}, {2});border:none;border: 1px solid white;border-radius:15px;”.format(
color.red(), color.green(), color.blue()))background_color = QtCore.pyqtProperty(QColor, getColor, setColor)
def enterEvent(self, event):
global anim
print(“I’m in animation”)
anim = QtCore.QPropertyAnimation(self, b’background_color’)
anim.setDuration(200)
anim.setStartValue(QColor(255, 255, 255))
anim.setEndValue(QColor(0, 170, 0))
anim.start()def leaveEvent(self, event):
self.setStyleSheet(
“border: 1px solid white;border-radius:15px;background-color: white;”)if __name__ == “__main__”:
import sysapp = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_MainWindow()
ui.setupUi(MainWindow)
MainWindow.show()sys.exit(app.exec_())
-
000חברה חדשה
אוקי, תודה רבה מאוד. בנתיים הצלחתי לעשות את זה עם טיימר. ממש ממש תודה על הזמן שהקדשת לי.
-
000חברה חדשה
חפירה אחרונה… 🙂 העתקתי את הקוד שלך, וכמו שכתבת האנימציה לא עבדה, עשיתי 3 שינויים של זיח ועבד!
הוצאת את הפונקציות get ו set “צעד אחורה” כלומר 4 רווחים פחות, שלא יהיו מתחת לפונקציה init אלא סתם פונקציות של הclass
ואותו דבר עשיתי ל background_color
הזזתי אחורה, שיהיה עוד משתנה כללי של הclass (ולא בתוך שום פונקציה)
וזה עבד מצויין! אולי יעזור לך…
Log in to reply.