@hutalk · Post #794 · 23.05.2022 г., 13:03
Welcome to my first English blog made by #Gridea ! link:https://eirms.com
Hashtags
TGINSIGHT SIMILAR POSTS
Изворен канал @pythonotes · Post #62 · 4 апр.
Когда разрабатываете свой 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
Пребарај: #gridea
@hutalk · Post #794 · 23.05.2022 г., 13:03
Welcome to my first English blog made by #Gridea ! link:https://eirms.com
Hashtags
@AboutRss · Post #999 · 29.03.2021 г., 01:00
最近一些支持自带 RSS / Atom Feed 的 #博客 平台或生成器 🔸#Nobelium :https://github.com/craigary/nobelium 用 #Notion 写博客,#开源 需自架;Newlearnerの自留地 频道有介绍。 🔸#Ghost : https://ghost.org/ #开源 可自架,亦可付费用官方; SpencerWoo 在少数派有介绍。 🔸 py-blog : https://py-blog.zcmimi.top/ 一个基于 Python3 的静态博客生成器, #开源 需自架。 Newlearnerの自留地 频道有介绍。 🔸#Maverick : https://alandecode.github.io/Maverick/ 一个基于 Python 的静态博客生成器, #开源 需自架。 Newlearnerの自留地 频道有介绍。 🔸 B3log 旗下的 #Solo 和 #Pipe : https://b3log.org/ #开源 需自架,专为程序员设计。 🔸#Halo : https://halo.run/ 一款现代化的博客/CMS系统。#开源 需自架,Newlearnerの自留地 频道有介绍。 🔸#Gridea : https://gridea.dev 一个静态博客写作客户端, #开源 可自架,可付费用官方。 Newlearnerの自留地 频道有介绍。 🔸#Peach Blog : https://github.com/LeetaoGoooo/peach-blog 基于 Flask 的博客平台, #开源 需自架。 🔸#Hey World : https://hey.com/world/ 新概念 Email 服务 #Hey 的附属功能:用邮件写博客。是付费服务。