数字图像处理MFC程序设计之灰度图像的线性变换
? ? 承接上一篇博客,接下來實(shí)現(xiàn)以下灰度圖像的線性拉伸變換,具體理論就不贅述了,學(xué)過數(shù)字圖像處理的基本都知道,下面來看看如何通過VC6.0的MFC編程實(shí)現(xiàn)它。
首先打開工作空間的resources視窗,創(chuàng)建菜單項(xiàng),如下:
然后為菜單創(chuàng)建消息響應(yīng)函數(shù),右鍵灰度線性變換,選擇ClassWizard,創(chuàng)建單擊事件函數(shù):
確定,點(diǎn)擊EditCode后發(fā)現(xiàn)有View.cpp中已經(jīng)有如下代碼:
? ? 下面,我們需要?jiǎng)?chuàng)建一個(gè)對話框,來接受用戶設(shè)置的線性變換參數(shù),最小值和最大值,可以右鍵Dialog,InsertDialog,設(shè)置對話框ID為:IDD_DIALOG_LinerTransSet
添加兩個(gè)Edit編輯框,ID分別為:IDC_EDIT_MAX、IDC_EDIT_MIN,如下:
? ? 為對話框創(chuàng)建類,雙擊對話框,提示創(chuàng)建新的類,選擇確定,設(shè)置類參數(shù)如下:
確定之后,為兩個(gè)Edit對象創(chuàng)建成員變量,在上面的類向?qū)е?#xff0c;選擇Member Variables選項(xiàng)卡,創(chuàng)建成員變量如下:
? ? ? ? 這些準(zhǔn)備工作做好了之后,便可以實(shí)現(xiàn)前面空著的OnLinertrans函數(shù)了,先在View.cpp文件上方添加頭文件包含# include "LinerTransDlg.h",然后實(shí)現(xiàn)OnLinertrans,
直接上代碼如下:
void CImageProcessView::OnLinertrans() {// TODO: Add your command handler code hereCLinerTransDlg linedlg;if(linedlg.DoModal()==IDOK){UpdateData(TRUE);CImageProcessDoc* pDoc=GetDocument();ASSERT_VALID(pDoc);BYTE* pData=pDoc->m_bmpFile.m_pImgDat;int cols=pDoc->m_bmpFile.m_Cols;int rows=pDoc->m_bmpFile.m_Rows;int min=linedlg.m_nMin;int max=linedlg.m_nMax;float mingray=255,maxgray=0;for(int r=0;r<rows;r++){for(int c=0;c<cols;c++){if(*(pData+cols*r+c)<mingray)mingray=*(pData+cols*r+c);if(*(pData+cols*r+c)>maxgray)maxgray=*(pData+cols*r+c);}}float a=(min-max)/(mingray-maxgray);for(r=0;r<rows;r++){for(int c=0;c<cols;c++){int gray=int(min+a*(*(pData+cols*r+c)-mingray));*(pData+cols*r+c)=BYTE(gray);}}Invalidate();} }這樣,整個(gè)編程任務(wù)完成,運(yùn)行程序:
確定后結(jié)果如下:
寫博客不多,歡迎指正,附上源碼下載地址:http://download.csdn.net/detail/whustyle/8246103
總結(jié)
以上是生活随笔為你收集整理的数字图像处理MFC程序设计之灰度图像的线性变换的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: comsol 4.4 matlab,如何
- 下一篇: comsol 超声声场模拟_Comsol