分享
 
 
 

在16色模式下显示256色及全彩色

王朝other·作者佚名  2008-06-01
窄屏简体版  字體: |||超大  

摘 要 该文描述了在VGA16色图形模式下显示256色及全彩色图像的抖动算法,并给出了显示BitMap图像的C语言程序。

要害词 抖动算法 亮度矩阵 显示

在编写有关图像显示的软件时,有时为了软件的兼容性和通用性,不得不采用VGA标准的图形模式,这就涉及到如何在16色图形模式下显示256色及全彩色图像的问题。解决这一问题有两种方法。一种是采用色彩近似的方法,即根据需要显示的全部颜色,经过寻优来选择16种最具代表性的颜色,每一种颜色都用这16种颜色中最接近的一种来代替。《计算机世界月刊》的《用集群方法进行颜色选择》一文具体描述了该方法。但事实上,该方法仅对于某些理想的情况适用,而对于更普遍的情况,该方法无论从运算速度还是从处理效果来讲,都不可能令人感到满足,因而不宜在实际中运用。另一种方法是被众多商品化软件所广泛采用的抖动技术,其原理是利用多种可见颜色的组合来模拟一种不可见的颜色。目前,关于彩色图像抖动算法的资料不多。笔者通过对灰度图像处理算法及Windows环境下一些图像处理软件的剖析,得出了抖动算法的一般原理和实现方法。

一、抖动算法原理

我们知道,在256色及全彩色图像中,每一种颜色均由R、G、B三个颜色分量组成,而每一个分量又一般由一个字节表示。这样,每一个颜色分量可有256级亮度变化。

本算法的要害在于引入亮度矩阵的概念,即采用一个16×16的矩阵来表示每一个颜色分量的亮度值,不同亮度值对应着矩阵的不同排列。矩阵全为0时对应亮度0,全为255时对应亮度255。

当亮度值为L时,亮度矩阵中将有[L255×256]个255及[(1-L255)×256]个0,此时,矩阵的平均亮度值为

L'={[L/255×256]×255+[(1-L/255)×256]×0}/256=L

这就是说,矩阵的平均亮度正好为颜色分量的实际亮度。

假设某一颜色C的R、G、B三个颜色分量的亮度矩阵分别为:

@@01A04600.GIF;公式一@@

其中rmn、gmn、bmn(0≤m, n≤15)取值为0或15。

将上述三个矩阵作叠加运算,得

@@01A04601.GIF;公式二@@

其中的Cmn为表1中由rmn、gmn、bmn所确定的颜色值。表1为VGA16色图形模式下的标准调色板(并非设置模式后的缺省调色板)。显然,Cmn只可能为0及9~15之中的一个。由此方法得到的矩阵Mc即可视为颜色C的模拟矩阵。由于颜色C的R、G、B三个颜色分量与亮度矩阵MR、MG、MB有着相等的亮度值,所以矩阵MC从视觉效果上来讲能很好地模拟颜色C。但在显示时,不可能用整个这样的矩阵来替代一个像素点,那将导致整幅图像长宽均变成原图的16倍。实际的做法是:若该像素点距离图像原点的座标为(X,Y),则令:

m=Y mod 16

n=X mod 16 (1)

此时,可用MC中的颜色Cmn来显示该像素。

@@01A04602.GIF;表1 16色图形模式标准调色板@@

二、算法实现

1.亮度矩阵的表示

算法中要用到257个16×16的亮度矩阵,假如对每一个都分别表示的话,将占用很大的内存空间(大于64K)。由于亮度矩阵的排列及增长均有一定的规律性,我们只需要采用一个16×16的矩阵即可。该矩阵中256个元素的取值分别为0~255,按一定规律排列。令其为:

@@01A04603.GIF;公式三@@

亮度为L时的矩阵可由H变化而来,其中

@@01A04604.GIF;公式四@@

2.颜色查找表算法中只用到了颜色0及9~15,我们可以忽略其他项并将有用部分表示为一个三维数组形式的颜色查找表,如表2所示。此时,r, g, b值作为数组下标,取值为0或1。

与之相应,我们将(2)式变为

@@01A04605.GIF;公式三@@

3.每一像素的显示步骤

①对256色图像,由颜色索引值查颜色映射表获取R、G、B值;对全彩色图像,直接读取R、G、B值;

②根据像素座标(X,Y),由(1)式求得m, n;

③根据R、G、B值,由(3)式求得rmn、gmn、bmn;

④由rmn、gmn、bmn查表2得颜色值C;

⑤将像素以颜色C显示于(X,Y)处。

本文所附程序用于在16色图形模式下显示256色及全彩色BitMap图像。

关于BitMap图像的格式及读取方法,许多资料均有介绍,这里不再赘述。

该程序由Turbo C 2.0及Borland C 3.1编译,运行通过。运行方法为:

show文件名.BMP

@@01A04606.GIF;公式三表2 颜色查找表@@

事实证实,采用本文所描述的算法,可以得到与许多商品化软件相似的处理速度和处理效果。

源程序:

#include<stdio.h>

#include<dos.h>

#include<stdio.h>

#include<conio.h>

#define NoError 0

#define ErrorFileOpen1

#define ErrorFileType 2

#define ErrorImageColor 3

typedef strUCt tagB99vMAPFILEHEADER {

unsigned int bfType;

unsigned longbfSize;

unsigned intbfReserved1; unsigned intbfReserved2;

unsigned longbfoffBits;

} B99vMAPFILEHEADER;

typedef struct tagB99vMAPINFOHEADER {

unsigned longbiSize;

unsigned long biWidth;

unsigned longbiHeight;

unsigned intbiPlanes;

unsigned intbiBitCount;

unsigned long biCompression;

unsigned long biSizeImage;

unsigned long biXPelsPerMeter;

unsigned long biYPelsPerMeter;

unsigned long biClrUsed;

unsigned long biClrImportant;

} B99vMAPINFOHEADER;

typedef struct tagRGBQUAD {

unsigned char rgbBlue;

unsigned char rgbGreen;

unsigned charrgbRed;

unsigned char rgbReserved;

} RGBQUAD;

void main(int argc,char *argv[]);

int ShowBmp(char *FileName);

int GetColor(unsigned char R,unsigned char G, unsigned char B,int X,int Y);

void SetVideoMode(unsigned char Mode);

void SetPalReg(unsigned char *palReg);

void SetDacReg(unsigned char *DacReg, int Color, int Count);

void PutPixel(int X, int Y,unsigned char Color);

unsigned char PalReg[17]= { 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,0};

unsigned char StandardPal[48]= {

0, 0, 0, 32, 0, 0, 0,32, 0, 32,32, 0, 0, 0,32, 32, 0,32, 0,32,32, 32,32,

32, 48,48,48, 63, 0, 0, 0,63, 0, 63,63, 0, 0, 0,63, 63, 0,63, 0,63,63, 63,6

3,63,};

unsigned char LightnessMatrix [16][16]= {

{ 0,235,59,219,15,231,55,215,2,232,56,217,12,229,52,213},

{128,64,187,123,143,79,183,119,130,66,184,120,140,76,180,116},

{33,192,16,251,47,207,31,247,34,194,18,248,44,204,28,244},

{161,97,144,80,175,111,159,95,162,98,146,82,172,108,156,92}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有