星星电脑技术论坛's Archiver

PS动漫设计产业 发表于 2007-5-6 01:17

利用C语言实现计算机图像处理的方法

[table=98%][tr][td=2,1] [/td][/tr][tr][td=2,1][/td][/tr][tr][td=2,1][/td][/tr][tr][td=2,1][table][tr][td][/td][/tr][/table]1.图像平移
!s-z*Ng)\})~1~(C1j {
5nQ'kfIu    图像平移只是改变图像在屏幕上的位置,图像本身并不发生变化。%r7s*bs \ ms/ER@6z
8ilD:VP8kQ(F
   假设原图像区域左上角坐标为(x0, y0),右下角坐标为(x1, y1),将图像分别沿x和y轴平移dx和dy,则新图像的左上角坐标为(x0 + dx, y0 + dy),右下角坐标为(x1 + dx, y1 + dy)。坐标平移变换公式为:
8_7@e]tP c
8I|%S6mH/n6X3w.\ [font=新宋体]  x′ = x + dx
*X+j'}&k0[ F    y′ = y + dy H:n gA$N"I,a![d7O
[/font]   在屏幕上实现图像的移动分为四个步骤:
4y-mu#IIt $K;K6?*aHg!T+{
   ⑴ 保存原图像到缓冲区。
%Y6w#Mz~2gffX
H$U _ ]E    ⑵ 擦除原图像。y%H7RS5dVpU
5~"XT+|V
   ⑶ 计算平移后的新坐标。Y0b@{X'or

XD#L8~"P$VI-J    ⑷ 在新的坐标位置重新显示原图像。
3o)l4O!~F*P:F${ JIl&} vPVi
   其中,擦除原图像的方法与图形变换中擦除原图形的方法一致,在实现中仍采用XOR异或方式画图擦除原图像。对于新坐标值的计算还需要考虑边界情况,不要在图像平移后超出允许的屏幕范围。此外,如果采用C函数getimage()和putimage()来保存和恢复图像,则图像的大小不能超过64K。:w&b(oaC-i
"Qw$E&f!Jx4G/u
   2.图像颠倒
&m?5N%B/f X3N
H+DfM d){.EB C    图像颠倒是指把定义好的图像区域上下翻转地显示在屏幕上。分析图像颠倒的过程,可发现每行的图像信息都保持不变,而只是改变了行的顺序,将第一行与最后的第n行相互交换,第二行与第n - 1行交换……,依此类推,从而实现了图像的颠倒。只需采用按行交换的方式,即可方便地修改缓冲区内容,实现图像的颠倒。基本步骤如下:"Lp2` A ry)`8h7mZ

^iZXPE#X8[    (1) 用getimage()保存原图像,并擦除原图像。I lsVUY(ojfr7r

cM6vd;ar^2?3J Rc*T    (2) 计算图像的高度,即行数height;计算图像宽度width;计算保存一行图像信息
H4WRq I| VP
p[c;Tt Z6}&Od [font=新宋体]   height = bottom - top + 1;1t7A9UA#W{2L2N8N([Y-o
   width = right - left + 1;
&mr2y r#Z    linebytes = (width + 7) / 8 * 4; 4B Qj G'_JD(G:V f
[/font]   (3)利用行交换缓冲区linebuf在图像内存缓冲区中进行信息交换,即把第一行与最末行交换,第2行与第n-1行交换……,依此类推,直至 全部交换完毕。 s$vMk@7B!B

d}$z'a:R0f V   (4)把交换后的图像缓冲区内容重新显示在屏幕上。
%bsEGv
,a4@0g2A+M8x0l8GT    3.图像镜像变换
n\+q H%z'T1v $\2WU }){Y
   镜像变换是指将指定区域的图像左右翻转地显示在屏幕。分析镜像变换过程可以发现:每行图像信息的处理方式是相同的,而且行顺序不发生变化,只是每一行的像素信息按从左到右的顺序进行了左右颠倒,从而实现了镜像变换。因此,采用按行逐点变换的方式实现图像的镜像。 F,I q3OI5v7] N&E1P
