翻新时间: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)上的应用
- 子网掩码与子网划分
- 《将相和》重难点分析
- 《将相和》整体阅读感知
- 《将相和》作家作品和写作背景
- 《梦想的力量》趣闻故事
- 《梦想的力量》美文欣赏一
- 《将相和》重点问题探究
- 《将相和》教学设计二
- 《将相和》趣闻故事
- 《梦想的力量》美文欣赏二
- 《将相和》重点字词意思
- 《将相和》同步作文写作指导
- 《将相和》随堂练习 巩固篇
- 《将相和》美文欣赏一
- 《梦想的力量》考点练兵 阅读篇
- 《将相和》同步作文范文欣赏