我正在尝试在感兴趣的圆形区域上平均图像的像素值。我试图使用cvAvgSdv
,它返回一个合理的平均值,但零标准差。我也尝试了cvCountNonZero
,它也返回0。一定是我犯的一个基本错误,但希望有人能指出来。png看起来是正确的(黑色背景上正确位置上的一个白点)。我的完整代码如下(VS c++ 2010 Express, Opencv245):
#include <opencv/cv.h>
#include <opencv2/highgui/highgui.hpp>
#include <stdio.h>
int main( int argc, char** argv )
{
IplImage* src;
if( argc >= 2 && (src=cvLoadImage(argv[1], 0))!= 0)
{
IplImage * roi;
roi = cvCreateImage(cvGetSize(src), 8, 1);
int n;
int centre_x = 396, centre_y = 317;
CvScalar pixel_mean, pixel_stdev;
cvZero(roi);
cvCircle(
roi,
cvPoint(centre_x, centre_y),
15, //radius<<<<<<<<<<<<<<<<<<<<<<<<<<<
cvScalar(255),
-1, 8, 0
);
cvAvgSdv(src, &pixel_mean, &pixel_stdev, roi);
n = cvCountNonZero(roi);
printf
(
"center x: %d y: %d A: %d B: %d av: %f stdev: %f n: %dn",
centre_x,
centre_y,
15,
15,
pixel_mean, //new
pixel_stdev, //new
n //new
);
cvSaveImage("roi.png", roi, 0);
}
}
谢谢
打印和使用cvScalars的错误。用pixel_mean.val[0]
和pixel_stdev.val[0]
代替pixel_mean
和pixel_stdev
。这段代码变成:
printf
(
"center x: %d y: %d A: %d B: %d av: %f stdev: %f n: %dn",
centre_x,
centre_y,
15,
15,
pixel_mean.val[0], //new
pixel_stdev.val[0], //new
n //new
);
更安全的方法是独立打印每个变量,这样即使您忘记了.val[0]
部分也没关系:
printf
(
"center x: %d y: %d A: %d B: %d",
centre_x,
centre_y,
15,
15
);
printf(" av: %f", pixel_mean.val[0]); //new
printf(" stdev: %f", pixel_stdev.val[0]); //new
printf(" n: %dn", n); //new
看起来有点麻烦,但如果忘记了.val[0]
也没关系,所以更安全。