图像轮廓提取算法(Opencv基于C++实现)

2023-05-16

Opencv图像轮廓提取

  • 0. 实现结果如下:
  • 1. 打开图像代码
  • 2. 轮廓提取函数
  • 3. 代码实现

本文主要实现了图像的轮廓提取,首先先给出直观的轮廓实现结果:

0. 实现结果如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1. 打开图像代码

注意图片存放路径不能出现中文,不然会报错!

	CString defaultDir = _T("请选择路径"); //设置默认打开文件夹
	CString fileFilter = _T("文件(*.jpg;*.bmp)|*.jpg;*.bmp|All File (*.*)|*.*||"); //设置文件过滤
	CFileDialog fileDlg(true, defaultDir, _T(""), OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, fileFilter, NULL);
	//弹出选择文件对话框

	if (fileDlg.DoModal() == IDOK)
	{
		filePath = fileDlg.GetPathName();//得到完整的文件名和目录名拓展名  
		CString filename = fileDlg.GetFileName();
	}
	char * A = CStringToChar(filePath); //CString转换Char
	Mat image = imread(A, 1);
	imshow("image", image);

2. 轮廓提取函数

寻找轮廓函数:findContours()

//函数原型:
void findContours//提取轮廓,用于提取图像的轮廓
(
InputOutputArray image,//输入图像,必须是8位单通道图像,并且应该转化成二值的
OutputArrayOfArrays contours,//检测到的轮廓,每个轮廓被表示成一个point向量
OutputArray hierarchy,//可选的输出向量,包含图像的拓扑信息。其中元素的个数和检测到的轮廓的数量相等
int mode,//说明需要的轮廓类型和希望的返回值方式
int method,//轮廓近似方法
Point offset = Point()
)

绘制轮廓函数: drawContours()

//函数原型:
void drawContours//绘制轮廓,用于绘制找到的图像轮廓
(
 InputOutputArray image,//要绘制轮廓的图像
 InputArrayOfArrays contours,//所有输入的轮廓,每个轮廓被保存成一个point向量
 int contourIdx,//指定要绘制轮廓的编号,如果是负数,则绘制所有的轮廓
 const Scalar& color,//绘制轮廓所用的颜色
 int thickness = 1, //绘制轮廓的线的粗细,如果是负数,则轮廓内部被填充
 int lineType = 8, /绘制轮廓的线的连通性
 InputArray hierarchy = noArray(),//关于层级的可选参数,只有绘制部分轮廓时才会用到
 int maxLevel = INT_MAX,//绘制轮廓的最高级别,这个参数只有hierarchy有效的时候才有效
                                          //maxLevel=0,绘制与输入轮廓属于同一等级的所有轮廓即输入轮廓和与其相邻的轮廓
                                          //maxLevel=1, 绘制与输入轮廓同一等级的所有轮廓与其子节点。
                                          //maxLevel=2,绘制与输入轮廓同一等级的所有轮廓与其子节点以及子节点的子节点
 Point offset = Point()
)

3. 代码实现

完整的C++与Opencv代码实现如下:

#include "opencv/highgui.h"
#include "opencv/cv.h"
using namespace cv;

void main()
{
	// TODO:  在此添加控件通知处理程序代码
	CString defaultDir = _T("请选择路径"); //设置默认打开文件夹
	CString fileFilter = _T("文件(*.jpg;*.bmp)|*.jpg;*.bmp|All File (*.*)|*.*||"); //设置文件过滤
	CFileDialog fileDlg(true, defaultDir, _T(""), OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, fileFilter, NULL);
	//弹出选择文件对话框

	if (fileDlg.DoModal() == IDOK)
	{
		filePath = fileDlg.GetPathName();//得到完整的文件名和目录名拓展名  
		CString filename = fileDlg.GetFileName();
	}
	char * A = CStringToChar(filePath); //CString转换Char
	Mat image = imread(A, 1);
	imshow("image", image);

	Mat gray;
	cvtColor(image, gray, CV_BGR2GRAY);
	GaussianBlur(gray, gray, Size(3, 3), 3, 3);
	Mat img;
	threshold(gray, img, 100, 255, THRESH_BINARY);
	imshow("二值", img);
	vector<vector<Point>> contours;
	vector<Vec4i> hierarchy;
	findContours(img, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_NONE);
	Mat resultImage = Mat::zeros(img.size(), CV_8UC3);
	drawContours(resultImage, contours, -1, CV_RGB(0, 20, 180),3);
	imshow("resultImage", resultImage);

}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

图像轮廓提取算法(Opencv基于C++实现) 的相关文章

  • Java入门基础知识

    JAVA基础知识记录 1 基础内容2 相关知识链接 写在最前面 xff1a 之前自学Java用的是 Eclipse 1 基础内容 常量 final相当于c 43 43 中的const 数组 int number 61 new int 100
  • 最全计算机图形学面试资料整理

    计算机图形学面试资料整理 1 什么是渲染管线2 有那几个坐标系 xff08 空间 xff09 xff1f 如何在空间之间进行转换 xff1f 3 三个重要的空间变换矩阵4 视口变换是什么 xff1f 5 顶点缓冲对象 xff08 Verte
  • OpenGL状态机

    OpenGL状态机 1 什么是状态机 xff1f 2 OpenGL状态机 1 什么是状态机 xff1f 先来解释什么是 状态 State 现实事物是有不同状态的 xff0c 例如一个自动门 xff0c 就有 open 和 closed 两种
  • OpenGL窗口实现

    OpenGL窗口实现 1 渲染循环包括的代码 xff1a 2 完整代码及解释3 实现的结果 1 渲染循环包括的代码 xff1a span class token comment 渲染循环 span span class token keyw
  • ubuntu安装nvidia显卡驱动

    系统环境 ubuntu 16 04 一 设定ubuntu的root密码 1 ubuntu默认root密码 在安装ubuntu操作系统时 xff0c 需要配置用于登录系统的用户名和密码 xff0c 却没有提示配置root密码 ubuntu默认
  • OpenGL绘制三角形

    OpenGL绘制三角形 1 可编程渲染管线2 标准化设备坐标 Normalized Device Coordinates 3 三角形顶点数据输入4 顶点着色器 Vertex Shader 编译顶点着色器 5 片段着色器 Fragment S
  • 多个着色器与多个VAO,VBO绘制三角形

    多个着色器与多个VAO VBO绘制三角形 设置不同片段着色器绘制两个三角形设置多个不同片段着色器绘制三个三角形 写在最前面 xff1a 如果对一个三角形的绘制过程还不明白建议先去看看 x1f449 这篇文章 设置不同片段着色器绘制两个三角形
  • OpenGL可编程着色器

    OpenGL着色器 1 什么是着色器2 着色器语言 xff08 GLSL xff09 2 1 数据类型2 2 着色器的输入与输出 3 Uniform3 1 绘制一个插值渐变三角形3 2 插值渐变三角形实现代码 xff1a 4 我们自己的着色
  • OpenGL纹理贴图

    OpenGL纹理 1 基本概念2 纹理环绕方式3 纹理过滤3 1 GL NEAREST3 2 GL LINEAR3 3 多级渐远纹理 Mipmap 4 纹理加载与创建4 1 纹理加载4 2 纹理创建 4 3 纹理的使用 1 基本概念 纹理是
  • OpenGL纹理叠加

    OpenGL纹理叠加 1 纹理贴图的实现2 纹理单元 在 OpenGL纹理贴图的基础上继续深入学习纹理相关内容 xff0c 本篇文章的主要目的是为了实现OpenGL纹理叠加 xff0c 需要引入 纹理单元的相关概念 1 纹理贴图的实现 按照
  • OpenGL中的变换

    OpenGL中的变换 1 矩阵变换1 1 缩放1 2 平移1 3 旋转1 4 矩阵组合 2 案例实现2 1 缩放 xff1a 2 1 1 等比缩放2 1 2 不等比缩放2 1 3 镜像X方向2 1 4 镜像Y方向 2 2 平移2 2 1 动
  • OpenGL坐标变换

    OpenGL坐标变换 1 坐标系统间的变换1 1 局部空间1 2 世界空间1 3 观察空间裁剪空间1 4 屏幕空间1 5 变换矩阵的组合 2 实现3 渲染部分代码 1 坐标系统间的变换 在渲染管线中 xff0c 物体的顶点在最终转化为屏幕坐
  • OpenGL立方体纹理贴图

    OpenGL正方体纹理贴图 0 写在最前面1 正方体顶点属性构建2 绑定多个VAO VBO3 创建多个纹理4 渲染循环5 实现代码6 多个立方体纹理贴图 0 写在最前面 要实现本篇的内容 xff0c 建议先学习下以下内容 x1f449 多个
  • OpenGL摄像机(Look At矩阵)

    OpenGL摄像机 1 摄像机 观察空间2 Look At3 lookAt 矩阵案例 1 摄像机 观察空间 观察矩阵将所有的世界坐标变换为相对于摄像机位置与方向的观察坐标 当定义一个摄像机时需要它在世界空间中的位置 观察的方向 一个指向它右
  • OpenGL摄像机键盘交互

    摄像机交互 对于摄像机基础实现内容较为生疏的可以参考该文章 x1f449 摄像机lookAt矩阵实现 考虑键盘交互实现opengl摄像机绕着目标物体自由移动 xff0c 首先需要设置一个摄像机系统 xff0c 定义lookAt函数变量 gl
  • Docker迁移以及环境变量问题

    问题一描述 将docker容器通过docker export命令打包 xff0c 传输到另外的服务器 xff0c 再通过docker import命令导入后 xff0c 发现原来docker容器中的环境变量失效了 解决方案 1 无效方案 直
  • OpenGL鼠标视角交互

    OpenGL鼠标视角交互 1 欧拉角2 鼠标输入 1 欧拉角 欧拉角 Euler Angle 是可以表示3D空间中任何旋转的3个值 xff0c 一共有3种欧拉角 xff1a 俯仰角 Pitch 偏航角 Yaw 和滚转角 Roll xff0c
  • 二维数组快速排序sort

    二维数组快速排序sort 1 使用比较函数cmp2 使用lambda表达式 使用c 43 43 的快排函数需要包含头文件 include lt algorithm gt 1 使用比较函数cmp span class token macro
  • OpenGL光照之颜色

    OpenGL光照之颜色 颜色什么是颜色如何表示物体颜色 光照场景的搭建 颜色 什么是颜色 颜色是通过眼 脑和我们的生活经验所产生的一种对光的视觉效应 xff0c 我们肉眼所见到的光线 xff0c 是由频率范围很窄的电磁波产生的 xff0c
  • OpenGL冯氏光照

    OpenGL冯氏光照 1 环境光照 Ambient lighting 2 漫反射光照 Diffuse lighting 3 镜面反射光照 Specular lighting 冯氏光照模型的主要结构由3个分量组成 xff1a 环境 Ambie

