@besteanimebilder · Post #5902 · 09.11.2019 г., 15:01
女儿 #kemonomimi#nekomimi # 2400x3800
Hashtags
TGINSIGHT SIMILAR POSTS
Изворен канал @pythonotes · Post #380 · 21 окт.
Регулярно приходится писать и ревьюить код, где используется PySide2-6. Заметил, что в подавляющем большинстве случаев настройка создаваемых базовых виджетов происходит через методы. Думаю, всем знаком такой способ. Простой пример с кнопкой: button = QPushButton("Click Me") button.setMinimumWidth(300) button.setFlat(True) button.setStyleSheet("font-size: 20pt") button.setToolTip("Super Button") button.clicked.connect(lambda: print("Button clicked")) Но есть и альтернативный способ - настройка через свойства. Это просто ключевые аргументы конструктора класса. Хоть они и не указаны в документации как аргументы, но они есть) Этот код делает тоже самое но с помощью Property button = QPushButton( "Click Me", minimumWidth=300, flat=True, styleSheet="font-size: 20pt", toolTip="Super Button", clicked=lambda: print("Button clicked"), ) Где это может быть полезно ▫️ Это выглядит более аккуратно и коротко, уже повод использовать ▫️ Может использоваться в заполнении лейаута, когда нам не нужно никакое другое взаимодействие с виджетом и поэтому сохранять его в переменную не требуется. Например, лейбл или кнопка. widget = QWidget(minimumWidth=400) layout = QHBoxLayout(widget) layout.addWidget(QLabel("Button >", alignment=Qt.AlignRight)) layout.addWidget(QPushButton("Click Me", clicked=lambda: print("Button clicked"))) widget.show() Либо так widget = QWidget(minimumWidth=400) layout = QHBoxLayout(widget) for wd in ( QLabel("Button >", alignment=Qt.AlignRight), QPushButton("Click Me", clicked=lambda: ...) ): layout.addWidget(wd) widget.show() ▫️ Можно хранить настройки в каком-то конфиге или генерировать на лету, после чего передавать как kwargs. kwargs = {"text": "Hello " * 30, "wordWrap": True} my_label = QLabel(**kwargs) Как получить полный список доступных свойств? Эта функция распечатает в терминал все свойства виджета и их текущие значения def print_widget_properties(widget): meta_object = widget.metaObject() for i in range(meta_object.propertyCount()): property_ = meta_object.property(i) property_name = property_.name() property_value = property_.read(widget) print(f"{property_name}: {property_value}") #tricks#qt
Пребарај: #nekomimi
@besteanimebilder · Post #5902 · 09.11.2019 г., 15:01
女儿 #kemonomimi#nekomimi # 2400x3800
Hashtags
@besteanimebilder · Post #6164 · 23.01.2020 г., 15:15
🐱 #original#kemonomimi#nekomimi 2591x3624
Hashtags
@besteanimebilder · Post #6255 · 22.02.2020 г., 09:45
#nekomimi#cute
@besteanimebilder · Post #6652 · 11.04.2021 г., 10:30
wip #original#cat#kemonomimi#nekomimi 1866x3387
@besteanimebilder · Post #6029 · 19.12.2019 г., 13:02
DEATHSTRANDING #death\stranding #kemonomimi#nekomimi 1800x2076
Hashtags
@CyunreiCollection · Post #11307 · 21.01.2026 г., 02:21
プラニャ | LISU #LISU#pixiv#ブルーアーカイブ#ブルアカ#プラナ#Nekomimi#セーラー服
@besteanimebilder · Post #6551 · 13.10.2020 г., 13:40
ゆきのん #oregairu#yukinoshita_yukino#nekomimi 1842x3945
@besteanimebilder · Post #6440 · 27.05.2020 г., 12:01
きなこのスマホ壁紙作ったよ🐈 #original#kinako#nekomimi#loli 1000x2000
@besteanimebilder · Post #6703 · 11.12.2021 г., 12:01
ぬこ #illustration#original#catgirl#nekomimi#kemonomimi 2048x1698
@besteanimebilder · Post #6483 · 21.06.2020 г., 13:40
69日目、羽川翼 #nekomonogatari#hanekawa_tsubasa#nekomimi 1000x1966
@besteanimebilder · Post #6197 · 29.01.2020 г., 16:25
今日は雨 #original#rain#umbrella#loli#kemonomimi#nekomimi 2500x2500
@besteanimebilder · Post #5981 · 02.12.2019 г., 16:40
Akashi Stranding #azur_lane#death_stranding#akashi#nekomimi#kemonomimi 1500x2262