均值滤波

图片边缘也处理的代码:

void MeanFilter(unsigned char *pImg,int width,int height,int kernel)
{
	//卷积核为奇数
	if (pImg==NULL||width<=0||height<=0||kernel<=0||kernel%2==0)
	{
		printf("The arguments send to function MeanFilter Error!\n")
		return;
	}

	unsigned char *pTempImg = new unsigned char[width*height*sizeof(unsigned char)];
	if (pTempImg==NULL)
	{
		printf("New pTempImg memory failed in funciton MeanFilter!\n");
		return;
	}
	
	long sum = 0;
	int m,n;
	for (int i=0;i<height;i++)
	{
		for (int j=0;j<width;j++)
		{
			sum = 0;
			for (int k=i-kernel/2;k<=i+kernel/2;k++)
			{
				m = k;
				if (m<0)
				{
					m = 0;
				}
				else if (m>=height)
				{
					m = height - 1;
				}
				for (int t=j-kernel/2;t<=j+kernel/2;t++)
				{
					n = t;
					if (n<0)
					{
						n = 0;
					}
					else if (n>=width)
					{
						n = width -1;
					}
					sum += pImg[m*width+n];
				}
			}
			sum = sum/(kernel*kernel);
			pTempImg[i*width+j] = (unsigned char)sum;
		}
	}
	
	memcpy(pImg,pTempImg,width*height*sizeof(unsigned char));

	if (pTempImg!=NULL)
	{
		delete []pTempImg;
		pTempImg = NULL;
	}
}

图像边缘不处理的代码:

void MeanFilter(unsigned char *pImg,int width,int height,int kernel)
{
	//卷积核为奇数
	if (pImg==NULL||width<=0||height<=0||kernel<=0||kernel%2==0)
	{
		printf("The arguments send to function MeanFilter Error!\n")
		return;
	}

	unsigned char *pTempImg = new unsigned char[width*height*sizeof(unsigned char)];
	if (pTempImg==NULL)
	{
		printf("New pTempImg memory failed in funciton MeanFilter!\n");
		return;
	}
 	long sum = 0;

	memcpy(pTempImg,pImg,width*height*sizeof(unsigned char));

	for (int i=kernel/2;i<height-kernel/2;i++)
	{
		for (int j=kernel/2;j<width-kernel/2;j++)
 		{
			sum = 0;
			for(int m=i-kernel/2;m<=i+kernel/2;m++)
			{
				for(int n=j-kernel/2;n<=j+kernel/2;n++)
				{
 					sum += pImg[m*width+n];
 				}
			}
	 		sum = sum/(kernel*kernel);
	 		pTempImg[i*width+j] = (unsigned char)sum;
	 	}
	}
	
	memcpy(pImg,pTempImg,width*height*sizeof(unsigned char));

	if (pTempImg!=NULL)
	{
		delete []pTempImg;
		pTempImg = NULL;
	}

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值