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

文档

下载

图书

论坛

安全

源码

硬件

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

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

[常用滤镜效果]

对于浮雕效果,大家一般也看过些相关代码,但一般不支持角度变化!这里根据角度的不同,在一个像素周围的8个像素中取不同的两个运算得到新颜色值,用这个值和它求差值实现浮雕效果。用到了线性插值的思想,没有使用浮点运算!

//浮雕

procedure Emboss(SrcBmp,DestBmp:TBitmap;AzimuthChange:integer);overload;

var

 i, j, Gray, Azimuthvalue, R, G, B: integer;

 SrcRGB, SrcRGB1, SrcRGB2, DestRGB: pRGBTriple;

begin

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

 begin

  SrcRGB := SrcBmp.ScanLine[i];

  DestRGB := DestBmp.ScanLine[i];

  if (AzimuthChange >= -180) and (AzimuthChange < -135) then

  begin

   if i > 0 then

    SrcRGB1 := SrcBmp.ScanLine[i-1]

   else

    SrcRGB1 := SrcRGB;

   Inc(SrcRGB1);

   SrcRGB2 := SrcRGB;

   Inc(SrcRGB2);

  end

  else if (AzimuthChange >= -135) and (AzimuthChange < -90) then

  begin

   if i > 0 then

    SrcRGB1 := SrcBmp.ScanLine[i-1]

   else

    SrcRGB1 := SrcRGB;

   SrcRGB2 := SrcRGB1;

   Inc(SrcRGB2);

  end

  else if (AzimuthChange >= -90) and (AzimuthChange < -45) then

  begin

   if i > 0 then

    SrcRGB1 := SrcBmp.ScanLine[i-1]

   else

    SrcRGB1 := SrcRGB;

   SrcRGB2 := SrcRGB1;

  end

  else if (AzimuthChange >= -45) and (AzimuthChange < 0) then

  begin

   SrcRGB1 := SrcRGB;

   if i > 0 then

    SrcRGB2 := SrcBmp.ScanLine[i-1]

   else

    SrcRGB2 := SrcRGB;

  end

  else if (AzimuthChange >= 0) and (AzimuthChange < 45) then

  begin

   SrcRGB2 := SrcRGB;

   if (i < SrcBmp.Height - 1) then

    SrcRGB1 := SrcBmp.ScanLine[i+1]

   else

    SrcRGB1 := SrcRGB;

  end

  else if (AzimuthChange >= 45) and (AzimuthChange < 90) then

  begin

   if (i < SrcBmp.Height - 1) then

    SrcRGB1 := SrcBmp.ScanLine[i+1]

   else

    SrcRGB1 := SrcRGB;

   SrcRGB2 := SrcRGB1;

  end

  else if (AzimuthChange >= 90) and (AzimuthChange < 135) then

  begin

   if (i < SrcBmp.Height - 1) then

    SrcRGB1 := SrcBmp.ScanLine[i+1]

   else

    SrcRGB1 := SrcRGB;

   SrcRGB2 := SrcRGB1;

   Inc(SrcRGB1);

  end

  else if (AzimuthChange >= 135) and (AzimuthChange <= 180) then

  begin

   if (i < SrcBmp.Height - 1) then

    SrcRGB2 := SrcBmp.ScanLine[i+1]

   else

    SrcRGB2 := SrcRGB;

   Inc(SrcRGB2);

   SrcRGB1 := SrcRGB;

   Inc(SrcRGB1);

  end;

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

  begin

   if (AzimuthChange >= -180) and (AzimuthChange < -135) then

   begin

    Azimuthvalue := AzimuthChange + 180;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= -135) and (AzimuthChange < -90) then

   begin

    Azimuthvalue := AzimuthChange + 135;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= -90) and (AzimuthChange < -45) then

   begin

    if j=1 then Inc(SrcRGB1,-1);

    Azimuthvalue := AzimuthChange + 90;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= -45) and (AzimuthChange < 0) then

   begin

    if j=1 then

    begin

     Inc(SrcRGB1,-1);

     Inc(SrcRGB2,-1);

    end;

    Azimuthvalue := AzimuthChange + 45;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= 0) and (AzimuthChange < 45) then

   begin

    if j=1 then

    begin

     Inc(SrcRGB1,-1);

     Inc(SrcRGB2,-1);

    end;

    Azimuthvalue := AzimuthChange;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= 45) and (AzimuthChange < 90) then

   begin

    if j=1 then Inc(SrcRGB2,-1);

    Azimuthvalue := AzimuthChange - 45;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= 90) and (AzimuthChange < 135) then

   begin

    Azimuthvalue := AzimuthChange - 90;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end

   else if (AzimuthChange >= 135) and (AzimuthChange <= 180) then

   begin

    Azimuthvalue := AzimuthChange - 135;

    R:=SrcRGB.rgbtRed-((SrcRGB1.rgbtRed)*Azimuthvalue div 45)-((SrcRGB2.rgbtRed)*(45-Azimuthvalue) div 45)+78;

    G:=SrcRGB.rgbtGreen-((SrcRGB1.rgbtGreen)*Azimuthvalue div 45)-((SrcRGB2.rgbtGreen)*(45-Azimuthvalue) div 45)+78;

    B:=SrcRGB.rgbtBlue-((SrcRGB1.rgbtBlue)*Azimuthvalue div 45)-((SrcRGB2.rgbtBlue)*(45-Azimuthvalue) div 45)+78;

   end;

   R:=Min(R,255);

   R:=Max(R,0);

   G:=Min(G,255);

   G:=Max(G,0);

   B:=Min(B,255);

   B:=Max(B,0);

   Gray := (R shr 2) + (R shr 4) + (G shr 1) + (G shr 4) + (B shr 3);

   DestRGB.rgbtRed:=Gray;

   DestRGB.rgbtGreen:=Gray;

   DestRGB.rgbtBlue:=Gray;

   if (j<SrcBmp.Width - 1) or not (((AzimuthChange>=-180) and (AzimuthChange<-135)) or ((AzimuthChange>=90) and (AzimuthChange<=180))) then

   begin

    Inc(SrcRGB1);

   end;

   if (j<SrcBmp.Width - 1) or not (((AzimuthChange>=135) and (AzimuthChange<180)) or ((AzimuthChange>=-180) and (AzimuthChange<=-90))) then

   begin

    Inc(SrcRGB2);

   end;

   Inc(SrcRGB);

   Inc(DestRGB);

  end;

 end;

