数字图像处理MFC程序设计之灰度图像的线性变换
生活随笔
收集整理的這篇文章主要介紹了
数字图像处理MFC程序设计之灰度图像的线性变换
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
? ? 承接上一篇博客,接下來實現以下灰度圖像的線性拉伸變換,具體理論就不贅述了,學過數字圖像處理的基本都知道,下面來看看如何通過VC6.0的MFC編程實現它。
首先打開工作空間的resources視窗,創建菜單項,如下:
然后為菜單創建消息響應函數,右鍵灰度線性變換,選擇ClassWizard,創建單擊事件函數:
確定,點擊EditCode后發現有View.cpp中已經有如下代碼:
? ? 下面,我們需要創建一個對話框,來接受用戶設置的線性變換參數,最小值和最大值,可以右鍵Dialog,InsertDialog,設置對話框ID為:IDD_DIALOG_LinerTransSet
添加兩個Edit編輯框,ID分別為:IDC_EDIT_MAX、IDC_EDIT_MIN,如下:
? ? 為對話框創建類,雙擊對話框,提示創建新的類,選擇確定,設置類參數如下:
確定之后,為兩個Edit對象創建成員變量,在上面的類向導中,選擇Member Variables選項卡,創建成員變量如下:
? ? ? ? 這些準備工作做好了之后,便可以實現前面空著的OnLinertrans函數了,先在View.cpp文件上方添加頭文件包含# include "LinerTransDlg.h",然后實現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();} }這樣,整個編程任務完成,運行程序:
確定后結果如下:
寫博客不多,歡迎指正,附上源碼下載地址:http://download.csdn.net/detail/whustyle/8246103
總結
以上是生活随笔為你收集整理的数字图像处理MFC程序设计之灰度图像的线性变换的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: comsol 4.4 matlab,如何
- 下一篇: comsol 超声声场模拟_Comsol