2014-03-07 21 views
1

我有一个包含查看器(显示Pixmaps的自定义QLabel)和其下的按钮的类,以滚动可用的图像(大小不同)。构建包含可变大小部件的QT设计器布局

我想让按钮直接出现在图像下方,这意味着每次图像变化时都需要移动按钮。但是,当加载更大的图像时,它仅覆盖按钮。我如何在QT设计器中设置它以避免这种情况?我认为将查看器和按钮放到QVBoxLayout中就足够了,但是当QLabel调整大小时,整个布局的大小不会。我已经尝试过使用尺寸政策一段时间了,但我一定不明白。

编辑 - 这里是我试图展示所需的最小代码和UI文件。

from sprite_viewer_ui import Ui_SpriteViewer 

class SpriteViewer(QWidget, Ui_SpriteViewer): 

    def __init__(self,parent = None): 
     super(SpriteViewer,self).__init__(parent) 
     self.setupUi(self) 

     self.session = Session() 

     self.sv = SpriteLabel(self.session,parent=self) 
     self.setupSession(self) 

    def setupSession(self): 
     #Update the slider and spinbox with the new range 
     self.spriteSlider.setRange(1,self.session.getNumSprites()) 
     self.spritePicker.setRange(1,self.session.getNumSprites()) 

     #Show the initial sprite 
     self.sv.showSprite(1) 
     self.spriteSlider.setValue(1) 

     #Make connections 
     self.spriteSlider.valueChanged.connect(self.session.setSprite) 
     self.session.spriteChanged.connect(self.sv.showSprite) 

if __name__ == "__main__": 
    a = QApplication(sys.argv) 

    se = SpriteViewer() 
    se.show() 

    sys.exit(a.exec_()) 

所以这里的代码只是使用的UI建立一个基本的接口与观众sv和纺纱器和滑块显示使用哪个精灵。该ui文件是:

<?xml version="1.0" encoding="UTF-8"?> 
<ui version="4.0"> 
<class>SpriteViewer</class> 
<widget class="QWidget" name="SpriteViewer"> 
    <property name="geometry"> 
    <rect> 
    <x>0</x> 
    <y>0</y> 
    <width>658</width> 
    <height>420</height> 
    </rect> 
    </property> 
    <property name="windowTitle"> 
    <string>Form</string> 
    </property> 
    <layout class="QVBoxLayout" name="verticalLayout"> 
    <property name="sizeConstraint"> 
    <enum>QLayout::SetDefaultConstraint</enum> 
    </property> 
    <item> 
    <widget class="QLabel" name="sv"> 
    <property name="minimumSize"> 
     <size> 
     <width>640</width> 
     <height>360</height> 
     </size> 
    </property> 
    <property name="text"> 
     <string/> 
    </property> 
    </widget> 
    </item> 
    <item> 
    <layout class="QHBoxLayout" name="horizontalLayout"> 
    <item> 
     <widget class="QSlider" name="spriteSlider"> 
     <property name="maximum"> 
     <number>0</number> 
     </property> 
     <property name="orientation"> 
     <enum>Qt::Horizontal</enum> 
     </property> 
     <property name="tickPosition"> 
     <enum>QSlider::TicksBelow</enum> 
     </property> 
     <property name="tickInterval"> 
     <number>30</number> 
     </property> 
     </widget> 
    </item> 
    <item> 
     <widget class="QSpinBox" name="spritePicker"> 
     <property name="maximum"> 
     <number>0</number> 
     </property> 
     </widget> 
    </item> 
    </layout> 
    </item> 
    </layout> 
</widget> 
<resources/> 
<connections> 
    <connection> 
    <sender>spriteSlider</sender> 
    <signal>valueChanged(int)</signal> 
    <receiver>spritePicker</receiver> 
    <slot>setValue(int)</slot> 
    <hints> 
    <hint type="sourcelabel"> 
    <x>562</x> 
    <y>361</y> 
    </hint> 
    <hint type="destinationlabel"> 
    <x>587</x> 
    <y>362</y> 
    </hint> 
    </hints> 
    </connection> 
    <connection> 
    <sender>spritePicker</sender> 
    <signal>valueChanged(int)</signal> 
    <receiver>spriteSlider</receiver> 
    <slot>setValue(int)</slot> 
    <hints> 
    <hint type="sourcelabel"> 
    <x>594</x> 
    <y>361</y> 
    </hint> 
    <hint type="destinationlabel"> 
    <x>540</x> 
    <y>363</y> 
    </hint> 
    </hints> 
    </connection> 
</connections> 
</ui> 

我意识到这是一个恶梦阅读。但基本上它是一个QHBoxLayout中的spinbox和滑块,以及一个QLabel(我后来将其设置为我的SpriteViewer类,它是QLabel的子类。这是一个问题 - 每个Sprite都有不同的大小,我希望SpriteViewer根据。SpriteLabel的大小

+1

如果没有看到.ui文件(加上任何可能直接相关的代码),这几乎是不可能的。 – ekhumoro

+0

谢谢,我会尝试尽快上传最小案例。我希望有一些简单的答案,例如在内部小部件的大小发生变化时调用layout.update()类型的东西。 –

回答

1

我解决了这一问题 - 只是跟进所以这个问题是不是半途而废

我没能理解如何促进小部件在Qt Designer中工作,所以在这条线:

self.sv = SpriteLabel(self.session,parent=self) 

我已经将self.sv分配给一个全新的SpriteLabel(它不是布局的一部分),所以resi它对布局没有影响。相反,我不得不使用Designer中的“Promote to”上下文菜单来指示它是一个SpriteLabel,然后将分配保留给UI文件。

相关问题