这是我的代码。当我执行它。鉴于任何仲裁形象。它总是将结果显示为完全黑色或完全白色的图像。迭代有问题吗?
int main(void)
{
int i=0,j=0,height=0,width=0,step=0,k=0;
Mat img_hsv,img_rgb,red_blob,blue_blob;
//reading image... rgb format(default)... CV_8U3C
img_rgb = imread("pic.png",1);
//converting rgb image to hsv format for applying further operations
cvtColor(img_rgb,img_hsv,CV_BGR2HSV);
//defining the various component values or rather the pointer to those
//components of HSV format... hue, sat and value
uchar img_h=*(img_hsv.data+i*img_hsv.step+j*img_hsv.elemSize());
uchar img_s=*(img_hsv.data+i*img_hsv.step+j*img_hsv.elemSize()+1);
uchar img_v=*(img_hsv.data+i*img_hsv.step+j*img_hsv.elemSize()+2);
//naming window to be displayed
//for(i=0;i<1000;i++){j=i;cout<<img_h;if(img_h==170)cout<<"yesss";}
namedWindow("win1", CV_WINDOW_AUTOSIZE);
Mat img_bw(img_hsv.rows,img_hsv.cols,CV_8U);
imshow("win1", img_hsv);
//applying threshold and hence applying conversions
//by iterating over the entire image//
for(i=0;i<img_hsv.rows;i++){
for(j=0;j<img_hsv.cols;j++){
if((img_h>120)) && (img_s>150 || img_s<25) && (img_v>150))
*(img_bw.data+i*img_bw.step+j*img_bw.elemSize())=255;
else *(img_bw.data+i*img_bw.step+j*img_bw.elemSize())=0;
}
}
imshow("win1", img_bw);
感谢您的回复!
答案 0 :(得分:1)
我想我已经在我之前的评论中回答了这个问题,现在正在考虑这个问题。 更具体的
uchar img_h=*(img_hsv.data+i*img_hsv.step+j*img_hsv.elemSize());
给出(i,j)处的像素,而(i,j)初始化为(0,0)。因此,如果(0,0)处的第一个像素低于阈值,则会得到一个完全黑色的图像,否则会得到白色图像。 您可能更愿意在每次迭代中重新计算img_h,img_s和img_v。
在pre-cv2.x中有一个访问像素的宏作为CV_IMAGE_ELEM,请阅读手册以获取替换。现在不应该有像img_hsv(i,j)这样的东西吗?