MFC几种简单的灰度线性变换

1、,建立一个ImageProcessing Wizard工程;
2、选择菜单里的工程->设置,选择C/C++选项卡,分类下拉条里选择Code Generation,然后在Struct member alignment中选择1 Byte;
3、通过CBmp类读入bmp文件;
4.给C~Dlg类添加一个成员变量CBmp* bmp;
5.在OninitDialog()内添加代码 :bmp=new CBmp;
bmp->load_bmp(“C:\cat.bmp”);
6.之后,读取原图、彩色图像灰度化、彩色图像反色变换、灰度图像反色变换,灰度图像阈值化处理代码如下:

void CImageTransformDlg::OnOK() 
{
	// TODO: Add extra validation here
	//读取图像
	for(int i=0;i<bmp->nWidth;i++)
		for(int j=0;j<bmp->nHeight;j++)
		{
			struct rgb tx;
			tx=bmp->pImageData[j*bmp->nWidth+i];
			pDC->SetPixel(i,j,RGB(tx.red,tx.grn,tx.blu));
		}
}

BOOL CImageTransformDlg::DestroyWindow() 
{
	// TODO: Add your specialized code here and/or call the base class
	
	return CDialog::DestroyWindow();
}

void CImageTransformDlg::OnButtonColorGrey() 
{
	// TODO: Add your control notification handler code here
	//彩色图像灰度化
	for(int i=0;i<bmp->nWidth;i++)
		for(int j=0;j<bmp->nHeight;j++)
		{
			struct rgb tx;
			tx=bmp->pImageData[j*bmp->nWidth+i];
			int x=(tx.red+tx.grn+tx.blu)/3;
			pDC->SetPixel(i,j,RGB(x,x,x));
		}

}

void CImageTransformDlg::OnButtonAntiColor() 
{
	// TODO: Add your control notification handler code here
	//彩色图像反色变换
		for(int i=0;i<bmp->nWidth;i++)
		for(int j=0;j<bmp->nHeight;j++)
		{
			struct rgb tx;
			tx=bmp->pImageData[j*bmp->nWidth+i];
			//int x=(tx.red+tx.grn+tx.blu)/3;
			pDC->SetPixel(i,j,RGB(255-tx.red,255-tx.grn,255-tx.blu));
		}
	
}

void CImageTransformDlg::OnButtonAntiGrey() 
{
	// TODO: Add your control notification handler code here
	//灰度图像反色变换
		for(int i=0;i<bmp->nWidth;i++)
		for(int j=0;j<bmp->nHeight;j++)
		{
			struct rgb tx;
			tx=bmp->pImageData[j*bmp->nWidth+i];
			int x=(tx.red+tx.grn+tx.blu)/3;
			pDC->SetPixel(i,j,RGB(255-x,255-x,255-x));
		}
	
}

void CImageTransformDlg::OnButtonThresholding() 
{
	// TODO: Add your control notification handler code here
	//阈值化
		for(int i=0;i<bmp->nWidth;i++)
		for(int j=0;j<bmp->nHeight;j++)
		{
			struct rgb tx;
			tx=bmp->pImageData[j*bmp->nWidth+i];
			int x=(tx.red+tx.grn+tx.blu)/3;
			if(x>100)
				x=255;
			else
				x=0;
			pDC->SetPixel(i,j,RGB(x,x,x));

		}
	
}

最后的结果如图:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值