首页 > 其他 > 详细

opencv分水岭算法对图像进行分割

时间:2014-08-15 00:04:36      阅读:834      评论:0      收藏:0      [点我收藏+]

先看效果

bubuko.com,布布扣

说明

使用分水岭算法对图像进行分割,设置一个标记图像能达到比较好的效果,还能防止过度分割。
1、这里首先对阈值化的二值图像进行腐蚀,去掉小的白色区域,得到图像的前景区域。并对前景区域用255白色标记
2、同样对阈值化后的图像进行膨胀,然后再阈值化并取反。得到背景区域。并用128灰度表示
3、将前景和背景叠加在一起在同一幅图像中显示。
4、用标记图和原图,利用opencv的watershed对图像进行分割。

源码
class WatershedSegment{
private:
	cv::Mat markers;
public:
	void setMarkers(const cv::Mat &image){
		image.convertTo(markers,CV_32S);
	}

	cv::Mat process(const cv::Mat &image) {

		// Apply watershed
		cv::watershed(image,markers);
		markers.convertTo(markers,CV_8U);
		return markers;
	}
};
int _tmain(int argc, _TCHAR* argv[])
{
	cv::Mat image = cv::imread("group.jpg");
	cv::Mat binary = cv::imread("binary.bmp",0);  //没加0害得我找好久错误的原因,即使"binary.bmp"为二值图像不加0读进来还是3通道
	//cv::threshold(image,binary,60,255,CV_THRESH_BINARY);  //阈值化操作
	//binary = 255 - binary; //让前景变为白色区域
	cv::namedWindow("binary",CV_WINDOW_AUTOSIZE);
	cv::imshow("binary",binary);

	cv::Mat fImage;
	cv::erode(binary,fImage,cv::Mat(),cv::Point(-1,-1),6); //binary = 255 - binary; //让前景变为白色区域//腐蚀去掉小的干扰物体得到前景图像
	cv::namedWindow("eroded",CV_WINDOW_AUTOSIZE);
	cv::imshow("eroded",fImage);

	cv::Mat bImage;
	cv::dilate(binary,bImage,cv::Mat(),cv::Point(-1,-1),6);
	cv::threshold(bImage,bImage,1,128,cv::THRESH_BINARY_INV);//对原始二值图像阈值化并取反,得到背景图像
	cv::namedWindow("bImage",CV_WINDOW_AUTOSIZE);
	cv::imshow("bImage",bImage);

	cv::Mat marker(binary.size(),CV_8U,cv::Scalar(0));
	marker = fImage + bImage;  //创建标记图像
	cv::namedWindow("marker",CV_WINDOW_AUTOSIZE);
	cv::imshow("marker",marker);

	WatershedSegment segmenter;
	segmenter.setMarkers(marker);
	cv::Mat segment = segmenter.process(image);
	cv::namedWindow("segmenter",CV_WINDOW_AUTOSIZE);
	cv::imshow("segmenter",segment);
	cv::waitKey(0);
	return 0;
}


opencv分水岭算法对图像进行分割,布布扣,bubuko.com

opencv分水岭算法对图像进行分割

原文:http://blog.csdn.net/h_wlyfw/article/details/38564537

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!