【Qt学习笔记】(四)Qt窗口

Qt窗口

  • 1 菜单栏
    • 1.1 创建菜单栏
    • 1.2 在菜单栏中添加菜单
    • 1.3 创建菜单项
    • 1.4 在菜单项之间添加分割线
    • 1.5 给菜单项添加槽函数
    • 1.6 给菜单项添加快捷键
  • 2 工具栏
    • 2.1 创建工具栏
    • 2.2 设置停靠位置
    • 2.3 设置浮动属性
    • 2.4 设置移动属性
    • 2.5 添加 Action
  • 3 状态栏
    • 3.1 状态栏的创建
    • 3.2 在状态栏中显示实时消息
    • 3.3 状态栏中放入控件
  • 4 浮动窗口
    • 4.1 浮动窗口的创建
    • 4.2 给浮动窗口添加控件
  • 5 对话框
    • 5.1 对话框介绍
    • 5.2 创建对话框
    • 5.3 对话框的内存释放问题
    • 5.4 自定义对话框
    • 5.5 模态对话框与非模态对话框
    • 5.6 Qt 内置对话框
      • 5.6.1 消息对话框 QMessageBox
      • 5.6.2 颜色对话框
      • 5.6.3 文件对话框
      • 5.6.4 字体对话框 QFontDialog
      • 5.6.5 输入对话框 QInputDialog

Qt窗口是通过QMainWindow类来实现的。
QMainWindow是一个为用户提供主窗口程序的类,继承自QWidget类,并且提供了一个预定义的布局。QMainWindow包含一个菜单栏(menu bar)、多个工具栏(tool bars)、多个浮动窗口(铆接部件) (dock widgets)、一个状态栏(status bar)和一个中心部件(central widget),它是许多应用程序的基础,如文本编辑器,图片编辑器等。如下图为QMainwindow中各组件所处的位置:

在这里插入图片描述

1 菜单栏

Qt中的菜单栏是通过QMenuBar这个类来实现的。一个主窗口最多只有一个菜单栏。位于主窗口顶部、主窗口标题栏下面。.
菜单栏中包含菜单.菜单中包含菜单项.

在这里插入图片描述

1.1 创建菜单栏

在 ui 界面中,已经创建好了菜单栏,直接输入对应的菜单项即可。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
也可以通过代码的方式去添加菜单栏

菜单栏的创建可以借助于QMainWindow类提供的menuBar()函数来实现。

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    
    //创建菜单栏
    QMenuBar* menubar = this->menuBar();
    //把菜单栏放入窗口中
    this->setMenuBar(menubar);
}

注意:
如果创建的代码是
QMenuBar* menubar = new QMenuBar();
在创建项目的时候,如果没有勾选自动生成 ui 文件,此时这种创建菜单栏的方式没有问题。但是如果勾选了自动生成 ui 文件,这行代码可能会引起内存泄漏。
原因是:程序已经创建好了一个 QMenuBar,当设置新的 QMenuBar 进来的时候,就会导致前者脱离 Qt 的对象树,导致无法自动释放内存。
在这里插入图片描述如果窗口关闭,对象树释放,此时进程也就结束了,进程结束,自然所有的内存都回收给系统,上述的内存泄漏不会造成影响。但是如果这样的代码是出现在一个多窗口的程序中,如果涉及到窗口的频繁跳转切换(窗口频繁创建销毁),上述内存泄漏就会严重一些。但是实际上由于现在的计算机内存都比较充裕,上述的内存泄漏都还好。服务器程序相比于客户端程序更害怕内存泄漏。服务器要处理很多请求,每个请求泄漏一点,请求积累下来就会累计很多。所以,我们更希望代码写得规范一些。

    //创建菜单栏
    //1.如果 QMenuBar 已经存在,直接获取并返回
    //2.如果 QMenuBar 不存在,就先创建一个新的,再返回
    QMenuBar* menubar = this->menuBar();
    //把菜单栏放入窗口中
    //如果是获取到已经存在 QMenuBar ,这里的设置就是自己替换自己,仍然在对象树上
    this->setMenuBar(menubar);

1.2 在菜单栏中添加菜单

