2015-10-19 72 views
1

在這種情況下,我想填充且已修改爲加載圖像使用類TableWidgetImage如何使用QThread從慢Sql語句填充自定義QTableWidget?

from PyQt4 import QtGui 
import sys 
class ImageWidget(QtGui.QWidget): 
    def __init__(self, imagePath, parent): 
     super(ImageWidget, self).__init__(parent) 
     self.picture = QtGui.QPixmap(imagePath) 
    def paintEvent(self, event): 
     painter = QtGui.QPainter(self) 
     painter.drawPixmap(0, 0, self.picture) 
class TableWidgetImage(QtGui.QTableWidget): 
    def setImage(self, row, col, imagePath): 
     image = ImageWidget(imagePath, self) 
     self.setCellWidget(row, col, image) 

的功能是一個QTableWidget的:我從「cbUser」(帳戶),選擇一個項目我按下「btnCargar」和「tableSusAmigos」加載好。我的問題集中在下一步。當我雙擊單行到「tableSusAmigos」它應該加載第二個QTableWidget。有用。但我的問題是有很多行時。我想加載使用QThread。我不怎麼修改使用QThread的UI QTableWidget控件。這是我的其他Python文件,它包含2個類:

class Ui_friendForm(QMdiSubWindow): 
    def __init__(self): 
     QtGui.QMdiSubWindow.__init__(self) 
     icon = QtGui.QIcon() 
     icon.addPixmap(QtGui.QPixmap(_fromUtf8(":/mmAmistad/mmAmistad.png")), QtGui.QIcon.Normal, QtGui.QIcon.Off) 
     self.setWindowIcon(icon) 
     self.resize(878, 637) 
     self.cbUser = QtGui.QComboBox(self) 
     self.cbUser.setGeometry(QtCore.QRect(20, 70, 211, 22)) 
     self.cbUser.setObjectName(_fromUtf8("cbUser")) 
     self.btnCargar = QtGui.QPushButton(self) 
     self.btnCargar.setGeometry(QtCore.QRect(250, 60, 91, 41)) 
     icon = QtGui.QIcon() 
     icon.addPixmap(QtGui.QPixmap(_fromUtf8(":/picLoad/btnLoad.png")), QtGui.QIcon.Normal, QtGui.QIcon.Off) 
     self.btnCargar.setIcon(icon) 
     self.btnCargar.setObjectName(_fromUtf8("btnCargar")) 
     self.tableSusAmigos = TableWidgetImage(self) 
     self.tableSusAmigos.setGeometry(QtCore.QRect(20, 110, 391, 461)) 
     self.tableSusAmigos.setColumnCount(3) 
     self.tableSusAmigos.setObjectName(_fromUtf8("tableSusAmigos")) 
     self.tableSusAmigos.setRowCount(0) 
     self.tableSusAmigos.verticalHeader().setDefaultSectionSize(50) 
     self.tableSusAmigos.setSelectionBehavior(QtGui.QAbstractItemView.SelectRows) 
     self.tableSusAmigos.setEditTriggers(QtGui.QAbstractItemView.NoEditTriggers) 
     self.tableSusAmigos.setSortingEnabled(1) 
     item = QtGui.QTableWidgetItem() 
     self.tableSusAmigos.setHorizontalHeaderItem(0, item) 
     item = QtGui.QTableWidgetItem() 
     self.tableSusAmigos.setHorizontalHeaderItem(1, item) 
     item = QtGui.QTableWidgetItem() 
     self.tableSusAmigos.setHorizontalHeaderItem(2, item) 
     self.tableAmigosde = TableWidgetImage(self) 
     self.tableAmigosde.setGeometry(QtCore.QRect(470, 110, 381, 461)) 
     self.tableAmigosde.setColumnCount(3) 
     self.tableAmigosde.setObjectName(_fromUtf8("tableAmigosde")) 
     self.tableAmigosde.setRowCount(0) 
     self.tableAmigosde.verticalHeader().setDefaultSectionSize(50) 
     self.tableAmigosde.setSelectionBehavior(QtGui.QAbstractItemView.SelectRows) 
     self.tableAmigosde.setEditTriggers(QtGui.QAbstractItemView.NoEditTriggers) 
     self.tableAmigosde.setSortingEnabled(1) 
     item = QtGui.QTableWidgetItem() 
     self.tableAmigosde.setHorizontalHeaderItem(0, item) 
     item = QtGui.QTableWidgetItem() 
     self.tableAmigosde.setHorizontalHeaderItem(1, item) 
     item = QtGui.QTableWidgetItem() 
     self.tableAmigosde.setHorizontalHeaderItem(2, item) 
     self.setWindowTitle(_translate("Form", "Form", None)) 
     self.btnCargar.setText(_translate("Form", "Cargar", None)) 
     self.btnCargar.clicked.connect(self.cargarAmigos) 
     item = self.tableSusAmigos.horizontalHeaderItem(0) 
     item.setText(_translate("Form", "ID", None)) 
     item = self.tableSusAmigos.horizontalHeaderItem(1) 
     item.setText(_translate("Form", "Nombre", None)) 
     item = self.tableSusAmigos.horizontalHeaderItem(2) 
     item.setText(_translate("Form", "Foto", None)) 
     item = self.tableAmigosde.horizontalHeaderItem(0) 
     item.setText(_translate("Form", "ID", None)) 
     item = self.tableAmigosde.horizontalHeaderItem(1) 
     item.setText(_translate("Form", "Nombre", None)) 
     item = self.tableAmigosde.horizontalHeaderItem(2) 
     item.setText(_translate("Form", "Foto", None)) 
     self.pbCarga = QtGui.QProgressBar(self) 
     self.pbCarga.setGeometry(QtCore.QRect(20, 590, 391, 23)) 
     self.pbCarga.setProperty("value", 24) 
     self.pbCarga.setValue(0) 
     self.pbCarga.setObjectName(_fromUtf8("pbCarga")) 
     self.setWindowTitle(_translate("Form", "List Friends", None)) 
     self.objDato = DBFacebook() 
     self.cargarCombo() 
     QtCore.QMetaObject.connectSlotsByName(self) 
     self.tableSusAmigos.doubleClicked.connect(self.doubleClicked_table) 
     self.thread = TaskThread(self) 
     self.thread.started.connect(self.handleTaskUpdated)  
    def cargarCombo(self): 
     self.objDato.__enter__() 
     for row in self.objDato.SELECT_CUENTA_USER(): 
      self.cbUser.addItem(str(row[1]),int(row[0])) 
     self.objDato.__exit__() 
    def doubleClicked_table(self): 
     index = self.tableSusAmigos.selectedIndexes()[0] 
     self.id_us = int(self.tableSusAmigos.model().data(index).toString()) 
     self.tableAmigosde.setRowCount(0); 
     self.pbCarga.setRange(0,0) 
     self.pbCarga.setValue(0) 
     self.thread.quit() 
     self.thread.start() 
    def handleTaskUpdated(self): 
     rowIndex = 0 
     self.objDato.__enter__() 
     for row in self.objDato.SELECT_AMISTADES(self.id_us): 
      self.tableAmigosde.insertRow(rowIndex) 
      for column in range(0,3): 
       if column == 2: 
        self.tableAmigosde.setImage(rowIndex, column, str(row[column])) 
       else: 
        newItem = QtGui.QTableWidgetItem(str(row[column]).decode('utf-8')) 
        self.tableAmigosde.setItem(rowIndex,column,newItem) 
      rowIndex = rowIndex + 1 
     self.objDato.__exit__() 
     self.pbCarga.setRange(0,1) 
     self.pbCarga.setValue(1) 
    def cargarAmigos(self): 
     id_us = self.cbUser.itemData(self.cbUser.currentIndex()).toPyObject() 
     self.objDato.__enter__() 
     rowIndex = 0 
     self.tableSusAmigos.setRowCount(0); 
     for row in self.objDato.SELECT_AMISTADES(id_us): 
      self.tableSusAmigos.insertRow(rowIndex) 
      for column in range(0,3): 
       if column == 2: 
        self.tableSusAmigos.setImage(rowIndex, column, str(row[column])) 
       else: 
        newItem = QtGui.QTableWidgetItem(str(row[column]).decode('utf-8')) 
        self.tableSusAmigos.setItem(rowIndex,column,newItem) 
      rowIndex = rowIndex + 1 
     self.objDato.__exit__() 
class TaskThread(QtCore.QThread): 
    def __init__(self,parent): 
     QtCore.QThread.__init__(self, parent) 
    def run(self): 
     self.emit(QtCore.SIGNAL('started'))   
if __name__ == "__main__": 
    import sys 
    app = QtGui.QApplication(sys.argv) 
    ui = Ui_friendForm() 
    ui.show() 
    sys.exit(app.exec_()) 

我將一張圖片附加到我的應用程序中。提前致謝。

enter image description here

+0

我想解決同樣的問題 –

回答

0

小部件僅被從主線程內被訪問。但是,只要使用默認連接類型,使用插槽和信號就可以從另一個線程與UI進行交互。

檢查this示例我前一段時間創建的示例(在wiki中有關於代碼的詳細信息)。基本上所有你需要做的是添加一個插槽,無論你的表小部件駐留在哪裏。使用槽的參數(它將提供表項的數據),您只需創建QTableWidgetItem並插入它。至於信號本身,它可以從您的工作線程發出,對象駐留的工作線程將查詢您的數據庫並將檢索到的數據轉換爲一個或多個表格行,然後通過該信號發送。