登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 信息 空间 VB VC Delphi Java Flash 补丁 控件 安全 黑客 电子书 笔记本 手机 MP3 杀毒 QQ群 产品库 分类信息 编程网站
  立华软件园 - 安全技术中心 - 技术文档 - Delphi 技术文章 | 相关下载 | 电子图书 | 攻防录像 | 安全网站 | 在线论坛 | QQ群组 | 搜索   
 安全技术技术文档
  · 安全配制
  · 工具介绍
  · 黑客教学
  · 防火墙
  · 漏洞分析
  · 破解专题
  · 黑客编程
  · 入侵检测
 安全技术工具下载
  · 扫描工具
  · 攻击程序
  · 后门木马
  · 拒绝服务
  · 口令破解
  · 代理程序
  · 防火墙
  · 加密解密
  · 入侵检测
  · 攻防演示
 安全技术论坛
  · 安全配制
  · 工具介绍
  · 防火墙
  · 黑客入侵
  · 漏洞检测
  · 破解方法
 其他安全技术资源
  · 攻防演示动画
  · 电子图书
  · QQ群组讨论区
  · 其他网站资源
最新招聘信息

基本图象处理代码(2)
发表日期:2003-03-07作者:ehom[] 出处:  

[亮度、对比度、饱和度的调整]

以下代码用ScanLine配合指针移动实现!

function Min(a, b: integer): integer;

begin

 if a < b then

  result := a

 else

  result := b;

end;

function Max(a, b: integer): integer;

begin

 if a > b then

  result := a

 else

  result := b;

end;

//亮度调整

procedure BrightnessChange(const SrcBmp,DestBmp:TBitmap;ValueChange:integer);

var

 i, j: integer;

 SrcRGB, DestRGB: pRGBTriple;

begin

 for i := 0 to SrcBmp.Height - 1 do

 begin

  SrcRGB := SrcBmp.ScanLine[i];

  DestRGB := DestBmp.ScanLine[i];

  for j := 0 to SrcBmp.Width - 1 do

  begin

   if ValueChange > 0 then

   begin

    DestRGB.rgbtRed := Min(255, SrcRGB.rgbtRed + ValueChange);

    DestRGB.rgbtGreen := Min(255, SrcRGB.rgbtGreen + ValueChange);

    DestRGB.rgbtBlue := Min(255, SrcRGB.rgbtBlue + ValueChange);

   end else begin

    DestRGB.rgbtRed := Max(0, SrcRGB.rgbtRed + ValueChange);

    DestRGB.rgbtGreen := Max(0, SrcRGB.rgbtGreen + ValueChange);

    DestRGB.rgbtBlue := Max(0, SrcRGB.rgbtBlue + ValueChange);

   end;

   Inc(SrcRGB);

   Inc(DestRGB);

  end;

 end;

end;

//对比度调整

procedure ContrastChange(const SrcBmp,DestBmp:TBitmap;ValueChange:integer);

var

 i, j: integer;

 SrcRow, DestRow: pRGBTriple;

begin

 for i := 0 to SrcBmp.Height - 1 do

 begin

  SrcRow := SrcBmp.ScanLine[i];

  DestRow := DestBmp.ScanLine[i];

  for j := 0 to SrcBmp.Width - 1 do

  begin

   if ValueChange>=0 then

   begin

   if SrcRow.rgbtRed >= 128 then

    DestRow.rgbtRed := Min(255, SrcRow.rgbtRed + (Abs(128 - SrcRow.rgbtRed) * ValueChange) div 128)

   else

    DestRow.rgbtRed := Max(0, SrcRow.rgbtRed - (Abs(128 - SrcRow.rgbtRed) * ValueChange) div 128);

   if SrcRow.rgbtGreen >= 128 then

    DestRow.rgbtGreen := Min(255, SrcRow.rgbtGreen + (Abs(128 - SrcRow.rgbtGreen) * ValueChange) div 128)

   else

    DestRow.rgbtGreen := Max(0, SrcRow.rgbtGreen - (Abs(128 - SrcRow.rgbtGreen) * ValueChange) div 128);

   if SrcRow.rgbtBlue >= 128 then

    DestRow.rgbtBlue := Min(255, SrcRow.rgbtBlue + (Abs(128 - SrcRow.rgbtBlue) * ValueChange) div 128)

   else

    DestRow.rgbtBlue := Max(0, SrcRow.rgbtBlue - (Abs(128 - SrcRow.rgbtBlue) * ValueChange) div 128);

   end

   else

   begin

   if SrcRow.rgbtRed >= 128 then

    DestRow.rgbtRed := Max(128, SrcRow.rgbtRed + (Abs(128 - SrcRow.rgbtRed) * ValueChange) div 128)

   else

    DestRow.rgbtRed := Min(128, SrcRow.rgbtRed - (Abs(128 - SrcRow.rgbtRed) * ValueChange) div 128);

   if SrcRow.rgbtGreen >= 128 then

    DestRow.rgbtGreen := Max(128, SrcRow.rgbtGreen + (Abs(128 - SrcRow.rgbtGreen) * ValueChange) div 128)

   else

    DestRow.rgbtGreen := Min(128, SrcRow.rgbtGreen - (Abs(128 - SrcRow.rgbtGreen) * ValueChange) div 128);

   if SrcRow.rgbtBlue >= 128 then

    DestRow.rgbtBlue := Max(128, SrcRow.rgbtBlue + (Abs(128 - SrcRow.rgbtBlue) * ValueChange) div 128)

   else

    DestRow.rgbtBlue := Min(128, SrcRow.rgbtBlue - (Abs(128 - SrcRow.rgbtBlue) * ValueChange) div 128);

   end;

   Inc(SrcRow);

   Inc(DestRow);

  end;

 end;

