2.21号qt

本文详细介绍了在Qt中,如何使用QMainWindow及其子类如QMenuBar、QToolBar、QStatusBar和QDockWidget,以及如何通过信号与槽机制进行组件间的通信,包括UI界面连接、手动连接、自定义信号触发和断开连接的方法。
摘要由CSDN通过智能技术生成

1.QMainWindow中常用的类

继承于QMainWindow类,原因该类提供了QWidget没有提供的成员函数。

菜单栏、工具栏、状态栏、浮动窗口(铆接部件)、核心部件

1.1 菜单栏 QMenuBar

    //创建菜单栏 QMenuBar  最多只能有一个
    QMenuBar *mbar = menuBar();
    //将菜单栏放入窗口中
    this->setMenuBar(mbar);
    //往菜单栏里增加菜单
    QMenu *file = mbar->addMenu("文件");
    QMenu *edit = mbar->addMenu("编辑");
    //往菜单中增加菜单项
    file->addAction("新建");
    //增加分隔符
    file->addSeparator();
    file->addAction("打开");

1.2 工具栏 QToolBar

  //创建工具栏 QToolBar  可以有多个
    QToolBar *tbar = new QToolBar(this);
    //将工具栏放入窗口中  设置停靠区域
    this->addToolBar(Qt::LeftToolBarArea,tbar);
    //后期设置 只允许左右停靠
    tbar->setAllowedAreas(Qt::LeftToolBarArea | Qt::RightToolBarArea);
    //不允许浮动
    tbar->setFloatable(false);
    //往工具栏中增加工具项
    tbar->addAction("欢迎");


    //实例化一个按钮
    QPushButton *btn = new QPushButton(this);
    btn->setText("编辑");
    //将按钮放入工具栏中
    tbar->addWidget(btn);

1.3 状态栏 QStatusBar

    //创建状态栏 QStatusBar  最多只能有一个
    QStatusBar *sbar = statusBar();
    //将状态栏放入窗口中
    this->setStatusBar(sbar);


    //实例化一个标签
    QLabel *lab = new QLabel("问题",this);
    //将标签放入状态栏中
    //sbar->addWidget(lab);//默认从左边显示
    sbar->addPermanentWidget(lab); //默认从右边显示

1.4 浮动窗口 QDockWidget

   //创建浮动窗口  QDockWidget 可以有多个
    QDockWidget *dock = new QDockWidget("浮动窗口",this);
    //将浮动窗口放入界面中
    this->addDockWidget(Qt::BottomDockWidgetArea,dock);
    //后期设置 只允许左右停靠
    dock->setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);


    //创建中心部件  最多只能有一个
    QTextEdit *text_edit = new QTextEdit(this);
    //将中心部件放入窗口中
    this->setCentralWidget(text_edit);

2.ui界面文件

1> ui界面文件是在项目工程文件的Forms文件夹下(XXX.ui)

2> ui界面上可以通过ui指针访问到ui界面上的所有组件。

3.信号与槽

qt以引为傲的核心机制:对象树、信号与槽、事件机制

1> 信号和槽是qt的核心机制之一,可以实现多个组件之间的通信。

2> 信号:信号函数。信号定义在类体的signals权限下,信号函数是一个不完整的函数,只需要声明,不需要实现。

3> 槽:槽函数。槽定义在类体的slots权限下,槽函数是一个完整的函数,既要有声明,也要有定义。该函数可以当成普通函数使用。

4> 任意一个组件都有系统提供的信号和槽。

3.1 带有信号和槽的类体定义

signals: //信号权限,该权限下函数 都是信号
    void my_signal(); //只需要声明 不需要实现
    
    
public slots: //槽函数权限  ,该权限下函数 都是槽函数
    void my_slot(); //需要声明 也要实现

3.2 信号和槽的连接方式

3.2.1

基于ui界面上的连接,在ui界面下的信号和槽区,将系统提供的信号和槽进行连接。

该连接,无需手动书写信号函数、槽函数、连接函数

3.2.2

基于ui界面上的连接,在组件上,右击转到槽,选中要发射的信号,在槽函数中处理相关逻辑代码。

该连接,无需手动书写信号函数、连接函数

3.2.3

手动连接信号和槽,基于qt4版本的连接,该连接是不友好的连接。

需要使用connect连接函数进行连接,在QObject类中

[static] QMetaObject::Connection //函数的返回值类型  静态成员函数
    QObject::connect( //函数名
        const QObject *sender, //发送者 组件的指针
        const char *signal, //发送的信号 信号的函数 应该用函数指针接收 不能用char *接收 所以需要使用宏函数转换
        const QObject *receiver, //接受者 组件的指针
        const char *method, // 槽函数 应该用函数指针接收 不能用char *接收 所以需要使用宏函数转换
        )

信号宏函数 SIGNAL()
槽宏函数 SLOT()

3.2.4

手动连接信号和槽,基于qt5版本的连接,该连接就是友好的连接

需要使用connect连接函数进行连接,在QObject类中

[static] QMetaObject::Connection //函数返回值类  静态函数
    QObject::connect( //函数名
        const QObject *sender, //信号的发送者  组件的指针
        PointerToMemberFunction signal, //信号函数  可以直接传函数名 原因是函数指针接收
        const QObject *receiver, //信号的接收者  组件的指针
        PointerToMemberFunction method, //槽函数 可以直接传函数名 原因是函数指针接收
        )

3.2.5

手动连接信号和功能函数,如果信号一旦被触发,则自动执行功能函数中的内容。

功能函数:全局函数、lambda表达式

[static] QMetaObject::Connection 
    QObject::connect(
        const QObject *sender, 
        PointerToMemberFunction signal, 
        Functor functor//功能函数
        )

3.3 自定义的信号

自定义的信号,定义在signals权限下,是一个不完整的函数,只要声明,不要实现。

自定义 的信号,需要手动触发,使用emit关键字进行发射信号,如果自定义的信号一旦被发射,则会自动执行对应的槽函数处理

3.4 断开连接

disconnect()和connect()函数的参数一样

作业

#include "widget.h"
#include "ui_widget.h"

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



    connect(ui->btn1,SIGNAL(clicked()),this,SLOT(close()));

    connect(ui->logbtn,&QPushButton::clicked,this,&Widget::my_slot1);


}

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

void  Widget::my_slot1()
{
    QString uname;
    QString pword;
    uname=ui->ed1->text();
    pword=ui->ed2->text();

    if(uname=="admin" && pword=="123456")
    {
        qDebug() << "登录成功" ;
        this->close();
    }
    else
    {
        qDebug() << "登录失败";
        ui->ed2->clear();
    }


}

  • 11
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值