8種常用圖像處理算法(函數(shù))_第1頁
8種常用圖像處理算法(函數(shù))_第2頁
8種常用圖像處理算法(函數(shù))_第3頁
8種常用圖像處理算法(函數(shù))_第4頁
8種常用圖像處理算法(函數(shù))_第5頁
已閱讀5頁,還剩22頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、 8種常用圖像處理算法(函數(shù)) 這是我畢業(yè)設(shè)計(jì)的一部分代碼/* * * 函數(shù)名稱: * * VertMirror() * * 參數(shù): * * LPSTR lpDIB /指向源DIB圖像指針 * * 返回值: * * BOOL /鏡像成功返回TRUE,否則返回FALSE。 * * 說明: * * 該函數(shù)用來實(shí)現(xiàn)DIB圖像的垂直鏡像。 * */BOOL WINAPI VertMirror(LPSTR lpDIB)/原圖象寬度 LONG lWidth;/原圖象高度LONG lHeight;/原圖象的顏色數(shù)WORD wNumColors;/原圖象的信息頭結(jié)構(gòu)指針LPBITMAPINFOHEADER l

2、pbmi;/指向原圖象和目的圖象的像素的指針LPBYTE lpSrc,lpDst;/平移后剩余圖像在源圖像中的位置(矩形區(qū)域)CRectrectSrc;/指向原圖像像素的指針LPBYTE lpDIBBits;/指向復(fù)制圖像像素的指針LPBYTE lpNewDIBBits;/內(nèi)存句柄HLOCALh;/循環(huán)變量LONGi;/圖像每行的字節(jié)數(shù)LONG lLineBytes;/獲取圖象的信息頭結(jié)構(gòu)的指針lpbmi=(LPBITMAPINFOHEADER)lpDIB;/找到圖象的像素位置lpDIBBits=(LPBYTE):FindDIBBits(lpDIB);/獲取圖象的寬度lWidth=:DIBWi

