3

在我的 Qt 程序中,我有一个模式QDialogs,旨在停止一切,直到它被解除后才继续执行代码。它适用于它所在的函数——我在下一行代码上放了一个断点,qDialog::exec()直到我关闭对话框后它才会中断。

但是,QTimer在其超时时有一个连接到插槽,即使模式对话框启动并执行其插槽中的代码,它也会继续运行。

我想我可以在显示modal dialog. 但是,可能存在对话框与计时器完全不同的类的情况。有没有办法真正停止程序的执行,直到QDialog被解雇?

例子:

QTimer* pTestTimer = new QTimer( this );
connect( pTestTimer , SIGNAL( timeout() ), this, SLOT( timerSlot() ) );

//Slot code elsewhere
void cMyClass::deleteMeTimerSlot()
{
    qDebug() << "See me during modal?";
}

//starting a modal dialog
pTestTimer->start( 1000 );

QDialog* pModalDlg = new QDialog( this, Qt::Dialog | Qt::FramelessWindowHint     | Qt::WindowStaysOnTopHint );

pModalDlg->setModal(true);
pMOdalDlg->exec();

输出仍然显示“在模态期间见我?” 而在exec();

4

1 回答 1

0

我想我可以在显示模态对话框之前停止计时器。但是,可能存在对话框与计时器完全不同的类的情况。

是的,您可以使用父上下文中可访问的所有计时器进行操作(看起来您正在寻找通用解决方案)。

// Halt all the timers within parent context.
// If all the timers have parent maybe the top app widget pointer
// should be used for parentObj
QList<QTimer*> listOfTimers = parentObj->findChildren<QTimer*>(
   QString(), Qt::FindChildrenRecursively);
for(QTimer* pTimer : listOfTimers)
   pTimer->stop();

有没有办法真正停止程序的执行,直到 QDialog 被解除?

除非您的意思是停止所有线程:不,QDialog 是程序的一部分,并不意味着停止任何执行,但模态对话框在自己的事件循环中运行,只会阻止用户操作其他程序 UI。我想您可能可以在退出模式对话框后重新启动所有停止的计时器。

pModalDlg->exec();

// restart all the timers within parent context
for(QTimer* pTimer : listOfTimers)
   pTimer->start();

您还可以查看 Qt 源代码(在 QDialog 和它使用的事件循环中)并创建您自己的复杂对话框类,并为其创建非常具体的事件循环。

于 2015-07-18T04:36:44.317 回答