当前位置:   article > 正文

QT—5种标准对话框使用详解_qt打开文件选择对话框

qt打开文件选择对话框

对话框是 GUI 程序中不可或缺的组成部分。一些不适合在主窗口实现的功能组件都必须放在对话框中设置。对话框通常会是一个顶层窗口,出现在程序最上层,用于实现短期任务或者简洁的用户交互。所谓标准对话框,是 Qt 内置的一系列对话框,用于简化开发。事实上,有很多对话框都是通用的,比如打开文件、设置颜色、打印设置等。这些对话框在所有程序中几乎相同。

Qt常用的内置对话框有QFileDialog、QColorDialog、QFontDialog、QInputDialog和QMessageBox。下面对这些对话框做一些简单示例。

对话框类

说明

静态函数

函数说明

QFileDialog

文件对话框

getOpenFileName()

选择打开一个文件

getOpenFileNames()

 选择打开多个文件

getSaveFileName()

选择保存一个文件

getExistingDirectory()

选择一个己有的目录

getOpenFileUrl()

选择打幵一个文件,可选择远程网络文件

QColorDialog

颜色对话框

getColor()

选择颜色

QFontDialog

字体对话框

QFont getFont()

选择字体

QInputDialog

输入对话框

getText()

输入单行文字  

getlnt()

输入整数

getDouble()

输入浮点数

getltem()

从一个下拉列表框中选择输入

getMultiLineText()

输入多行字符串

QMessageBox

消息框

information()

信息提示对话框

question()

询问并获取是否确认的对话框

waming()

警告信息提示对话框

critical()

错误信息提示对话框

about()

设置自定义信息的关于对话框

aboutQt()

关于Qt的对话框

QFileDialog文件对话框 

文件对话框可以通过调用QFileDialog::getOpenFileName方法实现,方法的第一个参数指定窗体的父窗体、第二个参数指定窗体的标题、第三个参数指定窗体的打开目录、第四个参数用于限定打开的文件类型,有多个类型时中间用;;隔开。下面程序演示了当用户点击按钮后会弹出文件对话框,之后将用户选择的文件路劲显示在文本框中。

  1. //文件对话框
  2. void Dialog::ShowFileDlg()
  3. {
  4. //打开文件对话框
  5. //函数返回打开的路径
  6. QString sPath = QFileDialog::getOpenFileName(
  7. this,//指定父窗口
  8. "标准文件对话框",//打开文件对话框的标题
  9. ".",//打开目录,"." 表示当前目录
  10. "C++ files(*.cpp);;"
  11. "C files(*.c);;"
  12. "Header files(*.h)"//设置文件过滤器,有多个条件时中间以两个;;隔开
  13. );
  14. m_fileEdit->setText(sPath);
  15. }

m_fileEdit是一个QLineEdit部件名,用来显示用户打开文件的路径。 

 QColorDialog颜色对话框

颜色对话框可以通过调用QColorDialog::getColor方法实现,方法的第一个参数表示默认选择的颜色。该方法会返回一个颜色类。

  1. void Dialog::ShowColorDlg()
  2. {
  3. QColor color = QColorDialog::getColor(
  4. Qt::yellow//默认选择的颜色
  5. );
  6. //判断颜色选择是否合法
  7. if(color.isValid()){
  8. //设置边宽颜色
  9. m_colorFrame->setPalette(QPalette(color));
  10. }
  11. }

 m_colorFram是一个QFrame类型,用来展示用户选择的颜色

QFontDialog字体对话框

字体对话框可以通过调用QFontDialog::getFont方法实现,该方法需要传入一个bool类型的参数用来接收函数是否成功执行,方法会返回一个字体字体类。

  1. //字体对话框
  2. void Dialog::ShowFontDlg()
  3. {
  4. bool ok;//接收函数是否执行成功
  5. QFont font = QFontDialog::getFont(
  6. &ok//接收函数是否执行成功
  7. );
  8. if(ok){
  9. //设置字体
  10. m_fontEdit->setFont(font);
  11. }
  12. }

 m_fontEdit是一个QLineEdit类型,用来展示用户选择的字体效果

QInputDialog输入对话框

