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