灰度处理的方法主要有如下3种:

1、最大值法:使R、G、B的值等于3值中最大的一个,即:
   R=G=B=max(R,G,B)

最大值法会使形成高亮度很高的灰度图象

  1. var
  2. bitmap:tbitmap;
  3. i,j:integer;
  4. a,b,c,crgb,temp:longint;
  5. res:byte;
  6. begin
  7. //最大值灰度处理方法
  8. bitmap:=tbitmap.Create;
  9. bitmap.Width:=image1.Width+1;
  10. bitmap.Height:=image1.Height+1;
  11. for i:=0 to image1.Width+1 do
  12. begin
  13. for j:=0 to image1.Height+1 do
  14. begin
  15. crgb:=colortorgb(image1.Canvas.Pixels[i,j]);
  16. a:=crgb;
  17. b:=crgb shr 8;
  18. c:=crgb shr 8;
  19. //求出3者之间的最大值
  20. if a>b then
  21. temp:=a
  22. else temp:=b;
  23. if c>temp then
  24. temp:=c ;
  25. res:=byte(temp);
  26. bitmap.Canvas.Pixels[i,j]:=rgb(res,res,res);
  27. end;
  28. end;
  29. image1.Canvas.Draw(0,0,bitmap);
  30. bitmap.Free;
  31. end;

2、平均值方法:使R、G、B的值求出平均值,即:
R=G=B=(R+G+B)3
平均值法会形成较柔和的灰度图象。

  1. var
  2. bitmap:tbitmap;
  3. i,j:integer;
  4. crgb:longint;
  5. rr,gg,bb:byte;
  6. res:byte;
  7. begin
  8. //图象的平均值处理
  9. bitmap:=tbitmap.Create;
  10. bitmap.Width:=image1.Width;
  11. bitmap.Height:=image1.Height;
  12. for i:=0 to image1.Width+1 do
  13. begin
  14. for j:=0 to image1.Height+1 do
  15. begin
  16. crgb:=colortorgb(image1.Canvas.Pixels[i,j]);
  17. rr:=byte(crgb);
  18. gg:=byte(crgb shr 8);
  19. bb:=byte(crgb shr 8);
  20. res:=(rr+gg+bb)div 3;
  21. bitmap.Canvas.Pixels[i,j]:=rgb(res,res,res);
  22. end;
  23. end;
  24. image1.Canvas.Draw(0,0,bitmap);
  25. bitmap.Free;
  26. end;

3、加权平均值法:根据重要性或其他指标给R、G、B赋予不同的权值,并使R、G、B它们的值加权平均,即:
R=G=B=(WrR+WrG+WbB)3,经实际经验和理论推导证明,采用R=G=B=0.30*R+0.59*G+0.11*B,可以得到最合理的灰度图象

    1. var
    2. bitmap:tbitmap;
    3. i,j:integer;
    4. rr,gg,bb,res:byte;
    5. crgb:longint;
    6. begin
    7. //加权平均处理方法
    8. bitmap:=tbitmap.Create;
    9. bitmap.Width:=image1.Width+1;
    10. bitmap.Height:=image1.Height+1;
    11. for i:=0 to image1.Width+1 do
    12. begin
    13. for j:=0 to image1.Height+1 do
    14. begin
    15. crgb:=colortorgb(image1.Canvas.Pixels[i,j]);
    16. rr:=byte(crgb);
    17. gg:=byte(crgb shr 8);
    18. bb:=byte(crgb shr 8);
    19. res:=(30*rr+59*gg+11*bb)div 100;
    20. bitmap.Canvas.Pixels[i,j]:=rgb(res,res,res);
    21. end;
    22. end;
    23. image1.Canvas.Draw(0,0,bitmap);
    24. bitmap.Free;
    25. end;

http://blog.csdn.net/aroc_lo/article/details/9256077