设置姓名,可以调用的是QInputDialog::getText( )方法用来获取输入的单行文本。方法的第一个参数指定父窗体,第二个参数指定对话框的标题,第三个参数指定对话框显示的内容,第四个参数纸档输入框的模式,第五个参数指定默认值,第六个参数是一个bool类型用来接收函数是否执行成功。

  1. //文本输入对话框
  2. void InputDlg::editName(){
  3. bool ok;
  4. QString strName = QInputDialog::getText(
  5. this,//指定父窗体
  6. "标准文本输入对话框",//指定对话框标题
  7. "请编辑姓名",//提示字符串
  8. QLineEdit::Normal,//输入框显示模式
  9. m_nameLabel->text(),//输入框的默认文本
  10. &ok//接收函数调用是否成功
  11. //最后一个参数表示窗体风格,这里采用默认的
  12. );
  13. if(ok && !strName.isEmpty()){
  14. m_nameLabel->setText(strName);
  15. }
  16. }

设置性别,可以调用的是QInputDialog::getItem( ) 方法用来获取用户从下拉列表选择的值。QInputDialog第三个参数用来设置下拉列表框,要传入一个QStringList类型的值。

  1. //条目输入对话框
  2. void InputDlg::editSex(){
  3. QStringList sexList;
  4. bool ok;
  5. sexList<<"男"<<"女"<<"未知";
  6. //可选项是QString 类型,接收也是QString
  7. QString strSex = QInputDialog::getItem(
  8. this,
  9. "标准条目输入对话框",//指定对话框标题
  10. "请选择性别", //指定显示内容
  11. sexList,//设置可选项,可选项是一个QStringList类型
  12. 0,//设置默认选选项
  13. false,//是否可编辑
  14. &ok//接收函数是否调用成功
  15. );
  16. if(ok && !strSex.isEmpty()){
  17. m_sexLabel->setText(strSex);
  18. }
  19. }

设置年龄,可以调用QInputDialog::getInt方法用来获取用户填入的整数值。getInt方法的第四个参数和第五个参数分别用来设置整数的最小值和最大值,第六个参数用来设置步长,即点击增加按钮时每次增加的值。

  1. void InputDlg::editAge(){
  2. bool ok;
  3. int age = QInputDialog::getInt(
  4. this,
  5. "标注int数据类型输入对话框",//对话框标题
  6. "请编辑年龄",//对话框显示的内容
  7. m_ageLabel->text().toInt(),//默认值
  8. 0,//最小值
  9. 120,//最大值
  10. 1,//步长
  11. &ok//接收函数是否调用成功
  12. );
  13. if(ok){
  14. m_ageLabel->setText(QString("%1").arg(age));
  15. }
  16. }

设置分数,可以调用QInputDialog::getDouble方法用来获取用户填入的浮点数值。getDouble方法的第四个参数和第五个参数分别用来设置整数的最小值和最大值,第六个参数用来设置精度,即点数据的小数位。

  1. void InputDlg::editScore(){
  2. bool ok;
  3. double score = QInputDialog::getDouble(
  4. this,//设置父窗体
  5. "标准double数据类型输入对话框",//对话框标题
  6. "请编辑分数",//对话框显示的内容
  7. m_scoreLabel->text().toDouble(),//默认值
  8. 0,//最小值
  9. 100,//最大值
  10. 1,//精度
  11. &ok//接收函数是否执行成功
  12. );
  13. if(ok){
  14. m_scoreLabel->setText(QString::number(score));
  15. }
  16. }

QMessageBox消息框

问题消息框,可以调用QMessageBox::question() 显示问题消息框,问题消息框可设置要显示的按钮,方法会返回一个枚举类型表示用户所点击的按钮。这里设置的是“确定”和“取消”按钮。

  1. void MsgBoxDlg::showQuestionMsgDlg() {
  2. m_tipLabel->setText("问题消息框");
  3. int res = QMessageBox::question(
  4. this,//指定父窗体
  5. "问题消息框",//指定标题
  6. "已打开问题消息框,是否关闭?",//显示的文本
  7. QMessageBox::Ok|QMessageBox::Cancel,//标注按钮
  8. QMessageBox::Ok//默认选择的按钮
  9. );
  10. switch (res) {
  11. case QMessageBox::Ok:
  12. m_tipLabel->setText("问题消息框 - 确定");
  13. break;
  14. case QMessageBox::Cancel:
  15. m_tipLabel->setText("问题消息框 - 取消");
  16. break;
  17. default:
  18. break;
  19. }
  20. }

