【Opencv&Cpp】05 处理图片:图像像素的算术操作--图片亮度、

// 加减乘除
    //dst = image - Scalar(50, 50, 50);//小心溢出;
    //dst = image -Scalar(50, 50, 50);//小心溢出;
    //divide(image, m, dst);
    //multiply(image, m, dst);

加法--提亮

Mat dst;

dst=image+Scalar(50,50,50);  //不过要防止数据丢失

 

 

 减法同理

Mat dst;

dst=image-Scalar(50,50,50);  //不过要防止数据丢失

 

乘、除法

Mat dst1 = Mat::zeros(image.size(), image.type());
Mat dst2 = Mat::zeros(image.size(), image.type());
Mat m = Mat::zeros(image.size(), image.type());

m = Scalar(2, 2, 2);

divide(image, m, dst1);
multiply(image, m, dst2);

imshow("原图", image);
imshow("除操作", dst1);
imshow("乘操作", dst2);

 

实质

int w = dst.cols;//列数
	int h = dst.rows;//行数

	dst = Scalar(50, 50, 50);
	for (int row = 0; row < h; row++) {
		for (int col = 0; col < w; col++) {	
		
			Vec3b p1 = image.at<Vec3b>(row, col);
			Vec3b p2 = dst.at<Vec3b>(row, col);
				dst.at<Vec3b>(row, col)[0] = saturate_cast<uchar>(p1[0] + p2[0]);  //防止溢出
				dst.at<Vec3b>(row, col)[1] = saturate_cast<uchar>(p1[1] + p2[1]);
				dst.at<Vec3b>(row, col)[2] = saturate_cast<uchar>(p1[2] + p2[1]);
		}
	}
	
	imshow("原图", image);
	imshow("操作", dst);	

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值