我试图在感兴趣的圆形区域上平均图像的像素值。我试图使用cvAvgSdv
并返回一个合理的均值,但零标准差。我也尝试cvCountNonZero
,它也返回零。一定是我犯的一个基本错误,但希望有人可以指出。 roi.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: %d\n",
centre_x,
centre_y,
15,
15,
pixel_mean, //new
pixel_stdev, //new
n //new
);
cvSaveImage("roi.png", roi, 0);
}
}
由于
答案 0 :(得分:1)
printf中的错误和使用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: %d\n",
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: %d\n", n); //new
看起来有点麻烦,但如果遗忘.val[0]
并不重要,那么更安全。