嵌入式养成计划-44----QT--消息对话框(QMessageBox)--字体对话框--颜色对话框--文件对话框

一百一十三、消息对话框 (QMessageBox)

  • 消息对话框给用户提供一个交互式的弹窗,
  • 该类提供两种实现版本,
    • 基于属性版本
    • 基于静态成员函数版本

  • 基于属性版本
    • 需要用消息对话框这样的类 实例化对象
      用该对象调用类里的相关成员函数进行相关设置
      需要调用exec()函数执行对话框
      有参构造:
      QMessageBox::QMessageBox(    //有参构造的函数名
          QMessageBox::Icon icon,  //消息对话框里的图标
          const QString &title,     //消息对话框的标题
          const QString &text,      //对话框显示文本
          QMessageBox::StandardButtons buttons = NoButton, //提供消息对话框按钮
          QWidget *parent = nullptr)  //指定父组件
      
      参数1:
      	QMessageBox::NoIcon  //无图标
      	QMessageBox::Question  //问题图标
      	QMessageBox::Information  //信息图标
      	QMessageBox::Warning  //警告图标
      	QMessageBox::Critical  //错误图标
      
      参数4:
      	QMessageBox::Ok  //OK按钮
      	QMessageBox::Open  //打开按钮
      	QMessageBox::Save
      	QMessageBox::Cancel
      	QMessageBox::Close
      	QMessageBox::Discard
      
      举个例子:
        QMessageBox msgBox;
        msgBox.setText("The document has been modified.");
        msgBox.setInformativeText("Do you want to save your changes?");
        msgBox.setStandardButtons(QMessageBox::Save | QMessageBox::Discard | QMessageBox::Cancel);
        msgBox.setDefaultButton(QMessageBox::Save);
        int ret = msgBox.exec();
      
    • ui界面:
      嵌入式养成计划-44----QT--消息对话框(QMessageBox)--字体对话框--颜色对话框--文件对话框_第1张图片
    • 示例 :
      //警告按钮对应的槽函数处理
      void Widget::on_pushButton_clicked()
      {
          //用消息对话框这样的类 实例化一个对象
          QMessageBox msg(
                      QMessageBox::Warning, //图标
                      "警告",                  //对话框标题
                      "你给我小心点",     //对话框文本
                      QMessageBox::Yes | QMessageBox::No, //提供按钮
                      this);  //父对象
          //要用exec()函数执行对话框
          int ret = msg.exec();
          //对用户选中的按钮进行判断
          if(ret == QMessageBox::Yes)
          {
              qDebug() <<"好哈哈哈";
          }
          else
          {
              qDebug() <<"别这样。。";
          }
      }
      
  • 基于静态成员函数消息对话框的弹出
    • 不需要实例化对象了,直接调用该类里的静态成员函数,
    • 提供了四个:critical、information、warning、questio
    • 以question为例:
      [static] QMessageBox::StandardButton  //函数返回值类型,用户选中的按钮
      		    QMessageBox::question(     //函数名
      		        QWidget *parent,   //指定父对象
      		        const QString &title, //对话框标题
      		        const QString &text,  //对话框文本
      		        QMessageBox::StandardButtons buttons = StandardButtons(Yes | No)) //默认提供了一对按钮
      
    • 示例 :
      //问题按钮2对应的槽函数处理
      void Widget::on_pushButton_5_clicked()
      {
          //直接调用静态成员函数
          int ret = QMessageBox::question(this,
                                "问题",
                                "天亮了吗",
                                QMessageBox::Yes | QMessageBox::No);
          //判断用户选的按钮
          if(ret==QMessageBox::Yes)
          {
              qDebug() <<"亮了";
          }
          else
          {
              qDebug()<<"还没";
          }
      }
      

一百一十四、字体对话框、颜色对话框、文件对话框

