OpenCV黑帽运算(BLACKHAT)的使用

作者:翟天保Steven 时间:2022-11-11 22:32:00 

原理

形态学是图像处理中常见的名词,图像处理的形态学基本属于数学形态学的范畴,是一门建立在格论和拓扑学基础上的图像分析学科。黑帽运算是结合了腐蚀和膨胀的一种运算,闭运算结果图减原图。

简单来说,黑帽运算就是将闭运算后的图像减去原图,突出了比原图轮廓周围区域更暗的区域。效果图见下方图1图2。

函数原型

void morphologyEx( InputArray src, OutputArray dst,
                  int op, InputArray kernel,
                  Point anchor = Point(-1,-1), int iterations = 1,
                  int borderType = BORDER_CONSTANT,
                  const Scalar& borderValue = morphologyDefaultBorderValue() );
其中op=MORPH_BLACKHAT

参数说明

  • InputArray类型的src,输入图像,如Mat类型。

  • OutputArray类型的dst,输出图像。

  • int类型的op,选择不同的运算操作,黑帽运算则是MORPH_BLACKHAT。

  • Point类型的anchor,锚点。默认值(-1,-1),表示位于单位中心,一般不用。

  • int类型的iterations,迭代使用的次数,默认值为1。

  • int类型的borderType,推断图像外部像素的边界模式,我OpenCV版本的默认值为BORDER_CONSTANT。如果图像边界需要扩展,则不同的模式下所扩展的像素,其生成原则不同。

  • const Scalar&类型的borderValue,当边界为常数时的边界值,默认值为morphologyDefaultBorderValue()。

测试代码

#include<iostream>
#include<opencv2/opencv.hpp>
#include<ctime>
using namespace std;
using namespace cv;
int main(void)
{
cv::Mat test = cv::Mat::zeros(64, 64, CV_8UC1);
cv::rectangle(test, cv::Rect(30, 30, 8, 8), 255, -1);
cv::rectangle(test, cv::Rect(33, 30, 2, 2), 0, -1);

cv::Mat element = getStructuringElement(MORPH_RECT, Size(3, 3));
cv::Mat result, close;
cv::morphologyEx(test, close, MORPH_CLOSE, element);
cv::morphologyEx(test, result, MORPH_BLACKHAT, element);

imshow("original", test);
imshow("close", close);
imshow("result", result);
waitKey(0);

system("pause");
return 0;
}

测试效果

OpenCV黑帽运算(BLACKHAT)的使用

OpenCV黑帽运算(BLACKHAT)的使用

OpenCV黑帽运算(BLACKHAT)的使用

如上图所示,有原先8*8的矩形,有一个2*2的凹处,我设置了3*3的矩形蒙版,对其进行闭运算操作如图2所示,凹进消失,对其进行黑帽操作如图3所示,突出了凹进的内容。

来源:https://blog.csdn.net/zhaitianbao/article/details/117214281

标签:OpenCV,黑帽运算
0
投稿

猜你喜欢

  • asp生成一个不重复的随机数字

    2007-09-12 19:12:00
  • pytorch-RNN进行回归曲线预测方式

    2022-01-27 08:40:32
  • python神经网络Keras GhostNet模型的实现

    2022-05-16 17:19:42
  • Pytorch-LSTM输入输出参数方式

    2021-02-22 18:49:28
  • 如何基于python实现脚本加密

    2021-10-07 19:23:05
  • JavaScript登录验证码的实现

    2023-08-23 21:03:12
  • asp如何删除数据库中的表或索引?

    2010-06-26 12:23:00
  • php统计数组不同元素的个数的实例方法

    2023-06-11 23:04:59
  • 浅谈django 模型类使用save()方法的好处与注意事项

    2021-05-17 10:43:59
  • MySQL怎么给字符串字段加索引

    2024-01-25 10:19:57
  • 发现一个不错的11px字体:PMingLiu

    2008-09-06 12:49:00
  • Python进度条tqdm的用法详解

    2022-09-03 00:27:35
  • django ManyToManyField多对多关系的实例详解

    2023-08-11 20:21:01
  • SQL“多字段模糊匹配关键字查询”

    2008-04-24 14:16:00
  • python中统计相同字符的个数方法实例

    2021-04-21 00:28:58
  • 解决js相同的正则多次调用test()返回的值却不同的问题

    2024-04-17 09:42:18
  • ORACLE数据库应用开发常见问题及排除

    2010-07-26 13:17:00
  • 详解python发送各类邮件的主要方法

    2023-07-27 11:08:50
  • MySQL的 DDL和DML和DQL的基本语法详解

    2024-01-15 06:40:43
  • python乱序字符串排序的实现方式

    2023-08-02 12:14:59
  • asp之家 网络编程 m.aspxhome.com