Sometimes my application crashes in QWidget::update() that is performing in non-GUI thread.
I am developing an application in which receives video frames from remote host and display them on QWidget.
For this purpose I use libVLC library that gives to me a decoded image. I receive image in libVLC callback, that is performing in separate libVLC thread. In this callback I'm trying to perform QWidget::update() method. Sometimes application crashes, and callstack is somewhere in this method. Here is the my callback code:
//! Called when a video frame is ready to be displayed, according to the vlc clock.
//! \c picture is the return value from lockCB().
void VideoWidget::displayCB(void* picture)
{
QImage* image = reinterpret_cast<QImage*>(picture);
onScreenPixmapMutex_.lock();
onScreenPixmap_ = QImage(*image);
onScreenPixmap_.detach();
onScreenPixmapMutex_.unlock();
delete image;
update();
}
I know that GUI operations outside the main thread are not allowed in Qt. But according documentation QWidget::update() just schedules a paint event for processing when Qt returns to the main event loop and does not cause an immediate repaint.
The questtion is: is the rule "GUI operations outside the main thread are not allowed" appliable for QWidget::update()? Does this operation belong to "GUI operations"?
I use Qt 4.7.3, the crash repoduces on Windows 7 and Linux.
Check out the Mandelbrot Example. In that example a worker thread is generating an image and passing it to rendering widget with signal/slot mechanism. Use the same method!
Instead of implementing a new updatePixmap() slot as given in the example you can directly connect update () slot of your widget as well.
From your code I can see that you have a mutex to provide concurrent access. So it should be easy to directly use your update slot.
Both methods still use signal/slot mechanism because GUI operations outside the main thread are not allowed in Qt.