圖像(像素)反轉2

接上一篇:圖像(像素)反轉1

上一篇是用cvNot()函數寫得,而這片是通過一個一個像素進行反轉。(參考了網上大牛們的代碼)

一開始時,出現了一些小錯誤,不小心在for循環後多加了一個分號“;”,可悲的VS2008編譯器竟然不報錯發火,程序可以通過,得出的圖片這樣,

錯誤結果圖:


害得我調試好長時間才搞定。

當然還這樣的錯,主要還是我自己敲代碼不夠仔細。

好了,原歸正傳,正確代碼如下:

  1. // 圖像的反轉2.cpp : 定義控制檯應用程序的入口點。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include "opencv2/opencv.hpp"  
  6.   
  7. int _tmain(int argc, _TCHAR* argv[])  
  8. {  
  9.     //窗口的命名  
  10.     cvNamedWindow("Src", 0);  
  11.     cvNamedWindow("Dst", 0);  
  12.     //改變窗口的大小  
  13.     //cvResizeWindow("Src", 200, 250);  
  14.     //cvResizeWindow("Dst", 200, 250);  
  15.   
  16.     IplImage* src= 0;  
  17.     uchar* data;  
  18.     int height;  
  19.     int width;  
  20.     int step;  
  21.     int channels;  
  22.     int i;  
  23.     int j;  
  24.     int k;  
  25.       
  26.     //加載圖像  
  27.     src= cvLoadImage("F:\\Opencv_picture\\1212.jpg");  
  28.     if(!src)    //判斷圖像時候加載成功  
  29.     {  
  30.         printf("Could not find this image\n");  
  31.     }  
  32.       
  33.     //顯示原圖像  
  34.     cvShowImage("Src", src);  
  35.   
  36.     height= src->height;  
  37.     width= src->width;  
  38.     step= src->widthStep;  
  39.     channels= src->nChannels;  
  40.     data= (uchar* )src->imageData;  
  41.   
  42.     //像素反轉  
  43.     for(i=0; i< height; i++)  
  44.     {  
  45.         for(j=0; j< width; j++)  
  46.         {  
  47.             for(k=0; k< channels; k++)  
  48.             {  
  49.                  data[i* step+ j* channels+ k]= 255- data[i* step+ j* channels + k];  
  50.             }  
  51.         }  
  52.     }  
  53.       
  54.    
  55.     //顯示反轉後的圖像  
  56.     cvShowImage("Dst", src);  
  57.   
  58.     cvWaitKey(0 );  
  59.   
  60.     cvReleaseImage(&src);  
  61.     cvDestroyWindow("Src");  
  62.     cvDestroyWindow("Dst");  
  63.        
  64.     return 0;  
  65. }  

結果圖請看:使勁的戳我^_^
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章