我正在图像中做一些椭圆识别,为了做到这一点,我打开了一个简单的图像:
img = imread("M:/Desktop/PsEyeRight.jpg", CV_LOAD_IMAGE_COLOR);选择ROI (这是在OpenCV 2.4.6中设置ROI的唯一方法,旧库中有一个cvSetImageROI()和cvResetImageROI(),我认为这比较简单):
Mat roi(img, Rect(Point(205, 72), Point(419,285)));用cvtColor更改其颜色空间:
cvtColor(roi, roi, CV_BGR2GRAY); 适用门槛值:
threshold(roi, roi, 150, 255, THRESH_BINARY); 然后,我使用克隆的图像处理findContours,因为findContours修改了函数中传递的图像,然后将ROI更改为BGR颜色空间:
cvtColor(roi, roi, CV_GRAY2BGR);并在roi中画出所有的椭圆。
当我显示roi时,我可以看到所有东西都是100%工作的,但我希望当我显示原始图像时,它将是原始图像,阈值中有ROI,里面有图纸,但是我只是得到原始图像本身,就像什么都没有改变一样。我认为这是因为cvtColor在复制roi,所以它不再“指向”img了。
什么是最好的方法(或建议)做同样的处理,并在原始图像中有ROI,显示算法的进展?
发布于 2013-11-08 09:06:47
主要的问题是,您不能有一个图像,它的一部分是3chan/rgb,部分是1 3chan/灰色。
我的解决方案是,首先处理roi的副本,然后将其转换回rgb并将其粘贴到原始图像中。
img = imread("M:/Desktop/PsEyeRight.jpg", CV_LOAD_IMAGE_COLOR); // original
Mat roi(img, Rect(Point(205, 72), Point(419,285)));
Mat work = roi.clone();
cvtColor(work , work , CV_BGR2GRAY);
threshold(work , work , 150, 255, THRESH_BINARY);
// findContours(work,...);
cvtColor(work , roi, CV_GRAY2BGR); //here's the trickhttps://stackoverflow.com/questions/19854941
复制相似问题