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

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

?? rxhints.pas

?? RX Library contains a large number of components, objects and routines for Borland Delphi with full
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
{*******************************************************}
{                                                       }
{         Delphi VCL Extensions (RX)                    }
{                                                       }
{         Copyright (c) 1997 Master-Bank                }
{                                                       }
{*******************************************************}

unit RxHints;

{$I RX.INC}

interface

uses {$IFDEF WIN32} Windows, {$ELSE} WinTypes, WinProcs, {$ENDIF} Messages,
  Graphics, Classes, Controls, Forms, Dialogs;

type
  THintStyle = (hsRectangle, hsRoundRect, hsEllipse);
  THintPos = (hpTopRight, hpTopLeft, hpBottomRight, hpBottomLeft);
  THintShadowSize = 0..15;

  TRxHintWindow = class(THintWindow)
  private
    FSrcImage: TBitmap;
    FImage: TBitmap;
    FPos: THintPos;
    FRect: TRect;
    FTextRect: TRect;
    FTileSize: TPoint;
    FRoundFactor: Integer;
    procedure WMEraseBkgnd(var Message: TMessage); message WM_ERASEBKGND;
{$IFDEF RX_D3}
    procedure WMNCPaint(var Message: TMessage); message WM_NCPAINT;
{$ENDIF}
    function CreateRegion(Shade: Boolean): HRgn;
    procedure FillRegion(Rgn: HRgn; Shade: Boolean);
  protected
    procedure CreateParams(var Params: TCreateParams); override;
    procedure Paint; override;
  public
    constructor Create(AOwner: TComponent); override;
    destructor Destroy; override;
    procedure ActivateHint(Rect: TRect; const AHint: string); override;
{$IFDEF RX_D3}
    procedure ActivateHintData(Rect: TRect; const AHint: string;
      AData: Pointer); override;
{$ENDIF}
    function CalcHintRect(MaxWidth: Integer; const AHint: string;
      AData: Pointer): TRect; {$IFDEF RX_D3} override; {$ENDIF}
  end;

procedure SetHintStyle(Style: THintStyle; ShadowSize: THintShadowSize;
  Tail: Boolean; Alignment: TAlignment);
procedure SetStandardHints;
procedure RegisterHintWindow(AClass: THintWindowClass);
function GetHintControl: TControl;

implementation

uses SysUtils, VclUtils, AppUtils, MaxMin;

const
  HintStyle: THintStyle = hsRectangle;
  HintShadowSize: THintShadowSize = 0;
  HintTail: Boolean = False;
  HintAlignment: TAlignment = taLeftJustify;

{ Utility routines }

procedure RegisterHintWindow(AClass: THintWindowClass);
begin
  HintWindowClass := AClass;
  with Application do
    if ShowHint then begin
      ShowHint := False;
      ShowHint := True;
    end;
end;

procedure SetStandardHints;
begin
  RegisterHintWindow(THintWindow);
end;

procedure SetHintStyle(Style: THintStyle; ShadowSize: THintShadowSize;
  Tail: Boolean; Alignment: TAlignment);
begin
  HintStyle := Style;
  HintShadowSize := ShadowSize;
  HintTail := Tail;
  HintAlignment := Alignment;
  RegisterHintWindow(TRxHintWindow);
end;

function GetHintControl: TControl;
var
  CursorPos: TPoint;
begin
  GetCursorPos(CursorPos);
  Result := FindDragTarget(CursorPos, True);
  while (Result <> nil) and not Result.ShowHint do
    Result := Result.Parent;
  if (Result <> nil) and (csDesigning in Result.ComponentState) then
    Result := nil;
end;