end;

procedure Emboss(Bmp:TBitmap;AzimuthChange:integer;ElevationChange:integer;WeightChange:integer);overload;

var

 DestBmp:TBitmap;

begin

  DestBmp:=TBitmap.Create;

  DestBmp.Assign(Bmp);

  Emboss(Bmp,DestBmp,AzimuthChange,ElevationChange,WeightChange);

  Bmp.Assign(DestBmp);

end;

//反色

procedure Negative(Bmp:TBitmap);

var

 i, j: Integer;

 PRGB: pRGBTriple;

begin

 Bmp.PixelFormat:=pf24Bit;

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

 begin

  PRGB := Bmp.ScanLine[i];

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

  begin

   PRGB^.rgbtRed :=not PRGB^.rgbtRed ;

   PRGB^.rgbtGreen :=not PRGB^.rgbtGreen;

   PRGB^.rgbtBlue :=not PRGB^.rgbtBlue;

   Inc(PRGB);

  end;

 end;

end;

//曝光

procedure Exposure(Bmp:TBitmap);

var

 i, j: integer;

 PRGB: pRGBTriple;

begin

 Bmp.PixelFormat:=pf24Bit;

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

 begin

  PRGB := Bmp.ScanLine[i];

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

  begin

   if PRGB^.rgbtRed<128 then

    PRGB^.rgbtRed :=not PRGB^.rgbtRed ;

   if PRGB^.rgbtGreen<128 then

    PRGB^.rgbtGreen :=not PRGB^.rgbtGreen;

   if PRGB^.rgbtBlue<128 then

    PRGB^.rgbtBlue :=not PRGB^.rgbtBlue;

   Inc(PRGB);

  end;

 end;

end;

//模糊

procedure Blur(SrcBmp:TBitmap);

var

 i, j:Integer;

 SrcRow:pRGBTriple;

 SrcNextRow:pRGBTriple;

 SrcPreRow:pRGBTriple;

 Value:Integer;

 procedure IncRow;

 begin

  Inc(SrcPreRow);

  Inc(SrcRow);

  Inc(SrcNextRow);

 end;

 procedure DecRow;

 begin

  Inc(SrcPreRow,-1);

  Inc(SrcRow,-1);

  Inc(SrcNextRow,-1);

 end;

begin

 SrcBmp.PixelFormat:=pf24Bit;

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

 begin

  if i > 0 then

   SrcPreRow:=SrcBmp.ScanLine[i-1]

  else

   SrcPreRow := SrcBmp.ScanLine[i];

  SrcRow := SrcBmp.ScanLine[i];

  if i < SrcBmp.Height - 1 then

   SrcNextRow:=SrcBmp.ScanLine[i+1]

  else

   SrcNextRow:=SrcBmp.ScanLine[i];

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

  begin

   if j > 0 then DecRow;

   Value:=SrcPreRow.rgbtRed+SrcRow.rgbtRed+SrcNextRow.rgbtRed;

   if j > 0 then IncRow;

   Value:=Value+SrcPreRow.rgbtRed+SrcRow.rgbtRed+SrcNextRow.rgbtRed;

   if j < SrcBmp.Width - 1 then IncRow;

   Value:=(Value+SrcPreRow.rgbtRed+SrcRow.rgbtRed+SrcNextRow.rgbtRed) div 9;

   if j < SrcBmp.Width - 1 then DecRow;

   SrcRow.rgbtRed:=value;

   if j > 0 then DecRow;

   Value:=SrcPreRow.rgbtGreen+SrcRow.rgbtGreen+SrcNextRow.rgbtGreen;

   if j > 0 then IncRow;

   Value:=Value+SrcPreRow.rgbtGreen+SrcRow.rgbtGreen+SrcNextRow.rgbtGreen;

   if j < SrcBmp.Width - 1 then IncRow;

   Value:=(Value+SrcPreRow.rgbtGreen+SrcRow.rgbtGreen+SrcNextRow.rgbtGreen) div 9;

   if j < SrcBmp.Width - 1 then DecRow;

   SrcRow.rgbtGreen:=value;

   if j > 0 then DecRow;

   Value:=SrcPreRow.rgbtBlue+SrcRow.rgbtBlue+SrcNextRow.rgbtBlue;

   if j > 0 then IncRow;

   Value:=Value+SrcPreRow.rgbtBlue+SrcRow.rgbtBlue+SrcNextRow.rgbtBlue;

   if j < SrcBmp.Width - 1 then IncRow;

   Value:=(Value+SrcPreRow.rgbtBlue+SrcRow.rgbtBlue+SrcNextRow.rgbtBlue) div 9;

   if j < SrcBmp.Width - 1 then DecRow;

   SrcRow.rgbtBlue:=value;

   IncRow;

  end;

 end;

end;

//锐化

procedure Sharpen(SrcBmp:TBitmap);

var

 i, j: integer;

 SrcRGB: pRGBTriple;

 SrcPreRGB: pRGBTriple;

 Value: integer;

begin

 SrcBmp.PixelFormat:=pf24Bit;

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

 begin

  SrcRGB := SrcBmp.ScanLine[i];

  if i > 0 then

   SrcPreRGB:=SrcBmp.ScanLine[i-1]

  else

   SrcPreRGB:=SrcBmp.ScanLine[i];

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

  begin

   if j = 1 then Dec(SrcPreRGB);

   Value:=SrcRGB.rgbtRed+(SrcRGB.rgbtRed-SrcPreRGB.rgbtRed) div 2;

   Value:=Max(0,Value);

   Value:=Min(255,Value);

   SrcRGB.rgbtRed:=value;

   Value:=SrcRGB.rgbtGreen+(SrcRGB.rgbtGreen-SrcPreRGB.rgbtGreen) div 2;

   Value:=Max(0,Value);

   Value:=Min(255,Value);

   SrcRGB.rgbtGreen:=value;

   Value:=SrcRGB.rgbtBlue+(SrcRGB.rgbtBlue-SrcPreRGB.rgbtBlue) div 2;

   Value:=Max(0,Value);

   Value:=Min(255,Value);

   SrcRGB.rgbtBlue:=value;

   Inc(SrcRGB);

   Inc(SrcPreRGB);

  end;

 end;

end;

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

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

最新招聘信息

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