Установить свойства виджета в PySide можно не только через соответствующие методы и конструктор класса. Можно их изменять с помощью метода setProperty по имени.
btn = QPushButton("Click Me")
btn.setProperty("flat", True)
Это аналогично вызову
btn.setFlat(True)
Если указать несуществующее свойство, то оно просто создается
btn.setProperty("btnType", "super")
Получить его значение можно методом .property(name)
btn_type = btn.property("btnType")
Когда это может быть полезно?
▫️Можно просто хранить какие то данные в виджете и потом их доставать обратно
widget = QWidget()
widget.setProperty('my_data', 123)
print(widget.property('my_data'))
▫️ Назначая эти свойства разным виджетам можно потом отличить виджеты во время итераци по ним. Например, найти все кнопки со свойством my_data="superbtn".
Но ведь вместо кастомного свойства можно использовать objectName, будет тот же результат.
Да, но y ObjectName есть ограничение - только строки.
▫️ Если нам потребуется не просто поиск а, например, сортировка по числу, то свойства позволяют нам это сделать. Поддерживается любой тип данных
widget.setProperty('my_data', {'Key': 'value'})
widget.setProperty('order', 1)
all_widgets.sort(key=w: w.property('order'))
Но ведь Python позволяет всё вышеперечисленное сделать простым созданием атрибута у объекта
widget.order = 1
widget.my_data = 123
Да, но я думаю что не надо объяснять почему не стоит так делать. К тому же, если у виджета нет свойства то метод .property(name) вернет None, а отсутствующий атрибут выбросит исключение.
▫️ Действительно полезное применение кастомным свойствам - контроль стилей. Здесь атрибутами не обойтись, нужны именно свойства.
Дело в том, что в селекторах стилей можно указывать конкретные свойства виджетов на которые следует назначать стиль.
Просто запустите этот код
from PySide2.QtWidgets import *
if __name__ == "__main__":
app = QApplication([])
widget = QWidget(minimumWidth=300)
layout = QVBoxLayout(widget)
btn1 = QPushButton("Action 1")
btn2 = QPushButton("Action 2")
btn3 = QPushButton("Action 3", flat=True)
layout.addWidget(btn1)
layout.addWidget(btn2)
layout.addWidget(btn3)
# добавим кастомное свойство одной кнопке
btn1.setProperty("btnType", "super")
# добавляем стили
widget.setStyleSheet(
"""
QPushButton[btnType="super"] {
background-color: yellow;
color: red;
}
QPushButton[flat="true"] {
color: yellow;
}
"""
)
widget.show()
app.exec_()
С помощью селектора мы избирательно назначили стили на конкретные кнопки.
Как получить список всех кастомный свойств?
Функция получения списка кастомных свойств отличается от получения дефолтных.
def print_widget_dyn_properties(widget):
for prop_name in widget.dynamicPropertyNames():
property_name = prop_name.data().decode()
property_value = widget.property(property_name)
print(f"{property_name}: {property_value}")
#tricks#qt
#hbar
🏎Компания McLaren Racing вошла в совет блокчейна Hedera!- релиз
Это значит, что команда McLaren будет участвовать в развитии и управлении сетью наравне с другими членами совета.
Для Hedera это заметное усиление consumer-направления: в экосистему приходит один из самых узнаваемых брендов мирового автоспорта с огромной глобальной аудиторией.
Параллельно McLaren уже запускает первые Web3-активации на Hedera: речь идёт о бесплатных цифровых коллекционных дропах для фанатов по ходу сезона Formula 1 и IndyCar. Первый релиз уже прошёл на уикенде Гран-при Австралии, второй — на Гран-при Китая, третий намечен на Гран-при Японии. По сути, McLaren получает инфраструктуру для новых фанатских механик и цифровых активов, а Hedera — сильный спортивный бренд внутри своей экосистемы.
Ранее: партнерство
Crypto Headlines
#HBAR/USDT analysis -
#HBAR is moving downward towards its weekly timeframe support zone. It is expected to test the zone and bounce off from there to test previous highs. Wait for the price to test and bounce from the support zone for a long entry.
TF : 1W
Entry : $0.0519
Target : $0.0996
SL : $0.0442
#HBAR/USDT analysis -
#HBAR is in a downtrend on the lower time frame, trading below the 200 EMA. After a corrective pullback, the price retraced to the 200 EMA and found support above the $0.0800 level. Following the breakout of the support, the price retested the zone and was rejected from there. The price is now expected to decline from this point and will test its previous swing low.
TF : 1h
Entry : $0.0776
Target : $0.0725
SL : $0.0809