zoukankan      html  css  js  c++  java
  • Qt信号与槽自动关联机制

    参考链接1:http://blog.csdn.net/skyhawk452/article/details/6121407

    参考链接2:http://blog.csdn.net/memory_exception/article/details/50953005

    信号与槽可以通过使用手写代码显式的实现关联 ,也可以运用 QMetaObject 类规定的槽 函数命名范式来实现自动关联。

    1. 显示关联
      1.  class MyWidget : public QWidget
         {
             Q_OBJECT
        
         public:
             MyWidget();
        
         signals:
             void buttonClicked();
        
         private:
             QPushButton *myButton;
         };
        
         MyWidget::MyWidget()
         {
             myButton = new QPushButton(this);
             connect(myButton, SIGNAL(clicked()),
                     this, SIGNAL(buttonClicked()));
    2. 自动关联
      • 为了实现槽函数自动进行关联,对于Qt窗口部件已经提供的信号,可按照以下规范命名:
         void on_<窗口部件名称>_<信号名称>_(<信号参数>);
      • 看如下实例:
        #include "mainwindow.h"
        #include "ui_mainwindow.h"
        
        MainWindow::MainWindow(QWidget *parent) :
            QMainWindow(parent),
            ui(new Ui::MainWindow)
        {
            ui->setupUi(this);
            QString a = "calculate";
            setWindowTitle(tr("%1").arg(a));
            //connect(ui->calButton,SIGNAL(clicked()),this,SLOT(on_calButton_clicked()));
            //QMetaObject::connectSlotsByName(this);
        }
        
        MainWindow::~MainWindow()
        {
            delete ui;
        }
        
        void MainWindow::on_calButton_clicked()
        {
            int a = (ui->firstLineEdit->text()).toInt() + (ui->secondLineEdit->text()).toInt();
            ui->resultLineEdit->setText(tr("%1").arg(a));
        }
      • 若未能自动关联,需要显示调用connectSlotByName(),调用方法如上注释处,详细请参照官方帮助文档:
  • 相关阅读:
    生信入门-爱课程上的华中农业大学
    PAT 1115 Counting Nodes in a BST[构建BST]
    PAT 1133 Splitting A Linked List[链表][简单]
    PAT 1037 Magic Coupon[dp]
    PAT 1033 To Fill or Not to Fill[dp]
    畅通工程续 HDU1874
    Free DIY Tour HDU1224
    六度分离 HDU1869
    Arbitrage HDU1217
    floyed算法
  • 原文地址:https://www.cnblogs.com/lxmwb/p/6220733.html
Copyright © 2011-2022 走看看