Когда разрабатываете свой GUI с помощью PyQt для какого-либо софта бывает необходимо позаимствовать цвета из текущего стиля интерфейса. Например, чтобы правильно раскрасить свои виджеты, подогнав их по цвету. Ведь бывает, что ваш GUI используется в разных софтах. Причём некоторые со светлой темой а другие с тёмной.
По умолчанию стили наследуются, но если вы задаёте какую-либо раскраску для части виджета через свой styleSheet, то требуется ссылаться на цвета текущего стиля.
Как это сделать? Как получить нужный цвет из палитры имеющегося стиля? Это достаточно просто, нужно использовать класс QPalette и его роли.
Например, мне нужно достать цвет текста из одного виджета и применить его в другом как цвет фона (не важно зачем именно так, просто захотелось😊).
Получаем палитру виджета и сразу достаём нужный цвет, указав его роль.
from PySide2.QtGui import QPalette
color = main_window.palette().color(QPalette.Text)
теперь можем использовать этот цвет в стилях
my_widget.setStyleSheet(f'background-color: {color.name()};')
Готово, мы динамически переопределили дефолтный стиль используя текущий стиль окна!
На самом деле есть запись покороче, в одну строку и без лишних переменных. Не очень-то по правилам CSS, но Qt это понимает.
my_widget.setStyleSheet('background-color: palette(Text);')
Этот способ не подходит если вам нужно как-то модифицировать цвет перед применением в своих стилях. В этом случае потребуется первый способ.
Зато он прекрасно сработает в файле .qss, то есть не придётся в коде прописывать раскраску отдельных элементов через ссылки на палитру, всё красиво сохранится в отдельном файле .qss!
QListView#my_widget::item:selected {
background: palette(Midlight);
}
Про имеющиеся роли можно почитать здесь🌍
#qt#tricks
🎉 Get Goated S2 이벤트 진행 중!
💡IoTeX란?
IoTeX는 스마트 기기와 실제 데이터를 블록체인과 연결하는 DePIN 플랫폼
!총 100M $IOTX(약 62억 원)의 보상이 걸린 초대형 이벤트에 지금 참여하세요!
기간: 10월 29일부터 약 3개월간 진행
참여 방법
1️⃣ 이벤트 사이트에서 미션 수행 (스테이킹, 유동성 공급 등)
2️⃣ 다양한 프로토콜(Bedrock, iZUMi 등)과 상호작용
3️⃣ BinoBits 포인트 적립
4️⃣ 텔레그램 미니앱(@Goat_Earn_Bot)에서 데일리 체크인
포인트 랭킹에 따라 보상이 지급됩니다!
🔥 현재까지 결과
- 참가자 수: 117,140명
- 누적 포인트: 181,958,191 BinoBits
유저가이드 | 이벤트 사이트
#IoTeX
#CyberCharge, the world's first Web3 smart charger presale event with @iotex_io, is coming soon!🚀
Play games, earn tokens, and grab airdrops—each mystery box brings exciting surprises! 🎁
🔥$IOTX Tokens
⚡️Web3 Smart Charger Set
Follow, 🔄, 👍, and comment for a chance to win a presale WL spot (10 spots) - FCFS!
#IoTeX#Web3#DePIN
Like👍, Retweet🔵, Comment
Link to the Tweet!
🔋#CyberCharge Debuts at #Token2049 Singapore!
We were a proud sponsor at one of the world’s most influential blockchain events!
👉Dive into the details:
link.medium.com/CPkTunaP2Mb
From showcasing future DePIN products to collaborating with global leaders like #Solana & #IoTeX, CyberCharge is driving Web3 into the real world.
Like👍, Retweet🔵, Comment
Link to Tweet
🤖Join Bot🐣X (Twitter)✉️Chat
Today at #R3alWorld, we had a great time connecting with the #IoTeX team, Raullen Chai, CEO of @iotex_io.
We exchanged valuable insights and ideas on DePIN devices and their innovative applications.
#Token2049singapore
Like👍, Retweet🔵, Comment
Link to Tweet
🎁Join our Airdrop Event
Link to MiniApp
CyberCharge showcased exciting content at the #R3alWorld DePIN Summit 2024 Workshop! 🎉
Our BD, Goran, shared CyberCharge's innovative Proof of Charge mechanism and seamless Web2 integration, bringing new energy to the future of #DePIN and charging experiences⚡️
#CyberCharge#IoTeX
Like👍, Retweet🔵, Comment
Link to Tweet
🎁Join our Airdrop Event
Link to MiniApp
🚀We’re excited to be a part of the R3alWorld DePIN Summit!
⚡️Join us at this groundbreaking event, hosted by @iotex_io and Co-Hosted by @MessariCrypto, where CyberCharge will showcase its innovations alongside other industry leaders.
🗓Sept 16th-17th
📍Amara Singapore
🔌Let’s power the future together!
#DePIN#CyberCharge#IoTeX#Messari#Token2049
Like👍, Retweet🔵, Comment
Link to the Tweet!
🔗Tweet From IoTeX: https://x.com/iotex_io/status/1829239846008934586?s=46