圖像處理-基本算法之閾值變換

閾值變換在圖像處理中有着非常高的作用,很多處理都會用到。最常見的應用就是產生黑白圖。

   代碼如下:

  1. /******************************************************************************
  2. *   作用:     灰度閾值變換函數
  3. *   參數: pDst     輸出圖像的像素數組
  4. *   參數: pSrc     原始圖像的像素數組
  5. *   參數: nWidth   原始圖像寬度
  6. *   參數: nHeight  原始圖像高度
  7. *   參數: thr         閾值
  8. ******************************************************************************/ 
  9. int ThresholdTrans(BYTE* pDst, BYTE* pSrc, int nWidth, int nHeight, int thr) 
  10.     if (!pSrc || !pDst) 
  11.     { 
  12.         return EXIT_FAILURE; 
  13.     } 
  14.  
  15.     // 灰度映射表 
  16.     BYTE map[256]; 
  17.  
  18.     int i; 
  19.  
  20.     for (i = 0; i < 256; i++) 
  21.     { 
  22.         if (i >= thr) 
  23.             map[i] = 255; 
  24.         else 
  25.             map[i] = 0; 
  26.     } 
  27.  
  28.     // 變換後的值直接在映射表中查找 
  29.     for (i = 0; i < nWidth * nHeight; i++) 
  30.     { 
  31.         int x = pSrc[i * 4]; 
  32.  
  33.         pDst[i*4] = pDst[i*4+1] = pDst[i*4+2] = map[x]; 
  34.         pDst[i*4+3] = 255; 
  35.     } 
  36.  
  37.     return EXIT_SUCCESS; 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章