• Qt菜单 QMenu QAction连接信号槽函数


    Menu菜单 或 其中的QAction 连接槽函数

    以下两句connect 任一均可实现:

     1 QStringList strList;
     2 for(int i = 0; i< strList.size(); ++i)
     3 {
     4     QString tmp = strList.at(i);
     5     QAction *act = new QAction(tmp, m_menu);
     6     act->setCheckable(true);
     7     act->setChecked(false);
     8     m_menu->addAction(act);
     9     connect(act, SIGNAL(triggered()), this, SLOT(checkedAction()));
    10 }
    11 //connect(m_menu, SIGNAL(triggered(QAction*)), this, SLOT(checkedLibAction(QAction*)));

    QSignalMapper 

    1 signalMapper = new QSignalMapper(this);
    2  
    3  for (int i = 0; i < texts.size(); ++i) 
    4 {
    5     QPushButton *button = new QPushButton(texts[i]);
    6     connect(button, SIGNAL(clicked()), signalMapper, SLOT(map()));
    7     signalMapper->setMapping(button, texts[i]);
    8 }
    9 connect(signalMapper, SIGNAL(mapped(QString)), this, SIGNAL(clicked(QString)));

    QSignalMapper 官方介绍:

    The QSignalMapper class bundles signals from identifiable senders.

     1     void setMapping(QObject *sender, int id);
     2     void setMapping(QObject *sender, const QString &text);
     3     void setMapping(QObject *sender, QWidget *widget);
     4     void setMapping(QObject *sender, QObject *object);
     5     void removeMappings(QObject *sender);
     6  
     7 Q_SIGNALS:
     8     void mapped(int);
     9     void mapped(const QString &);
    10     void mapped(QWidget *);
    11     void mapped(QObject *);

    这四种捆绑方式,使用超级灵活。同一个sender在一个map中可以被捆绑多次;

    int 型的以及 QString、QWidget等 的Map捆绑互相独立,互不影响。

    以及一个 signalMap 的 mapped信号最多可以连接到4个不同类型的槽函数,这四个信号槽相互独立。

     

    
    
  • 相关阅读:
    Redis配置文件详解
    linux系统配置Apache虚拟主机实例
    nginx File not found 错误分析与解决方法
    svn配置使用
    linux下svn命令使用大全
    Kendo UI For ASP.NET MVC项目资源
    ReSharper 配置及用法
    SQL判断某列中是否包含中文字符、英文字符、纯数字 (转)
    Visual Studio最好用的快捷键
    19个必须知道的Visual Studio快捷键
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/13632877.html
Copyright © 2020-2023  润新知