创建菜单,并通过QMenu提供的addMenu() 函数来添加菜单。

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

    //创建菜单栏
    //QMenuBar* menubar = this->menuBar();
    QMenuBar* menubar = new QMenuBar();
    //把菜单栏放入窗口中
    this->setMenuBar(menubar);
    //创建菜单
    QMenu* menu1 = new QMenu("文件");
    QMenu* menu2 = new QMenu("编辑");
    QMenu* menu3 = new QMenu("构建");
    //添加菜单到菜单栏中
    menubar->addMenu(menu1);
    menubar->addMenu(menu2);
    menubar->addMenu(menu3);
}

在这里插入图片描述

1.3 创建菜单项

在Qt中,并没有专门的菜单项类,可以通过QAction类,抽象出公共的动作。如在菜单中添加菜单项.

QAction可以给菜单栏使用,也可以给工具栏使用.

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

    //创建菜单栏
    //QMenuBar* menubar = this->menuBar();
    QMenuBar* menubar = new QMenuBar();
    //把菜单栏放入窗口中
    this->setMenuBar(menubar);
    //创建菜单
    QMenu* menu1 = new QMenu("文件");
    QMenu* menu2 = new QMenu("编辑");
    QMenu* menu3 = new QMenu("构建");
    //添加菜单到菜单栏中
    menubar->addMenu(menu1);
    menubar->addMenu(menu2);
    menubar->addMenu(menu3);
    //创建菜单项
    QAction* action1 = new QAction("open");
    QAction* action2 = new QAction("close");
    QAction* action3 = new QAction("create");
    //将菜单项添加到菜单上
    menu1->addAction(action1);
    menu1->addAction(action2);
    menu1->addAction(action3);
}

1.4 在菜单项之间添加分割线

在菜单项之间可以添加分割线。分割线如下图所示,添加分割线是通过QMenu 类提供的addSeparator()函数来实现;
在这里插入图片描述

    menu1->addAction(action1);
    menu1->addSeparator();//在 open 和 close 之间添加分割线
    menu1->addAction(action2);
    menu1->addAction(action3);

可以使用 setIcon 函数来给每个菜单项添加一个图标。在第三章常用控件中介绍到,这里不在赘述。

1.5 给菜单项添加槽函数

在菜单项被点击的时候,会触发 triggered 这个信号,利用这个信号去触发对应的槽函数

connect(action1,&QAction::triggered,this,&MainWindow::handle);

void MainWindow::handle()
{
    qDebug() << "点击了 open 菜单项";
}

这里只是简单打印一下。
在这里插入图片描述

1.6 给菜单项添加快捷键

添加快捷键的方法很简单,只需要在创建菜单项的时候,菜单项的名字后面加个(&+添加的快捷键即可)

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

    //创建菜单栏
    //QMenuBar* menubar = this->menuBar();
    QMenuBar* menubar = new QMenuBar();
    //把菜单栏放入窗口中
    this->setMenuBar(menubar);
    //创建菜单
    QMenu* menu1 = new QMenu("文件(&F)");
    QMenu* menu2 = new QMenu("编辑(&E)");
    QMenu* menu3 = new QMenu("构建(&C)");
    //添加菜单到菜单栏中
    menubar->addMenu(menu1);
    menubar->addMenu(menu2);
    menubar->addMenu(menu3);
    //创建菜单项
    QAction* action1 = new QAction("open(&O)");
    QAction* action2 = new QAction("close");
    QAction* action3 = new QAction("create");
    //将菜单项添加到菜单上
    menu1->addAction(action1);
    menu1->addSeparator();//在 open 和 close 之间添加分割线
    menu1->addAction(action2);
    menu1->addAction(action3);
    //点击 open 的时候触发槽函数
    connect(action1,&QAction::triggered,this,&MainWindow::handle);
}

按 ALT + 快捷键触发快捷键
在这里插入图片描述

2 工具栏

工具栏是应用程序中集成各种功能实现快捷键使用的一个区域 。可以有多个,也可以没有,它并不是应用程序中必须存在的组件。它是一个可移动的组件,它的元素可以是各种窗口组件,它的元素通常以图标按钮的方式存在。如下图为工具栏的示意图:
在这里插入图片描述

