Qt|常规操作函数&&从入门到实战精简内容笔记

[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()
{
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奇树谦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值