QSignalMapper使用以及替换方法
一、主要功能:
这个类收集一组无参数信号,并使用与发送信号的对象对应的整数、字符串或小部件参数重新发出它们。
该类支持使用setMapping()将特定字符串或整数映射到特定对象。然后可以将对象的信号连接到map()槽,该槽将发出带有与原始信令对象关联的字符串或整数的mapped()信号。
稍后可以使用removememing()来删除映射。
QSignalMapper支持的类型:int、QString、QWidget、QObject
setMapping()与重载函数:
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);
mapped()信号与重载函数:
Q_SIGNALS:
void mapped(int);
void mapped(const QString &);
void mapped(QWidget *);
void mapped(QObject *);
二、使用方式
这里实现这么一个小示例,生成一组按钮,在某一个按钮发生点击事件的时候,有一个带有QString参数的插槽来响应该次点击。
QSignalMapper* pMap = new QSignalMapper();
for (int i = 0; i < 5; ++i)
{
QString strBtnText = "button" + QString::number(i);
QPushButton* pButton = new QPushButton(strBtnText);
connect(pButton, SIGNAL(clicked()), pMap , SLOT(map()));
pMap ->setMapping(pButton, strBtnText);
}
connect(pMap , SIGNAL(mapped(QString)), this, SIGNAL(clicked(QString)));
核心的部分:
connect(pButton, SIGNAL(clicked()), pMap , SLOT(map()));
pMap ->setMapping(pButton, strBtnText);
可以自定义关联的值,每次信号发出时,都会发出该值。
实现效果:
三、替换方法
QSignalMapper的实现效果可以使用Lambda 来实现
上面的示例,使用Lambda来实现:
{
connect(pButton, &QPushButton::clicked, [=] {
clicked(strBtnText);
});
}
Lambda 格式: –capture->return-type{body}
[] //未定义变量.试图在Lambda内使用任何外部变量都是错误的.
x, &y //x 按值捕获, y 按引用捕获.
& //用到的任何外部变量都隐式按引用捕获
= //用到的任何外部变量都隐式按值捕获
&, x //x显式地按值捕获. 其它变量按引用捕获
=, &z //z按引用捕获. 其它变量按值捕获
{ return x + y; } // 隐式返回类型
{ ++x; } // 没有return语句 -> lambda 函数的返回类型是'void'
{ ++global_x; } // 没有参数,仅访问某个全局变量
[]{ ++global_x; } // 与上一个相同,省略了()
- 黑客是如何实施暴力破解的?
- Python的初学者你现在可以自己“看”到代码的运行了!
- ASP.NET Core的配置(3): 将配置绑定为对象[下篇]
- TensorFlow 深度学习笔记 从线性分类器到深度神经网络
- 微信版12306来了!用12306微信小程序买票靠谱吗
- 无需写try/catch,也能正常处理异常
- “人工智能毁灭人类”是一种末世恐惧传染病
- 有状态(Stateful)应用的容器化
- 实现一些字符串操作标准库函数、解决一些字符串问题
- 外卖陷阱,你入坑了么?
- ASP.NET Core的配置(4):多样性的配置来源[上篇]
- 37 个你必须知道的现代数据中心术语
- Python读书笔记7
- 2017年人工智能在游戏领域打败人类,未来我们将何去何从?
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法