图像编程学习笔记7——图像缩放

简介: 假设放大因子为ratio,(为了避免新图过大或过小,我们在程序中限制0.25≤ratio≤4),缩放(zoom)的变换矩阵很简单: (2.13) 缩放变换的源代码如下,因为和转置的那段程序很类似,程序中的注释就简单一些。

假设放大因子为ratio,(为了避免新图过大或过小,我们在程序中限制0.25≤ratio≤4),缩放(zoom)的变换矩阵很简单:

(2.13)

缩放变换的源代码如下,因为和转置的那段程序很类似,程序中的注释就简单一些。

 

[cpp]  view plain copy
 
  1. /** 
  2. * 函数名: zoom 
  3. * 参  数: ratio -- 缩放率 
  4. * 功  能: 对图片进行水平和垂直镜像操作 
  5. *         只保存原图大小的图像数据,如果没有就用白色填充 
  6. */  
  7. void zoom(double ratio)  
  8. {  
  9.     int height = bmpInfoHeader.biHeight;     
  10.     int width = bmpInfoHeader.biWidth;    
  11.     int imgSize = bmpInfoHeader.biSizeImage;  
  12.     int lineByte = (width * 8 +31) / 32 * 4;  //每行像素所占字节数  
  13.     pNewBmpData = new unsigned char[imgSize];   
  14.     memset(pNewBmpData,(BYTE)255,sizeof(unsigned char )*imgSize);   //先全部用白色填充,处理的时候没有数据的自然就是白色了  
  15.     int x0,y0;  
  16.     for(int i = 0; i < height; i++ )  
  17.     {  
  18.         for(int j = 0; j < width; j++ )  
  19.         {  
  20.             x0 = j / ratio;  
  21.             y0 = i / ratio;  
  22.             if( (x0>=0) && (x0<width) && (y0>=0) && (y0<height))  
  23.             {  
  24.                 *(pNewBmpData + (height - 1 - i)*lineByte + j) = *(pBmpData + (height - 1 - y0)*lineByte + x0);   
  25.             }  
  26.         }  
  27.     }  
  28. }  
目录
相关文章
|
3月前
|
大数据 计算机视觉
Halcon 学习笔记三:形态学
Halcon 学习笔记三:形态学
58 0
|
3月前
|
计算机视觉
Halcon 学习笔记八:颜色识别
Halcon 学习笔记八:颜色识别
94 0
|
4月前
|
计算机视觉
OpenCV(十二):图像透视变换
OpenCV(十二):图像透视变换
91 0
|
4月前
|
算法 计算机视觉
OpenCV中使用加速鲁棒特征检测SURF与图像降噪讲解与实战(附源码)
OpenCV中使用加速鲁棒特征检测SURF与图像降噪讲解与实战(附源码)
32 0
|
4月前
|
计算机视觉
OpenCV(十一):图像仿射变换
OpenCV(十一):图像仿射变换
61 0
|
4月前
|
算法 计算机视觉
[Halcon&图像] 图像滤波算法原理
[Halcon&图像] 图像滤波算法原理
68 1
|
9月前
|
机器学习/深度学习 存储 编解码
|
9月前
|
机器学习/深度学习 存储 编解码
|
9月前
|
机器学习/深度学习 存储 编解码
底层视觉与黑白图像上色
底层视觉(即视觉增强)是计算机视觉中的一个分支,它专注于提高图像整体的观看体验。如果 “中高层视觉” 关注的是如何让计算机理解图像中的内容,那么底层视觉则致力于解决图像的清晰度、色彩、时序等各类画质问题。这些问题的出现与拍摄环境、设备等因素有关,而视觉增强技术则旨在修复这些问题,提供更好的视觉观看体验。
|
存储 编解码 生物认证
图像方面基础知识
图像方面基础知识
114 0
图像方面基础知识