圖像編程學習筆記7――圖像縮放
睿豐德科技 專注RFID識別技術和條碼識別技術與管理軟件的集成項目。質量追溯系統、MES系統、金蝶與條碼系統對接、用友與條碼系統對接
假設放大因子為ratio,(為了避免新圖過大或過小,我們在程序中限制0.25≤ratio≤4),縮放(zoom)的變換矩陣很簡單:
(2.13)
縮放變換的源代碼如下,因為和轉置的那段程序很類似,程序中的注釋就簡單一些。
[cpp] view plaincopy
- /**
- * 函數名: zoom
- * 參 數: ratio -- 縮放率
- * 功 能: 對圖片進行水平和垂直鏡像操作
- * 只保存原圖大小的圖像數據,如果沒有就用白色填充
- */
- void zoom(double ratio)
- {
- int height = bmpInfoHeader.biHeight;
- int width = bmpInfoHeader.biWidth;
- int imgSize = bmpInfoHeader.biSizeImage;
- int lineByte = (width * 8 +31) / 32 * 4; //每行像素所占字節數
- pNewBmpData = new unsigned char[imgSize];
- memset(pNewBmpData,(BYTE)255,sizeof(unsigned char )*imgSize); //先全部用白色填充,處理的時候沒有數據的自然就是白色了
- int x0,y0;
- for(int i = 0; i < height; i++ )
- {
- for(int j = 0; j < width; j++ )
- {
- x0 = j / ratio;
- y0 = i / ratio;
- if( (x0>=0) && (x0<width) && (y0>=0) && (y0<height))
- {
- *(pNewBmpData + (height - 1 - i)*lineByte + j) = *(pBmpData + (height - 1 - y0)*lineByte + x0);
- }
- }
- }
- }