工程管理文件
QT += core gui
#工程文件项目所包含的类 core核心类 gui图形化界面类
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
#4.0版本后,自动添加widgets库
CONFIG += c++11
#支持C++11
# The following define makes your compiler emit warnings if you use
# any Qt feature that has been marked deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS
# You can also make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
#管理源文件
SOURCES += \
main.cpp \
widget.cpp
#管理头文件
HEADERS += \
widget.h
#管理ui界面文件
FORMS += \
widget.ui
# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target
头文件
//防止重复文件包含
#ifndef WIDGET_H
#define WIDGET_H
//父类的头文件
#include <QWidget>
QT_BEGIN_NAMESPACE
namespace Ui { class Widget; } //命名空间的声明,ui界面生成的头文件中的命名空间
QT_END_NAMESPACE
class Widget : public QWidget //自定义的类,继承子QWidget类
{
Q_OBJECT //处理信号与槽的元对象
signals: //该权限下声明的时信号函数,只有这一个权限
void my_signal(); //信号函数不能直接被调用,调用需要使用关键字emit
public:
Widget(QWidget *parent = nullptr); //构造函数的声明
~Widget(); //析构函数的声明
private slots: //该权限下声明槽函数,也可以是protected和public
void my_slot(); //槽函数可以被当作普通函数使用,但普通函数不能当作槽函数使用
void on_btn2_clicked();
private:
Ui::Widget *ui; //指向ui界面的指针
};
#endif // WIDGET_H
源文件
#include "widget.h" //包含自定义的头文件
#include "ui_widget.h" //包含ui界面的头文件
#include <QDebug>
Widget::Widget(QWidget *parent) //构造函数的实现
: QWidget(parent) //调用父类的构造函数
, ui(new Ui::Widget) //给指针成员初始化空间
{
ui->setupUi(this); //调用ui界面中的设置界面函数
this->setFixedSize(500,400);
//回显模式
ui->lineEdit2->setEchoMode(QLineEdit::Password);
//占位符
ui->lineEdit1->setPlaceholderText("请输入");
ui->lineEdit2->setPlaceholderText("请输入");
//连接信号与槽
connect(ui->btn1,SIGNAL(clicked()),this,SLOT(my_slot()));
}
Widget::~Widget() //析构函数的定义
{
delete ui; //将指针成员释放
}
//登录按钮对应的槽函数
void Widget::my_slot()
{
if(ui->lineEdit1->text()=="admin"&& ui->lineEdit2->text()=="123456")
{
qDebug()<<"登录成功";
close();
}
else
{
qDebug()<<"账号和密码不匹配,请重新输入";
ui->lineEdit2->clear();
}
}
//取消按钮对应的槽函数
void Widget::on_btn2_clicked()
{
close();
}
测试文件
#include "widget.h" //引入自定义的头文件
#include <QApplication> //引入应用程序的头文件
int main(int argc, char *argv[]) //主函数
{
QApplication a(argc, argv); //实例化应用程序的对象
Widget w; //使用自定义对象在栈区实例化一个对象
w.show(); // 调用show将界面显示出来
return a.exec(); //阻塞等待界面处理:等待信号与槽,等待用户操作界面,等待事件发生
}
结果