2.1 创建工具栏

调用QMainWindow类的addToolBar()函数来创建工具栏,每增加一个工具栏都需要调用一次该函数。
如添加一个工具栏并加入一个 QAction

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

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
}

在这里插入图片描述

2.2 设置停靠位置

工具栏停靠位置的设置有两种方式。-种是在创建工具栏的同时指定停靠的位置,另一种是通过
QToolBar类提供的setAllowedAreas()函数来设置。

在创建工具栏的同时,也可以设置工具栏的位置,其默认位置是在窗口的最上面;如上述代码,默认在最上面显示。工具栏允许停靠的区域由QToolBar类提供的allowAreas()函数决定,其中可以设置的位置包括:

  • Qt::LeftToolBarArea停靠在左侧
  • Qt::RightToolBarArea停靠在右侧
  • Qt::TopToolBarArea停靠在顶部
  • Qt::BottomToolBarArea 停靠在底部
  • Qt::AllToolBarAreas 以上四个位置都可停靠
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
    //指定工具栏在左侧显示
    this->addToolBar(Qt::LeftToolBarArea,toolBar1);
}

在这里插入图片描述
在窗口创建出来后,工具栏的位置可以依靠鼠标进行拖动
在这里插入图片描述
方式二:使用QToolBar类提供的setAllowedAreas()函数设置允许停靠位置。如下示例:

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

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
    //指定工具栏在左侧显示
    this->addToolBar(Qt::LeftToolBarArea,toolBar1);
    //设置只允许在上侧和左侧停靠
    toolBar1->setAllowedAreas(Qt::LeftToolBarArea | Qt::TopToolBarArea);
}

2.3 设置浮动属性

如果鼠标拖到窗口的中间位置,工具栏就会浮动在中间位置。
工具栏的浮动属性可以通过QToolBar类提供的setFloatable()函数来设置。

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

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
    //指定工具栏在左侧显示
    this->addToolBar(Qt::LeftToolBarArea,toolBar1);
    //设置只允许在上侧和左侧停靠
    toolBar1->setAllowedAreas(Qt::LeftToolBarArea | Qt::TopToolBarArea);

    //设置工具栏不允许浮动
    toolBar1->setFloatable(false);
}

2.4 设置移动属性

设置工具栏的移动属性可以通过QToolBar类提供的setMovable()函数来设置。

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

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
    //指定工具栏在左侧显示
    this->addToolBar(Qt::LeftToolBarArea,toolBar1);
    //设置只允许在上侧和左侧停靠
    toolBar1->setAllowedAreas(Qt::LeftToolBarArea | Qt::TopToolBarArea);
    //设置工具栏不允许浮动
    toolBar1->setFloatable(false);
    //设置工具栏不允许移动
    toolBar1->setMovable(false);
}

设置不允许移动后,鼠标无法拖动工具栏。

2.5 添加 Action

工具栏不仅可以添加Action,也可以添加一些控件,这里以添加 Action 为例

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

    QToolBar* toolBar1 = new QToolBar(this);
    this->addToolBar(toolBar1);
    //指定工具栏在左侧显示
    this->addToolBar(Qt::LeftToolBarArea,toolBar1);
    //设置只允许在上侧和左侧停靠
    toolBar1->setAllowedAreas(Qt::LeftToolBarArea | Qt::TopToolBarArea);
    //设置工具栏不允许浮动
    toolBar1->setFloatable(false);
    QAction* action1 = new QAction("保存");
    toolBar1->addAction(action1);
}

在这里插入图片描述

3 状态栏

**状态栏是应用程序中输出简要信息的区域。**一般位于主窗口的最底部,-、一个窗口中最多只能有一个状态栏。在Qt中,状态栏是通过QStatusBar类来实现的。在状态栏中可 以显示的消息类型有:

  • 实时消息:如当前程序状态
  • 永久消息:如程序版本号,机构名称
  • 进度消息:如进度条提示,百分百提示

3.1 状态栏的创建

状态栏和菜单栏一样,如果创建项目的时候勾选了创建 ui 界面,那么就会自动生成一个状态栏。在这里插入图片描述

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    //创建状态栏,已经存在就调用存在的,不存在就创建
    QStatusBar* stbar = this->statusBar();
    //将状态栏设置到窗口中
    this->setStatusBar(stbar);
}

