亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gradecolorimage.pas

?? 機房管理系統 是用VB設計的簡單的管理系統
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
unit GradeColorImage;

interface

uses
  Windows, Messages, SysUtils, Classes, Controls,Graphics;

type
  TGradientFillType=(rgsHorizontal, rgsVertical, rgsElliptic, rgsRectangle, rgsVerticalCenter,
        rgsHorizontalCenter, rgsNWSE, rgsNWSW, rgsSENW,rgsSWNE, rgsSweet, rgsStrange, rgsNeo);

const crDefaultWidth=24;
const crDefaultHeight=24;
const crDefaultFromColor=clRed;
const crDefaultToColor=clWhite;
const crDefaultFillType=rgsElliptic;

type
  TGCImg = class(TGraphicControl)
  private
    { Private declarations }
    bmp:TBitmap;
    r:TRect;
    InMousePress:boolean;
    FFromColor,FToColor:TColor;
    FGradientFillType:TGradientFillType;
    fOnClick, fOnDblClick: TNotifyEvent;
    fOnMouseDown, fOnMouseUp: TMouseEvent;
    fOnMouseMove: TMouseMoveEvent;
    procedure SetFromColor(value: TColor);
    procedure SetToColor(value: TColor);
    procedure SetGradientFillType(value: TGradientFillType);
  protected
    { Protected declarations }
    procedure Paint; override;
    procedure SetBounds(aLeft, aTop, aWidth, aHeight: Integer); override;
    procedure MouseDown(Button: TMouseButton; Shift: TShiftState; X,Y: Integer); override;
    procedure MouseMove(Shift: TShiftState; X, Y: Integer); override;
    procedure MouseUp(Button: TMouseButton; Shift: TShiftState; X,Y: Integer); override;
  public
    { Public declarations }
    constructor Create(AOwner: TComponent); override;
    destructor Destroy; override;
  published
    { Published declarations }
    // 屬性
    property Action;
    property Align;
    property Enabled;
    property FromColor:TColor read FFromColor write SetFromColor;
    property GradientFillType:TGradientFillType read FGradientFillType write SetGradientFillType;
    property ParentFont;
    property ParentShowHint;
    property PopupMenu;
    property ShowHint;
    property ToColor:TColor read FToColor write SetToColor;
    property Visible;
    // 方法
    property OnClick: TNotifyEvent read fOnClick write fOnClick;
    property OnDblClick: TNotifyEvent read fOnDblClick write fOnDblClick;
    property OnDragDrop;
    property OnDragOver;
    property OnEndDrag;
    {$IFNDEF VER80}
    property OnStartDrag;
    {$ENDIF}
    property OnMouseDown: TMouseEvent read fOnMouseDown write fOnMouseDown;
    property OnMouseMove: TMouseMoveEvent read fOnMouseMove write fOnMouseMove;
    property OnMouseUp: TMouseEvent read fOnMouseUp write fOnMouseUp;
  end;

procedure Register;
procedure RbsGradientFill(Canvas: TCanvas; grdType: TGradientFillType;
  fromCol, toCol: TColor; ARect: TRect);

implementation

procedure Register;
begin
  RegisterComponents('Wuqiu', [TGCImg]);
end;

constructor TGCImg.Create(AOwner: TComponent);
begin
  inherited Create(AOwner);
  width:=crDefaultWidth;
  Height:=crDefaultHeight;
  r:=Rect(0,0,width,Height);
  FFromColor:=crDefaultFromColor;
  FToColor:=crDefaultToColor;
  FGradientFillType:=crDefaultFillType;
  bmp:=TBitmap.Create;
  bmp.Width :=width;
  bmp.Height :=Height;
  InMousePress:=false;
  if bmp<>nil then
    RbsGradientFill(bmp.Canvas,FGradientFillType,FFromColor,FToColor,r);

end;

destructor TGCImg.Destroy;
begin
  inherited Destroy;
  bmp.Free;
end;

