opencv分水岭算法对图像进行切割
先看效果
说明
并用128灰度表示
源代码
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;
}
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分水岭算法对图像进行切割的更多相关文章
- Opencv分水岭算法——watershed自动图像分割用法
分水岭算法是一种图像区域分割法,在分割的过程中,它会把跟临近像素间的相似性作为重要的参考依据,从而将在空间位置上相近并且灰度值相近的像素点互相连接起来构成一个封闭的轮廓,封闭性是分水岭算法的一个重要特 ...
- opencv学习之路(30)、分水岭算法及图像修补
一.简介 二.分水岭算法 #include "opencv2/opencv.hpp" using namespace cv; void main() { Mat srcImg = ...
- 新手学,java使用分水岭算法进行图像切割(一)
近期被图像切割整的天昏地暗的,在此感谢老朋友周洋给我关于分水岭算法的指点!本来打算等彩色图像切割有个完满的结果再写这篇文章,可是考虑到到了这一步也算是一个阶段,所以打算对图像切割做一个系列的博文,于是 ...
- OpenCV——分水岭算法
分水岭算法,是一种基于拓扑理论的数学形态学的分割方法,其基本思想是把图像看作是测地学上的拓扑地貌,图像中每一点像素的灰度值表示该点的海拔高度,每一个局部极小值及其影响区域称为集水盆,而集水盆的边界则形 ...
- OpenCV学习(9) 分水岭算法(3)
本教程我学习一下opencv中分水岭算法的具体实现方式. 原始图像和Mark图像,它们的大小都是32*32,分水岭算法的结果是得到两个连通域的轮廓图. 原始图像:(原始图像必须是3通道图像) Mark ...
- OpenCV学习(8) 分水岭算法(2)
现在我们看看OpenCV中如何使用分水岭算法. 首先我们打开一副图像: // 打开另一幅图像 cv::Mat image= cv::imread("../to ...
- OpenCV学习(7) 分水岭算法(1)
分水岭算法主要用于图像分段,通常是把一副彩色图像灰度化,然后再求梯度图,最后在梯度图的基础上进行分水岭算法,求得分段图像的边缘线. 下面左边的灰度图,可以描述为右边的地 ...
- 第八节、图片分割之GrabCut算法、分水岭算法
所谓图像分割指的是根据灰度.颜色.纹理和形状等特征把图像划分成若干互不交迭的区域,并使这些特征在同一区域内呈现出相似性,而在不同区域间呈现出明显的差异性.我们先对目前主要的图像分割方法做个概述,后面再 ...
- 图片分割之GrabCut算法、分水岭算法
https://www.cnblogs.com/zyly/p/9392881.html 所谓图像分割指的是根据灰度.颜色.纹理和形状等特征把图像划分成若干互不交迭的区域,并使这些特征在同一区域内呈现出 ...
随机推荐
- pygame初步(一)绘制一个运动的矩形
<More Python Programming for the Absolute Beginner>一书中的第二章练习3(P33) 使用Python的Pygame库 import sys ...
- BZOJ 1898: [Zjoi2004]Swamp 沼泽鳄鱼( dp + 矩阵快速幂 )
----------------------------------------------------------------------- #include<cstdio> #incl ...
- 转:前端冷知识(~~some fun , some useful)
前端不为人知的一面——前端冷知识集锦 前端已经被玩儿坏了!像console.log()可以向控制台输出图片等炫酷的玩意已经不是什么新闻了,像用||操作符给变量赋默认值也是人尽皆知的旧闻了,今天看到Qu ...
- struts ModelDriven
在表单提交的时候传值是这样,name=admin.username name=admin.password,然后在action中定义属性admin生成get和set 也可以实现ModelDriven这 ...
- mysql merge table
SELECT COUNT(*) FROM `comment` SHOW CREATE TABLE `comment` CREATE TABLE `comment1` ( `id` INT(8) NOT ...
- 用AS3清空容器下所有子显示对象
容器中的子显示对象分为两类: 处于显示列表中的子显示对象.被numChildren所记录的. 由容器graphics对象绘制出来的矢量图.这个矢量图不属于Shape类型,不在容器的显示列表中,不被nu ...
- F - Free DIY Tour(动态规划,搜索也行)
这道题可用动态规划也可以用搜索,下面都写一下 Description Weiwei is a software engineer of ShiningSoft. He has just excelle ...
- PHP学习笔记6-时间/日期
时区/时间/日期 输出unix时间戳(从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数),用time() echo time();//unix时间戳 输出结果:143557475 ...
- 7.2.1 生成1~n的排列(全排列)【STL__next_permutation()_的应用】
#include <stdio.h> #include <math.h> #include <string.h> #include <stdlib.h> ...
- 原生弹窗拖拽代码demo+简单的抽奖
拖拽效果 效果: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...