我知道模态对话框(QDialog)和examples的应用和使用网络上到处都是,但我的用途是显示进度。
尝试过:
根据来自 here 的主题/帖子和 here ,我发现可以使用 accept()
、done()
、close()
、setResult()
但是这些都不关闭对话框,对话框只是挂起。
我有一个用于“单击关闭”的 connect()
但这并不完全满足要求,因为在任何一种情况下执行成功或不成功都将等待用户输入。
更新:刚刚尝试了setResult(Accepted);
,即使在成功执行之后,QDialog 仍然挂起。
问题:
模态对话框用于显示进度,成功执行结束时应自动关闭模态对话框,但如果未成功执行,对话框应保持打开状态以供用户查看显示的错误。
使用的函数:
我已经使用了上面建议的这些功能。这些不会关闭对话框,对话框只是挂起等待用户交互(即用按钮的插槽手动关闭它)
代码:
对话框执行:
dlgConnectStatus = new LoginStatusDialog(login, key, auth);
dlgConnectStatus->setModal(true);
int res = dlgConnectStatus->exec(); << see note below
qDebug() << "dlgConnectStatus result = " << QString::number(res);
注意:运行执行的所有代码都在 dlgConnectStatus 类构造函数中。此代码仅在 dlgConnectStatus->exec();
被调用后执行,但不会返回任何结果,代码执行结束并在最后一个构造函数行后挂起。
我尝试添加:
if (Return_Object->getCode() == ReturnCode::netcon_LoginSuccess) {
setResult(Accepted);
accept();
}
但它仍然挂起!
*完成信息(无关紧要,但要放在上下文中):
代码执行后(成功与否),在销毁之前从 dlgConnectStatus 对象中提取一个公共(public)对象。*
长话短说
如何关闭 QDialog,手动输入模态?
创建问题的基本/基本代码
调用代码:
dlgConnectStatus = new LoginStatusDialog(login, key, auth);
qDebug() << "Done LoginStatusDialog, setting modal";
dlgConnectStatus->setModal(true);
qDebug() << "Done setting modal, executing";
int res = dlgConnectStatus->exec();
qDebug() << "dlgConnectStatus result = " << QString::number(res);
//see below for debugger output -> the qDebug output
LoginStatusDialog.h
#ifndef LOGINSTATUSDIALOG_H
#define LOGINSTATUSDIALOG_H
#include <QDialog>
#include <QtCore>
#include <QtGui>
#include <QtWidgets>
#include <thread>
#include "returnobject.h"
#include "datamanager.h"
namespace Ui {
class LoginStatusDialog;
}
class LoginStatusDialog : public QDialog
{
Q_OBJECT
public:
// explicit LoginStatusDialog(QWidget *parent = 0);
LoginStatusDialog( QString _login, QString _key, QString *_auth_tok, QWidget *parent = 0);
~LoginStatusDialog();
private:
Ui::LoginStatusDialog *ui;
QString login, key;
ReturnObject *Return_Object;
void initGui();
};
#endif // LOGINSTATUSDIALOG_H
LoginStatusDialog.cpp
//custom constructor
LoginStatusDialog::LoginStatusDialog( QString _login, QString _key, QString *_auth_tok, QWidget *parent) :
QDialog(parent), ui(new Ui::LoginStatusDialog), login(_login), key(_key)
{
ui->setupUi(this);
//this code is basically self explanitory
Return_Object = new ReturnObject(ReturnCode::netcon_LoginSuccess, QString(""));
if (Return_Object->getCode() == ReturnCode::netcon_LoginSuccess) {
//by use ofbreakpoints, I can verify this close is reached but not executed.
qDebug() << "pre close";
close();
qDebug() << "post close";
}
}
调试信息
Debugging starts
Creating LoginStatusDialog
pre close
post close
Done LoginStatusDialog, setting modal
Done setting modal, executing
//remains open
最佳答案
您对 close 的检查是在构造函数中执行的,但 exec 是在它之后调用的,因此您需要在构造函数中执行类似计时器的操作,并将其超时信号与插槽连接,这将包含您的登录检查。此外,您可以重新实现 exec 方法以仅在 exec 调用后启动计时器。
关于c++ - 在不连接按钮的情况下手动关闭 Modal QDialog - 代码完成后对话框挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40234630/