@YuKongA13579 · Post #2102 · 07.05.2026 г., 14:38
补充了小米相册同款二级菜单设计,并非基于垃圾 Flutter 相册的组件,所有设计和动效以 View 版本相册为准。 #miuix
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
Пребарај: #miuix
@YuKongA13579 · Post #2102 · 07.05.2026 г., 14:38
补充了小米相册同款二级菜单设计,并非基于垃圾 Flutter 相册的组件,所有设计和动效以 View 版本相册为准。 #miuix
Hashtags
@YuKongA13579 · Post #2101 · 06.05.2026 г., 11:03
使用 miuix-blur 实现的带折射、色散和传感器驱动高光的液态玻璃悬浮底栏。大多数液态玻璃相关的 shader 和代码实现来自 backdrop 项目。 #miuix
Hashtags
@YuKongA13579 · Post #2062 · 04.05.2026 г., 17:52
由于前两天已经给 miuix-blur 添加了小米的边缘高光支持,所以今天索性拓展了 miuix-blur 接口。因为当初设计的时候 api 基本就照搬了 backdrop 的,改起来很容易。 现在,如果你既想要高级材质效果还想要液态玻璃效果,可以不用引入多个库,通过导入自定义 shader 就可以实现完整液态玻璃效果,我在example 中预留了一份,性能还不错。 你还可以简单修改实现基于传感器的高光跟随效果(需要注意的是,小米的边缘高光其实本身就是有这个能力的,但效果微乎其微)。 需要注意的是,miuix-blur 有着较为激进的降采样(默认,不可修改),所以模糊和液态玻璃的质量肯定是没其他库好的,但实际上没几个用户真的在意这点质量。 #miuix
Hashtags
@YuKongA13579 · Post #2059 · 02.05.2026 г., 01:45
看起来性能还不错了 #miuix
Hashtags
@YuKongA13579 · Post #1983 · 10.04.2026 г., 12:30
带有 miuix 主题的阅读 Compose 版:https://github.com/HapeLee/legado-with-MD3 带有 miuix 主题的 ScrcpyForAndroid:https://github.com/Miuzarte/ScrcpyForAndroid 带有 miuix 主题的音乐标签编辑器:https://github.com/Replica0110/Lyrico #miuix
Hashtags
@YuKongA13579 · Post #1975 · 05.04.2026 г., 02:22
不少人遇到用 miuix-blur 出现大色块问题,这里提示一下原因。 #miuix
Hashtags
@YuKongA13579 · Post #1974 · 02.04.2026 г., 11:13
已发布 v0.9.0 #miuix
Hashtags
@YuKongA13579 · Post #1971 · 31.03.2026 г., 05:12
下版本 Miuix 会在 MiuixTheme 中提供全局 G2 圆角开关,这是性能比 MD3 差的很大一部分原因。 #miuix
Hashtags
@YuKongA13579 · Post #1967 · 30.03.2026 г., 00:37
昨晚 miuix-blur 发在 GitHub Package 了,感兴趣的可以试试。 #miuix
Hashtags
@YuKongA13579 · Post #1966 · 29.03.2026 г., 05:00
0.9.x 版本准备大改一下 miuix 当前项目框架,具体修改如下: 1、平台实现和常用方法移至轻量 miuix-core; 2、基础 UI 组件移至 miuix-ui (Switch、CheckBox 等); 3、扩展封装组件移至 miuix-preference (SuperSwitch、SuperCheckBox 等,同时改名为 SwitchPreference、CheckBoxPreference...); 4、让 miuix-icons、miuix-blur、miuix-navigation3-ui 三个库均可独立于 miuix-ui/miuix-preference 使用,仅依赖轻量 miuix-core。 不出意外的话这应该就是 1.0 版本最终的结构了。 #miuix
Hashtags
@YuKongA13579 · Post #1872 · 13.02.2026 г., 07:28
0.8.2+ 版本会用 md3 的逻辑重构导航栏的组件用法,并添加四种样式自定义(因为有人很喜欢md3的模式,现在都加上了)。同时添加 NavRail 用于宽屏。 #miuix
Hashtags
@YuKongA13579 · Post #1841 · 30.01.2026 г., 07:06
os3 官方似乎给很多组件搞了高光描边,我这边 compose miuix 不会跟进,不喜欢这种跟风出来的设计。 以及后续组件如果有更好、更和谐的样式,可能不会完全保持官方风格。或者小米新的设计依托,也不会完全跟随小米设计。 什么是跟风设计,iOS26 有了之后,现在小米、OPPO、vivo、荣耀、华为全有了😇 #miuix
Hashtags