3.2 在状态栏中显示实时消息

    //状态栏中显示 2 秒的消息
    stbar->showMessage("这是一个状态消息",2000);

在这里插入图片描述
将后面的数字改为 0 ,则是永久显示

3.3 状态栏中放入控件

状态栏也可放入一些控件,这里以放入 label 为例

    QLabel* label = new QLabel("这是一个标签",this);
    stbar->addWidget(label);

在这里插入图片描述
调整显示消息的位置

    QLabel* label2 = new QLabel("这是一个标签2",this);
    stbar->addPermanentWidget(label2);

在这里插入图片描述

4 浮动窗口

在Qt中,浮动窗口也称之为铆接部件。浮动窗口是通过QDockWidget类来实现浮动的功能。浮动窗口一般是位于核心部件的周围,可以有多个。

4.1 浮动窗口的创建

浮动窗口的创建是通过QDockWidget类提供的构造方法QDockWidget()函数动态创建的;示例如下

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

    //创建浮动窗口
    QDockWidget* dockwidget = new QDockWidget("浮动窗口",this);
    //将浮动窗口置于当前窗口中,同时设置停靠在左侧
    addDockWidget(Qt::LeftDockWidgetArea,dockwidget);
}

4.2 给浮动窗口添加控件

要想给浮动窗口内部添加一些控件,需要创建一个单独的 QWidget ,把要添加的控件加入到 QWidget 中,然后再把这个 QWidget 设置到 dockWidget 中。

ainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    //创建浮动窗口
    QDockWidget* dockwidget = new QDockWidget("浮动窗口",this);
    //将浮动窗口置于当前窗口中,同时设置停靠在左侧
    addDockWidget(Qt::LeftDockWidgetArea,dockwidget);

    //创建一个 QWidget ,并加入到 dockWidget 中
    QWidget* container = new QWidget();
    dockwidget->setWidget(container);
    //创建一个标签和一个垂直的布局管理器,把布局管理器加入到 Qwidget 中
    //再把控件加入到布局管理器中
    QLabel* label = new QLabel("这是一个标签",this);
    QVBoxLayout* vlayout = new QVBoxLayout();
    container->setLayout(vlayout);
    vlayout->addWidget(label);
}

在这里插入图片描述

5 对话框

5.1 对话框介绍

对话框是GUI程序中不可或缺的组成部分。一些不适合在主窗口实现的功能组件可以设置在对话框中。对话框通常是一个顶层窗口,出现在程序最上层,用于实现短期任务或者简洁的用户交互。Qt常用的内置对话框有: QFiledialog (文件对话框)、QColorDialog (颜色对话框)、QFontDialog(字体对话框)、QInputDialog (输入对话框) 和QMessageBox (消息框)

5.2 创建对话框

在创建项目的时候,选择 QDialog
在这里插入图片描述
运行程序,可以看到通过基于 QDialog 作为父类创建出来的程序窗口和之前通过 QWidget 创建出来的非常相似。
在实际开发中,往往不会直接在创建项目的时候继承自 QDialog,而是在代码中创建其他的类,让其他的类继承 QDialog。主窗口不会作为一个对话框,而是在主窗口中产生一个对话框。

代码示例:主窗口中通过点击按钮,弹出一个新的对话框

创建项目时,选择 QMainWindow
在这里插入图片描述
添加一个按钮,并编写对应的槽函数

void MainWindow::on_pushButton_clicked()
{
    //创建一个对话框
    QDialog* dialog = new QDialog(this);
    //设置对话框大小
    dialog->resize(400,300);
    //设置对话框标题
    dialog->setWindowTitle("标题");
    dialog->show();
}

运行程序,并点击按钮,即可弹出对话框
在这里插入图片描述

5.3 对话框的内存释放问题

在上述代码示例中,每次点击按钮生成对话框,就会创建一个新的 QDialog 对象,并进行显示。如果点击很多次,就会产生很多个这样的对象,而且光是点击关闭对话框是没法进行内存释放的,所以很容易造成内存泄漏问题。
所以 Qt 给出了这样一个操作:当用户点击对话框关闭按钮的时候,触发 delete 操作。

