利用C语言实现电脑图像处理的方法

2008-02-23 05:26:30来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

 1.图像平移

  图像平移只是改变图像在屏幕上的位置,图像本身并不发生变化。

  假设原图像区域左上角坐标为(x0, y0),右下角坐标为(x1, y1),将图像分别沿x和y轴平移dx和dy,则新图像的左上角坐标为(x0 + dx, y0 + dy),右下角坐标为(x1 + dx, y1 + dy)。坐标平移变换公式为:

  x′ = x + dx
  y′ = y + dy

  在屏幕上实现图像的移动分为四个步骤:

  ⑴ 保存原图像到缓冲区。

  ⑵ 擦除原图像。

  ⑶ 计算平移后的新坐标。

  ⑷ 在新的坐标位置重新显示原图像。

  其中,擦除原图像的方法和图像变换中擦除原图像的方法一致,在实现中仍采用XOR异或方式画图擦除原图像。对于新坐标值的计算还需要考虑边界情况,不要在图像平移后超出允许的屏幕范围。此外,假如采用C函数getimage()和putimage()来保存和恢复图像,则图像的大小不能超过64K。

  2.图像颠倒

  图像颠倒是指把定义好的图像区域上下翻转地显示在屏幕上。分析图像颠倒的过程,可发现每行的图像信息都保持不变,而只是改变了行的顺序,将第一行和最后的第n行相互交换,第二行和第n - 1行交换……,依此类推,从而实现了图像的颠倒。只需采用按行交换的方式,即可方便地修改缓冲区内容,实现图像的颠倒。基本步骤如下:

  (1) 用getimage()保存原图像,并擦除原图像。

  (2) 计算图像的高度,即行数height;计算图像宽度width;计算保存一行图像信息

   height = bottom - top + 1;
  width = right - left + 1;
  linebytes = (width + 7) / 8 * 4;

  (3)利用行交换缓冲区linebuf在图像内存缓冲区中进行信息交换,即把第一行和最末行交换,第2行和第n-1行交换……,依此类推,直至 全部交换完毕。

  (4)把交换后的图像缓冲区内容重新显示在屏幕上。

  3.图像映像变换

  映像变换是指将指定区域的图像左右翻转地显示在屏幕。分析映像变换过程能够发现:每行图像信息的处理方式是相同的,而且行顺序不发生变化,只是每一行的像素信息按从左到右的顺序进行了左右颠倒,从而实现了映像变换。因此,采用按行逐点变换的方式实现图像的映像。

  首先,对于左上角为(left, top),右下角为(right, bottom)矩形区域图像,给出其中任意点(x0, y0)映像变换后的新坐标(x′, y′)的坐标变换公式:

  x′ = right - x0 + left
  y′ = y0

  根据以上公式,对各个像素点计算新坐标后,直接把他显示在屏幕的相应位置上。

  假如完全逐点地进行交换,处理一个像素点就要读取一次像素值,从而降低了变换速度。由于像素点是顺序存放在各个bit位上,每读取一个字节就包含了8个像素点的信息,只需配置不同的位屏值bitmask,就能够获得不同像素点的信息。因此采用按行逐字节变换的方式,每读一次就进行8个像素点的变换,以提高变换速度。

  将一矩形区域的图像进行映像变换的基本步骤如下:

  (1) 用getimage()把图像保存到内存缓冲区,并擦除原图像。

  (2) 计算图像高度,即行数高度height和宽度width;计算保存一行图像信息占用的字节数linebytes。计算公式如下:

  height = bottom - top + 1;
  width = right - left + 1;
  linebyte = (width + 7) / 8 *4;

  (3) 对图像进行映像。

  (4)释放内存图像缓冲区。

  4.图像旋转

  图像旋转是指把定义的图像绕某一点以逆时针或顺时针方向旋转一定的角度,通常是指绕图像的中央以逆时针方向旋转。

  假设图像的左上角为(left, top),右下角为(right, bottom),则图像上任意点(x0, y0)绕其中央(xcenter, ycenter)逆时针旋转angle角度后,新的坐标位置(x′, y′)的计算公式为:

xcenter = (right - left + 1) / 2 + left;
ycenter = (bottom - top + 1) / 2 + top;
x′ = (x0 - xcenter) cosθ - (y0 - ycenter) sinθ + xcenter;
y′ = (x0 - xcenter) sinθ + (y0 - ycenter) cosθ + ycenter;

  和图像的映像变换相类似,也采用按行逐点变换的方式实现图像的旋转,其步骤如下:

  (1) 用getimage()把图像保存到内存缓冲区,并擦除原图像。

  (2) 计算图像高度height,宽度width,及保存一行图像信息占用的字节数linebytes,计算公式和映像变换的计算公式相同。

  (3) 对图像逐行进行旋转变换。

  (4) 释放内存图像缓冲区。

  值得指出的是,这种处理方法不够。为此能够采用另一种方法:先在图像变换缓冲区中处理完毕后,再将变换后的图像一次显示在屏幕上。这样能够取得较好的显示效果。




标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: C语言实现MATLAB 6.5中M文档的方法

下一篇: C宏——智者的利刃,愚者的恶梦

热门词条
热门标签