信息消息框,可以调用QMessageBox::information( )方法实现,信息消息框的作用是给用户展示一段消息,无需用户做出操作,函数参数也比较简单。

  1. void MsgBoxDlg::showInformationMsgDlg() {
  2. m_tipLabel->setText("信息消息框");
  3. QMessageBox::information(
  4. this,//父窗体
  5. "信息提示框",//标题
  6. "这是个信息提示框"//文本内容
  7. );
  8. }

警告消息框,可以调用QMessageBox::waring方法,警告消息框同样可以设置消息框的按钮,方法会一个枚举类型表示用户的操作。这里设置的是“保存”、“忽视”和“取消”按钮。

  1. void MsgBoxDlg::showWarningMsgDlg() {
  2. m_tipLabel->setText("警告消息框");
  3. int res = QMessageBox::warning(
  4. this,//父窗体
  5. "警告消息框",//标题
  6. "有为保存的文件",//警告内容
  7. QMessageBox::Save|QMessageBox::Discard|QMessageBox::Cancel,
  8. QMessageBox::Save//默认选择的按钮
  9. );
  10. switch (res) {
  11. case QMessageBox::Save:
  12. m_tipLabel->setText("警告提示框 - 保存");
  13. break;
  14. case QMessageBox::Discard:
  15. m_tipLabel->setText("警告提示框 - 忽视");
  16. break;
  17. case QMessageBox::Cancel:
  18. m_tipLabel->setText("警告提示框 - 取消");
  19. break;
  20. default:
  21. break;
  22. }
  23. }

错误消息框,可以调用QMessageBox::critical方法,错误消息框也相当于一种消息提醒,会比信息消息框的效果显目,调用方法和信息消息框类似。

  1. void MsgBoxDlg::showCriticalMsgDlg() {
  2. m_tipLabel->setText("错误消息框");
  3. QMessageBox::critical(
  4. this,//父窗体
  5. "错误消息框",//标题
  6. "发生重大错误!!"//显示内容
  7. );
  8. }

关于消息框,调用QMessageBox::about方法,关于消息框也是一种消息提醒,调用方法与信息消息框类似。

  1. void MsgBoxDlg::showAboutMsgDlg() {
  2. m_tipLabel->setText("关于消息框");
  3. QMessageBox::about(
  4. this,//父窗体
  5. "关于消息框",//标题
  6. "这是个关于休斯顿的信息"//显示内容
  7. );
  8. }

关于QT消息框,调用QMessageBox::aboutQt方法,关于QT消息框会弹出一个有关QT的信息。其他功能暂无。

  1. void MsgBoxDlg::showAboutQtMsgDlg() {
  2. m_tipLabel->setText("关于QT消息框");
  3. QMessageBox::aboutQt(
  4. this,//父窗体
  5. "关于QT消息框"//标题
  6. );
  7. }

自定义消息框

自定义消息框设置了一个图标和三个按钮,其中两个按钮采用自定义形式,另一个按钮采用标准形式,当用户点击按钮后,从对话框中获取用户点击的按钮,然后显示出对应的文本。

  1. //自定义消息框
  2. void Dialog::ShowCustomDlg() {
  3. m_customLabel->setText("自定义消息框");
  4. QMessageBox customMsgBox;
  5. customMsgBox.setWindowTitle("自定义消息框");
  6. //返回一个按钮对象
  7. //自定义按钮
  8. QPushButton *yes = customMsgBox.addButton(
  9. "真的吗?",//指定文本
  10. QMessageBox::ActionRole//指定角色
  11. );
  12. //自定义按钮
  13. QPushButton *no = customMsgBox.addButton(
  14. "假的",//指定文本
  15. QMessageBox::ActionRole//指定角色
  16. );
  17. //标准按钮
  18. QPushButton *cancel = customMsgBox.addButton(
  19. QMessageBox::Cancel);
  20. //设置图标
  21. customMsgBox.setIconPixmap(QPixmap("msg.jpg"));
  22. customMsgBox.exec();
  23. if(customMsgBox.clickedButton()==yes){
  24. m_customLabel->setText("点了“真的吗?”");
  25. }else if(customMsgBox.clickedButton()==no){
  26. m_customLabel->setText("点了“假的 ”");
  27. }else if(customMsgBox.clickedButton()==cancel){
  28. m_customLabel->setText("点了“取消”");
  29. }
  30. }

 追风赶月莫停留,平芜尽处是春山!!!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/91214
推荐阅读
相关标签
  

闽ICP备14008679号