dialog->setAttribute(Qt::WA_DeleteOnClose);

5.4 自定义对话框

创建一个 QMainWindow 项目后,点击新建文件,点击 Qt 设计器界面类
在这里插入图片描述
这里选择第三个
在这里插入图片描述
一直点击下一步,Qt 会为我们自动创建一个对话框界面
在这里插入图片描述
可以看到,项目里面多了一些对话框的文件,包括设计对话框的 ui 界面

进入 ui 界面,加入一些控件,并完成按钮的槽函数
在这里插入图片描述

#include "dialog.h"
#include "ui_dialog.h"

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

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

void Dialog::on_pushButton_clicked()
{
    this->close();
}

回到 QMainWindow 的ui 界面,加入一个按钮,设计弹出对话框
在这里插入图片描述

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "dialog.h"
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
}

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

void MainWindow::on_pushButton_clicked()
{
    Dialog* dialog = new Dialog(this);
    dialog->show();
    dialog->setAttribute(Qt::WA_DeleteOnClose);
}

注意这里包含的头文件不是 QDialog,而是我们自己的类,继承自 QDialog
在这里插入图片描述

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

模态对话框指的是:显示后无法与父窗口进行交互,是一种阻塞式的对话框。使用QDialog::exec()函数调用。
模态对话框适用于必须依赖用户选择的场合,比如消息显示,文件选择,打印设置等。

非模态对话框显示后独立存在,可以同时与父窗口进行交互,是一种非阻塞式对话框,使用
QDialog:show()函数调用。

将上述代码的 show 函数改成 exec 函数,就是模态对话框。
运行程序,当窗口弹出后,无法操作父窗口

void MainWindow::on_pushButton_clicked()
{
    Dialog* dialog = new Dialog(this);
    //dialog->show();
    dialog->exec();
    dialog->setAttribute(Qt::WA_DeleteOnClose);
}

在这里插入图片描述

5.6 Qt 内置对话框

Qt提供了多种可复用的对话框类型,即Qt标准对话框。Qt 标准对话框全部继承于QDialog类。常用标准对话框如下:

在这里插入图片描述

5.6.1 消息对话框 QMessageBox

消息对话框是应用程序中最常用的界面元素。消息对话框主要用于为用户提示重要信息,强制用户进行选择操作。
QMessageBox类中定义了静态成员函数,可以直接调用创建不同风格的消息对话框,其中包括:
在这里插入图片描述
在这里插入图片描述
也可采用 setIcon 函数,输入对应的枚举类型,设置消息对话框类型
在这里插入图片描述
代码示例 : 警告类型对话框
在 ui 窗口上设置一个按钮,然后设置对应的槽函数

void MainWindow::on_pushButton_clicked()
{
    // 创建 QMessageBox
    QMessageBox* messageBox = new QMessageBox(this);
    messageBox->setWindowTitle("对话框窗口标题");
    messageBox->setText("这是对话框文本");
    //设置对话框类型
    messageBox->setIcon(QMessageBox::Warning);
    //在消息对话框上设置按钮
    messageBox->setStandardButtons(QMessageBox::Ok | QMessageBox::Save | QMessageBox::Cancel);
    messageBox->exec();
	messageBox->setAttribute(Qt::WA_DeleteOnClose);
}

其中设置对话框上的按钮,Qt 也已经枚举好了
在这里插入图片描述

运行程序,查看效果
在这里插入图片描述
代码示例:通过 exec 函数的返回值获得对话框被点击了哪个按钮
exec 函数是设定对话框是模态对话框,同时它也有一个返回值,返回值就是对话框被选中了哪个按钮的值。

