information

QMessageBox::information(NULL, "Title", "Content",

QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

这是比较常用的一种用法,效果如下:

information原型:

StandardButton QMessageBox::information(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton) [static]

第一个参数是父控件指针

第二个参数是标题

第三个参数是内容

第四个参数是窗口里面要多少个按钮(默认为OK)

第五个参数指定按下Enter时使用的按钮。(默认为NoButton,此时QMessageBox会自动选择合适的默认值。)

示例1:

QMessageBox::information(NULL, "Title", "Content");

此时第四第五为默认参数,效果:

示例2:

QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No);

此时效果(与图1相同):

示例三:

QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No|

QMessageBox::Abort);

添加多个按钮用|运算符连接,效果:

按钮类型参考:

enum StandardButton {

// keep this in sync with QDialogButtonBox::StandardButton

NoButton = 0x00000000,

Ok = 0x00000400,

Save = 0x00000800,

SaveAll = 0x00001000,

Open = 0x00002000,

Yes = 0x00004000,

YesToAll = 0x00008000,

No = 0x00010000,

NoToAll = 0x00020000,

Abort = 0x00040000,

Retry = 0x00080000,

Ignore = 0x00100000,

Close = 0x00200000,

Cancel = 0x00400000,

Discard = 0x00800000,

Help = 0x01000000,

Apply = 0x02000000,

Reset = 0x04000000,

RestoreDefaults = 0x08000000,

FirstButton = Ok, // internal

LastButton = RestoreDefaults, // internal

YesAll = YesToAll, // obsolete

NoAll = NoToAll, // obsolete

Default = 0x00000100, // obsolete

Escape = 0x00000200, // obsolete

FlagMask = 0x00000300, // obsolete

ButtonMask = ~FlagMask // obsolete

};

会创建消息提示框后,我们怎么知道用户点了什么呢,看如下小例子:

QMessageBox:: StandardButton result= QMessageBox::information(NULL, "Title", "Content",QMessageBox::Yes|QMessageBox::No);

switch (result)

{

case QMessageBox::Yes:

qDebug()<

break;

case QMessageBox::No:

qDebug()<

break;

default:

break;

}

critical

critical adj. 关键的; 批评的,爱挑剔的; 严重的; 极重要的;

