使内容和选项卡在pyqt5中可扩展

问题描述 投票:1回答:1

这是我想在QT Creator中解决的问题。我想使tab小部件的内容以及tab小部件本身可以根据屏幕大小进行扩展。到目前为止,我一直在寻找StackOverflow上的解决方案,但找不到任何解决方案。

一个小例子:

enter image description here

正如在其他答案中所建议的,我将所有内容组织在具有这些属性的网格布局中。

enter image description here

事实上,我甚至将相同的Expanding值添加到列表中的所有对象。但是,尽管如此,当我以全屏大小打开它时,我仍然会得到一个固定的标签小部件。

enter image description here

有关如何使标签小部件填充所有周围空间的任何建议吗?提前致谢!

UPD 1:分享我的.ui https://gist.github.com/Ren22/41ca0dc0333a360775aec530d6f38a62

python pyqt5 qt-designer
1个回答
4
投票

大小策略仅在窗口小部件几何体由布局处理时才有效,因此解决方案是将QTabWidget设置为centralwidget以右键单击QTabWidget外部但在QMainWindow内部的区域,然后单击图标enter image description here或生成以下内容的Qt Designer顶部的enter image description here图标:

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" 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">
   <layout class="QVBoxLayout" name="verticalLayout">
    <item>
     <widget class="QTabWidget" name="tabWidget">
      <widget class="QWidget" name="tab">
       <attribute name="title">
        <string>Tab 1</string>
       </attribute>
       <layout class="QVBoxLayout" name="verticalLayout_2">
        <item>
         <widget class="QListWidget" name="listWidget"/>
        </item>
        <item>
         <widget class="QPushButton" name="pushButton">
          <property name="text">
           <string>PushButton</string>
          </property>
         </widget>
        </item>
       </layout>
      </widget>
      <widget class="QWidget" name="tab_2">
       <attribute name="title">
        <string>Tab 2</string>
       </attribute>
      </widget>
     </widget>
    </item>
   </layout>
  </widget>
  <widget class="QMenuBar" name="menubar">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>800</width>
     <height>30</height>
    </rect>
   </property>
  </widget>
  <widget class="QStatusBar" name="statusbar"/>
 </widget>
 <resources/>
 <connections/>
</ui>
© www.soinside.com 2019 - 2024. All rights reserved.