


下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 在TVGA上实现全屏幕动画 在图像处理领域,当处理或分析序列运动图像时,需要在屏幕上连续显示这一序列图像(即动画播放),以便观察处理效果或分析动态信息。一般游戏动画的设计方法是慢速移动背景和快速刷新运动目标(小画面),难以实现全屏动画效果。为此笔者采用了汇编语言编程和快速写屏的方法,在普通的486微机(主频66M,配TVGA9000卡)上达到了每秒显示10幅640×480×256灰阶图像的速度,效果令人满意。 首先设置TVGA卡使其工作在0X5d方式下,屏幕分辨率是64
2、0×480×256色。然后重新构造调色板(RemapPalette(),使其适于显示256灰阶的图像。由于TVGA卡的颜色寄存器使用18位存储模式,即R、G、B分量各占6位,而要显示灰度图像R、G、B分量必须赋予相同的值,所以就只能显示区分26=64灰阶的图像。不过,实验表明人眼已无法区分64灰阶与256灰阶图像的差别。因此,在构造调色板时,03索引值对应的R、G、B分量值都为0,47索引值对应的R、G、B分量值都为1,依次类推,这样就可以正确显示一幅256灰阶的图像。 以下是动画播放序列运动图像完整的源代码(AVD.C)。为连续显示一序列图像,先将序列图像的数目(如20)
3、、存放图像数据文件的路径(f:zyf)、图像文件的名称(如z1.img,z2.img,)录入一文本文件(如imggroup.lst),运行程序时只需键入AVD imggroup.lst即可。源程序中显示每幅图像的代码部分采用嵌入汇编语言编写,以得到较高的显示速度。在程序运行过程中,按下空格键暂停;连击空格键实现单帧播放;按下任意其它键恢复连续播放;按下退出键(Escape)退回DOS。在程序设计时,为避免在一个循环结束过渡到下一个循环开始时将要从序列的最后一幅图像切换到第一幅图像,因为这时由于图像运动的不连续性将产生突变,以至屏幕显示有抖动感或闪烁感,所以笔者采用了第一个循环正向播放
4、,第二个循环反向播放(即正反相间)的方案。如果读者只希望正向播放,只须删除源程序中标有“/$”的四条语句行即可。 编译运行环境:本程序用MS C6.0编译通过,编译时请使用命令行参数/STACK:20480;图像数据文件来自大恒公司的VP32图像采集板(512×512×256灰阶)。 #include <graph.h> #include <stdio.h> #include <dos.h> #include <stdlib.h> #include <strin
5、g.h> #include <conio.h> #include <time.h> #define IMGGRP 30 /Image Number in a Cycle Showing #define ESCAPE 27 /Stop Showing and Exit #define SPACE 32 /Step Show-Hit Space Bar
6、 & One by One Showing void RemapPalette(void); void main (int argc,char *argv) static char grpflnmIMGGRP80; char path80,flnm80,bindfn80,arg5; char fnch2="0" char ch-imgnum5; int i,i1,i2,i12,ii,imgnum=IMGGRP
7、; int dispimgs,keyin,StepShow=0; unsigned short int VSEG; union REGS inregs,outregs; FILE *fp; unsigned short int row=480,col=512; unsigned char fb512; int m-b=0; clock-t cstart,cend; /* For clock */ unsigned
8、160;short int FH; / File Handle printf("n * GROUP IMAGES ANIMATEDLY SHOWING * n"); if(argc>1) strcpy(flnm,argv1); else printf("n Input the Image Group file name .lst:"); gets(flnm);
9、REDISP: if(!strchr(flnm,'.') strcat(flnm,".lst"); if(fp=fopen(flnm,"rt")=NULL) printf("n Open file failure! aan"); printf("n Please Check following files whether exist:"); printf("n%s",flnm);
10、printf("nn Note:The file extension name is appended automatically,"); printf("n such as .lst!"); exit(1); inregs.x.ax=0x005d; / Set TVGA Mode:640x480x256 levels int86(0x10,&inregs,&outregs); RemapP
11、alette(); / Remap all Palette cstart= clock(); /* Use clock for timing to hundredths of seconds */ strcpy(ch-imgnum,"0"); for(;) / Read image number in group fread(fnch,sizeof(char),1,f
12、p); if(int)fnch0=10) break; strcat(ch-imgnum,fnch); imgnum=atoi(ch-imgnum); strcpy(path,"0"); for(;) / Read image path in group fread(fnch,sizeof(char),1,fp); if(int)fnch0=10) break; strcat(path,fnch); for(i=0;i<imgnum;i+) / Read im
13、age name in group strcpy(grpflnmi,"0"); for(;) fread(fnch,sizeof(char),1,fp); if(int)fnch0=10) break; strcat (grpflnmi,fnch); keyin=0; StepShow=0; / Continuous Showing defaultly dispimgs=0; i1=0; i2=imgnum-1; i12=1; for(;) /
14、SHOW IMAGES-ANTMATE PICTURE STUDIO / REPEAT CYCLE FOREVER for(i=i1;i<=i2;i+=i12) if(kbhit() keyin=getch(); if(keyin=ESCAPE) goto CONTINUE; /Stop Showing and Exit if(keyin=SPACE) StepShow=1; / Step Show-Hit Sapce&
15、#160;Bar else StepShow=0; / Continuous Showing-Hit Any Other Key if(StepShow=1) keyin=getch(); /Standy by if(keyin=ESCAPE) goto CONTINUE; if(keyin!=SPACE) StepShow=0; strcpy(bindfn,path); strcat(bindfn,grpflnmi); strcpy(flnm,bindfn); VSEG=0
16、; -asm MOV AH,3dh Open File MOV AL,0c0h LEA DX,WORD PTR flnm INT 21h MOV FH, AX MOV AX,0a000h MOV ES,AX XOR DI,DI MOV AX,0eh MOV DX,3c4h OUT DX,AL XOR AX,AX XOR AX,02h MOV DX,3c5h OUT DX,AL MOV C
17、X,row OUTER-CYCLE: PUSH CX MOV AH,3fh Read File a Line Once MOV BX,FH MOV CX,col col=512 LEA DX,WORD PTR fb INT 21h MOV SI,DX MOV CX,col INTER-CYCLE: MOVSB OR DI,DI JNZ GO-INTER-LOOP MOV AX,0eh MOV DX
18、,3c4h OUT DX,AL MOV AX,VSEG INC AX MOV VSEG,AX XOR AX, 02h MOV DX,3c5h OUT DX,AL GO-INTER-LOOP: LOOP INTER-CYCLE ADD DI,128 128=640-512 JNC GO-OUTER-LOOP MOV AX,0eh MOV DX,3c4h OUT DX,AL MOV AX,VSEG INC AX MOV
19、VSEG,AX XOR AX,02h MOV DX,3c5h OUT DX,AL GO-OUTER-LOOP: POP CX LOOP OUTER-CYCLE MOV AH,3eh Close File MOV BX,FH INT 21h dispimgs+; /* The following line (4 sentences) can be Deleted if wish Up-sh
20、owing On ly */ ii=i1; i1=i2; i2=ii; i12*=(-1); /$ CONTINUE: cend=clock(); printf("a"); getch(); fclose(fp); if(argc>1) goto ENDP; printf("n Display Another Image Group(Y/N)?"); gets(arg); if(!strcmp(arg,"Y")|!str
21、cmp(arg,"y") printf("n Input image file name:"); gets(flnm); goto REDISP; ENDP: -SETVIDEOMODE(-TEXTC80); printf(" Show %5d images;Spend %4.2f seconds.n",dispimgs,(float)cend-cst art) /CLK-TCK); void RemapPalette(void) register int i,j; union REGS inregs,outregs; for(j=0;j<64;i+) /R
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 上海行健职业学院《运动项目理论与训练》2023-2024学年第二学期期末试卷
- 重庆外语外事学院《高层建筑结构课程设计》2023-2024学年第二学期期末试卷
- 2025办公家具采购合同
- 湖南工业大学科技学院《设计构成》2023-2024学年第二学期期末试卷
- 南昌大学共青学院《情绪行为异常儿童教育》2023-2024学年第二学期期末试卷
- 山东女子学院《中国文化概况》2023-2024学年第二学期期末试卷
- 江苏省如东县2025届高三下学期毕业班联考(二)历史试题含解析
- 2024中国能建葛洲坝集团绿色智能建造研究院公开招聘17人笔试参考题库附带答案详解
- 梧州医学高等专科学校《健康教育与管理》2023-2024学年第二学期期末试卷
- 文华学院《食品保藏技术》2023-2024学年第二学期期末试卷
- 急危重症患者抢救制度-杨丞磊、公维彬
- 异想天开的科学游戏
- 线性光耦隔离电路
- 进货单(标准模版)
- 内科学泌尿系统疾病总论课件
- 法律文献检索
- 小学五年级科学实验操作考试试题
- 军队文职人员考试国防和军队知识
- 酒店有限空间作业培训
- 《思想道德与法治》课件第四章明确价值要求践行价值准则第三节积极践行社会主义核心价值观
- 工业过程控制知到章节答案智慧树2023年哈尔滨工程大学
评论
0/150
提交评论