void(InputArray src1, double alpha, InputArray src2, double beta, double gamma, OutputArray dst, int dtype=-1);
- 第一个参数,InputArray类型的src1,表示需要加权的第一个数组,一般是一个Mat;
- 第二个参数,double类型的alpha,表示第一个数组的权重
- 第三个参数,InputArray类型的src2,表示需要加权的第二个数组,它需要和第一个数组拥有相同的尺寸和通道数;
- 第四个参数,double类型的beta,表示第二个数组的权重;
- 第五个参数,double类型的gamma,加到权重总和上的标量值(类似于偏置);
- 第六个参数,OutputArray类型的dst,输出的数组,它和输入的两个数组有相同的尺寸和通道数;
- 第七个参数,int类型的dtype,输出阵列的可选深度,默认值是-1。当两个输入数组有相同的深度时,设置为-1.
下面数学公式表示:用addWeighted函数计算两个数组的加权和:
dst = src1 * alpha + src2 * beta + gamma;
代码示例:
int main() {
Mat src1 = imread("/Users/dwz/Desktop/cpp//mogu.jpg");
Mat src2 = imread("/Users/dwz/Desktop/cpp/rain.jpg");
double alpha = 0.5;
double beta = 1 - alpha;
double gamma = 0;
Mat dst;
addWeighted(src1, alpha, src2, beta, gamma, dst, -1);
imwrite("addweighted.jpg", dst);
return 0;
}
输入图像:
输出: