时间:2021-05-20
轮廓是由一系列的点组成的集合,表现在图像中就是一条曲线。
OpenCV3.2.0中提供了查找轮廓的方法:
Imgproc.findContours(Mat image, List contours, Mat hierarchy, int mode, int method, Point offset)
参数说明:
image:8位单通道图像。
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<MatOfPoint> contours = new java.util.ArrayList<MatOfPoint>(); 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 < contours.size(); i++) { Imgproc.drawContours(src, contours, i, new Scalar(0, 0, 0, 0), 1); } Imgcodecs.imwrite("F:\\test.jpg", src); }原图片:
结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
首先大家可以对OpenCV有个初步的了解,可以参考:简单了解OpenCV轮廓(Contours),指的是有相同颜色或者密度,连接所有连续点的一条曲线。检测轮廓的
OpenCv提供了函数findContours()用于对物体轮廓进行检测,该函数实现算法是由S.suzukiK.Abe于1985年发表的。OpenCVSharp
本文实例为大家分享了Opencv处理图像之轮廓提取,使用cvfindContours对图像进行轮廓检测,供大家参考,具体内容如下#include#include
最近在OpenCV-Python接口中使用cv2.findContours()函数来查找检测物体的轮廓。根据网上的教程,PythonOpenCV的轮廓提取函数会
python+opencv车道线检测(简易实现),供大家参考,具体内容如下技术栈:python+opencv实现思路:1、canny边缘检测获取图中的边缘信息;