当前位置: 首页 > article >正文

QT中的信号槽

1.解释说明

        1- qt中一般是使用信号槽来绑定对应的事件

        2- 可以在初始化中调用connect来调用

        3- 这里分别用头文件、源文件、界面文件去写示例

2.头文件.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui {
class MainWindow;
}
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:
    void on_pushButton_2_clicked();

    void on_pushButton_clicked();

    void on_radioButton_clicked();

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H

3.源文件.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"

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

    //此处就为信号槽,连接一个对象和另一个对象的槽;当pushButton按钮进行点击时,则触发MainWindow::on_pushButton_2_clicked()的方法。
    QObject::connect(ui->pushButton, &QPushButton::clicked, this, & MainWindow::on_pushButton_2_clicked);

}

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

void MainWindow::on_pushButton_2_clicked()
{

}


void MainWindow::on_pushButton_clicked()
{

}


void MainWindow::on_radioButton_clicked()
{

}

4.界面文件.ui

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>MainWindow</class>
 <widget class="QMainWindow" name="MainWindow">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>300</width>
    <height>300</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>MainWindow</string>
  </property>
  <widget class="QWidget" name="centralwidget">
   <widget class="QRadioButton" name="radioButton">
    <property name="geometry">
     <rect>
      <x>80</x>
      <y>250</y>
      <width>72</width>
      <height>16</height>
     </rect>
    </property>
    <property name="text">
     <string>RadioButton</string>
    </property>
   </widget>
   <widget class="QWidget" name="verticalLayoutWidget">
    <property name="geometry">
     <rect>
      <x>20</x>
      <y>60</y>
      <width>160</width>
      <height>80</height>
     </rect>
    </property>
    <layout class="QVBoxLayout" name="verticalLayout">
     <item>
      <widget class="QPushButton" name="pushButton_2">
       <property name="text">
        <string>PushButton</string>
       </property>
      </widget>
     </item>
     <item>
      <widget class="QPushButton" name="pushButton">
       <property name="text">
        <string>PushButton</string>
       </property>
      </widget>
     </item>
    </layout>
   </widget>
  </widget>
  <widget class="QStatusBar" name="statusbar"/>
 </widget>
 <resources/>
 <connections/>
</ui>


http://www.kler.cn/news/343230.html

相关文章:

  • 游戏开发指南:使用 UOS C# 云函数快速构建与部署服务端逻辑实战教学
  • 【VUE】Vue2与Vue3中的双向数据绑定
  • 《网络基础之 HTTP 协议:常见 HTTP 方法详解》
  • gb28181对接发现信令包被篡改
  • 【M2TR】M2TR: Multi-modal Multi-scale Transformers for Deepfake Detection
  • Android Automotive(一)
  • SQL第13课挑战题
  • 大数据治理的全面指南
  • 人体工程学视角下的彗星现象
  • 在 EC2 AWS 中开启防火墙后将自己锁定在 SSH 之外
  • 在mybatisPlus项目中引入pageHelper导致依赖冲突
  • SSD |(二)SSD主控
  • 代码训练营 day26|LeetCode 669,LeetCode 108,LeetCode 538
  • Leetcode 486. 预测赢家
  • JavaEE一条龙学习----前端开发准备(二)
  • MacOS M系列芯片安装部署 ComfyUI 快速手册
  • vue2中 vue-count-to组件让数字从某个数字动态的显示到某个数字(后附vue3的用法)
  • 开关打开输入框才能输入文字,否则为禁用状态
  • ACR、PZ、AMC仪表接线说明及通讯协议解析
  • Linux系统:apt-get update 和apt update区别