随机推荐

  • Magics软件中实现蒙皮偏置

    Magics软件中实现蒙皮偏置 首先导入目标模型 对目标模型进行修复检查 一般比较简单的模型可以直接使用修复即可自动实现修复 xff0c 比较复杂的情况可以使用工具栏里面的操作实现人工修复 xff0c 修复完成后模型的诊断应该都是绿色打钩
  • Geomagic网格重划分与模型光顺

    Geomagic网格重划分与模型光顺 1 网格重划分2 模型光顺 首先先导入模型 xff0c 可以看到模型还是相对较为粗糙 xff0c 面片的法矢方向差别很大 xff0c 因此需要重新划分下网格 1 网格重划分 网格重划分的步骤为 xff1
  • 点集的读入与输出操作

    在MFC框架里实现从文件中读取点集 1 点集读入操作实现代码 xff1a 2 点集输出操作实现代码 xff1a 1 点集读入操作实现代码 xff1a 读入点集数据 ID x y z span class token keyword void
  • OpenGL物体材质

    OpenGL物体材质 定义材质的意义如何实现物体材质物体材质的设置光的属性 定义材质的意义 在现实世界里 xff0c 每个物体会对光产生不同的反应 xff0c 每个物体对镜面高光也有不同的反应 有些物体反射光的时候不会有太多的散射 xff0
  • OpenGL光照贴图

    光照贴图 1 光照贴图的意义2 漫反射贴图3 镜面光贴图 1 光照贴图的意义 现实世界中的物体通常并不只包含有一种材质 xff0c 而是由多种材质所组成 只有光照颜色的材质系统是不够的 xff0c 它只是一个最简单的模型 xff0c 难以模
  • OpenGL光源

    OpenGL光源 0 预备知识点1 平行光2 点光源2 1 简化版点光源2 2 点光源 4 聚光灯4 1 柔化边缘 平滑 0 预备知识点 在学习本节之前 xff0c 需要先掌握一些基础光照的知识 推荐学习以下两篇问章 xff1a 计算机图形
  • GPU并行效率问题——通过MPS提升GPU计算收益

    现象描述 使用V100 32G型号的GPU运行计算程序时 xff0c 发现程序每5秒能够完成一次任务 xff0c 耗费显存6G 鉴于V100 GPU拥有32G的显存 xff0c 还有很多空闲 xff0c 决定同时运行多个计算程序 xff0c
  • 对象数组初始化

    对象数组初始化问题 为什么使用对象数组遇到的问题解决方法 为什么使用对象数组 为了满足用户创建同一个类的多个对象 遇到的问题 应使用 初始化聚合对象不存在默认构造函数 span class token macro property span
  • MFC Check-box与Button结合

    在MFC中经常需要一个按钮能够实现多种功能 xff0c 这个时候可以考虑通过Check box的勾选操作来与其配合实现目标效果 首先在对话框里添加Check box xff0c 并且修改Check box的ID 双击添加好的Check bo
  • MFC+Opencv以图拼图

    MFC 43 Opencv拼图 MFC对话框添加按钮图片准备Opencv配置代码实现 本篇文章主要通过将一系列图片作为拼图的基础 xff0c 实现目标图形的拼图 xff0c 我们先给个结果图可以更直观了解生成的结果是如何的 MFC对话框添加
  • 判断点集与多边形的位置关系

    判断点集与多边形的位置关系 点集与凸多边形点集与一般性多边形 点集与凸多边形 点集或者是点与多边形位置关系无非就三种 点在多边形的内部点在多边形的外部点在多边形上 一般如果该多边形是凸的那么我们可以直接用面积法或者向量法来解决位置关系 xf
  • 模型轮廓提取

    模型轮廓提取 模型边界 孔洞 xff09 识别算法 对于三角网格模型 xff0c 如果存在某一条边只属于一个三角面片 xff0c 那么这个边为模型边界 xff0c 称这条边为模型的边界边 如果一条边同时属于两个三角形 xff0c 则为内部边
  • Opencv推荐学习网站

    中文学习网站网址 xff1a http www opencv org cn http wiki opencv org cn index php E9 A6 96 E9 A1 B5
  • 摄像头动态捕捉小程序

    Opencv摄像头实时捕捉小程序 驱动摄像头加入Canny边缘检测加入Sobel边缘检测 先上一个好玩的动图看看结果 xff1a 驱动摄像头 首先先驱动摄像头 实现的代码如下 xff1a span class token macro pro
  • Opencv图像美颜滤镜

    图像美颜 span class token keyword void span span class token function BeautyFace span span class token punctuation span span
  • Simplify3D打印参数设置

    Simplify3D打印参数设置 关键是打印进程的设定 xff0c 这边以TPU为例子 xff0c 其他材料可以查阅相关参数进行喷头温度 xff0c 打印速度的修改 xff0c 其他的基本一致 设置完成后进行模型切片 xff0c 完成后点击
  • CSDN如何转载一篇博客呢

    看到一篇挺好的文章想要转载怎么做呢 xff1f 方法一 xff1a 傻瓜式复制 不推荐 方法二 后台操作 推荐 方法一 xff1a 傻瓜式复制 不推荐 一个个图文抠 xff0c 效率低下 xff0c 且版面格式会发生变化 方法二 后台操作
  • Exchange 2013升级以及域名绑定等若干问题

    环境简介 Exchange 2013服务器位于ad域中 xff0c 系统为Windows server 2012 R2 xff0c 其内部域名为 xff1a mail ad com 一 Exchange客户端无法在浏览器中正常运行 在域中部
  • 无线攻击 --Wifite(批量破解无线工具)

    文章目录 一 用法概述二 命令格式三 用法示例3 1 破解某个AP 一 用法概述 Wifite使用命令行界面连续攻击多个WPA WPS加密的网络 xff0c 不需要记住参数即可使用它 xff1a 按信号强度排序 xff08 db单位 xff
  • 图像轮廓提取算法(Opencv基于C++实现)

    Opencv图像轮廓提取 0 实现结果如下 xff1a 1 打开图像代码2 轮廓提取函数3 代码实现 本文主要实现了图像的轮廓提取 xff0c 首先先给出直观的轮廓实现结果 xff1a 0 实现结果如下 xff1a 1 打开图像代码 注意图