TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

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

Hashtags

Резултати

Пронајдени 1 слични објави

Пребарај: #iconcomposer

当前筛选 #iconcomposer清除筛选
AppPie

@AppPie · Post #2445 · 11.06.2025 г., 07:03

#Apple Apple 发布 Icon Composer Apple 发布 了 Icon Composer,这是一款用于为 iPhone、iPad、Mac 和 Apple Watch 创建分层应用程序图标的工具。该工具支持一种新的多层图标格式,并引入了 Liquid Glass 材质,旨在与 Xcode 无缝协作。同时也可以选择导出扁平化版本的图标,以满足营销和传播需求。 主要功能 - 多平台设计: 该工具旨在简化跨 Apple 平台的设计流程。它使用新的、更圆润的外壳形状和更新的网格系统,以增强设计的一致性。用户可以基于单一设计,并可选择为每个平台进行定制。 - Liquid Glass 材质: 这是一种新的材质,其属性可响应动态光照并随图标自动缩放。用户可以导入和组织图稿图层,并调整高光、模糊、半透明度和阴影等属性,以创建具有全新深度和维度的图标。 - 渲染模式注释: Icon Composer 允许用户在单个文件中完全控制图标在不同渲染模式下的外观。支持的模式包括默认(Default)、深色(Dark)和单色(Mono)。 - 实时预览: 提供实时预览功能,用户可以查看设计在不同光照、背景和壁纸下的响应情况,并可在多种尺寸下进行审阅。 - 与 Xcode 集成: Icon Composer 生成的新图标文件类型可直接添加到 Xcode 项目中,所做的更改可以直接同步到项目内。该工具还提供了导出用于营销和传播的扁平化版本图标的选项。 系统要求 该工具需要 macOS Sequoia 或更高版本。 相关资源 WWDC25 视频: 《Say hello to the new look of app icons》 《Create icons with Icon Composer》 #AppleDeveloper#IconComposer#Design#Xcode#WWDC25 📮 频道 @AppPie