【转】Qt多线程操作界面---在QThread更新QProgressBar

复制代码
#include <QApplication>
#include <QThread>
#include <QMainWindow>
#include <QProgressBar>
#include <QPushButton>
class RenderThread : public QThread
{
        Q_OBJECT
signals:
        void notify(int);
public:
        RenderThread(QObject *parent = 0): QThread(parent)
        {

        };
        void test()
        {

                start(HighestPriority);
        };
protected:
    void run()
        {
                int i =0;
                while (i<101)
                {
                        msleep(50);
                        i++;
                        emit notify(i);
                }

        };
};

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = 0)
    {
        resize(600, 400);
        centralWidget = new QWidget(this);
        progressBar = new QProgressBar(centralWidget);
        progressBar->setGeometry(QRect(130, 180, 321, 23));
        progressBar->setValue(0);
        pushButton = new QPushButton("test",centralWidget);
        pushButton->setGeometry(QRect(110, 100, 75, 23));
        QObject::connect(pushButton, SIGNAL(clicked()), this, SLOT(OnClicked()));
        this->setCentralWidget(centralWidget);
    };
    ~MainWindow(){};

private:
    QProgressBar *progressBar;
    QPushButton *pushButton;
    QWidget *centralWidget;
    RenderThread render;
public slots:
    void OnClicked()
    {
        connect(&render,SIGNAL(notify(int)),this,SLOT(OnNotify(int)));
        render.test();    
    };
    void OnNotify(int i)
    {
        progressBar->setValue(i);    
    };

};
#include "test.moc"
int main(int argc,char* argv[])
{
    QApplication app(argc,argv);
    MainWindow window;
    window.show();
    return app.exec();
}
复制代码

http://blog.csdn.net/tingsking18/article/details/5096172

转载于:https://www.cnblogs.com/tiandsp/p/7580577.html

下面是多线程 QProgressBar 实现进度条的示例代码: ```python from PyQt5.QtCore import QThread, pyqtSignal from PyQt5.QtWidgets import QApplication, QWidget, QProgressBar, QPushButton, QVBoxLayout import time class Worker(QThread): progress_updated = pyqtSignal(int) def run(self): for i in range(101): time.sleep(0.1) self.progress_updated.emit(i) class MainWindow(QWidget): def __init__(self): super().__init__() self.progress_bar = QProgressBar() self.start_button = QPushButton("Start") self.start_button.clicked.connect(self.start_worker) layout = QVBoxLayout() layout.addWidget(self.progress_bar) layout.addWidget(self.start_button) self.setLayout(layout) self.worker = Worker() self.worker.progress_updated.connect(self.update_progress) def start_worker(self): self.worker.start() def update_progress(self, value): self.progress_bar.setValue(value) if __name__ == "__main__": app = QApplication([]) main_window = MainWindow() main_window.show() app.exec_() ``` 在这个示例中,我们创建了一个 `Worker` 类,它继承自 `QThread` 类。在 `Worker` 类中,我们定义了一个 `progress_updated` 信号,用于在进度更新时发射信号。在 `run` 方法中,我们使用一个循环模拟了一个长时间的任务,并且在每次循环中都让线程休眠了一小段时间。在循环中,我们发射了 `progress_updated` 信号,并且将当前进度作为参数传递。 在 `MainWindow` 类中,我们创建了一个 `QProgressBar` 控件和一个 `QPushButton` 控件,用于启动线程。当用户点击 `Start` 按钮时,我们启动了 `Worker` 线程。我们还定义了一个 `update_progress` 方法,用于更新进度条的值。在 `MainWindow` 类的构造函数中,我们连接了 `Worker` 的 `progress_updated` 信号到 `update_progress` 方法。 最后,我们创建了一个 `QApplication` 实例,并且创建了一个 `MainWindow` 实例并显示。当用户关闭窗口时,`app.exec_()` 方法会返回并退出应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值