PyQt异步动态添加控件

CreateThread.py
# -*- coding:utf-8 -*-
import threading
import time
from PyQt4 import QtCore
from PyQt4.QtCore import QThread

class CreateThread(QThread):
    signal_time = QtCore.pyqtSignal(str,int)
    def __init__(self, parent=None):
        super(CreateThread,self).__init__(parent)

    def start_thread(self):
        self.start()

    def run(self):
        print 'start block'
        print 'new thread :',threading.current_thread()
        time.sleep(3)    #模拟阻塞
        self.signal_time.emit("new button","aaa")
        print 'end block'
TestUI.py
# -*- coding:utf-8 -*-
import threading

from PyQt4 import QtGui, QtCore
from PyQt4.QtGui import QWidget
from CreateThread import CreateThread

class TestUI(QWidget):
    def __init__(self, parent=None):
        QtGui.QWidget.__init__(self, parent)
        self.instance = self
        self.setGeometry(100,100,500,400)
        self.layout = QtGui.QGridLayout()
        self.btnTest = QtGui.QPushButton()
        self.btnTest.setText("单击, 异步动态添加控件".decode(encoding='utf-8'))
        self.btnTest.setGeometry(QtCore.QRect(190, 74, 75, 23))
        self.layout.addWidget(self.btnTest)
        self.setLayout(self.layout)

        self.timetool = CreateThread()
        self.timetool.signal_time.connect(self.add_widget)

        self.connect(self.btnTest, QtCore.SIGNAL("clicked()"), self.click_start_btn)
        pass

    def click_start_btn(self):
        self.timetool.start_thread()

    def add_widget(self, text):
        btnaaa = QtGui.QPushButton()
        btnaaa.setText(text)
        self.layout.addWidget(btnaaa)

    def keyPressEvent(self, e):
        print e.key()

if __name__ == '__main__':
    print threading.current_thread()
    import sys
    app = QtGui.QApplication(sys.argv)
    form = TestUI()
    form.show()
    sys.exit(app.exec_())

这里写图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于Python中的PyQt5库,可以使用QComboBox件来实现下拉列表框,动态加载item的方法是使用一个线程或协程异步读取数据,然后将数据添加到QComboBox中。 示例代码如下: ```python import sys import time from PyQt5.QtWidgets import QApplication, QMainWindow, QComboBox from PyQt5.QtCore import pyqtSignal, QThread, Qt class DataLoaderThread(QThread): update_signal = pyqtSignal(list) def run(self): # 模拟异步加载数据 time.sleep(5) items = ['选项1', '选项2', '选项3'] self.update_signal.emit(items) class MyComboBox(QComboBox): def __init__(self): super().__init__() self.loadData() def loadData(self): thread = DataLoaderThread() thread.update_signal.connect(self.updateItems) thread.start() def updateItems(self, items): self.addItems(items) class MainWindow(QMainWindow): def __init__(self): super().__init__() combobox = MyComboBox() self.setCentralWidget(combobox) if __name__ == '__main__': app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ``` 在这个示例中,我们创建了一个继承自QComboBox的MyComboBox类,通过调用loadData()方法来开启一个DataLoaderThread线程来异步加载数据。当线程完成加载后,会通过一个update_signal信号将数据传递给MyComboBox来更新下拉列表框中的选项。 注意,在使用线程或协程异步加载数据时,需要注意线程安全和UI线程更新。可以使用QMutex或QMetaObject.invokeMethod()等工具来确保线程安全,使用信号槽连接来在UI线程更新界面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值