void MainWindow::on_pushButton_clicked()
{
    // 创建 QMessageBox
    QMessageBox* messageBox = new QMessageBox(this);
    messageBox->setWindowTitle("对话框窗口标题");
    messageBox->setText("这是对话框文本");
    //设置对话框类型
    messageBox->setIcon(QMessageBox::Warning);
    //在消息对话框上设置按钮
    messageBox->setStandardButtons(QMessageBox::Ok | QMessageBox::Save | QMessageBox::Cancel);
    int result = messageBox->exec();//获取到返回值
    if(result == QMessageBox::Ok)
    {
        qDebug() <<"QMessageBox::Ok";
    }
    else if(result == QMessageBox::Save)
    {
        qDebug() << "QMessageBox::Save";
    }
    else if(result == QMessageBox::Cancel)
    {
        qDebug() << "result == QMessageBox::Cancel";
    }
    messageBox->setAttribute(Qt::WA_DeleteOnClose);
}

运行程序,查看效果
当我们点击 OK 后,就执行对应的代码
在这里插入图片描述

代码示例:以调用函数的方式弹出对话框
在 ui 界面创建一个弹出对话框的按钮,然后编写对应的槽函数

void MainWindow::on_pushButton_clicked()
{
    int result = QMessageBox::information(this,"对话框标题","对话框文本",QMessageBox::Ok | QMessageBox::Cancel);
    if(result == QMessageBox::Ok)
    {
        qDebug() <<"QMessageBox::Ok";
    }
    else if(result == QMessageBox::Cancel)
    {
        qDebug() << "QMessageBox::Cancel";
    }
}

运行程序,查看效果
在这里插入图片描述

5.6.2 颜色对话框

颜色对话框的功能是允许用户选择颜色。继承自QDialog类。颜色对话框如下图示:
在这里插入图片描述
在这里插入图片描述
代码示例:创建一个颜色对话框
在 ui 界面创建一个按钮,并完成对应的槽函数
在这里插入图片描述

void MainWindow::on_pushButton_clicked()
{
//这个函数静态函数,不必创建对话框对象就可直接使用
    QColor color = QColorDialog::getColor(QColor(255,0,0),this,"选择颜色");
    qDebug() << color;//打印
}

QColor(255,0,0),是设置RGB,这里是红色。不了解的读者可以看看这篇文章的2.11
常用控件

运行程序,查看效果
在这里插入图片描述
这里默认选择红色,点击确定。
打印结果如下:
在这里插入图片描述
这里A指的是 Alpha,是不透明度
使用 0 ~ 1 表示 RGB的值,可以是小数
1 对应到整数的 255
0 对应到整数的 0

5.6.3 文件对话框

文件对话框用于应用程序中需要打开一个外部文件或需要将当前内容存储到指定的外部文件。

使用 getOpenFileName 打开文件,getSaveFileName 保存文件。
此处的打开 / 保存的功能是需要我们额外去实现的,这里只是简单介绍一下。

代码示例:弹出打开 / 保存 文件窗口
在 ui 界面上创建两个按钮,并完成对应的槽函数
在这里插入图片描述

void MainWindow::on_pushButton_clicked()
{
    QString filePath = QFileDialog::getOpenFileName(this);
    qDebug() << filePath;
}


void MainWindow::on_pushButton_2_clicked()
{
    QString filePath = QFileDialog::getSaveFileName(this);
    qDebug() << filePath;
}

运行程序,分别点击两个按钮
在这里插入图片描述

5.6.4 字体对话框 QFontDialog

Qt中提供了预定义的字体对话框类QFontDialog,用于提供选择字体的对话框部件。
使用 getFont 函数弹出字体对话框
代码示例:弹出字体对话框
在 ui 界面上设置一个按钮,并完全相应的槽函数
在这里插入图片描述

void MainWindow::on_pushButton_clicked()
{
    bool ok = false;//点击对话框的ok,ok 被设为 true,点击cancel设为 false
    QFont font = QFontDialog::getFont(&ok);
    qDebug() << "ok = " << ok;//查看 ok 的值
    qDebug() << font;//返回字体的相关参数
}

5.6.5 输入对话框 QInputDialog

Qt中提供了预定义的输入对话框类: QInputDialog, 用于进行临时数据输入的场合。

有 getInt 函数输入一个整数,getDouble 函数输入一个浮点数,getItem 函数输入一个条目,可提前添加条目进行选择

代码示例:整数数据输入对话框

在 ui 界面设置一个按钮,并完成相应的槽函数
在这里插入图片描述