114.1 字体对话框 (QFontDialog)

  • 该类给用户提供了一个字体对话框,可以直接使用该类中静态成员函数 getFont() 弹出字体对话框。
    • getFont() 函数 :如果想使用该函数 需要的头文件: QFontDialog、 QFont
    [static] QFont  //函数返回值类型  返回是用户选中的字体
        QFontDialog::getFont(  //函数名
            bool *ok,     //判断用户是否选中字体
            const QFont &initial,  //初始字体
            QWidget *parent = nullptr,  //父对象
            const QString &title = QString()) //对话框的标题  
    参数2QFont::QFont(const QString &family, 
    		int pointSize = -1, 
    		int weight = -1, 
    		bool italic = false)
    
    • ui界面
      嵌入式养成计划-44----QT--消息对话框(QMessageBox)--字体对话框--颜色对话框--文件对话框_第2张图片
    • 示例 :
      //字体按钮对应的槽函数
      void Widget::on_fontBtn_clicked()
      {
          bool ok; //判断用户是否选中了字体
          //调用静态成员函数弹出对话框
          QFont f = QFontDialog::getFont(&ok, //判断用户是否选中了字体
                               QFont("隶书",8,10,false),//初始字体
                               this, //父对象
                               "字体");//标题
          //判断ok,如果用户没有选中字体,那么ok是false,否则是true
          if(ok)
          {
              //说明用户选中了字体
              //将用户选中的字体设置文本中
              //ui->textEdit->setFont(f); //让文本全部设置成该字体
              ui->textEdit->setCurrentFont(f);
          }
          else
          {
              //说明用户没有选字体
              QMessageBox::information(this,"提示","没有选字体");
          }
      }
      

114.2 颜色对话框 (QColorDialog)

  • 该类提供一个颜色对话框给用户使用,直接使用类里静态成员函数 getColor() 直接弹出颜色对话框
    • getColor() : 需要两个头文件:QColorDialog 、QColor
      [static] QColor  //函数返回值类型 返回的是用户选中的颜色
          QColorDialog::getColor( //函数名
          const QColor &initial = Qt::white, //初始颜色
          QWidget *parent = nullptr, //父对象
          const QString &title = QString()) //颜色对话框标题
      参数1QColor::QColor(int r, int g, int b, int a = ...)
      
    • 示例 :
      //颜色按钮对应的槽函数处理
      void Widget::on_colorBtn_clicked()
      {
         //直接调用颜色对话框的静态成员函数
          QColor c = QColorDialog::getColor(QColor(0,255,255),
                                 this,
                                 "颜色对话框");
          if(c.isValid()) //判断是否是有效颜色
          {
              //说明用户选中的是有效颜色
              //将选中的颜色设置到文本中
              //ui->textEdit->setTextColor(c); 设置前景色
              ui->textEdit->setTextBackgroundColor(c);//背景色
          }
          else
          {
              //说明用户选中的是无效颜色
              QMessageBox::information(this,"提示信息","选中的是无效颜色");
          }
      }
      

