教育资源为主的文档平台

当前位置: 查字典文档网> 所有文档分类> 论文> 其他论文> 在Windows中显示多幅彩色图像的技术

在Windows中显示多幅彩色图像的技术

上传者:网友
|
翻新时间:2022-07-21

在Windows中显示多幅彩色图像的技术

在Windows中显示多幅彩色图像的技术 在Windows中显示多幅彩色图像的技术 在Windows中显示多幅彩色图像的技术 摘 要 该文论述了在Windows同一窗口中显示多幅彩色图像的技术和实现方法,并提供最优化程序压缩原图像的颜色数量。

关键词 调色板 Windows 图像处理然而,在某些应用中则要求同一窗口中显示两幅甚至更多的彩色图像,如果按照常规设计,窗口中只能正确地显示其中一幅图像,而其它的图像则由于其调色板被更换,颜色就会混乱。在我们开发多媒体查询系统——山东省旅游资源查询子系统时,系统要求以一幅山东省彩色地图为背景,然后在各个旅游景点设置一个触摸按钮,当用户触摸该按钮时,在窗口的右下部分显示该景点的彩色图像。如果图像不经过特殊处理,则在显示该景点的彩色图像的同时也更换了该窗口的调色板,使背景图像的颜色失真。为了解决这个问题,我们对图像做了特殊处理,使背景图像和各个景点图像的调色板不发生冲突。同时还要考虑到Windows占用了前20个调色板,在一般情况下不允许更改。根据系统的实际情况,我们对调色板做了如下布置:第0~19号调色板为Windows系统保留;第20~148号调色板为背景图像使用,一旦背景图像使用后,就不再更改;第149~255号调色板为各景点图像使用,当显示不同的景点图像时,随时更改这些调色板。定义一个PALETTEENTRY类型的数组palette[256]用来保存各颜色分量。该类型是Windows定义的一种结构:

typedef struct {

BYTE peRed;

/*调色板项的红色饱和度*/

BYTE peGreen;/*调色板项的绿色饱和度*/

BYTE peBlue;

/*调色板项的蓝色饱和度*/

BYTE peFlags;/*NULL、PC-EXPLICIT、PC-NOCOLLAPSE一般取PC-EXPLICIT*/

} PALETTEENTRY;ette[20]~palette[255]中,然后按下列步骤实现该调色板。

1.定义HDC hdc; HPALETTE w-hp; LOGPALETTE *pal;

2.给pal赋值

pal=(NPLOGPALETTE)LocalAlloc(LMEM-FIXED,

sizeof(LOGPALETTE)+256*sizeof(PALETTEENTRY));

pal->palVersion=0X300;/*

pal->palNumEntries=256;

memcpy(%pal->palPalEntry[0],&palette[0],

256*sizeof(PALETTEENTRY);

3.实现该调色板

hdc=GetDC(hWnd);

w-hp=CreatePalette((LPLOGPALETTE)pal);

w-hp=SelectPalette(hdc,w-hp,0);

RealizePalette(hdc);

LocalFree(HANDLE)pal);

其中hWnd为要显示图像的窗口句柄。按上述步骤实现该调色板后,读入要显示的图像,然后映射到hdc中即可。cpcolor图像文件名 颜色下限 颜色上限本程序使用最优化方法,使用效果良好。

/* 源程序cpcolor.c */

#include <stdio.h>

#include <math.h>

#include <alloc.h>

unsigned char palette[256][4];

long TAB[256];

unsigned char TT[256],BB[256];

int width,depth,bytes;

/* 该函数打开图像文件并读图像的宽、高和各调色板的颜色分量,并把文件指针指向图像的开始处*/

FILE *get-bitmap-file(char*fname)

{

unsigned char ch;

int i,j,n;

FILE *fp;

fp=fopen(fname,"rb+");

if (fp==NULL) return NULL;

fseek(fp,18L,SEEK-SET);fread(&depth,2,1,fp);fseek(fp,2L,SEEK-CUR);

n=width/4;

if (width%4 !=0) n++;

bytes=n*4;

fseek(fp,54L,SEEK-SET);

fread(&palette[0][0],4,256,fp);

return fp;

}

