C++ opencv之图像像素的算术操作

本文介绍了如何使用C++和OpenCV进行图像像素的加、减、乘、除操作,通过示例展示了API函数的应用,并解释了saturate_cast防止颜色溢出的原理。此外,还讨论了在进行像素乘法操作时遇到的问题及其解决方法。
摘要由CSDN通过智能技术生成

这节课我们来学习图像像素的读写操作。

一、像素的加减乘除操作

1、加法操作:

void QuickDemo::operators_Demo(Mat &image)
{
   
	Mat dst;
	dst = image + Scalar(50, 50, 50);
	imshow("加法操作", dst);
}

输出结果为:
在这里插入图片描述
可以明显的感受到右边这幅图,亮度增强了。

opencv也有现成的api函数像素加法的函数可以使用:

//第一个参数为第一张图片,第二个参数为第二张图片
//第三个参数为输出图片
add(image, m, dst);
void QuickDemo::operators_Demo(Mat &image)
{
   
	Mat dst;
	Mat m = Mat::zeros(image.size(), image.type());
	m= Scalar(50, 50, 50);
	add(image, m, dst);
	imshow("加法操作", dst);
}

在这里插入图片描述
可以看到输出结果是一致的。

那如果opencv没有现成的api函数的话,我们应该如何操作呢?

void QuickDemo::operators_Demo(Mat &image)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值