Turbo C位图和BMP位图格式分极及应用论文.docVIP

Turbo C位图和BMP位图格式分极及应用论文.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Turbo C位图和BMP位图格式分极及应用论文.doc

  Turbo C位图和BMP位图格式分极及应用论文 .freelage()函数用于将屏幕内的某矩形区域复制到内存缓冲区,putimage()函数将内存缓冲区中的内容再复制到屏幕上。但由于图像事先还没有出现在屏幕上,所以,.freelage()函数填写供putimage()函数显示的内存图像数据。不过可以把图像数据按getimage()函数产生的格式填于内存缓冲区中,然后调用putimage()函数,显示内存缓冲区图像,下面分析getimage()函数产生的格式: getimage(intletf,inttop,intnight,intbottm,*buf) 其中,left,top——矩形区域左上角坐标(x,y)。 right,bottom——矩形区域右上角坐标(x,y)。 *buf——指向存储屏幕数据的内存指针。 在内存中,图像数据是按行存放的。头两个字节为图像的宽度,接下去两个字节为图像的高度(均为低字节在前,高字节在后)。后面是真正的图像数据,它以图像的宽度为单位,先是图像的第一行第三位面的内容,然后是第一行第二位面的内容;第一行第一位面的内容;第一行第零位面的内容。第一行完后,接第二行的四个位面,第三行的四个位面等等。当屏幕状态为16色时,则需4个彩色页面。这时,如果图像的宽度为8的整数倍时,则每 行所需的字节数为: number=(right-left+8)18*4 如果图像的宽度不为8的倍数据时,则 number=(ceil((right-left)/8)*4) 其中,ceil(righ-left)8为取大于(right-left)/8的最小整数 则图像数据所需字节总数为: number*(bottom-top+1) 则所需内存缓冲区字节总数为: 6+number*(bottom-top+1) 这是因为头四个字节存放图像的宽和高,而缓冲区最后2个字节无意义,可以填零。 T5S04700.GIF;图1 这样,每行每页面的字节数为: p=number/4 如图1所示(设宽、高为16×16) 其中,图像的真正数据在每个页面的前m列,即: 当宽度为8的倍数据时,m=P-1,此时每页面的最后一列可为零。而当宽度不为8的倍 数时,m=P。 结合图1m=2,即数据在每页面的前2列。 二、BMP位图格式 MSain() { int1,i,j,k,q,h; intdriver=VGA,mode=VGAHI; intlenth,high,number,p,m; unsignedsize; unsignedcharch,a8,b4,e48; FILE*fp;char*s; fp=fopen(“party.bmp”,“rb”); fseek(fp,18,0);lenth=getber=(lenth+8)/8*4 #/*bytesofeachline*/ #elsenumber=4*(ceil((double)1enth/8)); up=number/4; mif((lenth%8)!=0)m=p; {/*bytesofeachline/4*/ elsem=p-1; size=6+number*(high+1) /*needmemorybytesofgraphics*/ if((s=char*)malloc(size))==NULL) {printf(“mallocerror!\n”);exit(0);} s0=lenth 0x00ff;s1=(lenth 0xff00) 8; s2=high 0x00ff;s3=(high 0xff00) 8; for(i=4;i size;i++)si=0; fseek(fp,118,0); #for(l=high-1;1 1--) #for(q=0;q q++){ #for(k=0;k k++){ #ch=getc(fp); uch=convert(ch); ma0=ch 0x1;a1=(ch 0x2) 1; {a2=(ch 0x4) 2;a3=(ch 0x8) 3; a4=(ch 0x10) 4;a5=(ch x20) 5; a6=(ch 0x40) 6;a7=(ch 0x80) 7; h=7; for(j=0;j i++) for(j=0;j i++){ eji+2*k=ah; h--; } } #for(i=0;i i++){ #bi=(ei0 7)+(ei1 6)+(ei2 5)+ #(ei3 4)+(ei4 3)+(ei5 2)+ #(ei6 1)+(ei7); us4+number*1+q=b0;s4+number*1+q+p=b1; ms4+number*1+q+2*p=b2;s4+number*1+q+3*p=b3; {} fclose(fp);initgraph( driver,

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档