pandas使用QGraphicsView自動排列項目的實現(xiàn)
我想使用 QGraphicsView 來編寫一個資源瀏覽器。它與使用 QGraphicsView 和 QGraphicsItems 的例子略有不同,因為我只希望有一個滾動條,并且我希望項目在視區(qū)大小更改時能夠自動移動。例如,當(dāng)視區(qū)寬度足夠大以顯示 4 個資產(chǎn)時,它們應(yīng)該像這樣顯示:
aaaa
aaaa
aa
但是當(dāng)視區(qū)縮小并且只能在一行中容納 3 個時,它應(yīng)該像這樣顯示:
aaa
aaa
aaa
a
我不想自己移動這些資產(chǎn),而是讓圖形視圖管理它們。這可能嗎?
我曾經(jīng)寫過這樣一件事,但使用 QWidget 和 paintEvent,自己繪制所有資產(chǎn)并跟蹤一行中可以顯示多少資產(chǎn)。可以用 QGraphicsView 更簡單地完成嗎?
解決方案
方法一:使用 QGraphicsFlowLayout
QGraphicsView 支持布局。您需要做的是實現(xiàn)您自己的布局管理器,繼承自 QGraphicsLayout。
對于您需要的布局,請查看 Qt 的流布局示例。轉(zhuǎn)換該示例將為您提供一個 QGraphicsFlowLayout。將您的 QGraphicsItems 添加到此布局并將您的 QGraphicsView 的布局設(shè)置為該布局,這將完成這項工作。
方法二:使用 QListWidget
聽起來您想要一個列表,而不是一個圖形視圖。可以將列表設(shè)置為顯示像您希望的那樣換行的內(nèi)容。請參閱拼圖示例,注意左側(cè)的拼圖塊列表。對于所提出的情況,設(shè)置起來非常簡單。
當(dāng)然,如果您真的想在圖形視圖中實現(xiàn)它,我想您可以將一個列表添加到視圖中并在那里使用它。
代碼示例
from PyQt5.QtCore import QRectF from PyQt5.QtGui import QBrush, QColor, QPen from PyQt5.QtWidgets import QApplication, QGraphicsItem, QGraphicsRectItem, QGraphicsScene, QGraphicsView, QVBoxLayout, QWidget class QGraphicsFlowLayout(QGraphicsLayout): def __init__(self): super().__init__() self.item_list = [] def addItem(self, item): self.item_list.append(item) def count(self): return len(self.item_list) def itemAt(self, index): return self.item_list[index] def takeAt(self, index): item = self.item_list.pop(index) return item def boundingRect(self): rect = QRectF() for item in self.item_list: rect |= item.rect() return rect def sizeHint(self, which, constraint): return self.boundingRect().size() def minimumSize(self): return self.sizeHint(QGraphicsLayout.MinimumSize, QSizeF()) def preferredSize(self): return self.sizeHint(QGraphicsLayout.PreferredSize, QSizeF()) def get_row_width(self): row_width = 0 for item in self.item_list: row_width += item.rect().width() return row_width def get_row_height(self): row_height = 0 for item in self.item_list: row_height = max(row_height, item.rect().height()) return row_height def get_num_rows(self, view_width): row_width = self.get_row_width() num_rows = 1 if row_width > view_width: num_rows = row_width // view_width + 1 return num_rows def get_row_spacing(self): return 10 def get_column_spacing(self): return 10 def get_item_position(self, item, row, column): x = column * (item.rect().width() + self.get_column_spacing()) y = row * (item.rect().height() + self.get_row_spacing()) return QPointF(x, y) def setGeometry(self, rect): view_width = rect.width() num_rows = self.get_num_rows(view_width) row_height = self.get_row_height() for i, item in enumerate(self.item_list): row = i // num_rows column = i % num_rows pos = self.get_item_position(item, row, column) item.setPos(pos) class QGraphicsFlowView(QGraphicsView): def __init__(self): super().__init__() self.scene = QGraphicsScene(self) self.layout = QGraphicsFlowLayout() self.scene.setLayout(self.layout) self.setRenderHints(QGraphicsView.Antialiasing | QGraphicsView.SmoothPixmapTransform) self.setViewportUpdateMode(QGraphicsView.FullViewportUpdate) def add_item(self, item): self.layout.addItem(item) def resizeEvent(self, event): super().resizeEvent(event) self.layout.setGeometry(self.rect()) class QGraphicsFlowItem(QGraphicsRectItem): def __init__(self, color): super().__init__() self.setRect(0, 0, 100, 100) self.setBrush(QBrush(color)) self.setPen(QPen(QColor(0, 0, 0), 1)) if __name__ == "__main__": app = QApplication([]) view = QGraphicsFlowView() view.add_item(QGraphicsFlowItem(QColor(255, 0, 0))) view.add_item(QGraphicsFlowItem(QColor(0, 255, 0))) view.add_item(QGraphicsFlowItem(QColor(0, 0, 255))) view.add_item(QGraphicsFlowItem(QColor(255, 255, 0))) view.add_item(QGraphicsFlowItem(QColor(255, 0, 255))) view.add_item(QGraphicsFlowItem(QColor(0, 255, 255))) view.show() app.exec_()
到此這篇關(guān)于pandas使用QGraphicsView自動排列項目的實現(xiàn)的文章就介紹到這了,更多相關(guān)pandas QGraphicsView自動排列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spyder 在控制臺(console)執(zhí)行python文件,debug python程序方式
這篇文章主要介紹了spyder 在控制臺(console)執(zhí)行python文件,debug python程序方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04Python對多屬性的重復(fù)數(shù)據(jù)去重實例
下面小編就為大家分享一篇Python對多屬性的重復(fù)數(shù)據(jù)去重實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04python判斷列表的連續(xù)數(shù)字范圍并分塊的方法
今天小編就為大家分享一篇python判斷列表的連續(xù)數(shù)字范圍并分塊的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11Python如何爬取微信公眾號文章和評論(基于 Fiddler 抓包分析)
這篇文章主要介紹了Python如何爬取微信公眾號文章和評論(基于 Fiddler 抓包分析),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-06-06windows系統(tǒng)Tensorflow2.x簡單安裝記錄(圖文)
這篇文章主要介紹了windows系統(tǒng)Tensorflow2.x簡單安裝記錄(圖文),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01