procedure TGCImg.MouseDown(Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
begin
  if Enabled then
  begin
    if Assigned(fOnMouseDown) then
      fOnMouseDown(Self, Button, Shift, X, Y);
    if (Button = mbLeft) then
    begin
      InMousePress := True;
      if (ssDouble in Shift) and Assigned(fOnDblClick) then
        fOnDblClick(Self);
    end;
  end;

end;

procedure TGCImg.MouseMove(Shift: TShiftState; X, Y: Integer);
begin
  if Assigned(fOnMouseMove) then
    fOnMouseMove(Self, Shift, X, Y);
end;

procedure TGCImg.MouseUp(Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
begin
  if InMousePress then
  begin
    InMousePress := False;
    if (X>=0)and(X<=Width)and(Y>0)and(Y<=Height) then
      if Assigned(fOnClick) then
        fOnClick(Self);
  end;
  if Assigned(fOnMouseUp) then
    fOnMouseUp(Self, Button, Shift, X, Y);
end;

procedure TGCImg.Paint;
begin
  if bmp<>nil then
    Canvas.CopyRect(r, bmp.Canvas, r);
end;

procedure TGCImg.SetBounds(aLeft, aTop, aWidth,
  aHeight: Integer);
begin
  inherited SetBounds(aLeft, aTop, aWidth, aHeight);
  if (width<>r.Right)or(Height<>r.Bottom) then
  begin
    if bmp<>nil then
    begin
      r:=Rect(0,0,Width,Height);
      bmp.Width :=width;
      bmp.Height :=height;
      RbsGradientFill(bmp.Canvas,FGradientFillType,FFromColor,FToColor,r);
      Invalidate;
    end;
  end;
end;

procedure TGCImg.SetFromColor(value: TColor);
begin
  if FFromColor<>value then
  begin
    FFromColor:=value;
    if bmp<>nil then
    begin
      RbsGradientFill(bmp.Canvas,FGradientFillType,FFromColor,FToColor,r);
      Invalidate;
    end;
  end;
end;

procedure TGCImg.SetGradientFillType(value: TGradientFillType);
begin
  if FGradientFillType<>value then
  begin
    FGradientFillType:=value;
    if bmp<>nil then
    begin
      RbsGradientFill(bmp.Canvas,FGradientFillType,FFromColor,FToColor,r);
      Invalidate;
    end;
  end;
end;

procedure TGCImg.SetToColor(value: TColor);
begin
  if FToColor<>value then
  begin
    FToColor:=value;
    if bmp<>nil then
    begin
      RbsGradientFill(bmp.Canvas,FGradientFillType,FFromColor,FToColor,r);
      Invalidate;
    end;
  end;
end;

procedure RbsGradientFill(Canvas: TCanvas; grdType: TGradientFillType;
  fromCol, toCol: TColor; ARect: TRect);
var
  FromR, FromG, FromB : Integer;
  DiffR, DiffG, DiffB : Integer;

  i: integer;
  bm:TBitmap;
  ColorRect:TRect;
  R,G,B:Byte;

  //for elliptical
  Pw, Ph : Real;
  x0,y0,x1,y1,x2,y2,x3,y3 : Real;
  points:array[0..3] of TPoint;
  haf:Integer;

begin
  //set bitmap
  bm:=TBitmap.Create;
  bm.Width := ARect.Right;
  bm.Height := ARect.Bottom;

  //calc colors
  FromR := fromcol and $000000ff;  //Strip out separate RGB values
  FromG := (fromcol shr 8) and $000000ff;
  FromB := (fromcol shr 16) and $000000ff;
  DiffR := (tocol and $000000ff) - FromR;   //Find the difference
  DiffG := ((tocol shr 8) and $000000ff) - FromG;
  DiffB := ((tocol shr 16) and $000000ff) - FromB;

  //draw gradient
  case grdType of
  rgsHorizontal:
     begin
     ColorRect.Top:= 0;                //Set rectangle top
     ColorRect.Bottom := bm.Height;
     for I := 0 to 255 do begin         //Make lines (rectangles) of color
      ColorRect.Left:= MulDiv (I, bm.Width, 256);    //Find left for this color
      ColorRect.Right:= MulDiv (I + 1, bm.Width, 256);   //Find Right
      R := fromR + MulDiv(I, diffr, 255);    //Find the RGB values
      G := fromG + MulDiv(I, diffg, 255);
      B := fromB + MulDiv(I, diffb, 255);
      bm.Canvas.Brush.Color := RGB(R, G, B);   //Plug colors into brush
      bm.Canvas.FillRect(ColorRect);           //Draw on Bitmap
     end;

     end;
  rgsVertical:
     begin
     ColorRect.Left:= 0;                //Set rectangle left&right
     ColorRect.Right:= bm.Width;
     for I := 0 to 255 do begin         //Make lines (rectangles) of color
      ColorRect.Top:= MulDiv (I, bm.Height, 256);    //Find top for this color
      ColorRect.Bottom:= MulDiv (I + 1, bm.Height, 256);   //Find Bottom
      R := fromr + MulDiv(I, diffr, 255);    //Find the RGB values
      G := fromg + MulDiv(I, diffg, 255);
      B := fromb + MulDiv(I, diffb, 255);
      bm.Canvas.Brush.Color := RGB(R, G, B);   //Plug colors into brush
      bm.Canvas.FillRect(ColorRect);           //Draw on Bitmap
    end;

     end;
  rgsElliptic:
     begin
     bm.Canvas.Pen.Style := psClear;
     bm.Canvas.Pen.Mode := pmCopy;
     x1 := 0 - (bm.Width / 4);
     x2 := bm.Width + (bm.Width / 4)+4;
     y1 := 0 - (bm.Height / 4);
     y2 := bm.Height + (bm.Height / 4)+4;
     Pw := ((bm.Width / 4) + (bm.Width / 2)) / 155;
     Ph := ((bm.Height / 4) + (bm.Height / 2)) / 155;
     for I := 0 to 155 do begin         //Make ellipses of color
      x1 := x1 + Pw;
      x2 := X2 - Pw;
      y1 := y1 + Ph;
      y2 := y2 - Ph;
      R := fromr + MulDiv(I, diffr, 155);    //Find the RGB values
      G := fromg + MulDiv(I, diffg, 155);
      B := fromb + MulDiv(I, diffb, 155);
      bm.Canvas.Brush.Color := R or (G shl 8) or (b shl 16);   //Plug colors into brush
      bm.Canvas.Ellipse(Trunc(x1),Trunc(y1),Trunc(x2),Trunc(y2));
    end;
       end;
     
  rgsRectangle:
     begin
     bm.Canvas.Pen.Style := psClear;
     bm.Canvas.Pen.Mode := pmCopy;
     x1 := 0;
     x2 := bm.Width+2;
     y1 := 0;
     y2 := bm.Height+2;
     Pw := (bm.Width / 2) / 255;
     Ph := (bm.Height / 2) / 255;
     for I := 0 to 255 do begin         //Make rectangles of color
      x1 := x1 + Pw;
      x2 := X2 - Pw;
      y1 := y1 + Ph;
      y2 := y2 - Ph;
      R := fromr + MulDiv(I, diffr, 255);    //Find the RGB values
      G := fromg + MulDiv(I, diffg, 255);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久综合网站| 91精品国产91热久久久做人人| 精品一区二区三区免费视频| 一区二区三区精品视频在线| 亚洲人午夜精品天堂一二香蕉| 亚洲欧美激情视频在线观看一区二区三区| 久久久亚洲综合| 国产精品久久久久久久久免费丝袜| 国产精品久久久久国产精品日日 | 欧美一级二级三级蜜桃| 欧美日韩黄视频| 欧美性大战久久久久久久| 99久久精品国产网站| 国产精品久久久久四虎| 久久久久久毛片| 九九久久精品视频| 色综合中文字幕| 国产午夜一区二区三区| 一区二区三区精品视频| 狠狠色丁香婷综合久久| 日韩国产精品久久久久久亚洲| 精品午夜久久福利影院| 91精品国产综合久久小美女| 日韩精品91亚洲二区在线观看 | 欧美一级理论性理论a| 日本一区二区不卡视频| 青青草一区二区三区| 国产夫妻精品视频| 不卡的电视剧免费网站有什么| 色综合久久中文综合久久牛| 久久99精品国产麻豆不卡| 久久精品国产成人一区二区三区| 亚洲成人av福利| 成人午夜av在线| 日韩天堂在线观看| 久久久久国产精品麻豆ai换脸| 久久国产精品第一页| 国产精品亚洲第一区在线暖暖韩国| 国产成人无遮挡在线视频| 日本亚洲一区二区| 天天综合色天天| 99久精品国产| 欧美欧美欧美欧美首页| 久久蜜臀中文字幕| 综合自拍亚洲综合图不卡区| 成人av电影免费在线播放| 国产成人精品影院| 91精品在线免费观看| 亚洲成人综合视频| 亚洲国产精品精华液ab| 7777精品伊人久久久大香线蕉的 | 欧美不卡一区二区三区| 日韩电影一区二区三区四区| 日韩欧美在线不卡| 国产精品一线二线三线| 国产精品乱子久久久久| 欧美色中文字幕| 91一区二区三区在线播放| 亚洲日本在线视频观看| 99riav久久精品riav| 国产日韩精品视频一区| 国产成人丝袜美腿| 欧美大黄免费观看| 亚洲动漫第一页| 9191成人精品久久| 秋霞电影网一区二区| 欧美精品一区二区三区很污很色的| 国产呦萝稀缺另类资源| 亚洲第一综合色| 亚洲欧洲日韩在线| 国产视频一区二区在线| 欧美一区二区私人影院日本| 9l国产精品久久久久麻豆| 国产美女av一区二区三区| 午夜精品福利一区二区蜜股av| 久久久久久99久久久精品网站| 91精品中文字幕一区二区三区| 99国产一区二区三精品乱码| 国产成人激情av| 高清beeg欧美| 成人一级片在线观看| 国产成人午夜精品影院观看视频| 久久精品国产99国产| 日韩av午夜在线观看| 精品一区二区日韩| www.日韩av| 久久福利资源站| 91精品国产综合久久久久久久 | 欧美视频一区二区在线观看| 午夜精品一区在线观看| 日韩欧美黄色影院| 91老司机福利 在线| 91麻豆免费观看| 欧美熟乱第一页| 6080亚洲精品一区二区| 日韩欧美综合一区| 久久久久国产精品麻豆ai换脸 | 国产精品中文字幕一区二区三区| 国产精品传媒视频| 欧美国产一区视频在线观看| 在线一区二区三区| 欧美日韩一级大片网址| 在线播放日韩导航| 国产欧美中文在线| 亚洲精品成人少妇| 麻豆国产精品777777在线| 国产精品1区二区.| 欧美性大战久久久| 欧美精品一区二区三区在线| 亚洲精品老司机| 国产在线一区观看| 欧美日韩一区二区三区四区| 久久久精品免费免费| 日韩精品午夜视频| 97久久精品人人澡人人爽| 日韩一区二区三区免费看 | 狠狠色狠狠色综合| 欧美三级中文字| 亚洲色图欧洲色图婷婷| 韩国毛片一区二区三区| 欧美一区国产二区| 亚洲成a人片在线观看中文| 成人一区二区在线观看| 欧美va在线播放| 天天操天天干天天综合网| 欧美综合天天夜夜久久| 国产精品黄色在线观看| 国产一区二区精品久久| 精品国产一二三| 狠狠色狠狠色综合日日91app| 91精品福利在线一区二区三区| 夜夜精品浪潮av一区二区三区| 成人免费看片app下载| 中文字幕不卡三区| 99久久久免费精品国产一区二区| 国产精品国产三级国产专播品爱网 | 久久99精品一区二区三区三区| 欧美人狂配大交3d怪物一区| 欧美激情在线一区二区| 国产成人精品三级| 亚洲另类在线制服丝袜| 欧美午夜精品久久久久久超碰| 一区二区三区日韩精品视频| 欧美日韩一区小说| 国产综合成人久久大片91| 欧美激情在线免费观看| 色88888久久久久久影院野外 | 成人激情综合网站| 亚洲综合小说图片| 久久亚洲一区二区三区四区| 中文字幕一区在线观看| 激情综合一区二区三区| 中文字幕精品一区| 欧美日韩国产美女| 99精品视频在线观看免费| 日韩在线a电影| 最新中文字幕一区二区三区 | 中文字幕乱码久久午夜不卡| 欧美亚洲综合网| 福利91精品一区二区三区| 天堂影院一区二区| 亚洲欧美国产77777| 久久久九九九九| 亚洲精品一区二区三区在线观看 | 亚洲国产精品精华液2区45| 欧美久久久影院| 欧美视频一区二区| 日本精品视频一区二区三区| 成人一区二区在线观看| 国产呦萝稀缺另类资源| 美女mm1313爽爽久久久蜜臀| 一区二区三区四区在线| 国产精品久久久久久久久果冻传媒| 91精品在线麻豆| 日韩视频免费观看高清完整版在线观看 | 一区二区三区在线影院| 亚洲另类中文字| 日韩激情在线观看| 老司机精品视频导航| 日本大胆欧美人术艺术动态| 午夜视频一区二区| 日日摸夜夜添夜夜添国产精品 | 欧美三级视频在线观看| 欧美色窝79yyyycom| 欧美午夜免费电影| 91精品国产高清一区二区三区 | 韩国欧美一区二区| 国产精品一二三四五| av毛片久久久久**hd| 欧美亚洲日本国产| 2021久久国产精品不只是精品| 久久午夜国产精品| 一区二区三区日韩| 久久精品国产免费| 色综合天天综合在线视频| 欧美精品99久久久**| 中文字幕一区二区视频| 日韩激情av在线| 96av麻豆蜜桃一区二区| 日韩欧美你懂的|