OpenCV 膨胀and腐蚀


#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>

using namespace std;
using namespace cv;


// 膨胀:计算掩膜覆盖下图像的最大像素值来替换锚点的像素
// 简单说 用高像素点来代替低像素点,图片越来越白


// 腐蚀:计算掩膜覆盖下图像的最小像素值来替换锚点的像素
// 图片越来越黑

Mat src, dst;
int element_size = 3;
int max_size = 21;

void CallBack_dilate(int, void *) {
    int s = element_size * 2 + 1;
    Mat structureElement = getStructuringElement(MORPH_RECT, Size(s, s), Point(-1, -1));
    dilate(src, dst, structureElement, Point(-1, -1), 1);
    imshow("output image", dst);
    return ;
}

void CallBack_erode(int, void*) {
    int s = element_size * 2 + 1;
    Mat structureElement = getStructuringElement(MORPH_RECT, Size(s, s), Point(-1, -1));
    erode(src, dst, structureElement, Point(-1, -1), 1);
    imshow("output image", dst);
    return ;
}


int main() {
    Mat src1, src2, gray_src, dst;
    src = imread("/Users/apple/Desktop/birth.jpg", IMREAD_COLOR);
    //src2 = imread("/Users/apple/Desktop/test2.jpg", IMREAD_COLOR);
    if (src.empty()) { // if (!src.data())
        cout << "could not load image..." << endl;
        return -1;
    }
    imshow("input", src);
    
    namedWindow("output image", CV_WINDOW_AUTOSIZE);
    createTrackbar("dilate size: ", "output image", &element_size, max_size, CallBack_dilate);
    createTrackbar("erode size:", "output image", &element_size, max_size, CallBack_erode);
    CallBack_dilate(0, 0);
    
    
    waitKey(0);
    
    return 0;
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值