opencv3.2.0形态学滤波之开运算、闭运算
/*
一、开运算:
(1)开运算,其实就是先腐蚀后膨胀的过程。
(2)数学表达式:dst = open(src,element) = dilate(erode(src,element))
(3)作用:开运算平滑物体的轮廓,断开较窄的狭颈,消除细的突出物
(4)核心API函数:morphologyEx() [详见《opencv3编程入门》 P205 ]
(5)morphologyEx()可取标识符 MORPH_OPEN 二、闭运算:
(1)闭运算,其实就是先膨胀后腐蚀的过程;
(2)数学表达式:dst = open(src,element) = erode(dilate(src,element))
(3)作用:闭运算同样也可以平滑轮廓的一部分,与开运算相反
通常会弥合较窄的间断和细长的沟壑,消除小的孔洞,填补轮廓线中的断裂
(4)核心API函数:morphologyEx() [详见《opencv3编程入门》 P205 ]
(5)morphologyEx()可取标识符 MORPH_CLOSE */
/*******开运算、闭操作相关程序示例*********/
/*******为了尽可能减少图片的失真****/
/*******程序按照数字图像处理书中的操作流程用opencv实现(P410)***********/ #include <QCoreApplication>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
using namespace std;
using namespace cv; int main()
{
Mat srcImage = imread("/home/ttwang/11.tif");//读入原图
namedWindow("[原图]");
imshow("[原图]",srcImage); //获取自定义核
Mat element = getStructuringElement(MORPH_RECT,Size(,));
Mat dstImage1;
Mat dstImage2;
Mat dstImage3;
Mat dstImage;
//先进行腐蚀操作
erode(srcImage,dstImage1,element);
namedWindow("腐蚀操作[效果图]");
imshow("腐蚀操作[效果图]",dstImage1); //由运行结果看,背景噪声在该阶段就被消除了 //对腐蚀后的图像,进行开运算操作
morphologyEx(dstImage1,dstImage2,MORPH_OPEN,element);
namedWindow("开运算操作[效果图]");
imshow("开运算操作[效果图]",dstImage2); //对dstImage2图像,进行膨胀处理
dilate(dstImage2,dstImage3,element);
namedWindow("膨胀操作[效果图]");
imshow("膨胀操作[效果图]",dstImage3); //对dstImage3图像进行闭运算操作,
morphologyEx(dstImage3,dstImage,MORPH_CLOSE,element);
namedWindow("闭运算操作[效果图]");
imshow("闭运算操作[效果图]",dstImage); waitKey();
return ;
}
[原图]
腐蚀操作[效果图]
开运算操作[效果图]
膨胀操作[效果图]
闭运算操作[效果图]
opencv3.2.0形态学滤波之开运算、闭运算的更多相关文章
- opencv3.2.0形态学滤波之形态学梯度、顶帽、黑帽
/*一.形态学梯度 (1)含义:是膨胀图和腐蚀图之差 (2)数学表达式:dst=morph-grad(src,element) =dilate(src,element) - erode(src,ele ...
- opencv3.2.0形态学滤波之膨胀
//名称:膨胀 //日期:12月21日 //平台:QT5.7.1+opencv3.2.0 /* 膨胀(dilate)的含义: 膨胀就是求局部最大值的操作,就是将图像(或图像的一部分,A)与核 B 进行 ...
- opencv3.2.0形态学滤波之腐蚀
/* 腐蚀(erode)含义: 腐蚀和膨胀是相反的一对操作,所以腐蚀就是求局部最小值的操作,腐蚀操作使原图中 国的高亮部分被腐蚀,效果图比原图有更小的高亮的区域. 腐蚀函数原型API及参数同膨胀相同 ...
- paper 76:膨胀、腐蚀、开、闭运算——数字图像处理中的形态学
膨胀.腐蚀.开.闭运算是数学形态学最基本的变换.本文主要针对二值图像的形态学膨胀:把二值图像各1像素连接成分的边界扩大一层(填充边缘或0像素内部的孔):腐蚀:把二值图像各1像素连接成分的边界点去掉从而 ...
- opencv 4 图像处理(2 形态学滤波:腐蚀与膨胀,开运算、闭运算、形态学梯度、顶帽、黑帽)
腐蚀与膨胀 膨胀(求局部最大值)(dilate函数) #include <opencv2/core/core.hpp> #include <opencv2/highgui/highg ...
- Python 图像处理 OpenCV (9):图像处理形态学开运算、闭运算以及梯度运算
前文传送门: 「Python 图像处理 OpenCV (1):入门」 「Python 图像处理 OpenCV (2):像素处理与 Numpy 操作以及 Matplotlib 显示图像」 「Python ...
- OpenCV计算机视觉学习(5)——形态学处理(腐蚀膨胀,开闭运算,礼帽黑帽,边缘检测)
如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 形态 ...
- 学习 opencv---(10)形态学图像处理(2):开运算,闭运算,形态学梯度,顶帽,黒帽合辑
上篇文章中,我们重点了解了腐蚀和膨胀这两种最基本的形态学操作,而运用这两个基本操作,我们可以实现更高级的形态学变换. 所以,本文的主角是OpenCV中的morphologyEx函数,它利用基本的膨胀和 ...
- 【OpenCV新手教程之十一】 形态学图像处理(二):开运算、闭运算、形态学梯度、顶帽、黑帽合辑
本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/23184547 作者:毛星云(浅墨) ...
随机推荐
- iOS-电池图标【结合贝塞尔曲线控制电量显示】
基于UIView类:WKJBatteryView WKJBatteryView.h #import <UIKit/UIKit.h> @interface WKJBatteryView : ...
- Ubuntu“无法打开锁文件(Could not get lock)”问题解决
用apt-get安装软件时提示: 无法获得锁 /var/lib/dpkg/lock - open(11:资源暂时不可用) 无法锁定管理目录(/var/lib/dpkg/),是否有其他进程正占用它? 其 ...
- 【GDKOI2017】小队任务 莫比乌斯反演+杜教筛
题目大意:给你n,求$\sum_{i=1}^{n}\sum_{j=i}^{n}[gcd(i,j)=1](i+1)(j+1)$ 子任务一:暴力 子任务二:$T=50000,n≤10^7$ 子任务三:$T ...
- 【Java】认识 JDK,JRE,JVM
JDK,JRE,JVM 今天我们讨论下这三个Java工具 JDK 全称Java Development ToolKit(Java 开发工具包). JDK是整个JAVA的核心,其包括了Java运行环境( ...
- VUE输入框显示时自动聚焦
directives: { focus: { inserted: function (el, {value}) { if (value) { el.focus() } } } } 注意点:1.用v-i ...
- web与app测试的区别
单纯从功能测试的层面上来讲的话,APP 测试.web 测试 在流程和功能测试上是没有区别的. 系统架构方面: web项目,一般都是b/s架构,基于浏览器的 app项目,则是c/s的,必须要有客户端,用 ...
- Android 开发工具类 26_getFile
从网络获取可执行文件 public void getFile() throws Exception{ // 首先得到请求的路径 String urlpath = "http://ftpcnc ...
- Python -- Gui编程 -- Qt库的使用 -- 配置资源文件
1.源文件(qtRes.py) import sys from PyQt4 import QtCore, QtGui, uic class MyDialog(QtGui.QDialog): def _ ...
- 一次tomcat数据乱码事件
一次环境变量出错导致的tomcat数据乱码事件 1.1 事件起因 由于业务的调整,我们需要将在A服务器上的后台系统迁移到B服务器上的后台,我们选择在下班后进行迁移,因为那个时间点,后台系统已经几乎没有 ...
- google glog 使用方法
#include <glog/logging.h> int main(int argc,char* argv[]) { google::ParseCommandLineFlags(& ...