end;

//饱和度调整

procedure SaturationChange(const SrcBmp,DestBmp:TBitmap;ValueChange:integer);

var

 Grays: array[0..767] of Integer;

 Alpha: array[0..255] of Word;

 Gray, x, y: Integer;

 SrcRGB,DestRGB: pRGBTriple;

 i: Byte;

begin

ValueChange:=ValueChange+255;

for i := 0 to 255 do

 Alpha[i] := (i * ValueChange) Shr 8;

x := 0;

for i := 0 to 255 do

begin

 Gray := i - Alpha[i];

 Grays[x] := Gray;

 Inc(x);

 Grays[x] := Gray;

 Inc(x);

 Grays[x] := Gray;

 Inc(x);

end;

for y := 0 to SrcBmp.Height - 1 do

begin

 SrcRGB := SrcBmp.ScanLine[Y];

 DestRGB := DestBmp.ScanLine[Y];

 for x := 0 to SrcBmp.Width - 1 do

 begin

  Gray := Grays[SrcRGB.rgbtRed + SrcRGB.rgbtGreen + SrcRGB.rgbtBlue];

  if Gray + Alpha[SrcRGB.rgbtRed]>0 then

   DestRGB.rgbtRed := Min(255,Gray + Alpha[SrcRGB.rgbtRed])

  else

   DestRGB.rgbtRed := 0;

  if Gray + Alpha[SrcRGB.rgbtGreen]>0 then

   DestRGB.rgbtGreen := Min(255,Gray + Alpha[SrcRGB.rgbtGreen])

  else

   DestRGB.rgbtGreen := 0;

  if Gray + Alpha[SrcRGB.rgbtBlue]>0 then

   DestRGB.rgbtBlue := Min(255,Gray + Alpha[SrcRGB.rgbtBlue])

  else

   DestRGB.rgbtBlue := 0;

  Inc(SrcRGB);

  Inc(DestRGB);

 end;

end;

end;

//RGB调整

procedure RGBChange(SrcBmp,DestBmp:TBitmap;RedChange,GreenChange,BlueChange:integer);

var

 SrcRGB, DestRGB: pRGBTriple;

 i,j:integer;

begin

 for i := 0 to SrcBmp.Height- 1 do

 begin

  SrcRGB := SrcBmp.ScanLine[i];

  DestRGB :=DestBmp.ScanLine[i];

  for j := 0 to SrcBmp.Width - 1 do

  begin

   if RedChange> 0 then

    DestRGB.rgbtRed := Min(255, SrcRGB.rgbtRed + RedChange)

   else

    DestRGB.rgbtRed := Max(0, SrcRGB.rgbtRed + RedChange);

   if GreenChange> 0 then

    DestRGB.rgbtGreen := Min(255, SrcRGB.rgbtGreen + GreenChange)

   else

    DestRGB.rgbtGreen := Max(0, SrcRGB.rgbtGreen + GreenChange);

   if BlueChange> 0 then

    DestRGB.rgbtBlue := Min(255, SrcRGB.rgbtBlue + BlueChange)

   else

    DestRGB.rgbtBlue := Max(0, SrcRGB.rgbtBlue + BlueChange);

   Inc(SrcRGB);

   Inc(DestRGB);

  end;

 end;

end;

如果有些图像处理的基础,这些代码都比较好理解,主要是三原色的值不要超过(0-255)的范围,有些朋友没有注意这问题,当超过范围后,会出现些难看的“色斑”!

[颜色调整]

//RGB<=>BGR

procedure RGB2BGR(const Bitmap:TBitmap);

var

 X: Integer;

 Y: Integer;

 PRGB: pRGBTriple;

 Color: Byte;

begin

 for Y := 0 to (Bitmap.Height - 1) do

 begin

  for X := 0 to (Bitmap.Width - 1) do

  begin

   Color := PRGB^.rgbtRed;

   PRGB^.rgbtRed := PRGB^.rgbtBlue;

   PRGB^.rgbtBlue := Color;

   Inc(PRGB);

  end;

  end

 end;

end;

//灰度化(加权)

procedure Grayscale(const Bitmap:TBitmap);

var

 X: Integer;

 Y: Integer;

 PRGB: pRGBTriple;

 Gray: Byte;

begin

 for Y := 0 to (Bitmap.Height - 1) do

 begin

  PRGB := Bitmap.ScanLine[Y];

  for X := 0 to (Bitmap.Width - 1) do

  begin

   Gray := (77 * Red + 151 * Green + 28 * Blue) shr 8;

   PRGB^.rgbtRed:=Gray;

   PRGB^.rgbtGreen:=Gray;

   PRGB^.rgbtBlue:=Gray;

   Inc(PRGB);

  end;

 end;

end;

关于灰度化,我的另一篇文章中进行了详细的探讨!

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 基本图象处理代码(2)

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

最新招聘信息

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.00205