DM642图像平移程序学习

简介:

DM642的图像平移程序,刚开始没明白为什么平移要分为两个半屏来平移,后来琢磨了一下不知道理解对不对,先上程序:

 

  1. /*确定图像的参数*/  
  2. int numPixels = 720;//每行720个像素  
  3. int numLines  = 576;//每帧576行(PAL)  
  4.   
  5. /*图像偏移量初始化*/  
  6. int intXOffset = -200;    //水平偏移量  
  7. int intYOffset = -200;    //垂直偏移量,必须是2的整数  
  8.   
  9. void geometryTrans()  
  10. {  
  11.     int i,j;  
  12.     int intCapX,intCapY;  
  13.     for(i=0;i<numLines;i++)  
  14.     {  
  15.         for(j=0;j<numPixels;j++)  
  16.         {                  
  17.             intCapX = j-intXOffset;  
  18.             intCapY = i-intYOffset/2;             
  19.               
  20.             //判断是否在原图范围内  
  21.             if((intCapX>=0) && (intCapX<numPixels))    
  22.             {    
  23.                 if((i<numLines/2) && (intCapY>=0) && (intCapY<numLines/2))  
  24.                 {  
  25.                     //传送亮度信号  
  26.                     *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + (i-intYOffset/2)*numPixels + intCapX);   
  27.                 }  
  28.                 else if((i>=numLines/2) && (i<numLines) && (intCapY>=numLines/2) && (intCapY<numLines))  
  29.                 {  
  30.                      //传送亮度信号  
  31.                     *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + (i-intYOffset/2)*numPixels + intCapX);                  
  32.                 }  
  33.                 else  
  34.                 {  
  35.                     *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;  
  36.                 }                                                                             
  37.             }  
  38.             else  
  39.             {  
  40.                  *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;  
  41.             }                                    
  42.         }       
  43.     }  
  44. }    

程序的功能是将采集到的图像偏移一定的偏移量之后再显示,既然是偏移就肯定要根据偏移量算出新的坐标,然后对应到新的坐标去显示。图像偏移之后只有还在源图像坐标范围内的像素才能够显示出来,因此需要判断偏移后各像素点的坐标在不在可显示的范围内。但是程序将判断分为了两部分,上半屏和下半屏分别判断传送。


本文转自emouse博客园博客,原文链接:http://www.cnblogs.com/emouse/archive/2010/03/20/2198237.html,如需转载请自行联系原作者

相关文章
|
算法 数据可视化
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
1523 0
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
|
1月前
|
算法 计算机视觉
OpenCV(四十四):亚像素级别角点位置优化
OpenCV(四十四):亚像素级别角点位置优化
41 0
|
1月前
|
计算机视觉
OpenCV(二十七):图像距离变换
OpenCV(二十七):图像距离变换
20 0
|
3月前
|
文字识别 Python
Halcon 学习笔记五:几何定位+仿射变换+测量
Halcon 学习笔记五:几何定位+仿射变换+测量
101 0
|
4月前
|
计算机视觉
OpenCV(十一):图像仿射变换
OpenCV(十一):图像仿射变换
59 0
|
9月前
ENVI Classic:如何进行图像融合(HSV变换/Brovey变换/PC变换)?
ENVI Classic:如何进行图像融合(HSV变换/Brovey变换/PC变换)?
555 0
|
4月前
|
算法 异构计算
基于FPGA的图像sobel锐化实现,包括tb测试文件和MATLAB辅助验证
基于FPGA的图像sobel锐化实现,包括tb测试文件和MATLAB辅助验证
|
7月前
|
C++ Python
C++ VS Open3D点云显示颜色渲染滤波
C++ VS Open3D点云显示颜色渲染滤波
95 0
|
编解码 计算机视觉
CV13 图像分辨率操作(图像金字塔与resize()函数)
其中,高斯核卷积运算就是对整幅图像进行加权平均的过程,每一个像素点的值,都由其本身和邻域内的其他像素值(券种不同)经过加权平均后得到。常见的 33与 55 高斯核(CV9 2D卷积与图像滤波)
133 0
利用矩阵进行平移,旋转,缩放等图像变换、创建第二个一模一样的图像并使之进行缩放等操作
利用矩阵进行平移,旋转,缩放等图像变换、创建第二个一模一样的图像并使之进行缩放等操作