@Stickers8Turn · Post #317 · 23.03.2024 г., 21:25
Member ♨️ : #Kyungmin
Hashtags
TGINSIGHT SIMILAR POSTS
Изворен канал @pythonotes · Post #381 · 23 окт.
Установить свойства виджета в 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
Пребарај: #kyungmin
@Stickers8Turn · Post #317 · 23.03.2024 г., 21:25
Member ♨️ : #Kyungmin
Hashtags
@Stickers8Turn · Post #300 · 27.10.2023 г., 15:23
✨✨✨✨#Kyungmin✨✨✨✨ Уже,как 20 минут назад наступил день рождение нашего любимого Кёнмина! Пусть каждый день твоей жизни будет наполнен счастьем и радостью. Желаем тебе крепкого здоровья, чтобы ты мог продолжать радовать нас своими выступлениями. Сегодня – твой праздник, наслаждайся им на полную катушку! ---------- Just like 20 minutes ago the birthday of our beloved Kyungmin! May every day of your life be filled with happiness and joy. We wish you good health so that you can continue to delight us with your performances. Today is your holiday, enjoy it on a full roll!
Hashtags
@Stickers8Turn · Post #106 · 29.09.2023 г., 16:27
Member 🪽 : #Kyungmin
Hashtags
@Stickers8Turn · Post #97 · 28.09.2023 г., 13:47
Member ✉️ : #Kyungmin For - @slaaay8
Hashtags
@Stickers8Turn · Post #38 · 12.09.2023 г., 17:00
Member 🍊 : #Kyungmin
Hashtags
@Stickers8Turn · Post #6 · 09.09.2023 г., 11:43
Member 🍓 : #Kyungmin
Hashtags
@turn8entertaiment · Post #44488 · 12.05.2026 г., 13:09
#Twitter × #Kyungmin 📍 Обновление твиттера MEMBERS_8TURN — Я отлично провел время в Японии! Давайте встречаться почаще! — I had a great time in Japan! Let's meet often from now on! 📢@Turn8Entertaiment For-8Turn #TurnNews #News
@turn8entertaiment · Post #43299 · 26.02.2026 г., 11:54
#Twitter × #Kyungmin 📍 Обновление твиттера 8TURN_official — 📓Дневник репетиций Кёнмина на фан-концерт❤️ — 📓Kyungmin's Fancon Practice Diary❤️ 📢@Turn8Entertaiment For-8Turn #TurnNews #News
@turn8entertaiment · Post #43081 · 15.02.2026 г., 17:28
#Twitter × #Kyungmin 📍 Обновление твиттера MEMBERS_8TURN Hanteo Music Awards🤍 📢@Turn8Entertaiment For-8Turn #TurnNews #News
@turn8entertaiment · Post #42172 · 29.01.2026 г., 15:28
#Twitter × #Kyungmin 📍 Обновление твиттера MEMBERS_8TURN 🖤❤️ 📢@Turn8Entertaiment For-8Turn #TurnNews #News
@turn8entertaiment · Post #41908 · 19.01.2026 г., 15:14
#Twitter 📍 Обновление твиттера 8TURN_official 8TURN Digital Single ‘BRUISE(불씨)’ 𝗖𝗢𝗡𝗖𝗘𝗣𝗧 𝗣𝗛𝗢𝗧𝗢 𝗕 #KYUNGMIN 💿2026.01.28 WED 6PM (KST) RELEASE 📢@Turn8Entertaiment For-8Turn #TurnNews #News
@turn8entertaiment · Post #41880 · 18.01.2026 г., 10:17
#Twitter 📍 Обновление твиттера 8TURN_official 8TURN Digital Single ‘BRUISE(불씨)’ 𝗖𝗢𝗡𝗖𝗘𝗣𝗧 𝗣𝗛𝗢𝗧𝗢 𝗔 #KYUNGMIN 💿 2026.01.28 WED 6PM (KST) RELEASE 📢@Turn8Entertaiment For-8Turn #TurnNews #News