[2023.4.3] 修改整理添加目录
文章目录
参考视频:https://www.bilibili.com/video/BV1g4411H78N
在VS2017里配置的Qt5均运行成功
善用qDebug()调试
对象模型(对象树):一定程度上简化了内存的回收机制
Qt中的对象树 当父对象析构时所有子对象也会被析构 局部对象的析构顺序应该按照其创建顺序的相反过程(和C++一样)
在Qt中,尽量在构造的时候就指定parent对象,并大胆在堆上创建。
Qt窗口坐标体系 以左上角为原点(0,0),x向右增加,y向下增加
***信号和槽机制 槽(slots)信号(signals)
connect(信号的发送者,发送的具体信号,信号的接收者,信号的处理(槽))
信号槽的优点,松散耦合,信号发送端和接收端本身是没有关联的,通过connect连接将两端耦合在一起。
一些控件通用的基础操作
//设置父亲
btn->setParent(this);
//重置窗口大小
resize(600,600);
//移动
btn->move(100,100);
//设置窗口标题
setWindowTitle("First Windoe");
//设置固定窗口大小
setFixedSize(600,600);
//设置背景图片
setAutoFillBackground(true);
Qpalette pal=this->palette();
pal.setBrush(backgroundRole(),QPixmap("./images/background.png"));
setPalette(pal);
//设置全屏显示
setParent(0);
showFullScreen();
//无边框设置可以鼠标缩放窗口
setWindowFlags(Qt::CustomizeWindowHint);
//无边框设置不可以鼠标缩放窗口
setWindowFlags(Qt::FramelessWindowHint);
//点击按钮关闭窗口
//参数1:信号的发送者 参数2:发送的信号(函数的地址) 参数3:信号的接收者 参数4:处理的槽函数
connect(mybtn,&QPushButton::clicked,this,&myWidget::close);
//QPushButton的父类QAbstractButton所包含的四个signals
void clicked(bool checked=false) //按钮点击
void pressed() //按下按钮
void released() //释放按钮
void toggled(bool checked) //切换 类似于灯的开关
//自定义的信号和槽
signals:
//自定义信号写到signals下
//返回值是void,只需要声明,不需要实现
//可以有参数,可以重载
void hungry(); //teacher
public slots:
//早期Qt版本,槽函数必须写到public slots,高级版本可以写道public或全局下
//返回值void,需要声明,也需要实现
//可以有参数,可以发生重载
void treat();//在.cpp实现
//触发自定义的信号
//emit自定义信号
emit 对象->信号函数();
//当自定义信号和槽出现重载
//需要利用函数指针 明确指向函数的地址
void( Teacher::* teacherSignal)(QString)=&Teacher::hungry;
//QString转成Char *
//1.ToUtf8()转为QByteArray
//2. .Data()转为Char *
信号可以连接信号
断开信号disconnect(和connect内容一致断谁写谁)
拓展
1.信号是可以连接信号
2.一个信号可以连接多个槽函数
3.多个信号可以连接同一个槽函数
4.信号和槽函数的参数必须类型一一对应
5.信号和槽参数个数不一定一致 信号可以多于槽
菜单栏、工具栏、状态栏、铆接部件、浮动窗口、核心部件
#pragma execution_character_set("utf-8")
#include "qtlearn.h"
#include<QMenuBar>
#include<QToolBar>
#include<QDebug>
#include<QPushButton>
#include<QStatusBar>
#include<QLabel>
#include<QDockWidget>
#include<QTextEdit>
qtlearn::qtlearn(QWidget *parent)
: QMainWindow(parent)
{
ui.setupUi(this);
//重置窗口大小
resize(600, 400);
//菜单栏 最多只能有一个
//菜单栏创建
QMenuBar * bar = menuBar();
//将菜单栏放入到窗口中
setMenuBar(bar);
//创建菜单
QMenu *fileMenu = bar->addMenu("文件");
QMenu *editMenu = bar->addMenu("编辑");
//创建菜单项
QAction * newAction=fileMenu->addAction("新建");
//添加分隔线
fileMenu->addSeparator();
QAction * openAction=fileMenu->addAction("打开");
//工具栏 可以有多个
QToolBar * toolBar = new QToolBar(this);
addToolBar(Qt::LeftToolBarArea,toolBar);
//后期设置 只允许 左右停靠
toolBar->setAllowedAreas(Qt::LeftToolBarArea | Qt::RightToolBarArea);
//设置浮动
toolBar->setFloatable(false);
//设置移动(总开关)
toolBar->setMovable(false);
//工具栏中可以设置内容
toolBar->addAction(newAction);
//添加分割线
toolBar->addSeparator();
toolBar->addAction(openAction);
//工具栏中添加控件
QPushButton * btn = new QPushButton("aa", this);
toolBar->addWidget(btn);
//状态栏 最多有一个
QStatusBar * stBar = statusBar();
//设置到窗口中
setStatusBar(stBar);
//放标签控件
QLabel * label = new QLabel("提示信息", this);
stBar->addWidget(label);
QLabel * label2 = new QLabel("右侧提示信息", this);
stBar->addPermanentWidget(label2);
//铆接部件 (浮动窗口) 可以有多个
QDockWidget * dockWidget = new QDockWidget("浮动", this);
addDockWidget(Qt::BottomDockWidgetArea, dockWidget);
//设置后期停靠区域,只允许上下
dockWidget->setAllowedAreas(Qt::TopDockWidgetArea | Qt::BottomDockWidgetArea);
//设置核心部件 只能有一个
QTextEdit * edit = new QTextEdit(this);
setCentralWidget(edit);
}
对话框:
分类:模态对话框、非模态对话框
消息对话框、其他标准对话框
#pragma execution_character_set("utf-8")
#include "QtWidgetsApplication3.h"
#include"ui_QtWidgetsApplication3.h"
#include<QDialog>
#include<QDebug>
QtWidgetsApplication3::QtWidgetsApplication3(QWidget *parent)
: QMainWindow(parent)
{
ui.setupUi(this);
//点击新建按钮 弹出一个对话框
connect(ui.actionnew,&QAction::triggered,[=]() {
//对话框 分类
//模态对话框(不可以对其他窗口进行操作) 非模态对话框(可以对其他窗口进行操作)
//模态创建 阻塞
QDialog dlg(this);
dlg.resize(200, 100);
dlg.exec();
qDebug() << "模态的对话框弹出了";
//非模态对话框 防止一闪而过创建堆区
QDialog * dlg2=new QDialog(this);
dlg2->resize(200, 100);
dlg2->show();
dlg2->setAttribute(Qt::WA_DeleteOnClose);//55号属性
qDebug() << "非模态的对话框弹出了";
});
}
//消息对话框
//错误对话框
QMessageBox::critical(this, "critical", "错误");
//信息对话框
QMessageBox::information(this, "info", "信息");
//提问对话框
//参数1 父亲 参数2 标题 参数3 提示内容 参数4 按键类型 参数5 默认关联回车的按键
QMessageBox::question(this, "ques", "提问",QMessageBox::Save|QMessageBox::Cancel,QMessageBox::Cancel);
if (QMessageBox::Save == QMessageBox::question(this, "ques", "提问", QMessageBox::Save | QMessageBox::Cancel, QMessageBox::Cancel)) {
qDebug()<<"选择的是保存";
}
else {
qDebug()<<"选择的是取消";
}
//警告对话框
QMessageBox::warning(this, "warning", "警告");
//其他标准对话框
//颜色对话框
QColor color=QColorDialog::getColor(QColor(255, 0, 0));
qDebug() << "r=" << color.red() << "g=" << color.green() << "b=" << color.blue();
//文件对话框 参数1 父亲 参数2 标题 参数3 默认打开路径 参数4 过滤文件格式
//返回值是 选择的路径
QString str=QFileDialog::getOpenFileName(this, "打开文件", "C:\\Users\\78286\\Desktop\\图片","(*.txt)");
qDebug() << str;
//字体对话框
bool flag;
QFont font=QFontDialog::getFont(&flag, QFont("微软雅黑", 36));
qDebug() << "字体:" << font.family().toUtf8().data() << "字号:" << font.pointSize() << "是否加粗" << font.bold() << "是否倾斜:" << font.italic();
控件:
按钮组:
QPushButton 常用按钮
QToolButton 工具按钮 用于显示图片,如图想显示文字,修改风格:toolButtonStyle,凸起风格 autoRaise
radioButton 单选按钮,设置默认 ui.radioButtonMan->setChecked(true);
checkbox 多选按钮,监听状态,2选中 1半选 0未选中
QListWidget列表容器
QListWidget * item 一行内容
ui.listWidget->addItem(item)
设置居中方式item->setTextAlignment(Qt::AlighHCenter);
可以利用addItems一次性添加整个诗内容
#pragma execution_character_set("utf-8")
#include "Contral.h"
#include"ui_Contral.h"
#include<qdebug.h>
#include<qcheckbox.h>
Contral::Contral(QWidget *parent)
: QWidget(parent)
{
ui.setupUi(this);
//设置单选按钮 男默认选中
ui.radioButtonMan->setChecked(true);
//选中女后 打印信息
connect(ui.radioButtonWoman, &QRadioButton::clicked, [=]() {
qDebug() << "选中了女";
});
//多选按钮 2是选中 0是未选中
connect(ui.checkBox_3, &QCheckBox::stateChanged, [=](int state) {
qDebug() << state;
});
//利用listWidget写诗
QListWidgetItem * item = new QListWidgetItem("one more time with feeling");
//将一行诗放入到listWidget控件中
ui.listWidget->addItem(item);
item->setTextAlignment(Qt::AlignHCenter);
//QStringList QList<QString>
QStringList list;
list << "one" << "two" << "three" << "four";
ui.listWidget->addItems(list);
}
QTreeWidget 树控件
#pragma execution_character_set("utf-8")
#include "Contral.h"
#include"ui_Contral.h"
#include<qdebug.h>
#include<qcheckbox.h>
#include<qlistwidget.h>
#include<qtreewidget.h>
Contral::Contral(QWidget *parent)
: QWidget(parent)
{
ui.setupUi(this);
//treeWidget树控件使用
//设置水平头
ui.treeWidget->setHeaderLabels(QStringList() << "英雄" << "英雄介绍");
QTreeWidgetItem * liItem = new QTreeWidgetItem(QStringList() << "力量");
QTreeWidgetItem * minItem = new QTreeWidgetItem(QStringList() << "敏捷");
QTreeWidgetItem * zhiItem = new QTreeWidgetItem(QStringList() << "智力");
//加载顶层的节点
ui.treeWidget->addTopLevelItem(liItem);
ui.treeWidget->addTopLevelItem(minItem);
ui.treeWidget->addTopLevelItem(zhiItem);
//追加子节点
QStringList hero1;
hero1 << "dd" << "击打空中目标";
QTreeWidgetItem * l1 = new QTreeWidgetItem(hero1);
liItem->addChild(l1);
}
QTableWidget表格控件
#include "TableWidget.h"
TableWidget::TableWidget(QWidget *parent)
: QWidget(parent)
{
ui.setupUi(this);
//TableWidget控件
//设置列数
ui.tableWidget->setColumnCount(3);
//设置水平表头
ui.tableWidget->setHorizontalHeaderLabels(QStringList() << "姓名" << "性别" << "年龄");
//设置行数
ui.tableWidget->setRowCount(5);
//设置正文
//ui.tableWidget->setItem(0, 0, new QTableWidgetItem("亚瑟"));
QStringList nameList;
nameList << "亚瑟" << "赵云" << "张飞" << "关羽" << "花木兰";
QList<QString> sexList;
sexList << "男" << "男" << "男" << "男" << "女";
for (int i = 0; i < 5; i++) {
int col = 0;
ui.tableWidget->setItem(i, col++, new QTableWidgetItem(nameList[i]));
ui.tableWidget->setItem(i, col++, new QTableWidgetItem(sexList.at(i)));
//int 转 QString
ui.tableWidget->setItem(i, col++, new QTableWidgetItem(QString::number(i+18)));
}
}
TableWidget::~TableWidget()
{
}