114.3 文件对话框 (QFileDialog)

  • 该类提供了一个文件对话框,用于给用户提供文件路径,

  • 类里有两个静态成员函数 getOpenFileName()getSaveFileName() 弹出文件对话框

    • 都需要包含 QFileDialog、QFile 这俩头文件
    • getOpenFileName()
      [static] QStringList //函数返回值类型  返回的是打开文件的路径
          QFileDialog::getOpenFileNames( //函数名
          QWidget *parent = nullptr,  //父对象
          const QString &caption = QString(), //文件对话框标题 
          const QString &dir = QString(),  //起始位置
          const QString &filter = QString(), //过滤器
          QString *selectedFilter = nullptr) //选中的过滤器
      
    • 举个例子:
      QStringList files = QFileDialog::getOpenFileNames(
                            this,
                            "Select one or more files to open",
                            "/home",
                            "Images (*.png *.xpm *.jpg)");
      
    • getSaveFileName()
      [static] QString 
          QFileDialog::getSaveFileName(
          QWidget *parent = nullptr, 
          const QString &caption = QString(), 
          const QString &dir = QString(), 
          const QString &filter = QString(), 
          QString *selectedFilter = nullptr, 
          QFileDialog::Options options = Options())
      
  • 读文件

    //打开按钮对应的槽函数实现
    void Widget::on_openBtn_clicked()
    {
       QString fileName = QFileDialog::getOpenFileName(this, //父对象
                                    "打开文件", //标题
                                    "./",   //起始位置
                                    "All(*.*);; Img(*.png *.jpg *.gif);; 文本(*.txt)");//过滤器
       qDebug() <<fileName;
       //实例化一个文件的对象
       QFile file(fileName);
       
       if(!file.exists())
       {
           return;
       }
       //打开文件
       if(!file.open(QFile::ReadWrite)) //判断是否能成功打开
       {
           return;
       }
       //读取文件内容
       QByteArray msg = file.readAll();
       //关闭文件
       file.close();
       //将读取的内容放入textEdit上
       //ui->textEdit->setText(QString::fromLocal8Bit(msg));
       ui->textEdit->setText(msg);
    }
    
  • 写文件

    //保存按钮对应的槽函数
    void Widget::on_saveBtn_clicked()
    {
        QString fileName = QFileDialog::getSaveFileName(this);
        //实例化一个文件类对象
        QFile file(fileName);
        //打开文件
        file.open(QFile::WriteOnly);
        //获取textEdit上的内容
        QString msg = ui->textEdit->toPlainText();
        //写入数据
        file.write(msg.toLocal8Bit());
        //关闭文件
        file.close();
    }
    

114.4 qt中文件读写

  • 用到的类是 : QFile
  • 步骤 :
    1. 用QFile实例化一个对象,可以给该对象一个文件路径
    2. 打开文件 需要写上打开方式 读、写
    3. 读取数据 read() readLine() readAll()
    4. 写入数据 write()
    5. 关闭文件 close()

小作业 完善登录框,并跳转到下一界面

1. 点击登录对话框,如果账号和密码匹配,则弹出信息对话框,给出提示”登录成功“,
	提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到新的界面中
	
2. 如果账号和密码不匹配,弹出错误对话框,给出信息”账号和密码不匹配,是否重新登录“,
	并提供两个按钮Yes|No,
	用户点击Yes后,清除密码框中的内容,继续让用户进行登录,
	如果用户点击No按钮,则直接关闭登录界面
	
3. 如果用户点击取消按钮,则弹出一个问题对话框,给出信息”您是否确定要退出登录?“,
	并给出两个按钮Yes|No,
	用户点击Yes后,关闭登录界面,
	用户点击No后,关闭对话框,继续执行登录功能
	
要求:对话框:基于属性版和基于静态成员函数版至少各用一个
要求:尽量每行代码都有注释

我写的

login.h

#ifndef LOGIN_H
#define LOGIN_H

#include 
#include 
#include 
#include 
#include 

QT_BEGIN_NAMESPACE
namespace Ui { class Login; }
QT_END_NAMESPACE

class Login : public QWidget
{
    Q_OBJECT

public:
    Login(QWidget *parent = nullptr);
    ~Login();

signals:
    //  跳转到下一界面的信号
    void jump();

//public slots:
    //  关闭登录窗口的槽,已注释掉
//    void close_window_slot();

private slots:
    //  点击取消按钮的槽函数
    void on_cencelBtn_clicked();

private:
    Ui::Login *ui;
};
#endif // LOGIN_H

second.h

#ifndef SECOND_H
#define SECOND_H

#include 

namespace Ui {
class Second;
}

class Second : public QWidget
{
    Q_OBJECT

public:
    explicit Second(QWidget *parent = nullptr);
    ~Second();

public slots:
    //  打开第二界面的槽函数声明
    void jumpSlot();

private slots:
    //  关闭第二界面的槽函数声明
    void on_closeSecondWindow_clicked();

private:
    Ui::Second *ui;
};

#endif // SECOND_H

login.cpp

#include "login.h"
#include "ui_login.h"