void MainWindow::on_pushButton_clicked()
{
    int result = QInputDialog::getInt(this,"整数输入对话框","请输入一个整数: ");
    qDebug() << result;
}

执行程序
在这里插入图片描述
代码示例:打开选择条目对话框
在这里插入图片描述

void MainWindow::on_pushButton_2_clicked()
{
    QStringList items;
    items.push_back("1");
    items.push_back("2");
    items.push_back("3");
    items.push_back("4");
    QString item = QInputDialog::getItem(this,"条目输入对话框","请输入条目",items);
    qDebug() << item;
}

运行程序,查看效果
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/424253.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【高级数据结构】Trie树

原理 介绍 高效地存储和查询字符串的数据结构。所以其重点在于&#xff1a;存储、查询两个操作。 存储操作 示例和图片来自&#xff1a;https://blog.csdn.net/qq_42024195/article/details/88364485 假设有这么几个字符串&#xff1a;b&#xff0c;abc&#xff0c;abd&…

基于springboot+vue的高校教师科研管理系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

Redis高级特性和应用(发布、订阅、Stream、慢查询、Pipeline、事务、Lua)

Redis高级特性和应用 发布和订阅 Redis提供了基于“发布/订阅”模式的消息机制&#xff0c;此种模式下&#xff0c;消息发布者和订阅者不进行直接通信,发布者客户端向指定的频道( channel)发布消息&#xff0c;订阅该频道的每个客户端都可以收到该消息。 操作命令 Redis主要…

手写 Attention 迷你LLaMa2——LLM实战

https://github.com/Yuezhengrong/Implement-Attention-TinyLLaMa-from-scratch 1. Attention 1.1 Attention 灵魂10问 你怎么理解Attention&#xff1f; Scaled Dot-Product Attention中的Scaled&#xff1a; 1 d k \frac{1}{\sqrt{d_k}} dk​ ​1​ 的目的是调节内积&…

OpenAI划时代大模型——文本生成视频模型Sora作品欣赏(十三)

Sora介绍 Sora是一个能以文本描述生成视频的人工智能模型&#xff0c;由美国人工智能研究机构OpenAI开发。 Sora这一名称源于日文“空”&#xff08;そら sora&#xff09;&#xff0c;即天空之意&#xff0c;以示其无限的创造潜力。其背后的技术是在OpenAI的文本到图像生成模…

BUGKU bp

打开环境&#xff0c;他提示了弱密码top1000&#xff0c;随便输入密码123抓包爆破 发现长度都一样&#xff0c;看一下响应发现一段js代码&#xff0c;若r值为{code: bugku10000}&#xff0c;则会返回错误&#xff0c;通过这一句“window.location.href success.php?coder.cod…

【软考】设计模式之访问者模式

目录 1. 说明2. 应用场景3. 结构图4. 构成5. java示例5.1 喂动物5.1.1 抽象访问者5.1.2 具体访问者5.1.3 抽象元素5.1.4 具体元素5.1.5 对象结构5.1.6 客户端类5.1.7 结果示例 5.2 超市销售系统5.2.1 业务场景5.2.2 业务需求类图5.2.3 抽象访问者5.2.4 具体访问者5.2.5 抽象元素…

实战:Oracle Weblogic 11g配置无密码启动,启动关闭脚本,修改节点内存

导读 上篇博文介绍了Oracle Weblogic 11g的安装部署&#xff0c;本文介绍Weblogic安装后的基本配置 包括&#xff1a;设置weblogic启动关闭的无密码验证&#xff0c;启动关闭脚本&#xff0c;修改默认的节点内存。 1、配置无密码启动 [weblogicw1 base_domain]$ cd servers/ […

C#,无监督的K-Medoid聚类算法(K-Medoid Algorithm)与源代码

1 K-Medoid算法 K-Medoid&#xff08;也称为围绕Medoid的划分&#xff09;算法是由Kaufman和Rousseeuw于1987年提出的。中间点可以定义为簇中的点&#xff0c;其与簇中所有其他点的相似度最小。 K-medoids聚类是一种无监督的聚类算法&#xff0c;它对未标记数据中的对象进行聚…

计算机网络|Socket