procedure StandardHintFont(AFont: TFont);
{$IFDEF WIN32}
var
  NonClientMetrics: TNonClientMetrics;
{$ENDIF}
begin
{$IFDEF WIN32}
  NonClientMetrics.cbSize := SizeOf(NonClientMetrics);
  if SystemParametersInfo(SPI_GETNONCLIENTMETRICS, 0, @NonClientMetrics, 0) then
    AFont.Handle := CreateFontIndirect(NonClientMetrics.lfStatusFont)
  else begin
    AFont.Name := 'MS Sans Serif';
    AFont.Size := 8;
  end;
  AFont.Color := clInfoText;
{$ELSE}
  AFont.Name := 'MS Sans Serif';
  AFont.Size := 8;
  AFont.Color := clWindowText;
{$ENDIF}
end;

{$IFDEF WIN32}
{$IFNDEF RX_D3}
function GetCursorHeightMargin: Integer;
{ Return number of scanlines between the scanline containing cursor hotspot
  and the last scanline included in the cursor mask. }
var
  IconInfo: TIconInfo;
  BitmapInfoSize: Integer;
  BitmapBitsSize: Integer;
  Bitmap: PBitmapInfoHeader;
  Bits: Pointer;
  BytesPerScanline, ImageSize: Integer;

    function FindScanline(Source: Pointer; MaxLen: Cardinal;
      Value: Cardinal): Cardinal; assembler;
    asm
            PUSH    ECX
            MOV     ECX,EDX
            MOV     EDX,EDI
            MOV     EDI,EAX
            POP     EAX
            REPE    SCASB
            MOV     EAX,ECX
            MOV     EDI,EDX
    end;

begin
  { Default value is entire icon height }
  Result := GetSystemMetrics(SM_CYCURSOR);
  if GetIconInfo(GetCursor, IconInfo) then
  try
    GetDIBSizes(IconInfo.hbmMask, BitmapInfoSize, BitmapBitsSize);
    Bitmap := AllocMem(BitmapInfoSize + BitmapBitsSize);
    try
      Bits := Pointer(Longint(Bitmap) + BitmapInfoSize);
      if GetDIB(IconInfo.hbmMask, 0, Bitmap^, Bits^) and
        (Bitmap^.biBitCount = 1) then
      begin
        { Point Bits to the end of this bottom-up bitmap }
        with Bitmap^ do
        begin
          BytesPerScanline := ((biWidth * biBitCount + 31) and not 31) div 8;
          ImageSize := biWidth * BytesPerScanline;
          Bits := Pointer(Integer(Bits) + BitmapBitsSize - ImageSize);
          { Use the width to determine the height since another mask bitmap
            may immediately follow }
          Result := FindScanline(Bits, ImageSize, $FF);
          { In case the and mask is blank, look for an empty scanline in the
            xor mask. }
          if (Result = 0) and (biHeight >= 2 * biWidth) then
            Result := FindScanline(Pointer(Integer(Bits) - ImageSize),
              ImageSize, $00);
          Result := Result div BytesPerScanline;
        end;
        Dec(Result, IconInfo.yHotSpot);
      end;
    finally
      FreeMem(Bitmap, BitmapInfoSize + BitmapBitsSize);
    end;
  finally
    if IconInfo.hbmColor <> 0 then DeleteObject(IconInfo.hbmColor);
    if IconInfo.hbmMask <> 0 then DeleteObject(IconInfo.hbmMask);
  end;
end;
{$ENDIF}
{$ENDIF}

{ TRxHintWindow }

constructor TRxHintWindow.Create(AOwner: TComponent);
begin
  inherited Create(AOwner);
  StandardHintFont(Canvas.Font);
  FImage := TBitmap.Create;
  FSrcImage := TBitmap.Create;
end;

destructor TRxHintWindow.Destroy;
begin
  FSrcImage.Free;
  FImage.Free;
  inherited Destroy;
end;

procedure TRxHintWindow.CreateParams(var Params: TCreateParams);
begin
  inherited CreateParams(Params);
  Params.Style := Params.Style and not WS_BORDER;
end;

{$IFDEF RX_D3}
procedure TRxHintWindow.WMNCPaint(var Message: TMessage);
begin
end;
{$ENDIF}

procedure TRxHintWindow.WMEraseBkgnd(var Message: TMessage);
begin
  Message.Result := 1;
end;

