【OpenCV 4】图像像素值统计

一、编程环境:

OpenCV 4.1.0
IDEVisual Studio 2017 Enterprise (15.9.13)
操作系统Windows 10 x64 中文专业版 (1903)

二、图像像素值统计:

  • 查找最大值、最小值以及它们所在位置:minMaxLoc()
void minMaxLoc(InputArray src, CV_OUT double* minVal,
               CV_OUT double* maxVal = 0, CV_OUT Point* minLoc = 0,
               CV_OUT Point* maxLoc = 0, InputArray mask = noArray());

src:输入图像。

minVal:返回像素最小值。可输入NULL表示不需要。

maxVal :返回像素最大值。可输入NULL表示不需要。

minLoc:返回最小值的位置。可输入NULL表示不需要。

maxLoc:返回最大值的位置。可输入NULL表示不需要。

mask:可选项。

  • 计算图像所有通道像素的均值与方差:meanStdDev()
void meanStdDev(InputArray src, OutputArray mean, 
                OutputArray stddev, InputArray mask=noArray());

src:输入图像。

mean:返回图像像素均值。

stddev:返回图像像素均差值。

mask:可选项。

三、示例代码:

#include <opencv2/opencv.hpp>
#include <iostream>

using namespace cv;
using namespace std;

int main(int argc, const char *argv[])
{
	Mat src = imread("../images/test.png", IMREAD_GRAYSCALE);
	if (src.empty()) {
		printf("不能加载图片!\n");
		return -1;
	}
	namedWindow("1--原图", WINDOW_AUTOSIZE);
	imshow("1--原图", src);

	double minVal, maxVal; 
	Point minLoc, maxLoc;
	//查找图像中最小值最大值及它们的位置
	minMaxLoc(src, &minVal, &maxVal, &minLoc, &maxLoc, Mat());

	printf("min: %.2f, max: %.2f \n", minVal, maxVal);
	printf("min location: (%d, %d) \n", minLoc.x, minLoc.y);
	printf("max location: (%d, %d) \n", maxLoc.x, maxLoc.y);
	
	src = imread("../images/test.png");
	Mat means, stddev;
	//计算:彩色图像三通道的均值与方差
	meanStdDev(src, means, stddev);
	printf("Channel--[Blue]  mean: %.2f, stddev: %.2f\n", means.at<double>(0, 0), stddev.at<double>(0, 0));
	printf("Channel--[Green] mean: %.2f, stddev: %.2f\n", means.at<double>(1, 0), stddev.at<double>(1, 0));
	printf("Channel--[Red]   mean: %.2f, stddev: %.2f\n", means.at<double>(2, 0), stddev.at<double>(2, 0));

	waitKey(0);
	return 0;
}

四、运行效果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值