文章目录 Socket并发socket Socket Socket是一种工作在TCP/IP协议栈上的API。 端口用于区分不同应用&#xff0c;IP地址用于区分不同主机。 以下是某一个服务器的socket代码。 其中with是python中的一个语法糖&#xff0c;代表当代码块离开with时&#xff0c;自动对s进行销毁…

Java 石头剪刀布小游戏

一、任务 编写一个剪刀石头布游戏的程序。程序启动后会随机生成1~3的随机数&#xff0c;分别代表剪刀、石头和布&#xff0c;玩家通过键盘输入剪刀、石头和布与电脑进行5轮的游戏&#xff0c;赢的次数多的一方为赢家。若五局皆为平局&#xff0c;则最终结果判为平局。 二、实…

chrome选项页面options page配置

options 页面用以定制Chrome浏览器扩展程序的运行参数。 通过Chrome 浏览器的“工具 ->更多工具->扩展程序”&#xff0c;打开chrome://extensions页面&#xff0c;可以看到有的Google Chrome扩展程序有“选项Options”链接&#xff0c;如下图所示。单击“选项Options”…

Redis 命令全解析之 List类型

文章目录 命令RedisTemplate API使用场景 Redis 的 List 是一种有序、可重复、可变动的数据结构&#xff0c;它基于双向链表实现。在Redis中&#xff0c;List可以存储多个相同或不同类型的元素&#xff0c;每个元素在List中都有一个对应的索引位置。这使得List可以用来实现队列…

Java中线程安全的集合类

在先前的文章中我们已经讲过了原子类(线程安全的基本类型&#xff0c;基于CAS实现)&#xff0c;详见常见锁策略&#xff0c;synchronized内部原理以及CAS-CSDN博客 &#xff0c;我们在来讲一下集合类&#xff0c;在原来的集合类&#xff0c;大多数是线程不安全的&#xff0c;虽…

ABAP - SALV教程11 红黄绿灯

SALV通过某列设置成异常列&#xff0c;SALV就会根据某列的值自动映射成红黄绿灯注意事项 该列的类型为CHAR1,即是结构的字段类型为CHAR1该字段的值赋值为 (space,1,2,3) space&#xff1a;灰灯、1&#xff1a;红灯、2&#xff1a;黄灯、3&#xff1a;绿灯 案例代码 CLASS lcl…

一份简单的前端开发指南

文章目录 一、HTML1、表格2、常见标签3、行内、块级4、行内块级元素 二、CSS1、三种样式2、链接样式3、浮动4、清除浮动5、伪类&#xff0c;伪元素6、position7、后代选择器8、弹性布局 三、JavaScripts1、null和undefined的区别2、var let const3、原生数据类型4、双等和三等5…

Qt 简约美观的加载动画 文本风格 第八季

今天和大家分享一个文本风格的加载动画, 有两类,其中一个可以设置文本内容和文本颜色,演示了两份. 共三个动画, 效果如下: 一共三个文件,可以直接编译 , 如果对您有所帮助的话 , 不要忘了点赞呢. //main.cpp #include "LoadingAnimWidget.h" #include <QApplic…

Github 2024-03-03 开源项目日报Top9

根据Github Trendings的统计&#xff0c;今日(2024-03-03统计)共有9个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量非开发语言项目4Rust项目1C项目1Jupyter Notebook项目1Python项目1Shell项目1 任天堂Switch模拟器yuzu&#x…

13-微服务初探-自研微服务框架

微服务初探 1. 架构变迁之路 1.1 单体架构 互联网早期&#xff0c;一般的网站应用流量较小&#xff0c;只需要一个应用&#xff0c;将所有的功能代码都部署在一起就可以&#xff0c;这样可以减少开发&#xff0c;部署和维护的成本。 比如说一个电商系统&#xff0c;里面包含…

【每日刷题】数组-LC56、LC238、随想录1、LC560

1. LC56 合并区间 题目链接 Arrays.sort先让intervals里的子数组按照子数组的第一个数字值从小到大排列。开一个新数组&#xff0c;newInterval&#xff0c;存放合并好的子数组让intervals的当前子数组i的第一个数字与newInterval的当前子数组index的最后一个数字比较大小&am…