function TRxHintWindow.CreateRegion(Shade: Boolean): HRgn;
var
  R: TRect;
  W, TileOffs: Integer;
  Tail, Dest: HRgn;
  P: TPoint;

  function CreatePolyRgn(const Points: array of TPoint): HRgn;
  type
    PPoints = ^TPoints;
    TPoints = array[0..0] of TPoint;
  begin
    Result := CreatePolygonRgn(PPoints(@Points)^, High(Points) + 1, WINDING);
  end;

begin
  R := FRect;
  Result := 0;
  if Shade then OffsetRect(R, HintShadowSize, HintShadowSize);
  case HintStyle of
    hsRoundRect: Result := CreateRoundRectRgn(R.Left, R.Top, R.Right, R.Bottom,
      FRoundFactor, FRoundFactor);
    hsEllipse: Result := CreateEllipticRgnIndirect(R);
    hsRectangle: Result := CreateRectRgnIndirect(R);
  end;
  if HintTail then begin
    R := FTextRect;
    GetCursorPos(P);
    TileOffs := 0;
    if FPos in [hpTopLeft, hpBottomLeft] then TileOffs := Width;
    if Shade then begin
      OffsetRect(R, HintShadowSize, HintShadowSize);
      Inc(TileOffs, HintShadowSize);
    end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区欧美激情| 久久久久久久精| 99久久精品国产麻豆演员表| 精品亚洲成a人| 蜜乳av一区二区三区| 亚洲小少妇裸体bbw| 一区二区三区欧美久久| 亚洲日本在线观看| 亚洲图片另类小说| 亚洲精品第一国产综合野| 国产精品久久久久久亚洲毛片| 久久看人人爽人人| 久久看人人爽人人| 国产精品全国免费观看高清| 中文欧美字幕免费| 国产精品嫩草99a| 一区二区三区蜜桃| 香蕉av福利精品导航| 亚洲成人精品影院| 精品一区二区久久| 国产黄色成人av| 91猫先生在线| 欧美日韩综合一区| 日韩三级视频在线看| 欧美精品一区在线观看| 久久人人97超碰com| 国产精品福利一区二区三区| 亚洲免费av观看| 亚洲6080在线| 国产在线精品免费av| 国产精品亚洲人在线观看| 91在线精品一区二区| 欧美群妇大交群中文字幕| 精品国产乱码久久久久久夜甘婷婷 | 亚洲国产欧美一区二区三区丁香婷| 一区二区三区精品在线| 老鸭窝一区二区久久精品| 高清国产午夜精品久久久久久| 色噜噜狠狠色综合欧洲selulu| 欧美精品黑人性xxxx| 国产精品久久久久久久岛一牛影视| 亚洲一区在线观看视频| 国产一区在线观看视频| 欧美综合一区二区| 久久综合九色综合97_久久久| 亚洲欧美二区三区| 国精产品一区一区三区mba桃花| 色又黄又爽网站www久久| 精品欧美一区二区久久| 亚洲综合图片区| 国产精品888| 日韩欧美在线影院| 亚洲激情av在线| 成人午夜视频免费看| 欧美人与性动xxxx| 亚洲综合在线五月| 成人免费视频一区| 久久先锋资源网| 玖玖九九国产精品| 欧美性一级生活| 亚洲人xxxx| 99精品视频在线免费观看| 欧美精品一区二区三区四区| 天天色综合天天| 欧美三级日韩在线| 一区二区三区中文在线| 91在线精品一区二区| 国产精品毛片无遮挡高清| 国产一区二区不卡在线| 欧美一级欧美一级在线播放| 亚洲大片免费看| 欧美又粗又大又爽| 一区二区不卡在线播放| 色噜噜偷拍精品综合在线| 亚洲图片激情小说| 不卡一卡二卡三乱码免费网站| 国产亚洲精品资源在线26u| 激情另类小说区图片区视频区| 欧美一区二区三区白人| 蜜臀久久99精品久久久久宅男| 在线91免费看| 久久国产精品99久久人人澡| 日韩欧美在线123| 美国毛片一区二区三区| 亚洲精品一区二区三区精华液 | 亚洲一区电影777| 欧美影院一区二区三区| 亚洲成a人片在线不卡一二三区| 欧美综合一区二区| 青娱乐精品视频| 精品美女一区二区| 粉嫩蜜臀av国产精品网站| 欧美激情一区二区三区全黄| 成人av电影在线播放| 亚洲欧美日韩国产中文在线| 欧美日韩在线观看一区二区| 五月婷婷另类国产| 久久久久九九视频| 91一区二区三区在线观看| 亚洲一区二区三区三| 欧美一区二区免费视频| 国产精品综合二区| 亚洲男人的天堂一区二区| 欧美日韩二区三区| 国产精品99久久久| 亚洲综合激情小说| 久久在线观看免费| 在线一区二区三区| 久久精品久久久精品美女| 欧美国产禁国产网站cc| 欧美午夜一区二区三区| 久久99国产精品久久99果冻传媒| 国产精品三级在线观看| 欧美高清视频不卡网| 成人亚洲精品久久久久软件| 亚洲小说春色综合另类电影| 国产午夜精品久久久久久久| 欧美视频一二三区| 成人黄色小视频在线观看| 午夜av一区二区三区| 亚洲欧美综合色| 欧美成人性战久久| 在线观看国产一区二区| 国产一区二区三区在线看麻豆| 亚洲视频免费在线观看| 精品剧情v国产在线观看在线| 一本色道久久综合狠狠躁的推荐| 开心九九激情九九欧美日韩精美视频电影 | 激情成人午夜视频| 亚洲综合免费观看高清完整版在线| 久久久国产精品麻豆| 欧美日韩国产另类不卡| 不卡的av在线| 国产酒店精品激情| 日韩av不卡在线观看| 亚洲一区在线观看网站| 亚洲欧洲韩国日本视频| 亚洲国产激情av| 亚洲精品一区二区三区四区高清| 欧美精品第一页| 欧美在线观看18| 99久久99久久久精品齐齐| 成人一区二区三区视频| 国产成人精品免费看| 国产毛片精品国产一区二区三区| 奇米在线7777在线精品| 亚洲成人免费影院| 亚洲成av人片一区二区| 亚洲国产成人av网| 亚洲成人av中文| 日韩电影在线免费看| 偷偷要91色婷婷| 人人超碰91尤物精品国产| 日本一不卡视频| 蜜桃一区二区三区在线| 九九精品一区二区| 精品一区二区免费看| 国产精品亚洲一区二区三区在线| 狠狠色丁香婷婷综合| 国产精品一品二品| 懂色av一区二区三区免费观看| 国产91高潮流白浆在线麻豆| 成人午夜大片免费观看| 99久久婷婷国产综合精品电影 | 国产91丝袜在线观看| 美女视频黄 久久| 国产精品亚洲一区二区三区妖精| 久久狠狠亚洲综合| 捆绑调教一区二区三区| 国产乱色国产精品免费视频| 国产专区欧美精品| 国产一区二区三区免费| 亚洲精品视频一区二区| 亚洲成人精品影院| 奇米777欧美一区二区| 蜜臀精品久久久久久蜜臀| 成人一级黄色片| 91香蕉视频污在线| 欧洲亚洲精品在线| 91久久精品午夜一区二区| 8x8x8国产精品| 久久综合999| 国产精品三级在线观看| 舔着乳尖日韩一区| 九色|91porny| 北条麻妃一区二区三区| 成人国产电影网| 91日韩精品一区| 欧美区在线观看| 国产日产欧美精品一区二区三区| 一区二区三区在线免费播放| 午夜精品一区二区三区免费视频 | 国产精品久久久久一区| 亚洲欧洲三级电影| 亚洲国产欧美在线| 国内不卡的二区三区中文字幕 | 一区二区免费视频| 免费观看91视频大全| 国产xxx精品视频大全| 成人国产精品免费观看视频|