/*该函数实现颜色的压缩*/{

unsigned char *p,*q,cc,ch;

long len;

int max-no, i,j,m,n,r0,b0,g0,r1,b1,g1;

double dd,dmin;

char s[4];

max-no=color2-color1+1;

for (i=0;i<256;i++) TAB[i]=0;

p=(char *)malloc(bytes+

1);

for (i=0;i<depth;i++) {

fread(p,bytes,1,fp);

q=p;

for (j=0;j<bytes;j++,q++) if(j>=width) break;

else {

ch=(unsigned char)*q;

TAB[ch]++;

}

}

for (i=0;i<256;i++) tt[i]=(unsigned char)i;if (TAB[i]<TAB[j]){

len=TAB[i];TAB[i]=TAB[摘 要 该文论述了在Windows同一窗口中显示多幅彩色图像的技术和实现方法,并提供最优化程序压缩原图像的颜色数量。

关键词 调色板 Windows 图像处理然而,在某些应用中则要求同一窗口中显示两幅甚至更多的彩色图像,如果按照常规设计,窗口中只能正确地显示其中一幅图像,而其它的图像则由于其调色板被更换,颜色就会混乱。在我们开发多媒体查询系统——山东省旅游资源查询子系统时,系统要求以一幅山东省彩色地图为背景,然后在各个旅游景点设置一个触摸按钮,当用户触摸该按钮时,在窗口的右下部分显示该景点的彩色图像。如果图像不经过特殊处理,则在显示该景点的彩色图像的同时也更换了该窗口的调色板,使背景图像的颜色失真。为了解决这个问题,我们对图像做了特殊处理,使背景图像和各个景点图像的调色板不发生冲突。同时还要考虑到Windows占用了前20个调色板,在一般情况下不允许更改。根据系统的实际情况,我们对调色板做了如下布置:第0~19号调色板为Windows系统保留;第20~148号调色板为背景图像使用,一旦背景图像使用后,就不再更改;第149~255号调色板为各景点图像使用,当显示不同的景点图像时,随时更改这些调色板。定义一个PALETTEENTRY类型的数组palette[256]用来保存各颜色分量。该类型是Windows定义的一种结构:

typedef struct {

BYTE peRed;

/*调色板项的红色饱和度*/

BYTE peGreen;/*调色板项的绿色饱和度*/

BYTE peBlue;

/*调色板项的蓝色饱和度*/

BYTE peFlags;/*NULL、PC-EXPLICIT、PC-NOCOLLAPSE一般取PC-EXPLICIT*/

} PALETTEENTRY;ette[20]~palette[255]中,然后按下列步骤实现该调色板。

1.定义HDC hdc; HPALETTE w-hp; LOGPALETTE *pal;

2.给pal赋值

pal=(NPLOGPALETTE)LocalAlloc(LMEM-FIXED,

sizeof(LOGPALETTE)+256*sizeof(PALETTEENTRY));

pal->palVersion=0X300;/*

pal->palNumEntries=256;

memcpy(%pal->palPalEntry[0],&palette[0],

256*sizeof(PALETTEENTRY);

3.实现该调色板

hdc=GetDC(hWnd);

w-hp=CreatePalette((LPLOGPALETTE)pal);

w-hp=SelectPalette(hdc,w-hp,0);

RealizePalette(hdc);

LocalFree(HANDLE)pal);

其中hWnd为要显示图像的窗口句柄。按上述步骤实现该调色板后,读入要显示的图像,然后映射到hdc中即可。cpcolor图像文件名 颜色下限 颜色上限本程序使用最优化方法,使用效果良好。

/* 源程序cpcolor.c */

#include <stdio.h>

#include <math.h>

#include <alloc.h>

unsigned char palette[256][4];

long TAB[256];

unsigned char TT[256],BB[256];

int width,depth,bytes;

/* 该函数打开图像文件并读图像的宽、高和各调色板的颜色分量,并把文件指针指向图像的开始处*/

FILE *get-bitmap-file(char*fname)

{

unsigned char ch;

int i,j,n;

FILE *fp;

fp=fopen(fname,"rb+");

if (fp==NULL) return NULL;

fseek(fp,18L,SEEK-SET);fread(&depth,2,1,fp);fseek(fp,2L,SEEK-CUR);

n=width/4;

if (width%4 !=0) n++;

bytes=n*4;

fseek(fp,54L,SEEK-SET);

fread(&palette[0][0],4,256,fp);

return fp;

}

/*该函数实现颜色的压缩*/{

unsigned char *p,*q,cc,ch;

long len;

int max-no, i,j,m,n,r0,b0,g0,r1,b1,g1;

double dd,dmin;

char s[4];

max-no=color2-color1+1;

for (i=0;i<256;i++) TAB[i]=0;

p=(char *)malloc(bytes+

1);

for (i=0;i<depth;i++) {

fread(p,bytes,1,fp);

q=p;

for (j=0;j<bytes;j++,q++) if(j>=width) break;

else {

ch=(unsigned char)*q;

TAB[ch]++;

}

}

for (i=0;i<256;i++) tt[i]=(unsigned char)i;if (TAB[i]<TAB[j]){

len=TAB[i];TAB[i]=TAB[j];TAB[j]=len;

cc=TT[i];TT[i]=TT[j];TT[j]=cc;

memcpy(s,&palette[i][0],

4);

memcpy(&palette[i][0],&palette[j][0],

4);

memcpy(&palette[j][0],s,

4);

}

for (i=color2;i>=color1;i--)

memcpy(&palette[i][0],&palette[i-color1][0],

4);

for (i=0;i<max-no;i++) BB[TT[i]]=(unsigned char)i;

for (i=max-no;i<256;i++) {

r0=palette[i][2];

g0=palette[i][1];

b0=palette[i][0];

dmin=256.0*256.0*256.0;

m=0;

for (j=0;j<max-no;j++) {g1=palette[j][1];

b1=palette[j][0];

dd=1.0*(r0-r

1)*(r0-r

1)+1.0*(g0-g

1)*(g0-g

1)+1.0*(b0-b

1)*(b0-b

1);

dd=sqrt(dd);

if (dmin>dd) {dmin=dd;m=j;}

}

BB[TT[i]]=(unsigned char)m;

}

for (i=0;i<256;i++) BB[i]+=color1;

}

void w-create-bitmap(FILE *fp)

{

int i,j,n,m,t;

long len;

unsigned char far *p,far *q,cc,ch;

unsigned nn;

fseek(fp,54L,SEEK-SET);

len=ftell(fp);

fwrite(&palette[0][0],4,256,fp);

p=(unsigned char far *)farmalloc(bytes+

1);

len=ftell(fp);

for (i=0;i<depth;i++) {

fseek(fp,len,SEEK-SET);

fread(p,bytes,1,fp);

fseek(fp,len,SEEK-SET);

len+=bytes;

q=p;

for (j=0;j<width;j++,q++) {

cc=(unsigned char)(*q);

ch=BB[cc];

*q=ch;

}

fwrite(p,bytes,1,fp);

}

farfree(p);

}

main(int argc,char *args[])

{

FILE *fp;

if (argc<

4) {

printf("参数:文件名 颜色下限 颜色上限n");

return;

}

fp=get-bitmap-file(args[1]);

if (fp==NULL) return;

zh-fan-tu(fp,atoi(args[2],atoi(args[3]));

w-create-bitmap(fp);

fclose(fp);

}

参考文献

王旭 张军译.Microsoft Windows 3.1程序员参考手册.北京:清华大学出版社,1994.

下载文档

版权声明:此文档由查字典文档网用户提供,如用于商业用途请与作者联系,查字典文档网保持最终解释权!

网友最新关注

My English teacher
我的老师(My Teacher)
A letter to my pen pal
This is my school
我的书包 My Backpack
My Mother
My father(我的爸爸)
My bedroom(我的卧室 )
My favourite person
年级英语作文 旅游 Traveling
A Trip一次旅行
I love Spring Festival(我爱春节)
My hobby我的爱好
summer vacation
春节放鞭炮
微软的考题(数学篇)
苏宁:全面启动3C校园精英培育计划
挑战宝洁:从申请到Offer的艰难求职路
雀巢SMC面试攻略
网易互动2006校园招聘提前敲锣!
“纳才团”11月启程到各地招聘毕业生
应聘诺基亚:一场接一场的考试
上海交大女生:我用执著打动了GE
唐骏招聘大学生背后
应聘麦当劳:麦当劳总经理谈麦当劳招聘
宝洁公司的笔试
西门子北京总部:30秒看一份简历 求职要积极主动
揭开宝洁CMK的面纱-暑期实习经历(4)
Shell company代表性考题
求职经历:展现真实自我终被IBM录用
动态哈夫曼编码的改进
利用EXCEL实现财务预测的回归分析
加密与解密算法的研究
找出计算机上当前登录入网的用户
Project
基于ARM核的AT75C220及其在指纹识别系统中的应用
基于PKI的电子商务安全密钥托管技术
EXCEL在工资管理中的运用
浅谈实现教育信息网络安全的对策
间谍软件之危害及其防范对策
ASP
数字图书馆系统中的IP网络存储技术研究
基于IP网络构建视频会议系统技术浅析
Linux在信息家电(IA)上的应用
子网掩码与子网划分
《将相和》重难点分析
《将相和》整体阅读感知
《将相和》作家作品和写作背景
《梦想的力量》趣闻故事
《梦想的力量》美文欣赏一
《将相和》重点问题探究
《将相和》教学设计二
《将相和》趣闻故事
《梦想的力量》美文欣赏二
《将相和》重点字词意思
《将相和》同步作文写作指导
《将相和》随堂练习 巩固篇
《将相和》美文欣赏一
《梦想的力量》考点练兵 阅读篇
《将相和》同步作文范文欣赏