# 图像的侵蚀处理

1.Erode.h Erode.c 是图像侵蚀的头文件、核心函数文件
Erode.h

``````#ifndef _ERODE_H_
#define _ERODE_H_

#ifdef __cplusplus
extern "C"
{
#endif

int erodeFunction(float * inData, float * outData, int dataWidth, int dataHeight, int erodeWidth, int erodeHeight, int channels);

#ifdef __cplusplus
}
#endif

#endif``````

Erode.c

``````#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <memory.h>
#include "Erode.h"
#include "myMath.h"
int erodeFunction(float * inData, float * outData, int dataWidth, int dataHeight, int erodeWidth, int erodeHeight, int channels){
int widthTemp, heightTemp;
int i, j;
int m, n, z;
float * dataTemp = NULL;
int count = 0;
float medianData = 0.f;
if(channels > 32){
printf("channels is larger.\n");
return -1;
}
if(erodeWidth % 2 == 0){
widthTemp = erodeWidth / 2 - 1;
}else{
widthTemp = erodeWidth / 2;
}
if(erodeHeight % 2 == 0){
heightTemp = erodeHeight / 2 - 1;
}else{
heightTemp = erodeHeight / 2;
}

dataTemp = (float*)malloc(sizeof(float) * erodeWidth * erodeHeight);
for(z = 0; z < channels; z ++){
for(i = 0; i < dataHeight; i ++){
for(j = 0; j < dataWidth; j ++){
memset(dataTemp, 0, sizeof(float) * erodeWidth * erodeHeight);
count = 0;
medianData = 0.0f;
for(m = -heightTemp; m < erodeHeight - heightTemp; m ++){
for(n = -widthTemp; n < erodeWidth - widthTemp; n ++){
if(i + m >= 0 && i + m < dataHeight && j + n >= 0 && j + n < dataWidth){
dataTemp[count] = inData[((i + m) * dataWidth + (j + n)) * channels + z];
count ++;
}
}
}

medianData = getMinValue(dataTemp, count);
outData[(i * dataWidth + j) * channels + z] = medianData;
}
}
}
free(dataTemp);
return 0;
}``````

2.主程序函数

``````#include "stdafx.h"
#include "Tools.h"
#include "Erode.h"
#include <opencv2\opencv.hpp>
using namespace cv;
int main()
{
int imageWidth, imageHeight;
int channels = 1;
imshow("srcImage", mImage);
float * imageData = NULL;
float * imageOutData = NULL;
imageWidth = mImage.cols;
imageHeight = mImage.rows;
channels = mImage.channels();
imageData = (float*)malloc(sizeof(float) * imageWidth * imageHeight * channels);
imageOutData = (float*)malloc(sizeof(float) * imageWidth * imageHeight * channels);
uCharDataToFloatData(mImage.data, imageData, imageWidth, imageHeight, channels);
erodeFunction(imageData, imageOutData, imageWidth, imageHeight, 5, 5, channels);
floatDataToUCharData(imageOutData, mImage.data, imageWidth, imageHeight, channels, 1);
imshow("erode Image", mImage);
waitKey(0);
free(imageData);
free(imageOutData);
return 0;
}``````

3.getMinValue();

http://blog.csdn.net/jsf921942722/article/details/51527155
uCharDataToFloatData();
floatDataToUCharData();

http://blog.csdn.net/jsf921942722/article/details/51526673
4.效果图
****************************3通道彩色图原图********************

****************************3通道彩色图侵蚀后图********************

****************************1通道灰度图原图********************

****************************1通道灰度图侵蚀后图********************

• 本文已收录于以下专栏：

## 图像的“膨胀”与“腐蚀”

• yarina
• 2016年05月09日 16:57
• 4989

## opencv3_java 图像的侵蚀Erode erode

• sileixinhua
• 2017年05月31日 21:26
• 1067

## 图像的模糊处理原理

• rainbowchou
• 2016年01月27日 12:21
• 2695

## 图像预处理与特征提取（1）——白化处理和直方图均衡化

• jxwhg
• 2015年12月05日 16:18
• 3606

## 警惕日本文化的侵蚀

• Musicwind
• 2005年03月27日 22:50
• 1919

## android使用opencv图片腐蚀与扩张

• xy1213236113
• 2018年01月23日 23:41
• 23

## POJ图像模糊处理

• Sylar2016
• 2017年02月28日 09:13
• 367

## Matlab处理图像的一般方法

Matlab是强大的数学问题处理软件，同时也是图像处理强有力的工具。本文通过几个实例具体介绍Matlab下如何进行图像处理。 （1）图像的读取与输出 Matlab读取图像的基本方法是 image...
• Sync_hronize
• 2015年04月06日 22:03
• 673

## opencv 图像分块处理

• chaihuimin
• 2016年09月22日 09:43
• 2451

## 数字图像处理，图像的伪彩色处理

• EbowTang
• 2015年04月15日 17:53
• 2182

举报原因： 您举报文章：图像的侵蚀处理 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)