动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C/C++教程 ]的信息

本月文章推荐
.Visual Basic使用技巧.
.自制c语言编制cgi实现搜索功能.
.kingofark关于学习C++和编程的50.
.C++中通过溢出覆盖虚函数指针列表.
.C++的iostream标准库介绍(3).
.MINI-FOOLFLY 游戏代码.
.C++中使用BHO来屏蔽特定网站.
.C++ Builder 初学问与答(三).
.大家进来瞧瞧我编的小迷宫,望大.
.C++实例教学-基础知识.
.C++之父Bjarne谈C++在2005年.
.十全十美游戏.
.在Window右下角的添加图标.
.C++中理解“传递参数”和异常之间.
.创建和使用库:静态、共享和动态.
.PE文件格式详解(5).
.通过COM来获取CookieContainer,简.
.C语言程序设计经典实例之九.
.API之控件与消息函数.
.exit()子程序终止函数与return().

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

发表日期:2008-3-8 |


摘 要 该文描述了在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}

上一篇:在BCB中使用VCL控件数组1 人气:439
下一篇:在 Linux 下用 C 编写显示时间的程序 人气:615
浏览全部C/C++的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-10 企业网站智能管理系统(TZIMS) v6
2008-10-10 拓文asp.net网站内容管理系统 v6
2008-10-10 动网论坛PHP版 v2.0++ Build 081
2008-10-10 免费时代CMS v5.0
2008-10-10 wodig第四季中文DIGG社区 v4.1 b
2008-10-10 老Y文章管理系统 v2.2 bulid 081
2008-10-10 魔法盒动感相册 ASP+SQL版 v2.0
2008-10-10 Asoft签到管理系统 v3.0 Pack1
2008-10-10 哥特人音乐网潮流留言本 v1.1
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号