随笔 - 632  文章 - 17  评论 - 54  阅读 - 93万

OpenCV实现开操作、闭操作、形态学梯度、顶帽、黑帽

一、概述

  案例:利用opencv实现开操作、闭操作、形态学梯度、顶帽、黑帽

二、示例图

  1.开操作

  

 

 

  2.闭操作

 

 

  3.形态学梯度

 

 

  4.顶帽

 

 

  5.黑帽

 

 

三、示例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
//开操作:先腐蚀后膨胀,可以去掉小的对象
//闭操作:先膨胀、后腐蚀,可以填充小的洞
//形态学梯度:又称为基本梯度,基本原理是:膨胀减去腐蚀
//顶帽:原图像与开操作之间的差值图像
//黑帽:原图像与闭操作图像的差值图像
//
 
 
 
 
 
#include <opencv2/opencv.hpp>
#include <iostream>
 
using namespace cv;
using namespace std;
void getGray();
void getThreshold();
 
Mat src,dst,gray,thresholdMat;
/**获取原生图像*/
int getSrc(){
    src = imread("girl.jpg");
    if(!src.data){
        cout << "can't load image..."<<endl;
        return -1;
    }
    imshow("src",src);
    // getGray();
    // getThreshold();
    return 0;
}
 
/**对图像进行灰度处理*/
void getGray(){
    //转换色彩空间--->将彩色图转换为灰度图
    cvtColor(src,gray,COLOR_BGR2GRAY);
    imshow("gray",gray);
}
 
/**
 * 对图像进行二值分割
 * */
void getThreshold(){
    threshold(gray,thresholdMat,0,255,THRESH_OTSU);
    imshow("thresholdMat",thresholdMat);
}
 
/**
 * 开操作
 * */
void openOption(){
    getSrc();
    Mat kernel = getStructuringElement(MORPH_RECT,Size(7,7),Point(-1,-1));
    morphologyEx(src,dst,MORPH_OPEN ,kernel);
    imshow("dst",dst);
 
}
 
/**
 * 闭操作
 * */
void closeOption(){
    getSrc();
    Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1));
    morphologyEx(src,dst,MORPH_CLOSE,kernel);
    imshow("dst",dst);
}
 
/**
 *
 * 形态学梯度:突出高亮区域的外围、为轮廓查找提供思路
 * */
void gradOption(){
    getSrc();
    Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1));
    morphologyEx(src,dst,MORPH_GRADIENT,kernel);
    imshow("dst",dst);
}
 
/**
 * 顶帽操作:用于背景提取、顶帽运算往往用来分离比临近点亮一些的斑点,当一副图像具有大幅背景的时候,而微小物品比较有规律的
    情况下可以用顶帽运算进行背景提取
 * */
void topOption(){
    getSrc();
    Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1));
    morphologyEx(src,dst,MORPH_TOPHAT,kernel);
    imshow("dst",dst);
}
/**
 * 黑帽操作
 * */
void blackOption(){
    getSrc();
    Mat kernel = getStructuringElement(MORPH_RECT,Size(5,5),Point(-1,-1));
    morphologyEx(src,dst,MORPH_BLACKHAT,kernel);
    imshow("dst",dst);
}
 
int main(int argc, char const *argv[])
{
     
    // openOption();
    // closeOption();
    // gradOption();
    // topOption();
    blackOption();
 
    waitKey(0);
    return 0;
}

  

posted on   飘杨......  阅读(244)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示