DM642的图像平移程序,刚开始没明白为什么平移要分为两个半屏来平移,后来琢磨了一下不知道理解对不对,先上程序:
- /*确定图像的参数*/
- int numPixels = 720;//每行720个像素
- int numLines = 576;//每帧576行(PAL)
- /*图像偏移量初始化*/
- int intXOffset = -200; //水平偏移量
- int intYOffset = -200; //垂直偏移量,必须是2的整数
- void geometryTrans()
- {
- int i,j;
- int intCapX,intCapY;
- for(i=0;i<numLines;i++)
- {
- for(j=0;j<numPixels;j++)
- {
- intCapX = j-intXOffset;
- intCapY = i-intYOffset/2;
- //判断是否在原图范围内
- if((intCapX>=0) && (intCapX<numPixels))
- {
- if((i<numLines/2) && (intCapY>=0) && (intCapY<numLines/2))
- {
- //传送亮度信号
- *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + (i-intYOffset/2)*numPixels + intCapX);
- }
- else if((i>=numLines/2) && (i<numLines) && (intCapY>=numLines/2) && (intCapY<numLines))
- {
- //传送亮度信号
- *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + (i-intYOffset/2)*numPixels + intCapX);
- }
- else
- {
- *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;
- }
- }
- else
- {
- *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;
- }
- }
- }
- }
程序的功能是将采集到的图像偏移一定的偏移量之后再显示,既然是偏移就肯定要根据偏移量算出新的坐标,然后对应到新的坐标去显示。图像偏移之后只有还在源图像坐标范围内的像素才能够显示出来,因此需要判断偏移后各像素点的坐标在不在可显示的范围内。但是程序将判断分为了两部分,上半屏和下半屏分别判断传送。
本文转自emouse博客园博客,原文链接:http://www.cnblogs.com/emouse/archive/2010/03/20/2198237.html,如需转载请自行联系原作者