Когда разрабатываете свой 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
📩#AVAXUSDT 30m | Mid-Term
📉Long Entry Zone: 23.323-21.858
🎯 - Strategy Accuracy: 89.06%
Last 5 signals: 100.0%
Last 10 signals: 100.0%
Last 20 signals: 90.0%
⏳ - Signal details:
Target 1: 23.673
Target 2: 24.023
Target 3: 24.373
Target 4: 25.422
_____
🧲Trend-Line: 21.858
❌Stop-Loss: 21.531
💡After reaching the first target you can put the rest of the position to breakeven
📩#AVAXUSDT 30m | Mid-Term
📉Long Entry Zone: 25.868-24.942
🎯 - Strategy Accuracy: 88.69%
Last 5 signals: 100.0%
Last 10 signals: 100.0%
Last 20 signals: 90.0%
⏳ - Signal details:
Target 1: 26.256
Target 2: 26.644
Target 3: 27.032
Target 4: 28.196
_____
🧲Trend-Line: 24.942
❌Stop-Loss: 24.568
💡After reaching the first target you can put the rest of the position to breakeven
👆 Propheta living up to its name yet again 🔮
Reached 9th TP on our #AVAXUSDT trade! 🔥🔥🔥
🤑 All this profit could have been yours! 🔥ACCESS TO MANUAL TRADING for 70usdt/month
👉 We're sure that 99% of the signals channels simply cannot provide transparent performance reports like we do! Check it out - @propheta_reports
Register and get bonuses up to $6,000
Binance | OKX | ByBit👈🏻click!
#cryptobot#CryptoSignal#cryptonews
Oops, we did it again 🤣
#AVAXUSDT reached 9th TP!
Signal from our VIP CLUB channel!
Easy $450 with a 5% entry and a $1000 deposit!
ACCESS TO MANUAL TRADING for 70usdt/month
💪Rule the market with Propheta AI Signals: ultra-sharp alerts, full-on process automation, and a killer Cornix synergy — your fast track to max profits! GET THE ACCESS TO AI SIGNALS
Register and get bonuses up to $6,000
Binance | OKX | ByBit👈🏻click!
#tradingindicator#passiveincome#cryptochannel