(I9NgKo&O1k [6[){`
   首先,对于左上角为(left, top),右下角为(right, bottom)矩形区域图像,给出其中任意点(x0, y0)镜像变换后的新坐标(x′, y′)的坐标变换公式:1_Uj u}G/xU

Y d:Lz2Tn%|uD;M @ [font=新宋体]  x′ = right - x0 + left
`:z!YjW E    y′ = y0
0v,]c [!p-D A%Ks [/font]   根据以上公式,对各个像素点计算新坐标后,直接把它显示在屏幕的相应位置上。
e+e&[E#JL
?}kP(_K    如果完全逐点地进行交换,处理一个像素点就要读取一次像素值,从而降低了变换速度。由于像素点是顺序存放在各个bit位上,每读取一个字节就包含了8个像素点的信息,只需设置不同的位屏值bitmask,就可以获得不同像素点的信息。因此采用按行逐字节变换的方式,每读一次就进行8个像素点的变换,以提高变换速度。t!V2VK0w!g `

i!R0^ny?%]    将一矩形区域的图像进行镜像变换的基本步骤如下:3{I$O"B{1Tx9QQW
7eAwY |M
   (1) 用getimage()把图像保存到内存缓冲区,并擦除原图像。P3_W YhhF`

(|gG x$`'N    (2) 计算图像高度,即行数高度height和宽度width;计算保存一行图像信息占用的字节数linebytes。计算公式如下:
C&E-|U5E7v^M7Z Rm)UO6X/L,cq
[font=新宋体]  height = bottom - top + 1;.H,W)ox`4v o
   width = right - left + 1;
C Da L'A!fM%a)r7a    linebyte = (width + 7) / 8 *4; b#_.o;P+_y0lY2{
[/font]   (3) 对图像进行镜像。I`1d1~/u;}F
V/\Yoh8KXX
   (4)释放内存图像缓冲区。
%\6y@:Tk:T)m{ J+?G4LLLy
   4.图像旋转"c!dWH%t@
Mzp"T e-c
   图像旋转是指把定义的图像绕某一点以逆时针或顺时针方向旋转一定的角度,通常是指绕图像的中心以逆时针方向旋转。
*w;c|JKq5S q y 4mS6Q}%zHI$M*\
   假设图像的左上角为(left, top),右下角为(right, bottom),则图像上任意点(x0, y0)绕其中心(xcenter, ycenter)逆时针旋转angle角度后,新的坐标位置(x′, y′)的计算公式为:n%Hj6]$I k
k:G3MeeC%V
[font=新宋体]xcenter = (right - left + 1) / 2 + left;
g]"Q.^0{3@T5]:t ycenter = (bottom - top + 1) / 2 + top;
QPkrY!B x′ = (x0 - xcenter) cosθ - (y0 - ycenter) sinθ + xcenter;
&]Jo{ v y′ = (x0 - xcenter) sinθ + (y0 - ycenter) cosθ + ycenter;
N:R ~R y R x*b [/font]   与图像的镜像变换相类似,也采用按行逐点变换的方式实现图像的旋转,其步骤如下:L4xv#hn1|2?U
M8}hq b(s
   (1) 用getimage()把图像保存到内存缓冲区,并擦除原图像。+f\6e.AxZm

g4xo8hS6g+k    (2) 计算图像高度height,宽度width,及保存一行图像信息占用的字节数linebytes,计算公式与镜像变换的计算公式相同。^#D$O!riQdHO

\[6Y!staO}    (3) 对图像逐行进行旋转变换。B)B.s1irQ{

0~+L#x({|vs(tr    (4) 释放内存图像缓冲区。p:q Q6jP.Rg8c s

&bi.s#tn    值得指出的是,这种处理方法不够。为此可以采用另一种方法:先在图像变换缓冲区中处理完毕后,再将变换后的图像一次显示在屏幕上。这样可以取得较好的显示效果。k x t0t,HtK8O
[/td][/tr][/table]

janice 发表于 2007-7-8 18:00

謝謝分享, ding !

页: [1]
手机号码所在地查询:
Google
IP地址:

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.