opencv中边缘提取、孔洞填充以及阈值分割的实际应用

2023-10-27 23:50

本文主要是介绍opencv中边缘提取、孔洞填充以及阈值分割的实际应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、应用中使用的opencv接口

1.1 阈值分割(threshold)

      threshold 函数参数介绍

 double threshold( InputArray src, OutputArray dst,double thresh, double maxval, int type );

      第一个参数为输入的图像,Mat类型的即可。

      第二个参数为输出图像,且和输入图像有同等大小和类型

      第三个参数为设定阙值的具体值

      第四个参数 maxval是当第五个参数类型为CV_THRESH_BINARY和CV_THRESH_BINARY_INV是的最大值

1.2边缘提取

void Canny(Mat image, Mat edges,double threshold1,double threshold2, int aperture_size=3);

   

1.3孔洞填充(findContours)

void findContours( InputOutputArray image, OutputArrayOfArrays contours,OutputArray hierarchy, int mode,int method, Point offset=Point())

使用findContours会同步使用findContours()与边缘检测算法

 

2、待分割图片

带分割图片如下,需要将图片中的小章鱼都分割出来

对图片的处理是先将图片进行颜色空间转换,有RGB转换成为HSV,再基于HSV的图片进行分割;下面三张图分别是进行颜色空间转换、边缘提取、以及孔洞填充后的效果,因为轮廓选择的时候不理想,所以最终分割的效果不好。后面会根据轮廓提取后的效果进一步分割;

以上分割效果不好,后期的处理更偏向于像素的处理,分析样本中蓝色的像素值,把蓝色的区域去掉,代码示例如下:

#include <iostream>
#include <opencv2/opencv.hpp>using namespace std;
using namespace cv;void fillholds(Mat &src, Mat &dst, Mat &sourceImage)
{Mat m_with_border;copyMakeBorder(src, m_with_border, 1, 1, 1, 1, BORDER_CONSTANT, Scalar());copyMakeBorder(sourceImage, sourceImage, 1, 1, 1, 1, BORDER_CONSTANT, Scalar());vector<vector<Point>> contours;vector<Vec4i> hierarchy;// 提取边缘坐标findContours(m_with_border, contours, hierarchy, CV_RETR_TREE, CV_CHAIN_APPROX_NONE);Mat cvImg;sourceImage.copyTo(cvImg);if (!contours.empty()){for (unsigned int idx = 0; idx < contours.size(); idx++){drawContours(cvImg, contours, idx, Scalar::all(0), CV_FILLED, 8);}}Mat resImage = cvImg(Rect(1, 1, m_with_border.cols - 2, m_with_border.rows - 2));//使用孔洞填充的时候部分区域提取异常,对提取异常的区域重新Mat mask = resImage(Rect(0, 0, 230, resImage.rows));for (int i = 0; i < mask.rows; i++){uchar *ptR = resImage.ptr<uchar>(i);uchar *ptS = sourceImage.ptr<uchar>(i);for (int j = 0; j < mask.cols; j++){// 还处理分割失败已经边缘黑色区域if (ptR[j * 3 + 2] == 0 && ptR[j * 3 + 1] == 0 && ptR[j * 3] == 0){ptR[j * 3] = ptS[j * 3];ptR[j * 3 + 1] = ptS[j * 3 + 1];ptR[j * 3 + 2] = ptS[j * 3 + 2];}// 再对最后一个章鱼进行分割if (ptR[j * 3 + 2] > 150){ptR[j * 3] = 0;ptR[j * 3 + 1] = 0;ptR[j * 3 + 2] = 0;}}}// 对部分比分割不好的进行形态学变换Mat ele = getStructuringElement(MORPH_RECT, Size(3, 3));morphologyEx(resImage, resImage, MORPH_ERODE, ele);dst = resImage;}int main()
{string sPath = "C:\\Users\\Administrator\\Desktop\\img\\segment.png";Mat src = imread(sPath);Mat srcimg;src.copyTo(srcimg);Mat hsvSrc;cvtColor(src, hsvSrc, CV_BGR2HSV);Mat showImg(src.rows * 2, src.cols * 2, CV_8UC3);vector<Mat> vImg;split(hsvSrc, vImg);Mat img1 = vImg[0];Mat cannyBoredr;Canny(vImg[0], cannyBoredr, 60, 180, 3);Mat mask;threshold(cannyBoredr, mask, 0, 255, THRESH_OTSU);Mat dst1;fillholds(mask, dst1, srcimg);// 使用直接减的方式会将上一步形态学变换的部分区域显示出来,达不到最好的效果Mat resultImage = src - dst1;// 使用二次分割的方式再进行一次提取Mat segImg(dst1.rows, dst1.cols,CV_8UC3);segImg = Scalar(0);for (int i = 0; i < segImg.rows; i++){uchar *ptR = segImg.ptr<uchar>(i);uchar *ptS = src.ptr<uchar>(i);uchar *ptB = dst1.ptr<uchar>(i);for (int j = 0; j < segImg.cols; j++){if (ptB[j * 3]	< 50){ptR[j * 3] = ptS[j * 3];ptR[j * 3 + 1] = ptS[j * 3 + 1];ptR[j * 3 + 2] = ptS[j * 3 + 2];}}}system("pause");return 0;
}

代码处理中的中间图如下,第一张图是轮廓提取后的效果图,可以明显看见,左侧的小章鱼分割失败,此时就需要对这个小章鱼进行额外提取;第二张图是根据像素值分割后的掩码结果;由于掩码图经过膨胀炒作,所以直接使用原图减mask图就出现第三张图的效果;最后一张是基于像素重新处理后的图片,分割效果较好。

上述只是介绍了边缘提取、孔洞填充的使用,代码可读性比较差,后续重构;

https://mp.csdn.net/editor/html?spm=1010.2135.3001.5352

这篇关于opencv中边缘提取、孔洞填充以及阈值分割的实际应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/289265

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