3、dth(lpDIB);/獲取圖象的高度lHeight=:DIBHeight(lpDIB);/獲取圖象的顏色數(shù)wNumColors=:DIBNumColors(lpDIB);/計(jì)算圖像每行的字節(jié)數(shù)lLineBytes = WIDTHBYTES(lWidth *(lpbmi-biBitCount);/ 暫時(shí)分配內(nèi)存,以保存新圖像h= LocalAlloc(LHND, lLineBytes);/ 分配內(nèi)存失敗,直接返回if (!h)return FALSE;/ 鎖定內(nèi)存lpNewDIBBits = (LPBYTE)LocalLock(h);/如果是256色位圖或真彩色位圖if(wNumColors=

4、256|wNumColors=0) /平移圖像,每次移動(dòng)一行 for(i = 0; ibiBitCount);/將旋轉(zhuǎn)角度從度轉(zhuǎn)換到弧度fArcAngle =(iAngle*PI)/180.0;/計(jì)算旋轉(zhuǎn)角度的正弦fSin = (float) sin(fArcAngle);/計(jì)算旋轉(zhuǎn)角度的余弦fCos = (float) cos(fArcAngle);/計(jì)算原圖的四個(gè)角的坐標(biāo)(以圖像中心為坐標(biāo)系原點(diǎn))fSrcX1 = (float) (- (lWidth - 1) / 2);fSrcY1 = (float) ( (lHeight - 1) / 2);fSrcX2 = (float) ( (lW

5、idth - 1) / 2);fSrcY2 = (float) ( (lHeight - 1) / 2);fSrcX3 = (float) (- (lWidth - 1) / 2);fSrcY3 = (float) (- (lHeight - 1) / 2);fSrcX4 = (float) ( (lWidth - 1) / 2);fSrcY4 = (float) (- (lHeight - 1) / 2);/計(jì)算新圖四個(gè)角的坐標(biāo)(以圖像中心為坐標(biāo)系原點(diǎn))fDstX1 = fCos * fSrcX1 + fSin * fSrcY1;fDstY1 = -fSin * fSrcX1 + fCos

6、* fSrcY1;fDstX2 = fCos * fSrcX2 + fSin * fSrcY2;fDstY2 = -fSin * fSrcX2 + fCos * fSrcY2;fDstX3 = fCos * fSrcX3 + fSin * fSrcY3;fDstY3 = -fSin * fSrcX3 + fCos * fSrcY3;fDstX4 = fCos * fSrcX4 + fSin * fSrcY4;fDstY4 = -fSin * fSrcX4 + fCos * fSrcY4;/計(jì)算旋轉(zhuǎn)后的圖像實(shí)際寬度lNewWidth = (LONG) ( max( fabs(fDstX4 - f

7、DstX1), fabs(fDstX3 - fDstX2) ) + 0.5);/計(jì)算旋轉(zhuǎn)后的圖像高度lNewHeight = (LONG) ( max( fabs(fDstY4 - fDstY1), fabs(fDstY3 - fDstY2) ) + 0.5);/計(jì)算旋轉(zhuǎn)后圖像每行的字節(jié)數(shù)lNewLineBytes = WIDTHBYTES(lNewWidth * lpbmi0-biBitCount);/計(jì)算兩個(gè)常數(shù)f1 = (float) (-0.5 * (lNewWidth - 1) * fCos - 0.5 * (lNewHeight - 1) * fSin+ 0.5 * (lWidth

8、 - 1);f2 = (float) ( 0.5 * (lNewWidth - 1) * fSin - 0.5 * (lNewHeight - 1) * fCos+ 0.5 * (lHeight - 1);/暫時(shí)分配內(nèi)存,以保存新圖像hDIB=(HDIB):GlobalAlloc(GHND, lNewHeight*lNewLineBytes+*(LPDWORD)lpDIB+:PaletteSize(lpDIB);/分配內(nèi)存失敗,直接返回if (!hDIB)return NULL;/鎖定內(nèi)存lpNewDIB = (LPSTR):GlobalLock(HGLOBAL)hDIB);/復(fù)制DIB信息頭

9、和調(diào)色板memcpy(lpNewDIB,lpDIB,*(LPDWORD)lpDIB+:PaletteSize(lpDIB);/獲取圖象的信息頭結(jié)構(gòu)的指針lpbmi=(LPBITMAPINFOHEADER)lpNewDIB;/更新DIB圖象的高度和寬度lpbmi-biWidth=lNewWidth;lpbmi-biHeight=lNewHeight;/找到新DIB像素的起始位置lpNewDIBBits=(LPBYTE):FindDIBBits(lpNewDIB);/如果是256色位圖if(wNumColors=256) /旋轉(zhuǎn)后圖像每行 for(i = 0; ilNewHeight; i+) /

10、旋轉(zhuǎn)后圖象每列 for(j=0;j= 0) & (j0 = 0) & (i0 lHeight) / 指向源DIB圖象第i0行,第j0個(gè)象素的指針 lpSrc = (LPBYTE)lpDIBBits + lLineBytes * (lHeight - 1 - i0) + j0; / 復(fù)制象素 *lpDst = *lpSrc; else / 對于源圖中沒有的象素,直接賦值為255 * (LPBYTE)lpDst) = 255; /如果是24位真彩色位圖else if(wNumColors=0) /旋轉(zhuǎn)后圖像每行 for(i = 0; ilNewHeight; i+) /旋轉(zhuǎn)后圖象每列 for(j=

11、0;j= 0) & (j0 = 0) & (i0 biBitCount);/ 計(jì)算縮放后的圖像實(shí)際寬度/ 此處直接加0.5是由于強(qiáng)制類型轉(zhuǎn)換時(shí)不四舍五入,而是直接截去小數(shù)部分lNewWidth = (LONG) (lWidth* fXZoomRatio + 0.5);/ 計(jì)算新圖像每行的字節(jié)數(shù)lNewLineBytes = WIDTHBYTES(lNewWidth * (lpbmi0-biBitCount);/ 計(jì)算縮放后的圖像高度lNewHeight = (LONG) (lHeight * fYZoomRatio + 0.5);/ 分配內(nèi)存,以保存新DIBhDIB = (HDIB) :Glo

12、balAlloc(GHND, lNewLineBytes * lNewHeight + *(LPDWORD)lpDIB + :PaletteSize(lpDIB);/ 判斷是否內(nèi)存分配失敗if (hDIB = NULL)/ 分配內(nèi)存失敗return NULL;/ 鎖定內(nèi)存lpNewDIB = (LPSTR):GlobalLock(HGLOBAL) hDIB);/ 復(fù)制DIB信息頭和調(diào)色板memcpy(lpNewDIB, lpDIB, *(LPDWORD)lpDIB + :PaletteSize(lpDIB);/ 找到新DIB象素起始位置lpNewDIBBits = (LPBYTE):FindD

13、IBBits(lpNewDIB);/ 獲取指針lpbmi = (LPBITMAPINFOHEADER)lpNewDIB;lpbmc = (LPBITMAPCOREHEADER)lpNewDIB;/ 更新DIB中圖像的高度和寬度if (IS_WIN30_DIB(lpNewDIB)/ 對于Windows 3.0 DIBlpbmi-biWidth = lNewWidth;lpbmi-biHeight = lNewHeight;else/ 對于其它格式的DIBlpbmc-bcWidth = (unsigned short) lNewWidth;lpbmc-bcHeight = (unsigned sh

14、ort) lNewHeight;if(wNumColors=256)/ 針對圖像每行進(jìn)行操作for(i = 0; i lNewHeight; i+)/ 針對圖像每列進(jìn)行操作for(j = 0; j = 0) & (j0 = 0) & (i0 lHeight)/ 指向源DIB第i0行,第j0個(gè)象素的指針lpSrc = (LPBYTE)lpDIBBits + lLineBytes * (lHeight - 1 - i0) + j0;/ 復(fù)制象素*lpDst = *lpSrc;else/ 對于源圖中沒有的象素,直接賦值為255* (LPBYTE)lpDst) = 255;else if(wNumCo

15、lors=0)for(i = 0; i lNewHeight; i+)/ 針對圖像每列進(jìn)行操作for(j = 0; j = 0) & (j0 = 0) & (i0 GetHDIB();/ 獲取指向BITMAPINFO結(jié)構(gòu)的指針(Win3.0)lpbmi = (LPBITMAPINFO)lpDIB;/ 獲取指向BITMAPCOREINFO結(jié)構(gòu)的指針(OS/2)lpbmc = (LPBITMAPCOREINFO)lpDIB;/ 鎖定DIB/ 獲取DIB中顏色表中的顏色數(shù)目wNumColors = :DIBNumColors(lpDIB);/ 判斷是否是256色位圖if (wNumColors !=

16、 256)MessageBox(不是256色位圖!);/ 解除鎖定:GlobalUnlock(HGLOBAL) pDoc-GetHDIB();/ 返回return;/ 更改光標(biāo)形狀BeginWaitCursor();/ 判斷是否是WIN3.0的DIBbWin30DIB = IS_WIN30_DIB(lpDIB);/將原圖象的調(diào)色板轉(zhuǎn)化為灰度調(diào)色板/建立原調(diào)色板索引與灰度調(diào)色板索引的映射關(guān)系for (i = 0; i bmiColorsi.rgbRed + 0.587 * lpbmi-bmiColorsi.rgbGreen + 0.114 * lpbmi-bmiColorsi.rgbBlue +

17、 0.5);/ 建立灰度調(diào)色板 /紅色分量lpbmi-bmiColorsi.rgbRed = i;/ 綠色分量lpbmi-bmiColorsi.rgbGreen = i;/ 藍(lán)色分量lpbmi-bmiColorsi.rgbBlue = i;/ 保留位lpbmi-bmiColorsi.rgbReserved = 0;else/對原256色調(diào)色板的每一表項(xiàng)計(jì)算對應(yīng)的灰度值bGrayMapi = (BYTE)(0.299 * lpbmc-bmciColorsi.rgbtRed + 0.587 * lpbmc-bmciColorsi.rgbtGreen + 0.114 * lpbmc-bmciColo

18、rsi.rgbtBlue + 0.5); /建立灰度調(diào)色板/ 紅色分量lpbmc-bmciColorsi.rgbtRed = i;/ 綠色分量lpbmc-bmciColorsi.rgbtGreen = i;/ 藍(lán)色分量lpbmc-bmciColorsi.rgbtBlue = i;/ 找到DIB圖像象素起始位置lpDIBBits = :FindDIBBits(lpDIB);/ 獲取圖像寬度lWidth = :DIBWidth(lpDIB);/ 獲取圖像高度lHeight = :DIBHeight(lpDIB);/ 計(jì)算圖像每行的字節(jié)數(shù)OneLineBytes = WIDTHBYTES(lWidt

19、h * 8);/ 更換原256色位圖的每個(gè)象素的顏色索引/ 每行for(ih = 0; ih lHeight; ih+)/ 每列for(iw= 0; iw GetDocPalette()-SetPaletteEntries(0,256,(LPPALETTEENTRY)lpbmi-bmiColors);/ 設(shè)置臟標(biāo)記pDoc-SetModifiedFlag(TRUE);/ 實(shí)現(xiàn)新的調(diào)色板OnDoRealize(WPARAM)m_hWnd,0);/ 更新視圖pDoc-UpdateAllViews(NULL);/ 解除鎖定:GlobalUnlock(HGLOBAL) pDoc-GetHDIB();/

20、 恢復(fù)光標(biāo)EndWaitCursor();/* * * 函數(shù)名稱: * * RandomNoise() * * 參數(shù): * * LPSTR lpDIB / 指向源DIB圖像指針 * * 返回值: * * BOOL / 加入隨機(jī)噪聲操作成功返回TRUE,否則返回FALSE。 * * 說明: * * 該函數(shù)用來對256色位圖和24位真彩色位圖進(jìn)行加入隨即噪聲操作。 * */BOOL WINAPI RandomNoise (LPSTR lpDIB)/ 圖像寬度和高度LONG lWidth,lHeight;/ 指向圖像像素的指針LPSTR lpDIBBits;/ 指向源圖像的指針LPSTRlpSrc;

21、/循環(huán)變量long i;long j;/ 圖像每行的字節(jié)數(shù)LONG lLineBytes;/指向圖像信息頭結(jié)構(gòu)的指針LPBITMAPINFOHEADER lpbmi;/圖像的顏色數(shù)WORD wNumColors;/噪聲BYTE NoiseValue;/ 計(jì)算圖像每行的字節(jié)數(shù)lpbmi=(LPBITMAPINFOHEADER)lpDIB;/計(jì)算圖像的高度和寬度lWidth=:DIBWidth(lpDIB);lHeight=:DIBHeight(lpDIB);/找到圖像像素的起始位置lpDIBBits=:FindDIBBits(lpDIB);/計(jì)算圖像的顏色數(shù)wNumColors=:DIBNumC

22、olors(lpDIB);/計(jì)算圖像每行的字節(jié)數(shù)lLineBytes = WIDTHBYTES(lWidth * lpbmi-biBitCount);/生成偽隨機(jī)種子srand(unsigned)time(NULL);/在圖像中加噪/如果是256色位圖if(wNumColors=256) for (j = 0;j lHeight ;j+) for(i = 0;i lWidth ;i+)/隨機(jī)的噪聲值 NoiseValue=rand()/1024; / 指向源圖像倒數(shù)第j行,第i個(gè)象素的指針 lpSrc = (char *)lpDIBBits + lLineBytes * j + i; /在像素

23、值中加入噪聲值 *lpSrc = (BYTE)(BYTE)*(lpSrc)*224/256 + NoiseValue);/如果是24位真彩色位圖else if(wNumColors=0)for (j = 0;j lHeight ;j+) for(i = 0;i lWidth ;i+) NoiseValue=rand()/1024; / 指向源圖像倒數(shù)第j行,第i個(gè)象素的指針 lpSrc = (char *)lpDIBBits + lLineBytes * j + 3*i; /在每個(gè)像素的RGB分量中加入隨機(jī)的噪聲值 *lpSrc+ = (BYTE)(BYTE)*(lpSrc+)*224/256

24、 + NoiseValue);*lpSrc+ = (BYTE)(BYTE)*(lpSrc+)*224/256 + NoiseValue);*lpSrc+ = (BYTE)(BYTE)*(lpSrc+)*224/256 + NoiseValue);/如果既不是256色位圖也不是24 位真彩色位圖,直接返回elseAfxMessageBox(只支持256色位圖和24位真彩色位圖);return false;/ 返回return true;/* * * 函數(shù)名稱: * * AdjustBrightness () * * 參數(shù): * * LPSTR lpDIB / 指向源DIB圖像指針 * * int

25、 db * * BOOL /操作成功返回TRUE,否則返回FALSE。 * * 說明: * * 該算法函數(shù)用來對256色位圖和24位真彩色位圖進(jìn)行亮度調(diào)整操作。 * */BOOL WINAPI AdjustBrightness(LPSTR lpDIB, int db)BYTE r, g, b; BITMAPINFO *pbmi; WORD wNumColors; LONG i; LPSTR lpDIBBits; int nDelta; int iWidth, iHeight;if (lpDIB = NULL)return FALSE;pbmi = (BITMAPINFO *)lpDIB;if

26、(! pbmi)return FALSE;wNumColors =:DIBNumColors(lpDIB);if (wNumColors=256) for (i=0; ibmiColorsi.rgbRed = BOUND(pbmi-bmiColorsi.rgbRed+db, 0, 255);pbmi-bmiColorsi.rgbGreen = BOUND(pbmi-bmiColorsi.rgbGreen+db, 0, 255);pbmi-bmiColorsi.rgbBlue = BOUND(pbmi-bmiColorsi.rgbBlue+db, 0, 255);else if(wNumColo

27、rs=0)lpDIBBits= :FindDIBBits(lpDIB); nDelta = WIDTHBYTES(pbmi-bmiHeader.biBitCount)*(pbmi-bmiHeader.biWidth) - (pbmi-bmiHeader.biWidth)*(pbmi-bmiHeader.biBitCount)+7)/8;for (iHeight=0; iHeightbmiHeader.biHeight; iHeight+)for (iWidth=0; iWidthbmiHeader.biWidth; iWidth+)b = (BYTE)*(lpDIBBits);g = (BYTE)*(lpDIBBits+1);r = (BYTE)*(lpDIBBits+2);*lpDIBBits+= BOUND(b+db, 0, 255);*lpDIBBits+= BOUND(g+db, 0, 255);*lpDIBBits+= BOUND(r+db, 0, 255);lpDIBBits += nDelta; elseAfxMessageBox(只處理256色和24位位圖); return false;return TRUE;/* * * 函數(shù)名

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論