Using a custom PySide2 widget in Qt Designer

后端 未结 1 608
失恋的感觉
失恋的感觉 2021-01-05 23:22

I\'m searching for a way to use custom widgets in Qt Designer written with Qt for Python (PySide2) effectively.

I found out, that it is possible to design the GUI wi

相关标签:
1条回答
  • 2021-01-05 23:31

    There are 2 main ways to use a custom widget in Qt Designer:

    1. Promoting the widget:

    This is the simplest and least laborious way, if it's an internal widget you just have to right click on the widget and select Promote To ..., then in:

    • Base Class Name choose the class from which you inherit
    • Promoted Class Name place the name of the class a
    • Header File place the path of the file changing the extension .py to .h

    What the above does is generate the following:

    ...
        <widget class="RadialBar" name="widget" native="true"/>
    ...
     <customwidgets>
      <customwidget>
       <class>RadialBar</class>
       <extends>QWidget</extends>
       <header>radialbar.h</header>
       <container>1</container>
      </customwidget>
     </customwidgets>
    ...
    

    That is, change class, and add a field in customwidget pointing to the name of the class: <class> NAME_OF_CLASS </class>, name of the class they inherit <extends>CLASS_EXTENDS</extends> and file path changing the file extension from .py to .h <header>PATH_OF_FILE.h</header>, that is, the same data as You entered the form.

    In the case of the root widget it can not be done through Qt Designer, but I see that you have understood the logic but you have not modified everything correctly, your main mistake is to point out the class from which they inherit

     <customwidgets>
      <customwidget>
       <class>MyMainWindow</class>
       <extends>QMainWindow</extends> <----
       <header>mymainwindow.h</header>
       <container>1</container>
      </customwidget>
     </customwidgets>
    

    So the correct file is:

    custom_widget_modified.ui

    <?xml version="1.0" encoding="UTF-8"?>
    <ui version="4.0">
     <class>MainWindow</class>
     <widget class="MyMainWindow" name="MainWindow">
      <property name="geometry">
       <rect>
        <x>0</x>
        <y>0</y>
        <width>800</width>
        <height>600</height>
       </rect>
      </property>
      <property name="windowTitle">
       <string>MainWindow</string>
      </property>
      <widget class="QWidget" name="centralwidget">
       <property name="geometry">
        <rect>
         <x>0</x>
         <y>0</y>
         <width>155</width>
         <height>15</height>
        </rect>
       </property>
       <layout class="QGridLayout" name="gridLayout">
        <item row="0" column="0">
         <widget class="QLabel" name="label_2">
          <property name="text">
           <string>TextLabel</string>
          </property>
         </widget>
        </item>
        <item row="0" column="2">
         <widget class="QLabel" name="label">
          <property name="text">
           <string>TextLabel</string>
          </property>
         </widget>
        </item>
        <item row="0" column="1">
         <widget class="QLabel" name="label_3">
          <property name="text">
           <string>TextLabel</string>
          </property>
         </widget>
        </item>
       </layout>
      </widget>
      <widget class="QMenuBar" name="menubar">
       <property name="geometry">
        <rect>
         <x>0</x>
         <y>0</y>
         <width>800</width>
         <height>21</height>
        </rect>
       </property>
       <widget class="QMenu" name="menuFile">
        <property name="title">
         <string>File</string>
        </property>
        <addaction name="actionExit"/>
       </widget>
       <addaction name="menuFile"/>
      </widget>
      <widget class="QStatusBar" name="statusbar">
       <property name="geometry">
        <rect>
         <x>0</x>
         <y>0</y>
         <width>3</width>
         <height>18</height>
        </rect>
       </property>
      </widget>
      <action name="actionExit">
       <property name="text">
        <string>Exit</string>
       </property>
      </action>
     </widget>
     <customwidgets>
      <customwidget>
       <class>MyMainWindow</class>
       <extends>QMainWindow</extends>
       <header>mymainwindow.h</header>
       <container>1</container>
      </customwidget>
     </customwidgets>
     <resources/>
     <connections>
      <connection>
       <sender>actionExit</sender>
       <signal>triggered()</signal>
       <receiver>MainWindow</receiver>
       <slot>close()</slot>
       <hints>
        <hint type="sourcelabel">
         <x>-1</x>
         <y>-1</y>
        </hint>
        <hint type="destinationlabel">
         <x>399</x>
         <y>299</y>
        </hint>
       </hints>
      </connection>
     </connections>
    </ui>
    

    mymainwindow.py

    import sys
    
    from PySide2.QtUiTools import QUiLoader
    from PySide2.QtWidgets import QApplication, QMainWindow, QMessageBox
    from PySide2.QtCore import QFile
    
    
    class MyMainWindow(QMainWindow):
        def __init__(self, *args, **kwargs):
            super().__init__(*args, **kwargs)
            self.setWindowTitle("Demo QtWidget App")
    
        def closeEvent(self, event):
            msgBox = QMessageBox()
            msgBox.setWindowTitle("Quit?")
            msgBox.setText("Exit application?")
            msgBox.setStandardButtons(QMessageBox.Yes | QMessageBox.No)
            msgBox.setDefaultButton(QMessageBox.No)
            ret = msgBox.exec_()
            if ret == QMessageBox.Yes:
                event.accept()
            else:
                event.ignore()
    
    
    if __name__ == '__main__':
        app = QApplication([])
        file = QFile("custom_widget_modified.ui")
        file.open(QFile.ReadOnly)
        loader = QUiLoader()
        loader.registerCustomWidget(MyMainWindow)
        main_window = loader.load(file)
        main_window.show()
        sys.exit(app.exec_())
    

    2. Promoting the widget:

    0 讨论(0)
提交回复
热议问题