如果在消息框之后调用,setOverrideCursor(Qt::WaitCursor) 不工作
setOverrideCursor(Qt::WaitCursor) not working if called just after a message box
QMessageBox::information(this, "hello", "hello");
QApplication::setOverrideCursor(Qt::WaitCursor);
QThread::sleep(5);
QApplication::restoreOverrideCursor();
执行上述代码时,我希望等待光标设置为 5 秒。但是等待光标根本没有出现。如果我一开始就删除消息框,等待光标出现并按预期停留 5 秒。
这可能是什么原因?
静态消息框方法使用 exec()
,因此它会停止执行您当前的代码。从 QThread
睡眠会阻塞整个主线程,这意味着没有更新,没有重绘,只是冻结 GUI。
解决方案:
不要使用静态消息框方法,在堆上创建新框并设置特殊标志以避免内存泄漏:
QMessageBox *box = new QMessageBox;
box->setText(...);
//add info to box
box->setAttribute(Qt::WA_DeleteOnClose);
box->exec();
不要使用 QThread::sleep
,使用 QTimer
中的 singleshot
,只需创建一些用于恢复光标的插槽:
//override cursor
QTimer::singleShot(time,this,SLOT(slotWhichRestoresCursor()));
在这种情况下,您的所有操作都将是异步的,并且 GUI 不会被冻结。
QMessageBox::information(this, "hello", "hello");
QApplication::setOverrideCursor(Qt::WaitCursor);
QThread::sleep(5);
QApplication::restoreOverrideCursor();
执行上述代码时,我希望等待光标设置为 5 秒。但是等待光标根本没有出现。如果我一开始就删除消息框,等待光标出现并按预期停留 5 秒。
这可能是什么原因?
静态消息框方法使用 exec()
,因此它会停止执行您当前的代码。从 QThread
睡眠会阻塞整个主线程,这意味着没有更新,没有重绘,只是冻结 GUI。
解决方案:
不要使用静态消息框方法,在堆上创建新框并设置特殊标志以避免内存泄漏:
QMessageBox *box = new QMessageBox;
box->setText(...);
//add info to box
box->setAttribute(Qt::WA_DeleteOnClose);
box->exec();
不要使用 QThread::sleep
,使用 QTimer
中的 singleshot
,只需创建一些用于恢复光标的插槽:
//override cursor
QTimer::singleShot(time,this,SLOT(slotWhichRestoresCursor()));
在这种情况下,您的所有操作都将是异步的,并且 GUI 不会被冻结。