1.基本消息框
简单信息提示
#include <qmessagebox> // 信息提示框 qmessagebox::information(nullptr, "标题", "这是一条信息"); // 警告框 qmessagebox::warning(nullptr, "警告", "这是一个警告!"); // 错误框 qmessagebox::critical(nullptr, "错误", "发生了一个错误!"); // 询问框 qmessagebox::question(nullptr, "询问", "你确定要执行此操作吗?");
2.带按钮的消息框
基本按钮配置
// 带 yes/no 按钮
qmessagebox::standardbutton reply;
reply = qmessagebox::question(nullptr, "确认", "确定要退出吗?",
qmessagebox::yes | qmessagebox::no);
if (reply == qmessagebox::yes) {
qdebug() << "用户选择了 yes";
} else {
qdebug() << "用户选择了 no";
}
// 带多个按钮
qmessagebox::standardbutton reply = qmessagebox::question(
nullptr,
"保存文件",
"文件已修改,是否保存?",
qmessagebox::save | qmessagebox::discard | qmessagebox::cancel
);
switch (reply) {
case qmessagebox::save:
qdebug() << "保存文件";
break;
case qmessagebox::discard:
qdebug() << "不保存";
break;
case qmessagebox::cancel:
qdebug() << "取消操作";
break;
}3.自定义消息框
基本示例
qmessagebox msgbox;
msgbox.setwindowtitle("自定义标题");
msgbox.settext("这是一条详细的消息内容");
msgbox.setinformativetext("这是附加信息");
msgbox.setdetailedtext("这是详细的技术信息:\n错误代码: 0x1234\n文件: main.cpp");
msgbox.seticon(qmessagebox::information);
msgbox.setstandardbuttons(qmessagebox::ok | qmessagebox::cancel);
msgbox.setdefaultbutton(qmessagebox::ok);
int ret = msgbox.exec();
if (ret == qmessagebox::ok) {
qdebug() << "用户点击了确定";
}设置父窗口
// 在类的方法中使用 this 作为父对象
void mainwindow::showmessage()
{
qmessagebox::information(this, "提示", "操作成功完成");
// 或者使用对象方式
qmessagebox msgbox(this);
msgbox.setwindowtitle("父对象示例");
msgbox.settext("这个对话框会居中显示在父窗口");
msgbox.exec();
}设置默认按钮
qmessagebox msgbox;
msgbox.settext("请选择操作");
msgbox.setstandardbuttons(qmessagebox::yes | qmessagebox::no | qmessagebox::cancel);
msgbox.setdefaultbutton(qmessagebox::no); // 默认选中 no 按钮
msgbox.exec();自定义告警对话框(按钮居中显示)
void myselfboxwarn(const qstring & title, const qstring & content)
{
qmessagebox msgbox;
msgbox.setwindowtitle(title);
msgbox.settext(content);
msgbox.setstandardbuttons(qmessagebox::ok);
// 设置字体大小 - 使用样式表
msgbox.setstylesheet("qlabel{ font-size: 32px; }"
"qpushbutton{ font-size: 32px; width: 200px; height: 36px; }"
"qdialogbuttonbox {qproperty-centerbuttons: true;}");
msgbox.exec();
}自定义告警提示选择对话框(按钮居中显示)
qmessagebox msgbox;
msgbox.setwindowtitle(tr("manage"));
msgbox.settext(tr("set success. must be restarted to take effect."));
msgbox.setstandardbuttons(qmessagebox::yes | qmessagebox::no);
msgbox.setdefaultbutton(qmessagebox::yes);
// 设置样式表
msgbox.setstylesheet(
"qmessagebox {"
" font-size: 16px;"
" font-family: source han sans sc;"
"}"
"qmessagebox qlabel {"
" font-size: 16px;"
" min-width: 400px;"
" min-height: 60px;"
"}"
"qmessagebox qpushbutton {"
" font-size: 14px;"
" min-width: 100px;"
" min-height: 35px;"
" padding: 8px;"
"}"
"qdialogbuttonbox {"
" qproperty-centerbuttons: true;" // 使用 qt 属性
"}"
);
if(msgbox.exec() == qmessagebox::yes){
// 获取当前程序的路径和参数
qstring program = qapplication::applicationfilepath();
qstringlist arguments = qapplication::arguments();
// 启动新进程(startdetached 会在当前程序退出后运行)
qprocess::startdetached(program, arguments);
// 关闭当前程序
qapplication::quit();
}设置图标和样式
qmessagebox msgbox;
msgbox.setwindowtitle("样式化消息框");
msgbox.settext("<h3>html 格式文本</h3>");
msgbox.setinformativetext("支持 <b>粗体</b>、<i>斜体</i> 等 html 标签");
// 设置图标
msgbox.seticonpixmap(qpixmap(":/images/icon.png").scaled(64, 64));
// 设置样式
msgbox.setstylesheet(
"qmessagebox {"
" background-color: #f0f0f0;"
" font-size: 14px;"
"}"
"qmessagebox qpushbutton {"
" min-width: 80px;"
" min-height: 30px;"
"}"
);
msgbox.exec();4. 按钮(默认和自定义)
常用按钮类型
// 标准按钮组合 qmessagebox::ok // 确定 qmessagebox::open // 打开 qmessagebox::save // 保存 qmessagebox::cancel // 取消 qmessagebox::close // 关闭 qmessagebox::discard // 放弃 qmessagebox::apply // 应用 qmessagebox::reset // 重置 qmessagebox::restoredefaults // 恢复默认 qmessagebox::help // 帮助 qmessagebox::saveall // 全部保存 qmessagebox::yes // 是 qmessagebox::yestoall // 全是 qmessagebox::no // 否 qmessagebox::notoall // 全否 qmessagebox::abort // 中止 qmessagebox::retry // 重试 qmessagebox::ignore // 忽略
qmessagebox msgbox;
msgbox.setwindowtitle("按钮角色");
// 不同角色的按钮
msgbox.addbutton("确定", qmessagebox::acceptrole); // 接受操作
msgbox.addbutton("应用", qmessagebox::applyrole); // 应用更改
msgbox.addbutton("重置", qmessagebox::resetrole); // 重置设置
msgbox.addbutton("是", qmessagebox::yesrole); // 肯定回答
msgbox.addbutton("否", qmessagebox::norole); // 否定回答
msgbox.addbutton("拒绝", qmessagebox::rejectrole); // 拒绝操作
msgbox.addbutton("帮助", qmessagebox::helprole); // 请求帮助
msgbox.addbutton("自定义", qmessagebox::actionrole); // 自定义操作
msgbox.settext("不同角色的按钮示例");
msgbox.exec();带图标的自定义按钮
qmessagebox msgbox;
msgbox.setwindowtitle("带图标的按钮");
msgbox.settext("请选择操作:");
// 创建带图标的按钮
qpushbutton* okbutton = new qpushbutton(qicon(":/icons/ok.png"), "确定");
qpushbutton* cancelbutton = new qpushbutton(qicon(":/icons/cancel.png"), "取消");
qpushbutton* helpbutton = new qpushbutton(qicon(":/icons/help.png"), "帮助");
// 添加到消息框
msgbox.addbutton(okbutton, qmessagebox::acceptrole);
msgbox.addbutton(cancelbutton, qmessagebox::rejectrole);
msgbox.addbutton(helpbutton, qmessagebox::helprole);
msgbox.setdefaultbutton(okbutton);
msgbox.exec();
if (msgbox.clickedbutton() == okbutton) {
qdebug() << "确定";
} else if (msgbox.clickedbutton() == helpbutton) {
qmessagebox::information(&msgbox, "帮助", "这是帮助信息");
}5. 图标(默认和自定义)
默认图标
qmessagebox::information - 蓝色信息图标 qmessagebox::warning - 黄色警告图标 qmessagebox::critical - 红色错误图标 qmessagebox::question - 蓝色问号图标 qmessagebox::noicon - 无图标
#include <qmessagebox>
// 1. 无图标
qmessagebox msgbox;
msgbox.seticon(qmessagebox::noicon);
msgbox.settext("没有图标的消息框");
msgbox.exec();
// 2. 信息图标
qmessagebox::information(nullptr, "信息", "这是一个信息提示");
// 3. 警告图标
qmessagebox::warning(nullptr, "警告", "这是一个警告消息");
// 4. 错误图标
qmessagebox::critical(nullptr, "错误", "这是一个错误消息");
// 5. 询问图标
qmessagebox::question(nullptr, "询问", "这是一个询问消息");使用 seticon() 方法设置图标
qmessagebox msgbox;
msgbox.setwindowtitle("设置图标类型");
// 设置不同的图标类型
msgbox.seticon(qmessagebox::information); // 信息图标
// msgbox.seticon(qmessagebox::warning); // 警告图标
// msgbox.seticon(qmessagebox::critical); // 错误图标
// msgbox.seticon(qmessagebox::question); // 询问图标
msgbox.settext("使用 seticon() 方法设置图标");
msgbox.exec();自定义图标
1)使用 seticonpixmap()
qmessagebox msgbox;
msgbox.setwindowtitle("自定义图标");
msgbox.settext("使用自定义图标的消息框");
// 使用自定义图标替换默认图标
qpixmap custompixmap(":/images/my_icon.png"); // 从资源文件
// 或者: qpixmap custompixmap("c:/icons/custom.png"); // 从文件系统
// 缩放图标到合适大小
custompixmap = custompixmap.scaled(64, 64, qt::keepaspectratio, qt::smoothtransformation);
msgbox.seticonpixmap(custompixmap);
msgbox.exec();2)完全自定义图标的方法
qmessagebox msgbox;
msgbox.setwindowtitle("完全自定义");
// 重要:必须先设置为 noicon,否则自定义图标可能不显示
msgbox.seticon(qmessagebox::noicon);
// 然后设置自定义图标
qpixmap customicon(":/images/success.png");
customicon = customicon.scaled(48, 48, qt::keepaspectratio, qt::smoothtransformation);
msgbox.seticonpixmap(customicon);
msgbox.settext("操作成功完成!");
msgbox.exec();6. 长文本显示
自动换行(默认行为)
qmessagebox 会自动根据对话框宽度换行:
qmessagebox::information(this, "自动换行",
"这是一段很长的文本,qmessagebox 会自动根据对话框的宽度进行换行处理,"
"确保所有内容都能正确显示给用户,不需要手动添加换行符。");手动添加换行符
qmessagebox::information(this, "手动换行",
"第一行文本\n"
"第二行文本\n"
"第三行文本\n"
"这是最后一行");使用 html 标签控制格式
qmessagebox msgbox;
msgbox.setwindowtitle("html 格式");
msgbox.settext("<html>"
"<p>这是第一段文本,可以自动换行</p>"
"<p>这是第二段文本</p>"
"<p style='color: red;'>这是红色文本</p>"
"<ul>"
"<li>列表项 1</li>"
"<li>列表项 2</li>"
"<li>列表项 3</li>"
"</ul>"
"</html>");
msgbox.exec();设置固定宽度的消息框
qmessagebox msgbox;
msgbox.setwindowtitle("固定宽度");
msgbox.settext("这是一段很长的文本,我们将通过设置样式表来控制对话框的宽度,从而实现更好的换行效果。");
msgbox.setstylesheet("qmessagebox { min-width: 500px; }");
msgbox.exec();使用 settext 和 setinformativetext 组合
qmessagebox msgbox;
msgbox.setwindowtitle("组合文本");
msgbox.settext("主要信息:操作成功完成");
msgbox.setinformativetext("详细信息:文件已保存到指定位置,所有更改都已应用。"
"您可以继续其他操作或查看保存的文件。");
msgbox.exec();超长文本使用 setdetailedtext
qmessagebox msgbox;
msgbox.setwindowtitle("详细文本");
msgbox.settext("操作完成");
msgbox.setinformativetext("基本操作已执行成功");
msgbox.setdetailedtext("这是详细的执行日志:\n"
"1. 步骤一:初始化系统... 完成\n"
"2. 步骤二:加载配置文件... 完成\n"
"3. 步骤三:处理数据... 完成\n"
"4. 步骤四:保存结果... 完成\n"
"5. 步骤五:清理资源... 完成\n"
"所有操作执行成功,耗时 2.3 秒");
msgbox.exec();到此这篇关于qt中qmessagebox使用小结的文章就介绍到这了,更多相关qt qmessagebox使用内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论