delphi实现图象灰度处理的3种方法的更多相关文章

  1. delphi TreeView 从数据库添加节点的四种方法

    方法一:delphi中递归算法构建treeView 过程:通过读取数据库中table1的数据,来构建一颗树.table1有两个字段:ID,preID,即当前结点标志和父结点标志.所以整个树的表示为父母 ...

  2. Delphi中拖动无边框窗口的5种方法

    1.MouseMove事件中加入: // ReleaseCapture;// Perform(WM_SYSCOMMAND, $F017 , 0); 2.MouseDown事件中加入: // POSTM ...

  3. Android-将RGB彩色图转换为灰度图

    package com.example.yanlei.wifi; import android.graphics.Bitmap; import android.graphics.BitmapFacto ...

  4. 2015.1.25 Delphi打开网址链接的几种方法

    Delphi打开网址链接的几种方法1.使用shellapi打开系统中默认的浏览器              首先需在头部引用 shellapi单元即在uses中添加shellapi,这里我们需要知道有 ...

  5. java实现甘特图的2种方法:SwiftGantt和Jfree (转)

    http://blog.sina.com.cn/s/blog_50a7c4a601009817.html 第一种方法使用SwiftGantt实现甘特图(进度图推荐这个)   import java.a ...

  6. UML类图画法及其之间的几种关系(转)

    UML类图画法及其之间的几种关系 最近做重构项目,需要画一下类图,发现类图的画法及其之间的几种关系已经淡忘了很多,所以整理总结一下,有问题的地方大家可以一起讨论下. 文章目录如下: 类图画法 类之间的 ...

  7. Delphi中弹出提示框的四种方法

    参考:http://blog.itpub.net/8432156/viewspace-924843/ 更为详细的内容请参见:http://blog.csdn.net/akof1314/article/ ...

  8. UML类图画法及其之间的几种关系

    最近做重构项目,需要画一下类图,发现类图的画法及其之间的几种关系已经淡忘了很多,所以整理总结一下,有问题的地方大家可以一起讨论下. 文章目录如下: 类图画法 类之间的几种关系:泛化(Generaliz ...

  9. 【转】delphi程序只允许运行一个实例的三种方法:

    一.        创建互斥对象 在工程project1.dpr中创建互斥对象 Program project1 Uses Windows,Form, FrmMain in 'FrmMain.pas' ...

随机推荐

  1. USACO Cow Pedigrees 【Dp】

    一道经典Dp. 定义dp[i][j] 表示由i个节点,j 层高度的累计方法数 状态转移方程为: 用i个点组成深度最多为j的二叉树的方法树等于组成左子树的方法数 乘于组成右子树的方法数再累计. & ...

  2. Ubuntu上搭建DokuWiki

    1.准备工作 1) 安装Apache sudo apt-get install apache2 2)在浏览器中输入http://localhost 如果现实It works则说明Apache安装成功, ...

  3. SolrCloud简介

    原文地址:http://www.chepoo.com/solrcloud-introduction.html 一.简介 SolrCloud是Solr4.0版本以后基于Solr和Zookeeper的分布 ...

  4. svn笔记3

    如果你是从头到尾按章节阅读本书,你一定已经具备了使用Subversion客户端执行大多数不同的版本控制操作足够的知识,你理解了怎样从Subversion版本库取出一个工作拷贝,你已经熟悉了通过svn ...

  5. 数据分析≠Hadoop+NoSQL

    数据分析≠Hadoop+NoSQL 目录(?)[+]           Hadoop让大数据分析走向了大众化,然而它的部署仍需耗费大量的人力和物力.在直奔Hadoop之前,是否已经将现有技术推向极限 ...

  6. Java网络蜘蛛/网络爬虫 Spiderman

    Spiderman - 又一个Java网络蜘蛛/爬虫 Spiderman 是一个基于微内核+插件式架构的网络蜘蛛,它的目标是通过简单的方法就能将复杂的目标网页信息抓取并解析为自己所需要的业务数据. 主 ...

  7. 快捷键accesskey

    <!DOCTYPE html> <html> <body> <a href="http://www.w3school.com.cn/html/&qu ...

  8. ant_0105

    在projectA中执行projectB的构件文件.projectA的构件文件内容如下 <?xml version="1.0"?> <!-- 在projectA中 ...

  9. hdu4710

    Balls Rearrangement Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  10. 浅谈初次搭建nginx+php+mysql遇到的问题

    先说明下我linux上的环境: nginx + php(5.5.10) + mysql 開始的源代码已经在本地写好,并调试成功(本地的环境是用XAMPP的默认配置).在把代码上传至linux上时,出现 ...