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,如需转载请自行联系原作者

相关文章
|
机器学习/深度学习 传感器 算法
【交互式阈值二进制图像】采用彩色或单色图像通过交互/手动方式阈值单色图像或彩色图像的单个色带研究(Matlab代码实现)
【交互式阈值二进制图像】采用彩色或单色图像通过交互/手动方式阈值单色图像或彩色图像的单个色带研究(Matlab代码实现)
|
算法 数据可视化
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
2010 0
Halcon边缘检测和线条检测(3),文章含BLOB检测常用方法和shape_trans内接和外接算子的说明
|
4月前
|
编解码 并行计算 算法
MPI分形图像高精度绘制程序和PC端Mandelbrot-Julia分形集预览程序
这篇文章描述了一个使用2010年技术的集群程序,该程序基于Linux + MPI + C++或Windows + .NET + C#,用于并行计算生成高分辨率BMP图像,特别是Mandelbrot和Julia集。在8台节点上,程序实现了7.31的稳定加速比,并在更大规模任务中有望提升。它支持MPI并行计算、任务日志、不同阶数的分形集生成、批处理、多线程以及优化的颜色处理等功能。创新点包括颜色表的正弦控制、动态调整运算精度、复杂颜色生成、优化的颜色更新和并发机制等。程序产生的图像样本显示了其多样性和质量。作者提供源代码,并提到设计思路可应用于类似图像生成任务。
|
4月前
|
计算机视觉
OpenCV图像像素逻辑操作
OpenCV图像像素逻辑操作
|
5月前
|
计算机视觉
OpenCV(二十七):图像距离变换
OpenCV(二十七):图像距离变换
52 0
|
5月前
|
算法 计算机视觉
OpenCV(四十四):亚像素级别角点位置优化
OpenCV(四十四):亚像素级别角点位置优化
145 0
|
5月前
[Halcon&图像] 图像、区域和轮廓相互转化
[Halcon&图像] 图像、区域和轮廓相互转化
252 1
|
5月前
|
文字识别 Python
Halcon 学习笔记五:几何定位+仿射变换+测量
Halcon 学习笔记五:几何定位+仿射变换+测量
448 0
|
5月前
|
算法 计算机视觉 芯片
[Halcon&定位] 二维仿射变换原理与算子解析
[Halcon&定位] 二维仿射变换原理与算子解析
272 0
|
C++ Python
C++ VS Open3D点云显示颜色渲染滤波
C++ VS Open3D点云显示颜色渲染滤波
140 0