hkvm
6th September 2009, 14:17
Hi everyone,
I need some help with this problem I have... I'm trying to make a worker thread perform a long operation and have the GUI stay responsive. I need to give the thread a chunk of data to work on and let it run. I've read that the best way to pass data inbetween threads is signals and slots, so what I did is I subclassed a QThread like this (slightly simplified example: the thread gets a vector of floats and returns an image):
class Worker : public QThread
{
Q_OBJECT
public:
void run();
signals:
void done(QImage);
public slots:
void makeImage(std::vector<float>);
};
void Worker::run()
{
exec();
}
The run() function just launches the event loop and at the end of makeImage slot I call exit(), I only need it to process the one signal. When the thread is done working it passes the result with the "done" signal. The vector type is registered with qRegisterMetaType() so it can be used with QueuedConnection.
Now the (possibly) problematic code:
Worker* worker = new Worker();
connect(this, SIGNAL(makeImage(std::vector<float>)), worker, SLOT(makeImage(std::vector<float>)), Qt::QueuedConnection);
connect(worker, SIGNAL(done(QImage)), this, SLOT(newImage(QImage)), Qt::QueuedConnection);
worker->start();
emit makeImage(my_vector);
I call for QueuedConnection explicitly to make sure the slot is called from the new thread.
The problem is: it doesn't seem like a new thread is started at all, the GUI is blocked and when I call QThread::currentThread() from the working function, the result is the same as from the GUI thread! How come it's not spawning a new thread to do the work? If what I'm doing can be done better please tell me.
I need some help with this problem I have... I'm trying to make a worker thread perform a long operation and have the GUI stay responsive. I need to give the thread a chunk of data to work on and let it run. I've read that the best way to pass data inbetween threads is signals and slots, so what I did is I subclassed a QThread like this (slightly simplified example: the thread gets a vector of floats and returns an image):
class Worker : public QThread
{
Q_OBJECT
public:
void run();
signals:
void done(QImage);
public slots:
void makeImage(std::vector<float>);
};
void Worker::run()
{
exec();
}
The run() function just launches the event loop and at the end of makeImage slot I call exit(), I only need it to process the one signal. When the thread is done working it passes the result with the "done" signal. The vector type is registered with qRegisterMetaType() so it can be used with QueuedConnection.
Now the (possibly) problematic code:
Worker* worker = new Worker();
connect(this, SIGNAL(makeImage(std::vector<float>)), worker, SLOT(makeImage(std::vector<float>)), Qt::QueuedConnection);
connect(worker, SIGNAL(done(QImage)), this, SLOT(newImage(QImage)), Qt::QueuedConnection);
worker->start();
emit makeImage(my_vector);
I call for QueuedConnection explicitly to make sure the slot is called from the new thread.
The problem is: it doesn't seem like a new thread is started at all, the GUI is blocked and when I call QThread::currentThread() from the working function, the result is the same as from the GUI thread! How come it's not spawning a new thread to do the work? If what I'm doing can be done better please tell me.