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

1、概述

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

2、示例图

2.1、开操作

2.2、闭操作

2.3、形态学梯度

2.4、顶帽

 

2.5、黑帽

3、示例代码

//开操作:先腐蚀后膨胀,可以去掉小的对象
//闭操作:先膨胀、后腐蚀,可以填充小的洞
//形态学梯度:又称为基本梯度,基本原理是:膨胀减去腐蚀
//顶帽:原图像与开操作之间的差值图像
//黑帽:原图像与闭操作图像的差值图像
//
 
 
 
 
 
#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;
}

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值