delphi 覆盖模式处理透明  
官方Delphi 学习QQ群: 682628230(三千人)\n
频道

delphi 覆盖模式处理透明


delphi 覆盖模式处理透明

1、创建一个Mark图层

2、对覆盖区域进行行列扫描(使用背景色,设置透明)

  PRGB = ^TRGB;
  TRGB = record
    b, g, r, a: Byte;
  end;
  PRGBArray = ^TRGBArray;
  TRGBArray = array [0 .. 65565] of TRGB;

 


        // use cMask image to remove overlaping rTab area
        slPtr := Integer(cBmp.ScanLine[y1]);
        slSize := Integer(cBmp.ScanLine[y1 + 1]) - slPtr;
        slPtr2 := Integer(cMask.ScanLine[y1]);
        slSize2 := Integer(cMask.ScanLine[y1 + 1]) - slPtr2;
        if i > 0 then
        begin
          for h := y1 to y2 - 1 do
          begin
            Row := PRGBArray(slPtr);
            Row2 := PRGBArray(slPtr2);
            for w := 0 to FTabOverLap - 1 do
              if Row2[w + (FTabWidth - FTabOverLap) + 1].g <> 0 then
              begin
                Row[w + x1].r := Byte(FColorBackground);
                Row[w + x1].g := Byte(FColorBackground shr 8);
                Row[w + x1].b := Byte(FColorBackground shr 16);
                Row[w + x1].A := 0;
              end;
            slPtr := slPtr + slSize;
            slPtr2 := slPtr2 + slSize2;
          end;
        end;
        // overlaping rTab area cleared


推荐分享
图文皆来源于网络,内容仅做公益性分享,版权归原作者所有,如有侵权请告知删除!
 

Copyright © 2014 DelphiW.com 开发 源码 文档 技巧 All Rights Reserved
晋ICP备14006235号-8 晋公网安备 14108102000087号

执行时间: 0.33701610565186 seconds