Menu菜单 或 其中的QAction 连接槽函数
以下两句connect 任一均可实现:
QStringList strList;
for(int i = 0; i< strList.size(); ++i)
{
QString tmp = strList.at(i);
QAction *act = new QAction(tmp, m_menu);
act->setCheckable(true);
act->setChecked(false);
m_menu->addAction(act);
connect(act, SIGNAL(triggered()), this, SLOT(checkedAction()));
}
//connect(m_menu, SIGNAL(triggered(QAction*)), this, SLOT(checkedLibAction(QAction*)));
QSignalMapper
signalMapper = new QSignalMapper(this);
for (int i = 0; i < texts.size(); ++i) {
QPushButton *button = new QPushButton(texts[i]);
connect(button, SIGNAL(clicked()), signalMapper, SLOT(map()));
signalMapper->setMapping(button, texts[i]);
}
connect(signalMapper, SIGNAL(mapped(QString)), this, SIGNAL(clicked(QString)));
QSignalMapper 官方介绍:
The QSignalMapper class bundles signals from identifiable senders.
void setMapping(QObject *sender, int id);
void setMapping(QObject *sender, const QString &text);
void setMapping(QObject *sender, QWidget *widget);
void setMapping(QObject *sender, QObject *object);
void removeMappings(QObject *sender);
Q_SIGNALS:
void mapped(int);
void mapped(const QString &);
void mapped(QWidget *);
void mapped(QObject *);
这四种捆绑方式,使用超级灵活。同一个sender在一个map中可以被捆绑多次;
int 型的以及 QString、QWidget等 的Map捆绑互相独立,互不影响。
以及一个 signalMap 的 mapped信号最多可以连接到4个不同类型的槽函数,这四个信号槽相互独立。