Login::Login(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Login)
{
    ui->setupUi(this);
    //  上半部分的图画
    ui->loginLab->setPixmap(QPixmap(":/pictrue/qq_login.gif"));
    //  设置上半部分图画为自适应大小
    ui->loginLab->setScaledContents(true);

    //  设置窗口左上角的企鹅和QQ
    this->setWindowTitle("QQ");
    this->setWindowIcon(QIcon(":/pictrue/qie.png"));

    //  设置输入框前面的企鹅和密码图片
    ui->unameLab->setPixmap(QPixmap(":/pictrue/qie.png"));
    ui->passwdLab->setPixmap(QPixmap(":/pictrue/passwd.jpg"));
    //  设置密码输入形式
    ui->passwdEdit->setEchoMode(QLineEdit::Password);
    //  设置头像
    ui->touxiang->setPixmap(QPixmap(":/pictrue/touxiang.ico"));
    //  设置右下角的二维码
    ui->ewm->setPixmap(QPixmap(":/pictrue/eweima.png"));

    //  用 QT4 的方式连接自定义的槽函数,用于让 取消按钮 去 关闭窗口
//    connect(ui->cencelBtn, SIGNAL(clicked()), this, SLOT(close_window_slot()));

    //  用 QT5 的方式 让登录按钮 连接自定义的槽函数
    connect(ui->loginBtn,&QPushButton::clicked,[&](){
        //  如果用户名为"admin"且密码为"123456"
        if(ui->unameEdit->text() == "admin" && ui->passwdEdit->text() == "123456"){
            //  用静态成员函数的方式打开(提示信息)消息对话框
            int res = QMessageBox::information(this,                //  父对象
                                               "登录成功",           //  标头
                                               "恭喜你,登录成功",     //  提示信息
                                               QMessageBox::Ok);    //  按钮
            //  如果在消息对话框中点击的是Ok
            if(res==QMessageBox::Ok){
                //  关闭当前窗口(登录窗口)并发射jump信号
                this->close();
                emit jump();
            }
        }
        //  如果用户名和密码不是"admin"和"123456"
        else
        {
            //  用定义对象的方式打开(错误提示)消息对话框
            QMessageBox msg(QMessageBox::Critical,                //  错误提示方式
                            "登录失败",                            //  标头
                            "账号和密码不匹配,是否重新登陆",          //  提示信息
                            QMessageBox::Yes | QMessageBox::No,   //  按钮
                            this);  //  父对象
            //  接收消息对话框的点击结果
            int res = msg.exec();
            //  如果点击的是  Yes,则清空密码输入框
            if(res==QMessageBox::Yes){
                ui->passwdEdit->clear();
            }else if(res==QMessageBox::No){//  如果点击的是  No,则关闭窗口
                this->close();
            }
        }
    });

}

Login::~Login()
{
    delete ui;
}

//  关闭登录界面的槽函数实现,已注释
//void Login::close_window_slot()
//{
//    this->close();
//}

//  点击取消按钮的槽函数实现
void Login::on_cencelBtn_clicked()
{
    //  弹出(询问)消息对话框
    int res = QMessageBox::question(this,"提示","是否取消登录?");
    //  如果点击的是Yes,则关闭当前界面(登录界面),点击其他则只是关闭这个弹出的(询问)消息对话框
    if(res==QMessageBox::Yes){
        this->close();
    }
}

second.cpp

#include "second.h"
#include "ui_second.h"

Second::Second(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Second)
{
    ui->setupUi(this);
}

Second::~Second()
{
    delete ui;
}

//  关闭第二界面的槽函数实现
void Second::on_closeSecondWindow_clicked()
{
    this->close();
}
//  打开第二界面的槽函数实现
void Second::jumpSlot(){
    this->show();
}

main.cpp

#include "login.h"
#include "second.h"

#include 

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Login w;
    w.show();

    //  创建第二界面对象
    Second s;
    //  将登录界面的 jump 信号,与第二界面的 jumpSlot 槽函数绑在一起
    QObject::connect(&w, &Login::jump, &s, &Second::jumpSlot);
    return a.exec();
}

你可能感兴趣的:(QT,qt,开发语言,c++)