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個不同類型的槽函數,這四個信號槽相互獨立。

 

 
       


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM