1

ウィンドウのサイズ変更イベントをキャッチしようとしていますが、基本的には gridLayout 内のすべてのウィジェット項目を削除し、新しいサイズ変更されたウィンドウに合わせて行/列を再構築します。これが適切に機能するのに問題があり、これが私が使用した最良の方法であるかどうかわかりません. 現在、次の 2 つの問題が発生しています。

  1. ウィンドウのサイズを大きくすると、アイテムの削除、再構築、および列の追加が適切に行われていないようです (一部のアイテムは削除され、一部は追加されますが、重なって新しいウィンドウ サイズに収まらないようです)。

  2. ウィンドウの開始/作成時にサイズ変更が呼び出されるようです。

class Window (QtGui.QMainWindow):
    def __init__(self):
        super(Window, self).__init__()
        self.thumbs = []
        self.thumbWidgets = []

        self._resize_timer = None
        self.resizeCompleted.connect(self.handleResizeCompleted)

        self.setGeometry(100, 100, 800, 600)
        self.home()

    def home(self):

        self.centralwidget = QtGui.QWidget(self)

        '''MainLAYOUT
        '''
        self.mainLayout = QtGui.QVBoxLayout(self.centralwidget)

        self.thumb_tab_QGroupBox = QtGui.QGroupBox(self.centralwidget)

        '''GroupBoxLAYOUT
        '''
        self.vLayout =  QtGui.QVBoxLayout(self.thumb_tab_QGroupBox)
        self.vLayout.setObjectName("GroupVLayout")


        #Scroll Area
        self.thumbScrollArea = QtGui.QScrollArea(self.thumb_tab_QGroupBox)
        self.thumbScrollArea.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
        self.thumbScrollArea.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
        self.thumbScrollArea.setWidgetResizable(True)
        self.thumbScrollArea.setAlignment(QtCore.Qt.AlignLeft)
        self.thumbScrollArea.setObjectName("thumb_scrollArea")

        self.scrollAreaWidgetContents = QtGui.QWidget()
        self.scrollAreaWidgetContents.setMinimumSize(QtCore.QSize(840, scrollAreaX))
        self.scrollAreaWidgetContents.setObjectName("scrollAreaWidgetContents")
        self.thumbScrollArea.setWidget(self.scrollAreaWidgetContents)

        self.vLayout.addWidget(self.thumbScrollArea)
        self.mainLayout.addWidget(self.thumb_tab_QGroupBox)

        #Grid in Scroll Area
        self.gridLayoutWidget = QtGui.QWidget(self.scrollAreaWidgetContents)
        self.gridLayoutWidget.setObjectName("gridLayoutWidget")
        self.gridLayout_QGridLayout = QtGui.QGridLayout(self.gridLayoutWidget)
        self.gridLayout_QGridLayout.setObjectName("gridLayout")

        #Loads thumbnails
        self.getThumbnails()

        self.mainLayout.setAlignment(QtCore.Qt.AlignLeft)
        self.setCentralWidget(self.centralwidget)

    def resizeEvent(self, resizeEvent):
        self.updateResizeTimer(300)

    def updateResizeTimer(self, interval=None):
        if self._resize_timer is not None:
            self.killTimer(self._resize_timer)
        if interval is not None:
            self._resize_timer = self.startTimer(interval)
        else:
            self._resize_timer = None

    def timerEvent(self, event):
        if event.timerId() == self._resize_timer:
            self.updateResizeTimer()
            self.resizeCompleted.emit()

    def handleResizeCompleted(self):
        print('resize complete')

        # Get new window size on resize
        width = self.centralwidget.frameGeometry().width()
        height = self.centralwidget.frameGeometry().height()

        thumbsPerRow = width / 200
        print "numThumbnails per Width", thumbsPerRow

        self.gridLayoutWidget.adjustSize()
        self.gridLayout_QGridLayout.maximumSize()

        for widget in self.thumbWidgets:
            print "Removing widget", widget
            self.gridLayout_QGridLayout.removeWidget(widget)
            #widget.deleteLater()

        self.populate(self.thumbWidgets, QtCore.QSize(200,200), thumbsPerRow)

    def queryThumbnailCount(self):
        ....
        ...
        ..
        return sizeX

    def getThumbnails(self):
        .....
        ....
        ...
        .
        self.createThumbWidgets(self.thumbs, QtCore.QSize(200,200))
        self.populate(self.thumbs, QtCore.QSize(200,200))

    def createThumbWidgets(self, pics, size, imagesPerRow=4, flags=QtCore.Qt.KeepAspectRatioByExpanding):
        for pic in pics:           
            label = QtGui.QLabel("")
            pixmap = QtGui.QPixmap(pic)
            pixmap = pixmap.scaled(size, flags)
            label.setPixmap(pixmap)
            self.thumbWidgets.append(label)


    #Add thumbnails to grid
    def populate(self, pics, size, imagesPerRow=6, flags=QtCore.Qt.KeepAspectRatioByExpanding):
        row = col = 0
        for widget in self.thumbWidgets:          
            print "Adding Image to column "+str(col)
            self.gridLayout_QGridLayout.addWidget(widget, row, col)
            col +=1
            if col % imagesPerRow == 0:
                row += 1
                col = 0        


GUI = Window()
GUI.show()
4

1 に答える 1

0

これは、QGraphicsView.

QGraphicsViewそれ自体にも を作成する a のサブクラスを作成QGraphicsSceneします。表示するピックスマップのリストを保存します。resizeEventサブクラスの をオーバーライドして をクリアし、QGraphicsSceneを使用してすべてのピックスマップをシーンに再度追加しQGraphicsPixmapItemsます。それらをシーンに追加する前に、 から幅と高さの合計を取得しQGraphicsView.viewport()ます。行/列で割ることで、個々のピックスマップの幅/高さを取得できます。次に、各ピックスマップをシーンに追加する前にスケーリングします。

于 2016-03-23T00:22:17.103 に答える