QMessageBox::critical(NULL, "critical", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

warning

QMessageBox::warning(NULL, "warning", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

question

QMessageBox::question(NULL, "question", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);

效果:

about

原型:static void about(QWidget *parent, const QString &title, const QString &text);

QMessageBox::about(NULL, "About", "by hjwblog.com");

效果:

使用QMessageBox对象

如果是自己创建的QMessageBox对象,而不是用上面的static函数

示例1:

void MainWindow::on_pushButton_clicked()

{

QMessageBox messageBox;

messageBox.show();

}

这里在按钮的clicked槽里面创建了一个QMessageBox,但是这样会出现消息框一闪而过。这是因为c++局部变量的生命周期结束了,QMessageBox messageBox是函数局部变量,函数结束后它的生命周期也结束了。

示例2:

void MainWindow::on_pushButton_clicked()

{

static QMessageBox messageBox;

messageBox.show();

}

效果:

这样就好理解了,c++函数里面的static变量在函数结束时不会被回收。

示例3:

void MainWindow::on_pushButton_clicked()

{

QMessageBox *messageBox=new QMessageBox;

messageBox->show();

}

这样写也能显示提示框,但是这样会内存泄漏。

示例4:

前面的用法都不太完美,我们希望能方便的显示提示框并且获取用户点击了哪个按钮。因为QMessageBox继承QDialog,而QDialog有一个神奇的函数exec(),调用这个函数后,消息循环会在这个函数里面进行更新,而调用它的函数是被“暂停”的,就是说等用户点击按钮后,调用exec()的函数才继续执行。

直接上代码:

void MainWindow::on_pushButton_clicked()

{

QMessageBox messageBox(QMessageBox::NoIcon,

"退出", "你确定要退出吗?",

QMessageBox::Yes | QMessageBox::No, NULL); ;

int result=messageBox.exec();

switch (result)

{

case QMessageBox::Yes:

qDebug()<

close();

break;

case QMessageBox::No:

qDebug()<

break;

default:

break;

}

}

上面的代码实现了点击按钮退出,并且在退出前确定的功能。

exec()的返回值和前面的information()一样,是整数(information()是枚举)。可以通过返回值来确定用户点击了哪个按钮。

QMessageBox对象调用exec()函数能实现与前面的几个静态函数相似的功能。

qt 关闭对话框 提醒_qt5信息提示框QMessageBox用法相关推荐

  1. DELMIA软件:文本信息提示框功能介绍与使用方法

    目录 概述 文本信息创建 修改文本信息 增加文本信息 删除文本信息 仿真运行 本文已经首发在个人微信公众号:工业机器人仿真与编程(微信号:IndRobSim),欢迎关注! 概述 DELMIA软件在机器 ...

  2. BootStrap笔记-信息提示框的使用

    程序运行截图如下: 源码如下: <!DOCTYPE html> <html lang="en"> <head><meta charset= ...

  3. WEB前端网页设计-Bootstrap4 信息提示框

    目录 提示框添加链接 关闭提示框 提示框动画 Bootstrap 4 可以很容易实现信息提示框. 提示框可以使用 .alert 类, 后面加上 .alert-success, .alert-info, ...

  4. 1.2文字排版、颜色、表格、图像形状、Jumbotron、信息提示框、按钮、按钮组、徽章、加载效果、分页、列表组、卡片、下拉菜单、折叠

    Bootstrap 5 默认设置 Bootstrap 5 默认的 font-size 为 16px, line-height 为 1.5. 此外,所有的 <p> 元素 margin-top ...

  5. Bootstrap 信息提示框

    一.Bootstrap 信息提示框 1.1 基本信息提示框 提示框可以使用 .alert 类, 后面加上 .alert-success, .alert-info, .alert-warning, .a ...

  6. 爬虫训练场项目前端之 Bootstrap 信息提示框,按钮与按钮组,徽章,进度条

    爬虫训练场项目前端之 Bootstrap 信息提示框,按钮与按钮组,徽章,进度条 Bootstrap5 信息提示框 Bootstrap 5 按钮和按钮组 Bootstrap 5 徽章 进度条 Boot ...

  7. CSS特效十:信息提示框

    今天来讲一个信息提示框,可以在上下左右四个方向展示,先给大家看看效果图(文末有彩蛋!!!): 其中的重点就是一个尖角的展示: 我们可以用CSS 伪元素 ::after 及 content 属性为提示工 ...

  8. Framework7中弹出确认信息提示框,取消/确定

    使用Framework7框架进行开发时,如果需要弹出确认信息提示框之后根据用户选择再进行后续操作,相关代码如下: myApp.confirm('确定删除此订单吗?', '系统提示',     func ...

  9. java提示框easyui风格_[Java教程]jQuery EasyUI 提示框(Messager)用法

    [Java教程]jQuery EasyUI 提示框(Messager)用法 0 2013-10-10 19:00:06 jQuery EasyUI 提示框(Messager)不仅强大,而且也不用任何的 ...

最新文章

  1. python解释器pypy
  2. Educational Codeforces Round 12 D. Simple Subset 最大团
  3. android 设置PopupWindow的显示大小
  4. 面试心得与总结——BAT、网易、蘑菇街
  5. Python进阶(5)_进程与线程之协程、I/O模型
  6. centOS 6环境下安装R-3.3.2及Rstudio-server
  7. python抢货程序_写个Python程序上下班抢个顺风单
  8. 解决Establishing SSL connection without servers identity verification is not recommended问题
  9. 让你的微信私人账号也具备公众账号的 关键字回复功能
  10. SAP GUI 安全性 下载文件
  11. AutoCAD2000 DWG 格式 section location部分(简述)
  12. acwing-2240. 餐饮(最大流+拆点)
  13. Mysql(免安装版)安装、配置与卸载
  14. Java响应式编程基础-响应式流
  15. 订单管理系统(OMS)搭建实战 - 低代码拖拽定制订单管理系统
  16. android studio记账,Android Studio——记账本以及图表可视化实现
  17. 一文读懂麦克风典型应用电路
  18. 换手率研究精解(转载)
  19. ddmmyy日期格式是多少_英语中关于年月日以及数字
  20. 985、211学校分为哪八个档次?

热门文章

  1. EF Code First Migrations数据库迁移
  2. 基于syslog+logstash+elasticSearch+redis日志分析系统实现
  3. css限制单行文本输入,超出部分使用...替换
  4. 阿里云中间件团队首次解密企业级分布式应用服务EDAS
  5. client intended to send too large body
  6. Android开发小知识点(二)
  7. linux svn 常用命令
  8. 《大数据,小时代,向移动互联网迁徙-2012上半年移动互联网数据分享》_DCCI
  9. 我是如何超越PPG的(摘自:IT经理世界;作者:李黎)
  10. asp.net生成高质量缩略图通用函数(c#代码),支持多种生成方式