OpenCV(三十):图像膨胀

1.图像膨胀原理

图像膨胀的原理是将一个结构元素(也称为核或模板)在图像上滑动,并将其与图像中对应位置的像素进行比较。如果结构元素的所有像素与图像中对应位置的像素都匹配,那么该位置的像素值保持不变。如果结构元素的任何一个像素与图像中对应位置的像素不匹配,那么 图像中对应位置的像素被置为1,从而改变了图像的形状和结构。

2.结构元素生成函数getStructuringElement()

Mat cv::getStructuringElement ( int shape,

Size ksize,

Point anchor = point(-1,-1)

)

  • shape:结构元素的种类。
  • ksize:结构元素的尺寸大小。
  • anchor:中心点的位置,默认参数为结构元素的几何中心点。

其中结构元素的种类有:

3.图像膨胀操作函数dilate()

void cv::dilate ( InputArray src,

OutputArray dst,

InputArray kernel,

Point anchor = point(-1,-1),

int iterations = 1,

int borderType = BORDER_CONSTANT,

const Scalar & borderValue = morphologyDefaultBorderValue()

)

  • src: 输入的待膨胀图像,图像的通道数可以是任意的,但是图像的数据类型必须是CV_8U,CV_16U,CV_16S,CV_32F或CV_64F之一。
  • dst:腐蚀后的输出图像,与输入图像src具有相同的尺寸和数据类型。
  • kernel:用于膨胀操作的结构元素,可以自己输入,也可以用getStructuringElement0函数生成
  • anchor:中心点在结构元素中的位置,默认参数为结构元素的几何中心点
  • iterations:腐蚀的次数
  • borderType:像素外推法选择标志
  • borderValue:边界不变的边界值。

4.示例代码:

复制代码
//图像膨胀
void image_dilate(Mat image){
    Mat gray;
    cvtColor(image,gray,COLOR_BGR2GRAY);//灰度化
    Mat dilate_black1,dilate_black2;
    //黑背景图像膨胀
    Mat struct1= getStructuringElement(0,Size(3,3));//矩形结构元素
    Mat struct2= getStructuringElement(1,Size(3,3));//十字结构元素

    dilate(gray,dilate_black1,struct1);//膨胀
    dilate(gray,dilate_black2,struct2);
   
}
相关推荐
l***749410 分钟前
开源模型应用落地-工具使用篇-Spring AI-Function Call(八)
人工智能·spring·开源
智慧地球(AI·Earth)14 分钟前
DeepSeek开源IMO金牌模型:AI数学垄断时代终结
人工智能
选与握1 小时前
深度学习基本知识+tensorflow
人工智能
大千AI助手1 小时前
ROUGE-SU4:文本摘要评估的跳连智慧
人工智能·机器学习·nlp·rouge·文本摘要·大千ai助手·rouge-su4
草莓熊Lotso1 小时前
unordered_map/unordered_set 使用指南:差异、性能与场景选择
java·开发语言·c++·人工智能·经验分享·python·网络协议
stormsha2 小时前
裸眼3D原理浅析AI如何生成平面裸眼3D图像以科幻战士破框而出为例
人工智能·计算机视觉·平面·3d·ai
咔咔咔的3 小时前
1930. 长度为 3 的不同回文子序列
c++
春日见5 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
陈文锦丫7 小时前
MixFormer: A Mixed CNN–Transformer Backbone
人工智能·cnn·transformer
小毅&Nora8 小时前
【人工智能】【AI外呼】系统架构设计与实现详解
人工智能·系统架构·ai外呼