亚洲欧美第一页_禁久久精品乱码_粉嫩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精品一区二区三区| 亚洲精品日韩专区silk| 精品国产一区二区在线观看| 欧美中文字幕一区二区三区| 国产麻豆精品一区二区| 日韩成人午夜精品| 亚洲制服欧美中文字幕中文字幕| 国产亚洲欧洲一区高清在线观看| 56国语精品自产拍在线观看| 色一情一乱一乱一91av| 高清不卡在线观看av| 久久se这里有精品| 日本在线播放一区二区三区| 亚洲一区二区av在线| 国产精品激情偷乱一区二区∴| 精品乱人伦小说| 日韩欧美一级二级| 欧美精品一级二级三级| 国产亚洲女人久久久久毛片| 制服丝袜亚洲网站| 欧美亚洲一区三区| 在线观看视频91| 91毛片在线观看| 91小视频免费观看| 不卡的av在线| 成人毛片老司机大片| 国产成人精品一区二区三区网站观看| 麻豆精品一二三| 日韩高清不卡一区二区| 香蕉加勒比综合久久| 亚洲愉拍自拍另类高清精品| 亚洲精品欧美激情| 亚洲黄一区二区三区| 亚洲欧洲一区二区在线播放| 中文字幕中文字幕一区| 国产精品久久久久久久岛一牛影视 | 成+人+亚洲+综合天堂| 国产不卡在线一区| 丰满岳乱妇一区二区三区| 国产激情视频一区二区在线观看| 国产精品自在欧美一区| 岛国精品在线播放| 91美女在线看| 欧美色涩在线第一页| 欧美日韩一区二区在线观看视频| 欧美色倩网站大全免费| 日韩亚洲欧美中文三级| 精品乱人伦小说| 国产精品色婷婷久久58| 亚洲色图色小说| 亚洲电影第三页| 日本美女视频一区二区| 久久精品二区亚洲w码| 国产精品1区2区| 91在线码无精品| 欧美精品久久天天躁| 日韩欧美亚洲国产另类| 久久久久久久久久久黄色 | 日本 国产 欧美色综合| 国产做a爰片久久毛片 | 日韩三区在线观看| 久久久夜色精品亚洲| 综合自拍亚洲综合图不卡区| 亚洲第一狼人社区| 国产在线播放一区| 91偷拍与自偷拍精品| 欧美肥大bbwbbw高潮| 久久亚洲精华国产精华液 | aaa欧美日韩| 欧美久久婷婷综合色| 久久精品这里都是精品| 亚洲免费在线播放| 久久精品久久精品| 91小视频在线| 亚洲精品在线免费观看视频| 亚洲人成电影网站色mp4| 久久精品国产亚洲高清剧情介绍| 国产成人亚洲综合a∨猫咪| 欧美午夜片在线看| 欧美一卡2卡3卡4卡| 中文字幕在线观看不卡| 久久精品国产第一区二区三区| 99久久国产综合精品色伊| 欧美一区二区免费观在线| 中文字幕一区二区三区乱码在线 | www.欧美亚洲| 日韩一区二区三区免费看 | 亚洲不卡av一区二区三区| 黄色日韩三级电影| 欧美性大战久久久久久久蜜臀| 久久亚洲免费视频| 日韩福利电影在线| 91在线观看高清| 久久久久久97三级| 喷白浆一区二区| 欧美午夜精品久久久久久孕妇| 国产午夜精品久久久久久久| 婷婷国产在线综合| 色噜噜狠狠成人中文综合| 久久久99精品免费观看不卡| 天天操天天综合网| 欧美影院一区二区| 自拍av一区二区三区| 国产91在线观看丝袜| 日韩欧美色综合| 午夜欧美电影在线观看| 91精品福利在线| 一区精品在线播放| 成人动漫视频在线| 久久久久99精品一区| 精品无码三级在线观看视频| 91精品麻豆日日躁夜夜躁| 亚洲成人精品影院| 欧美探花视频资源| 一区二区不卡在线播放 | 色综合网色综合| 国产精品白丝在线| 成人黄色综合网站| 国产精品免费视频观看| 国产91精品精华液一区二区三区| 精品久久久久香蕉网| 美女视频网站久久| 日韩欧美一区二区视频| 日本在线观看不卡视频| 4438x成人网最大色成网站| 午夜久久福利影院| 制服视频三区第一页精品| 日韩电影免费一区| 91精品国产色综合久久不卡电影| 午夜精品一区二区三区三上悠亚| 欧美日韩一级黄| 天涯成人国产亚洲精品一区av| 欧美日韩国产123区| 五月婷婷色综合| 日韩亚洲国产中文字幕欧美| 麻豆精品一区二区综合av| 精品国产一区二区三区av性色| 免费看黄色91| 久久网这里都是精品| 国产福利一区二区三区在线视频| 日本一区二区三区国色天香 | 五月激情六月综合| 欧美精品九九99久久| 免费在线看成人av| 精品久久久久久久久久久久久久久久久| 理论片日本一区| 国产女主播在线一区二区| av在线一区二区三区| 一区二区三区在线观看视频| 欧美三级视频在线| 蜜桃视频免费观看一区| 久久精品视频网| 成人av网站在线| 亚洲一区av在线| 日韩免费一区二区三区在线播放| 极品少妇xxxx偷拍精品少妇| 国产欧美日本一区二区三区| 色婷婷国产精品| 免费不卡在线观看| 中文字幕的久久| 欧美日韩综合色| 国产做a爰片久久毛片| 亚洲天堂精品视频| 欧美一级艳片视频免费观看| 国产成人午夜99999| 亚洲一线二线三线久久久| 日韩一区二区不卡| 成人av电影免费在线播放| 午夜激情久久久| 中文字幕av不卡| 欧美日韩不卡一区二区| 国产99久久久国产精品潘金| 亚洲午夜久久久久中文字幕久| 精品国产一区二区三区不卡| 一本色道亚洲精品aⅴ| 久久99日本精品| 亚洲精品久久嫩草网站秘色| 日韩美女在线视频| 99精品桃花视频在线观看| 蜜桃精品视频在线| 亚洲欧美成aⅴ人在线观看| 欧美成人性战久久| 在线免费av一区| 成人中文字幕合集| 奇米色777欧美一区二区| 亚洲精品国产一区二区三区四区在线| 日韩一区二区三区四区| 91福利视频在线| 国产99久久久久久免费看农村| 日本不卡在线视频| 亚洲天堂精品在线观看| 欧美精品一区二区三区高清aⅴ | 欧美精品aⅴ在线视频| 91老师片黄在线观看| 国产精品亚洲人在线观看| 天天操天天综合网| 亚洲综合网站在线观看|