Qt窗口与对话框

目录

Qt窗口

1.菜单栏

2.工具栏

3.状态栏

4.滑动窗口

QT对话框

1.基础对话框QDiaog

创建新的ui文件

模态对话框与非模态对话框

[2.消息对话框 QMessageBox](#2.消息对话框 QMessageBox)

3.QColorDialog

4.QFileDialog文件对话框

5.QFontDialog

6.QInputDialog

Qt窗口

前言:之前以上的代码我们都是创建项目基于QWidget(控件)的项目,实际上在开发过程中使用更多的是QMainWindow.QMainWindow的布局如下:

最上层是一个窗口的标题,下面是一个菜单栏,在下层是一个工具栏,在下层就是一个子窗口(铆接部件),最中间的就是中央控件。最下层有一个状态栏。通过这种方式我们的窗口就更加丰富了。接下来就逐一讲解每个部分。

当我们创建项目,生成的代码好像和QWidget的大差不差,进入QT Designer观察好像也差不多,但当我们仔细观察右边的对象树,我们就会发现,不仅仅有一个主窗口,还多了其他部件(菜单栏,状态栏),这些部件在项目创建的时候就被自带了,这里将所有组件进行介绍:

1.菜单栏

我们可以看到在新建的项目中的ui的界面中的有一个请输入,这个其实就是一个菜单,我们可以选中输入,还可以添加菜单项,还可以添加菜单。这就是MianWindow的布局,上来就是菜单,最上层就是标题。
Qt 中的菜单栏是通过 QMenuBar 这个类来实现的。⼀个主窗⼝最多只有⼀个菜单栏。位于主窗⼝顶部、主窗⼝标题栏下⾯。 一个菜单栏中可以包含多个菜单. 每次菜单中可以包含多个菜单项.

添加菜单以及菜单项

 //创建菜单栏
    QMenuBar * menubar=new QMenuBar();
    this->setMenuBar(menubar);
    //创建菜单
    QMenu * menu1=new QMenu("文件(&F)");
    QMenu * menu2=new QMenu("编辑(&E)");
    QMenu * menu3=new QMenu("视图(&V)");
    QMenu * menu4=new QMenu("构建(&B)");//并且设置简易快捷键alt+快捷键,淡然使用shrotcut创建快捷键也可以
    menubar->addMenu(menu1);
    menubar->addMenu(menu2);
    menubar->addMenu(menu3);
    menubar->addMenu(menu4);
    //添加菜单项
    QAction*  action1=new QAction("新建");
    QAction * action2=new QAction("打开");
    QAction * action3=new QAction("保存");
    QAction * action4=new QAction("另存为");
    QAction * action5=new QAction("退出");
    menu1->addAction(action1);
    menu1->addAction(action2);
    menu1->addAction(action3);
    menu1->addAction(action4);
    menu1->addAction(action5);
   //给具体Action添加信号槽,或者给menu添加信号槽
    connect(action1,&QAction::triggered,this,&MainWindow::handle);

给菜单添加子菜单

    //QMenuBar可以addMenu代表菜单,给QMenu菜单对象也可以addMenu。即菜单的子菜单
    QMenu*  test1=new QMenu("新建");
    QMenu * test2=new QMenu("打开");
    menu2->addMenu(test1);
    menu2->addMenu(test2);

此外我们还可以添加分割线,使用QMenu中的addseprator这样的函数,将我们的菜单项分成几部分。

    //设置分割并且添加图标。
    menu1->addSeparator();
    //对菜单项行图标i的设置,当然菜单也是可以设置的
    menu1->setIcon(QPixmap(":/pictures/file.png"));//菜单设置图标会将标题覆盖掉
    action1->setIcon(QPixmap(":/pictures/files.png"));
    action2->setIcon(QPixmap(":/pictures/fileopen.png"));

但是这里的代码有一个小问题,我们这里是自己创建的一个菜单栏,然后添加到窗口当中,二在项目创建之后就已经为我们创建好了一个MenuBar,此时改菜单栏就失去了与对象树的连接,我们自己创建的这个可以不用我们释放,但是原先的这个就需要我们去释放,否则会造成内存泄漏。

2.工具栏

QMianWindow的第三层就是工具栏QToolBar Area,在上下左都能可以进行工具栏的设置。

实际上就是一堆按钮,进行某些简单工具的快速使用。

    QToolBar * toolbar=new QToolBar();
    this->addToolBar(toolbar);//这里是add说明工具栏可以有多个,而setMenubar说明只能设置一个。
    toolbar->setMovable(true);//设置可以拖拽
    QAction*  a1=new QAction("计算器");
    QAction * a2=new QAction("保存");
    toolbar->addAction(a1);
    toolbar->addAction(a2);

除了这种写法,工具栏中的action其实也可以出现在菜单中。其次我们在添加action的时候指定初始位置,在前面再加一个参数QLeftToolBarArea.

    this->addToolBar(Qt::LeftToolBarArea,toolbar);
    toolbar ->setAllowedAreas(Qt::LeftToolBarArea| Qt::RightToolBarArea);

• Qt::LeftToolBarArea 停靠在左侧
• Qt::RightToolBarArea 停靠在右侧
• Qt::TopToolBarArea 停靠在顶部
• Qt::BottomToolBarArea 停靠在底部
• Qt::AllToolBarAreas 以上四个位置都可停靠

3.状态栏

状态栏是应⽤程序中输出简要信息的区域。⼀般位于主窗⼝的最底部,⼀个窗⼝中最多只能有⼀个状 态栏。在 Qt 中,状态栏是通过 QStatusBar类 来实现的。 在状态栏中可以显⽰的消息类型有:
• 实时消息:如当前程序状态
• 永久消息:如程序版本号,机构名称
• 进度消息:如进度条提⽰,百分百提⽰

  //创建状态栏
    QStatusBar *statusbar=this->statusBar();//有就返回,没有就创建
    this->setStatusBar(statusbar);
    // statusbar->showMessage("当前无状态");//显示状态信息
    //如果设置了message就不能显示标签内容了
    //添加子控件
    QLabel *label=new QLabel();
    label->setText("标签一");
    statusbar->addWidget(label);//从左往右addPermanentWidget是从上往下
    QLabel *label2=new QLabel();
    label2->setText("标签二");
    statusbar->addWidget(label2);
    //当然其他子控件也可以,一般会有进度条提醒当前任务状态

4.滑动窗口

在 Qt 中,浮动窗⼝也称之为铆接部件。浮动窗⼝是通过 QDockWidget类 来实现浮动的功能。浮动窗 ⼝⼀般是位于核⼼部件的周围,可以有多个。
我们可以对滑动窗口进行拖拽。

    //添加滑动窗口
    QDockWidget * dockwidget=new QDockWidget();
    this->addDockWidget(Qt::LeftDockWidgetArea,dockwidget);//同时设置初始位置
    dockwidget->setWindowTitle("浮动窗口");//设置标题
    //我们也可以在浮动窗口上添加组件,但是不能直接添加,需要新建一个Qwidget
    QWidget * window=new QWidget();
    QGridLayout *layout=new QGridLayout;
    window->setLayout(layout);
    QPushButton * button =new QPushButton();
    QPushButton * button2 =new QPushButton();
    button->setText("按钮");
    button2->setText("按钮二");
    layout->addWidget(button,0,0);
    layout->addWidget(button2,0,1);
    dockwidget->setWidget(window);
   dockwidget->setAllowedAreas(Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea | Qt::TopToolBarArea);//设置允许拖拽的位置

QT对话框

    //将delete与点击信号关联,QDialog提供了属性。
    log->setAttribute(Qt::WA_DeleteOnClose);

对话框是 GUI 程序中不可或缺的组成部分。⼀些不适合在主窗⼝实现的功能组件可以设置在对话框 中。对话框通常是⼀个顶层窗⼝,出现在程序最上层,⽤于实现短期任务或者简洁的⽤⼾交互。Qt常 ⽤的内置对话框有:QFiledialog(⽂件对话框)、QColorDialog(颜⾊对话框)、QFontDialog(字体对话框)、QInputDialog (输⼊对话框)和 QMessageBox(消息框) 。
在我们创建项目时,,其中就可以选择创建一个对话框。不过我们并不是直接就在窗口上创建一个dialog,而是创建其他的类,之后让dialog去继承其他类,所以这里还是用QMianWindow.
简单看一下:

void MainWindow::on_pushButton_clicked()
{
    //每次点击,就会新键一个对话框,会造成内存泄露
    QDialog * log=new QDialog (this);
    log->resize(200,200);
    log->show();
}

因此还需要去设置一个属性:

  //虽然主窗口关闭会释放资源,但是我们还是希望在关闭窗口的时候就释放资源
    //将delete与点击信号关联,QDialog提供了属性。
    log->setAttribute(Qt::WA_DeleteOnClose);

通过这种方式就不会出现无限创建的情况了。

1.基础对话框QDiaog

既然对话框上可以放各种部件,那么我们就可以就可以实现一个丰富的对话框,我们直接在原项目中再创建一个类,用来表示对话框。

之后我们就可以在主窗口创建使用,在本地dialog进行其他构建的编写,需要注意的是要么手动写关闭释放,要么直接调用接口Atrribute(WA_DELETE_ON_CLOSE).

创建新的ui文件

其次如果只是创建一个类文件,效果貌似并不是太好啊,我们只能通过代码的方式进行其他构建的添加,所以在这里添加文件时,我们还可以选择一个QT中的设计器界面类:

并且还会为我们提供一些模板供使用。此时就会一步到位,为我们创建好类和ui文件。
之后我们就可以在deisgner中进行图形化编辑了。

模态对话框与非模态对话框

模态对话框指的是:显⽰后⽆法与⽗窗⼝进⾏交互,是⼀种阻塞式的对话框。使⽤QDialog::exec() 函数调⽤。 模态对话框适⽤于必须依赖⽤⼾选择的场合,⽐如消息显⽰,⽂件选择,打印设置等。
模态对话必须要多对话框进行操作,其他行为被阻止了。
⾮模态对话框 :⾮模态对话框显⽰后独⽴存在,可以同时与⽗窗⼝进⾏交互,是⼀种⾮阻塞式对话框,使⽤ QDialog::show()函数调⽤。

    Dialog1 * log=new Dialog1(this);
    log->setAttribute(Qt::WA_DeleteOnClose);
    log->show();
    log->resize(200,200);
    //log->exec();

2.消息对话框 QMessageBox

显示一些消息给用户,在提供一些选择给用户,这是消息对话框最常用的场景,例如系统警告,是否关闭,是否保存等等。消息对话框的mudle默认是模态的,与此对应QT页内置了相关的按钮以及图标如下
内置按钮

 QMessageBox * message=new QMessageBox(this);//先创建一个messgeboxd的对象
    message->setIcon(QMessageBox::Warning);//QT内部也提供了一些图标
    message->setWindowTitle("这是一个对话框");
    message->resize(300,300);
    message->setStandardButtons(QMessageBox::Ok | QMessageBox::Save | QMessageBox::Cancel );//设置基本的按钮。例如ok与保存按钮,这些都是内置的常用的按钮
    message->show();


当然我们也可以进行自定义按钮,QMessageBox为我们提供了添加 button的方法,在添加时我们还需要设置对应的按钮类型。
按钮类型

  QMessageBox * message=new QMessageBox(this);//先创建一个messgeboxd的对象
    message->setIcon(QMessageBox::Warning);//QT内部也提供了一些图标
    message->setWindowTitle("这是一个对话框");
    message->resize(300,300);
    QPushButton * button=new QPushButton();
    button->setText("自定义按钮");
    message->addButton(button,QMessageBox::AcceptRole);//设置为接受式的按钮,实际上与内置的ok按钮是一致的
    message->show();

虽然对于内置按钮无法进行槽函数和信号的绑定,但是提供了更加简单的方式,我们只需要调用接口exec的返回值,在模式化显示之后返回值是选区的按钮,因此对返回值进行判断就可以去执行你想要进行的操作。

QMessageBox * message=new QMessageBox(this);//先创建一个messgeboxd的对象
    message->setIcon(QMessageBox::Warning);//QT内部也提供了一些图标
    message->setWindowTitle("这是一个对话框");
    message->resize(300,300);
    QPushButton * button=new QPushButton();
    button->setText("自定义按钮");
    connect(button,&QPushButton::clicked,this,&Widget::handle);
    message->addButton(button,QMessageBox::AcceptRole);//设置为接受式的按钮,实际上与内置的ok按钮是一致的
    message->setStandardButtons(QMessageBox::Ok | QMessageBox::Save | QMessageBox::Cancel );//设置基本的按钮。例如ok与保存按钮,这些都是内置的常用的按钮
    int btn=message->exec();\
     if(btn==QMessageBox::Ok)
    {
        qDebug()<<"Ok";
     }else if(btn==QMessageBox::Save)
     {
         qDebug()<<"Save";
     }else if(btn==QMessageBox::Cancel)
     {
         qDebug()<<"Cancel";
     }
  //除了以上的方式,对话框以及内置按钮的创建还有更简便的方式,QT内置了函数,我们调用即可
  QMessageBox::warning(this,"对话标题","对话框",QMessageBox::Ok,QMessageBox::Cancel);
   //通过该接口可以直接创建对话框以及按钮
   //除了warning还有information等。

3.QColorDialog

QColorDialog即颜色对话框,即在内部内置了一个调色板一样的东西,是用户直接选中颜色就可以进行颜色的改变。

//    QColorDialog * colordialog=new QColorDialog(this);
//    colordialog->resize(400,400);
//    colordialog->setAttribute(Qt::WA_DeleteOnClose);
//    colordialog->show();
    //我们不用上述方式来创建显示,对于颜色对话框,Qt也内置了一个静态函数getcolor,我们可以直接调用
 QColor color=QColorDialog::getColor(QColor(0,255,0),this,"选择颜色");
//参数一次为颜色父类,标题
  
 qDebug()<<color; //返回值就是选择颜色后点击确定返回的颜色

4.QFileDialog文件对话框

可以通过QFileDialog打开一个文件, 获取文件路径,删除文件的等。

1、打开⽂件(⼀次只能打开⼀个⽂件)
QString getOpenFileName (QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options())
2、打开多个⽂件(⼀次可以打开多个⽂件)
QStringList getOpenFileNames (QWidget *parent = nullptr, const QString &caption = QString(), const QString &dir = QString(), const QString &filter = QString(), QString *selectedFilter = nullptr, QFileDialog::Options options = Options())
3、 保存⽂件
QString 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_pushButton_clicked()
{
    QString name= QFileDialog ::getOpenFileName(this,"文件");//参数包含过滤器,设置什么样的文件fileter
    qDebug()<<name;

}

void Widget::on_pushButton_2_clicked()
{
    QString name= QFileDialog ::getSaveFileName(this,"文件");
    qDebug()<<name;

}

QWidget *parent = nullptr:父窗口部件(widget)。

const QString &caption = QString():对话框的标题。

const QString &dir = QString():初始目录。

const QString &filter = QString():文件过滤器。这个参数允许你指定用户可以在对话框中看到的文件类型。过滤器是一个或多个由分号 ; 分隔的模式字符串。

QString *selectedFilter = nullptr:选择的过滤器。

QFileDialog::Options options = Options():对话框选项

这里的保存并不是你一按就真的保存了,这个保存需要我们在捕捉信号后去实现文件保存。

5.QFontDialog

Qt 中提供了预定义的字体对话框类 QFontDialog,⽤于提供选择字体的对话框部件。
还是使用内置的静态函数进行创建。

bool *ok:

这是一个指向布尔值的指针。当字体对话框关闭时,这个布尔值会被设置为 true(如果用户选择了一个字体并确认)或 false(如果用户取消了对话框或没有选择任何字体)。这允许调用者知道用户是否成功选择了一个字体。

const QFont &initial:

这是一个 QFont 类型的常量引用,表示在字体对话框中最初显示的字体。这允许调用者预先设定一个初始字体,以便用户从这个字体开始选择。

QWidget *parent = nullptr:

这是一个指向 QWidget 的指针,用于指定字体对话框的父窗口。如果提供了父窗口,字体对话框就会作为该窗口的子窗口显示。如果设置为 nullptr,字体对话框将没有父窗口。

const QString &title = QString():

这是一个 QString 类型的常量引用,用于指定字体对话框的标题。如果未提供标题,则可能会使用默认的标题(这取决于具体的实现)。

FontDialogOptions options = FontDialogOptions():

这是一个枚举类型的组合,用于指定字体对话框的选项或行为。FontDialogOptions 是一个枚举类型(注意这里使用的是假设的枚举名,Qt 中实际使用的是 QFontDialog::FontDialogOptions),它可能包含各种标志,如指定对话框是否应该显示颜色选择、样式选择等。如果未提供选项,字体对话框将使用默认的行为和选项。

    bool ok=false;
    QFont font= QFontDialog ::getFont(&ok);//根据对话框按钮的选择进行bool值设置,即输入性参数
    this->setFont(font);//拿到字体信息我们就可以对想要设置的设置了
    qDebug()<<font;

打印的信息:QFont(华文仿宋,9,-1,5,400,0,0,0,0,0,0,0,0,0,0,1,Regular)

6.QInputDialog

Qt 中提供了预定义的输⼊对话框类:QInputDialog,⽤于进⾏临时数据输⼊的场合

1、双精度浮点型输⼊数据对话框
double getDouble (QWidget *parent, const QString &title, const QString &label, double
value = 0, double min = -2147483647, double max = 2147483647, int decimals = 1, bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags());
2、整型输⼊数据对话框
int getInt (QWidget *parent, const QString &title, const QString &label, int value = 0, int
min = -2147483647, int max = 2147483647, int step = 1, bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags());
3、选择条⽬型输⼊数据框
QString getItem (QWidget *parent, const QString &title, const QString &label, const
QStringList &items, int current = 0, bool editable = true, bool *ok = nullptr,
Qt::WindowFlags flags = Qt::WindowFlags(), Qt::InputMethodHints inputMethodHints =
Qt::ImhNone) ;
可以进行输入设置为浮点数,整数,数据框三种类型。

    //double num=QInputDialog::getDouble(this,"输入框","标签");
     //double num=QInputDialog::getInt(this,"输入框","标签");
    QStringList item;
    item.push_back("哎呦~");
    item.push_back("哎呦~");
    item.push_back("你干嘛~");
    QString num=QInputDialog::getItem(this,"输入框","标签",item);
    qDebug()<<num;

相关推荐
Ajiang28247353048 分钟前
对于C++中stack和queue的认识以及priority_queue的模拟实现
开发语言·c++
幽兰的天空13 分钟前
Python 中的模式匹配:深入了解 match 语句
开发语言·python
Theodore_10223 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee
----云烟----5 小时前
QT中QString类的各种使用
开发语言·qt
lsx2024065 小时前
SQL SELECT 语句:基础与进阶应用
开发语言
开心工作室_kaic6 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
向宇it6 小时前
【unity小技巧】unity 什么是反射?反射的作用?反射的使用场景?反射的缺点?常用的反射操作?反射常见示例
开发语言·游戏·unity·c#·游戏引擎
武子康6 小时前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud
转世成为计算机大神6 小时前
易考八股文之Java中的设计模式?
java·开发语言·设计模式
宅小海7 小时前
scala String
大数据·开发语言·scala