Установить свойства виджета в 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
🎧⤴
TON Blockchain Faces Heat: 500,000 New Wallets Created, But DOGS Token Causes Chaos!
The TON blockchain recently experienced a significant disruption following the airdrop of the DOGS memecoin, which led to the creation of over 500,000 new wallets. Despite this surge, the price of Toncoin (TON) remained stable, although the network faced a three-hour outage due to unprecedented congestion. The TON Foundation quickly addressed the issue, ensuring no loss of user funds, and the network has since recovered. The DOGS token has become a top gainer, with a 21.80% increase in value, highlighting its rising popularity despite the technical hiccups.
Verse 1:
TON got hit with a storm, no block, just pause,
500K new wallets, but they ain't break no laws,
DOGS dropped hard, crashed the chain with a cause,
Validators lost the rhythm, but we back with no loss.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
Verse 2:
From Binance to Bybit, exchanges felt the strain,
Suspended withdrawals, but TON ain't in vain,
67K per second, transactions hit the lane,
Yet Toncoin stands tall, pushing through the pain.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
Bridge:
DOGS flying high, memecoin of the day,
TON's resilience showed, come what may,
Validators sync up, no more delay,
Crypto's wild ride, just another day.
Verse 3:
TON shook but didn’t fall, learned from the past,
500K wallets, this storm won’t last,
DOGS might bark loud, but TON's built to blast,
New blocks, new hopes, we rising fast.
Chorus:
DOGS on the rise, TON had to pay,
But no coin lost, we still in the game,
From Paris to the chain, Durov's fight ain’t lame,
Network's back strong, ain't nobody to blame.
#TONwallet
#DOGS
#Ton
🎧@toncoin_rap
🚀Обновление экосистемы MirraCoin: новые возможности на DigitalExchange.art и в Mirra Wallet😎
Экосистема MirraCoin продолжает активно развиваться. Мы внедрили ряд важных обновлений и улучшений на платформе DigitalExchange.art и в Mirra Wallet, направленных на удобство, безопасность и расширение функционала для пользователей.
🖼 Обновления на DigitalExchange.art
🔂 Повышена безопасность - поддержка Google Authenticator для 2FA и возможность включить проверку при отправке транзакций.
🔂 Расширена загрузка изображений - теперь при добавлении товара можно прикрепить до 20 изображений вместо прежних 5.
🔂 NFT-копии - добавлено пояснение через информационную кнопку, чтобы пользователи лучше понимали назначение этого инструмента.
🔂 Новая система верификации пользователей - реализована двухуровневая логика выбора:
• Верификация продавца (18+)
• «Благотворительность – дети» благотворительное направление для детей с разделением по возрасту.
🔂 Реализована система поддержки всех продавцов, через пожертвования в криптовалюте: 1 ❤️ => 1 😎
🔂 Обновлена система уведомлений - уведомления теперь приходят как внутри платформы, так и на email пользователя.
🔂 Обновлена главная страница - добавлены новости, раздел "Маркетплейс", отображение балансов.
🔂 Добавлены кошельки - теперь пользователь видит свой баланс в MIRRC, в ₽, в USDT, BTC. Скоро будет добавлен кошелек в EUR и USD.
🔂 Доработан интерфейс - обновлён дизайн и добавлены информационные подсказки для более удобной навигации.
🆕Обновление Mirra Wallet
🔂
Подключение TON Wallet - мы интегрировали возможность прямой конвертации TON=>MIRRC, а также возможность прямой оплаты товаров и пакетов MIRRC за TON.
🔂
Добавили в раздел "Магазин" вкладку "Маркетплейс" - теперь попасть из приложения
Mirra Wallet
на
DigitalExchange.art
возможно в один клик.
🔂
Добавили в раздел "Майнинг" новый буст 500 MIRRC за 1 TON.
🌳 Экосистема MirraCoin продолжает развивать инфраструктуру Web3 и создавать удобные инструменты для пользователей
👉Переходите на платформу, изучайте новые функции и пользуетесь обновлёнными возможностями экосистемы.
👉Подписывайтесь на канал, присоединяйтесь и станьте частью экосистемы MirraCoin, следите за новостями, скоро мы опубликуем о новых разработках и обновлениях.
#MirraCoin#MIRRC#DigitalExchangeArt#MirraWallet#Web3#Blockchain#NFT#Crypto#TonWallet#интеграция#Обновление#Экосистема#Сделано_в_России
@MirraChannel😎