Java+opencv3.2.0实现轮廓检测

网友投稿 209 2023-06-21

Java+opencv3.2.0实现轮廓检测

轮廓是由一系列的点组成的集合,表现在图像中就是一条曲线。

OpenCV3.2.0中提供了查找轮廓的方法:

Imgproc.findContours(Mat image, List conto

http://

urs, Mat hierarchy, int mode, int method, Point offset)

参数说明:

image:8位单通道图http://像。

contours:存储检测到的轮廓的集合。

hierarchy:可选的输出向量,包含了图像轮廓的拓扑信息。

mode:轮廓检索模式。有如下几种模式:

1、RETR_EXTERNAL只检测最外围的轮廓

2、RETR_LIST提取所有的轮廓,不建立上下等级关系,只有兄弟等级关系

3、RETR_CCOMP提取所有轮廓,建立为双层结构

4、RETR_TREE提取所有轮廓,建立网状结构

method:轮廓的近似方法。取值如下:

1、CHAIN_APPROX_NONE获取轮廓的每一个像素,像素的最大间距不超过1

2、CHAIN_APPROX_SIMPLE压缩水平垂直对角线的元素,只保留该方向的终点坐标(也就是说一条中垂线a-b,中间的点被忽略了)

3、CHAIN_APPROX_TC89_LI使用TEH_CHAIN逼近算法中的LI算法

4、CHAIN_APPROX_TC89_KCOS使用TEH_CHAIN逼近算法中的KCOS算法

offset:每个轮廓点的可选偏移量。

示例代码:

public static void main(String[] args)

{

// TODO Auto-generated method stub

System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Mat src = Imgcodecs.imread("F:\\1_m1109048058.jpg");

Mat dst = src.clone();

Imgproc.cvtColor(dst, dst, Imgproc.COLOR_BGRA2GRAY);

Imgproc.adaptiveThreshold(dst, dst, 255, Imgproc.ADAPTIVE_THRESH_MEAN_C,

Imgproc.THRESH_BINARY_INV, 3, 3);

java.util.List contours = new java.util.ArrayList();

Mat hierarchy = new Mat();

Imgproc.findContours(dst, contours, hierarchy, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE,

new Point(0, 0));

System.out.println(contours.size());

for (int i = 0; i < conhttp://tours.size(); i++)

{

Imgproc.drawContours(src, contours, i, new Scalar(0, 0, 0, 0), 1);

}

Imgcodecs.imwrite("F:\\test.jpg", src);

}

原图片:

结果:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java提示解析时已到达文件结尾的解决方法
下一篇:Elasticsearch 基础介绍及索引原理分析
相关文章

 发表评论

暂时没有评论,来抢沙发吧~