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

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

?? bsskinmenus.pas

?? BusinessSkinForm Ver3.95 full source_漢化版_最新
?? PAS
?? 第 1 頁 / 共 5 頁
字號:
                    GetWindowLong(Handle, GWL_EXSTYLE) or WS_EX_LAYERED);
      if ParentMenu.First and ParentMenu.AlphaBlendAnimation
      then SetAlphaBlendTransparent(Handle, 0)
      else SetAlphaBlendTransparent(Handle, ParentMenu.AlphaBlendValue);
    end;
  //
  SetWindowPos(Handle, HWND_TOPMOST, ShowX, ShowY, 0, 0,
               SWP_NOACTIVATE or SWP_SHOWWINDOW or SWP_NOSIZE);
  Visible := True;
  if CheckW2KWXP and ParentMenu.AlphaBlend and ParentMenu.AlphaBlendAnimation and
     ParentMenu.First
  then
    begin
      i := 0;
      ABV := ParentMenu.AlphaBlendValue;
      repeat
        Inc(i, AnimationStep);
        if i > ABV then i := ABV;
        SetAlphaBlendTransparent(Handle, i);
      until i >= ABV;
    end;
  //
  MouseTimer.Enabled := True;
  ActiveItem := -1;
  if ItemList.Count > 0
  then
    for i := 0 to ItemList.Count - 1 do
     with TbsSkinMenuItem(ItemList.Items[i]) do
     begin
       if (MenuItem.Enabled) and (MenuItem.Caption <> '-')
       then
         begin
           WaitCommand := True;
           ActiveItem := i;
           MouseEnter(True);
           Break;
         end;
     end;
end;

procedure TbsSkinPopupWindow.Show2;

procedure CalcMenuPos(var X, Y: Integer; R: TRect);
var
  WA: TRect;
  ChangeY: Boolean;

  function GetY: Integer;
  var
    Offset: Integer;
  begin
    if Scroll and not Scroll2
    then
      Result := WA.Top
    else
      begin
        if PopupByItem
        then
          begin
            Offset := R.Top + Height - NewItemsRect.Top - WA.Bottom;
            if Offset > 0
            then
              begin
                if R.Top < WA.Top + RectHeight(WA) div 2
                then
                  Result := WA.Bottom - Height
                else
                  begin
                    Result := R.Bottom - Height + NewItemsRect.Top;
                    if Result  < WA.Top then Result := WA.Top;
                  end
              end
            else
              Result := R.Top - NewItemsRect.Top;
          end
        else
          begin
            if PopupUp
            then
              begin
                if R.Top - Height < WA.Top
                then
                  begin
                    if R.Top < WA.Top + RectHeight(WA) div 2
                    then
                      begin
                        Result := R.Bottom;
                        Offset := Result + Height - WA.Bottom;
                        if Offset > 0
                        then
                          begin
                            Result  := Result - Offset;
                            ChangeY := True;
                          end;
                       end
                     else
                       begin
                         Result := WA.Top;
                         ChangeY := True;
                       end;
                  end
                else
                  Result  := R.Top - Height;
              end
            else
              begin
                Offset := R.Bottom + Height - WA.Bottom;
                if Offset > 0
                then
                  begin
                    if R.Top < WA.Top + RectHeight(WA) div 2
                    then
                      begin
                        Result := R.Bottom - Offset;
                        ChangeY := True
                      end
                    else
                      begin
                        if R.Top - Height < WA.Top
                        then
                          begin
                            Result := WA.Top;
                            ChangeY := True;
                          end
                        else
                          Result := R.Top - Height;
                      end
                  end
                else
                  Result := R.Bottom;
              end;
          end;
      end;
  end;

  function GetX: Integer;
  begin
    if PopupByItem or (Scroll and not Scroll2) or ChangeY
    then
      begin
        if R.Right + Width + 1 > WA.Right
        then Result := R.Left - Width - 1 else Result := R.Right + 1;
      end
    else
      begin
        if R.Left + Width > WA.Right
        then Result := WA.Right - Width else
        if R.Left < WA.Left then Result := WA.Left else Result := R.Left;
      end;
  end;

begin
  WA := ParentMenu.WorkArea;
  ChangeY := False;
  Y := GetY;
  X := GetX;
end;

const
  WS_EX_LAYERED = $80000;
  AnimationStep = 3;
var
  i: Integer;
  ABV: Integer;
begin
  if CheckW2KWXP and ParentMenu.AlphaBlend and ParentMenu.AlphaBlendAnimation and
     ParentMenu.First
  then
    Application.ProcessMessages;
    
  CreateMenu2(AItem, AItem2, StartIndex);
  CalcMenuPos(ShowX, ShowY, R);
  //
  if CheckW2KWXP and ParentMenu.AlphaBlend
  then
    begin
      SetWindowLong(Handle, GWL_EXSTYLE,
                    GetWindowLong(Handle, GWL_EXSTYLE) or WS_EX_LAYERED);
      if ParentMenu.First and ParentMenu.AlphaBlendAnimation
      then SetAlphaBlendTransparent(Handle, 0)
      else SetAlphaBlendTransparent(Handle, ParentMenu.AlphaBlendValue);
    end;
  //
  SetWindowPos(Handle, HWND_TOPMOST, ShowX, ShowY, 0, 0,
               SWP_NOACTIVATE or SWP_SHOWWINDOW or SWP_NOSIZE);
  Visible := True;
  if CheckW2KWXP and ParentMenu.AlphaBlend and ParentMenu.AlphaBlendAnimation and
     ParentMenu.First
  then
    begin
      i := 0;
      ABV := ParentMenu.AlphaBlendValue;
      repeat
        Inc(i, AnimationStep);
        if i > ABV then i := ABV;
        SetAlphaBlendTransparent(Handle, i);
      until i >= ABV;
    end;
  //
  MouseTimer.Enabled := True;
  ActiveItem := -1;
  if ItemList.Count > 0
  then
    for i := 0 to ItemList.Count - 1 do
     with TbsSkinMenuItem(ItemList.Items[i]) do
     begin
       if MenuItem.Enabled and (MenuItem.Caption <> '-')
       then
         begin
           WaitCommand := True;
           ActiveItem := i;
           MouseEnter(True);
           Break;
         end;
     end;
end;

procedure TbsSkinPopupWindow.PaintMenu;
var
  C: TCanvas;
  i: Integer;
  B: TBitMap;
begin
  C := TCanvas.Create;
  C.Handle := DC;
  B := TBitMap.Create;
  CreateRealImage(B);
  // Draw items
  for i := VisibleStartIndex to VisibleStartIndex + VisibleCount - 1 do
    TbsSkinMenuItem(ItemList.Items[i]).Draw(B.Canvas);
  // markers
  if Scroll
  then
    begin
      DrawUpMarker(B.Canvas);
      DrawDownMarker(B.Canvas);
    end;
  C.Draw(0, 0, B);
  B.Free;
  C.Free;
end;

procedure TbsSkinPopupWindow.WMEraseBkgrnd;
begin
  PaintMenu(Message.WParam);
end;

procedure TbsSkinPopupWindow.MouseUp;
begin
  TestActive(X, Y);
  if (ActiveItem <> -1) and (Button = mbleft) and GetActive(X, Y)
  then
    with TbsSkinMenuItem(ItemList.Items[ActiveItem]) do
     if MenuItem.Caption <> '-' then MouseDown(X, Y);
end;

procedure TbsSkinPopupWindow.TestMouse;
var
  P, P1: TPoint;
begin
  GetCursorPos(P1);
  P := ScreenToClient(P1);
  if (OMX <> P.X) or (OMY <> P.Y)
  then 
    if InWindow(P1)
    then
      TestActive(P.X, P.Y)
    else
      if Scroll
      then
        begin
          ScrollCode := 0;
          DrawUpMarker(Canvas);
          DrawDownMarker(Canvas);
        end;
  OMX := P.X;
  OMY := P.Y;
end;

function TbsSkinPopupWindow.GetActive;
var
  i: Integer;
begin
  i := -1;
  if ItemList.Count = 0
  then
    Result := False
  else
  repeat
    Inc(i);
    with TbsSkinMenuItem(ItemList.Items[i]) do
      Result := FVisible and PtInRect(ObjectRect, Point(X, Y));
  until Result or (i = ItemList.Count - 1);
end;

procedure TbsSkinPopupWindow.TestActive;
var
  i: Integer;
  B: Boolean;
  R1, R2: TRect;
begin
  if Scroll
  then
    begin
      R1 := Rect(NewItemsRect.Left, NewItemsRect.Top,
            NewItemsRect.Right, NewItemsRect.Top + MarkerItemHeight);
      R2 := Rect(NewItemsRect.Left, NewItemsRect.Bottom - MarkerItemHeight,
            NewItemsRect.Right, NewItemsRect.Bottom);

      if PtInRect(R1, Point(X, Y)) and (ScrollCode = 0) and CanScroll(1)
      then
        begin
          ScrollCode := 1;
          DrawUpMarker(Canvas);
          StartScroll;
        end
      else
      if PtInRect(R2, Point(X, Y)) and (ScrollCode = 0)  and CanScroll(2)
      then
        begin
          ScrollCode := 2;
          DrawDownMarker(Canvas);
          StartScroll;
        end
      else
        if (ScrollCode <> 0) and not PtInRect(R1, Point(X, Y)) and
                                 not PtInRect(R2, Point(X, Y))
        then
          StopScroll;
     end;

  if (ItemList.Count = 0) then Exit;

  OldActiveItem := ActiveItem;

  i := -1;
  repeat
    Inc(i);
    with TbsSkinMenuItem(ItemList.Items[i]) do
    begin
      B := FVisible and PtInRect(ObjectRect, Point(X, Y));
    end;
  until B or (i = ItemList.Count - 1);

  if B then ActiveItem := i;

  if OldActiveItem >= ItemList.Count then OldActiveItem := -1;
  if ActiveItem >= ItemList.Count then ActiveItem := -1;
  if (OldActiveItem = ActiveItem) and (ActiveItem <> -1)
  then
    begin
      with TbsSkinMenuItem(ItemList.Items[ActiveItem]) do
       if WaitCommand
       then
         begin
           WaitCommand := False;
           if MenuItem.Count <> 0
           then
             MouseEnter(False);
         end;
    end
  else
  if (OldActiveItem <> ActiveItem)
  then
    begin
      if OldActiveItem <> - 1
      then
        with TbsSkinMenuItem(ItemList.Items[OldActiveItem]) do
        begin
          if MenuItem.Enabled and (MenuItem.Caption <> '-')
          then
            MouseLeave;
        end;

      if ActiveItem <> - 1
      then
        with TbsSkinMenuItem(ItemList.Items[ActiveItem]) do
        begin
          if MenuItem.Enabled and (MenuItem.Caption <> '-')
          then
            MouseEnter(False);
        end;
    end;

end;

function TbsSkinPopupWindow.InWindow;
var
  H: HWND;
begin
  H := WindowFromPoint(P);
  Result := H = Handle;
end;

//====================TbsSkinMenu===================//
constructor TbsSkinMenu.CreateEx;
begin
  inherited Create(AOwner);
  FOnMenuClose := nil;
  MaxMenuItemsInWindow := 0;
  FUseSkinFont := True;
  AlphaBlendAnimation := False;
  AlphaBlend := False;
  AlphaBlendValue := 150;
  FPopupList := TList.Create;
  WaitTimer := TTimer.Create(Self);
  WaitTimer.Enabled := False;
  WaitTimer.OnTimer := WaitItem;
  WaitTimer.Interval := WaitTimerInterval;
  WItem := nil;
  FVisible := False;
  FForm := AForm;
  PopupCtrl := nil;
  DCtrl := nil;
  FDefaultMenuItemHeight := 20;
  FDefaultMenuItemFont := TFont.Create;
  with FDefaultMenuItemFont do
  begin
    Name := '宋體';
    Style := [];
    Height := 14;
  end;
end;

destructor TbsSkinMenu.Destroy;
begin
  CloseMenu(0);
  FPopupList.Free;
  WaitTimer.Free;
  FDefaultMenuItemFont.Free;
  inherited Destroy;
end;

procedure TbsSkinMenu.SetDefaultMenuItemFont(Value: TFont);
begin
  FDefaultMenuItemFont.Assign(Value);
end;

function TbsSkinMenu.GetWorkArea;
begin
  Result := GetMonitorWorkArea(FForm.Handle, True);
end;

procedure TbsSkinMenu.WaitItem(Sender: TObject);
begin
  if WItem <> nil then CheckItem(WItem.Parent, WItem, True, False);
  WaitTimer.Enabled := False;
end;

function TbsSkinMenu.GetPWIndex;
var
  i: Integer;
begin
  for i := 0 to FPopupList.Count - 1 do
    if PW = TbsSkinPopupWindow(FPopupList.Items[i]) then Break;
  Result := i;
end;

procedure TbsSkinMenu.CheckItem;
var
  Menu: TMenu;
  MenuI: TMenuItem;
  i: Integer;
  R: TRect;
begin
  if (MI.MenuItem.Count = 0) and not Down
  then
    begin
      WaitTimer.Enabled := False;
      WItem := nil;
      i := GetPWIndex(PW);
      if i < FPopupList.Count - 1 then CloseMenu(i + 1);
    end
  else
  if (MI.MenuItem.Count = 0) and Down
  then
    begin
      WaitTimer.Enabled := False;
      WItem := nil;
      MenuI := MI.MenuItem;
      Hide;
      //
      Menu := MenuI.GetParentMenu;
      Menu.DispatchCommand(MenuI.Command);
   

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品欧美久久久久一区二区| 免费的成人av| 精品制服美女丁香| 91亚洲精品久久久蜜桃| 精品sm捆绑视频| 亚洲综合色丁香婷婷六月图片| 国产激情91久久精品导航| 欧美日本精品一区二区三区| 国产精品成人免费| 激情图片小说一区| 日韩一区二区精品在线观看| 亚洲午夜激情网站| 91免费版在线| 国产精品家庭影院| 成人激情图片网| 国产婷婷色一区二区三区在线| 日韩电影在线看| 欧洲精品视频在线观看| 亚洲女子a中天字幕| 成人深夜在线观看| 国产精品久线在线观看| 国产一区 二区 三区一级| 日韩欧美一区二区在线视频| 亚洲电影第三页| 精品视频999| 午夜精品久久久久久久 | 亚洲精品视频免费观看| 成人一级黄色片| 欧美激情资源网| 国产91精品一区二区麻豆网站 | 日韩一区日韩二区| 成人禁用看黄a在线| 国产精品美女久久久久久2018| 国产精品911| 欧美经典一区二区| 不卡影院免费观看| 国产亲近乱来精品视频| 成人av免费在线播放| 亚洲乱码国产乱码精品精98午夜 | 欧美变态tickling挠脚心| 免费观看日韩电影| 久久综合久久综合久久综合| 国产盗摄视频一区二区三区| 国产精品天干天干在线综合| 99精品国产视频| 自拍偷拍亚洲欧美日韩| 欧美视频日韩视频| 日本不卡免费在线视频| 久久综合色婷婷| 成人性色生活片| 丝袜美腿亚洲综合| 欧美一三区三区四区免费在线看| 日韩不卡手机在线v区| 日韩手机在线导航| 国产精品996| 亚洲尤物在线视频观看| 日韩天堂在线观看| 成人污视频在线观看| 亚洲一区二区三区四区五区黄| 欧美一区二区在线免费播放| 精彩视频一区二区| 亚洲私人影院在线观看| 欧美日韩亚洲综合在线| 国产精品123| 亚洲va韩国va欧美va| 久久这里都是精品| 欧美在线观看你懂的| 麻豆精品视频在线观看视频| 亚洲欧美综合色| 欧美一二三区在线观看| 99久免费精品视频在线观看| 日日摸夜夜添夜夜添亚洲女人| 日本一区二区三区国色天香 | 99国产一区二区三精品乱码| 午夜精品一区二区三区三上悠亚| 国产亚洲综合av| 91麻豆精品国产91久久久资源速度 | 激情综合色综合久久综合| 亚洲天堂2016| 久久九九影视网| 欧美一级二级三级乱码| 99久久国产免费看| 国产麻豆视频一区二区| 亚洲制服丝袜一区| 欧美国产日韩在线观看| 欧美大片免费久久精品三p| 在线观看视频欧美| 高清shemale亚洲人妖| 蜜臀91精品一区二区三区 | 欧洲中文字幕精品| 国产99精品国产| 久久精品久久综合| 亚洲r级在线视频| 午夜欧美视频在线观看| 最近中文字幕一区二区三区| 337p粉嫩大胆色噜噜噜噜亚洲 | 日韩精品中文字幕一区| 欧美日韩国产首页在线观看| 国产麻豆91精品| 韩国一区二区视频| 日本少妇一区二区| 视频一区视频二区中文| 一区二区三区在线影院| 国产精品对白交换视频 | 丁香激情综合国产| 国产精品一区专区| 国内外成人在线| 久久国产婷婷国产香蕉| 久久精品国产第一区二区三区| 三级不卡在线观看| 亚洲成av人片一区二区三区| 亚洲精品成人少妇| 亚洲另类色综合网站| 亚洲精品写真福利| 亚洲国产另类av| 日韩精品久久久久久| 日本欧美在线观看| 日本伊人精品一区二区三区观看方式 | 亚洲美女偷拍久久| 亚洲视频一区二区在线| 亚洲另类在线制服丝袜| 亚洲制服丝袜av| 日韩专区在线视频| 丝袜国产日韩另类美女| 美女高潮久久久| 国内精品伊人久久久久av影院| 国产一区二区三区观看| 国产91精品在线观看| a美女胸又www黄视频久久| 色噜噜久久综合| 91精品国产综合久久久久久久久久| 欧美日韩亚州综合| 欧美电影免费观看高清完整版在线观看 | 91麻豆精品国产91久久久更新时间 | 欧美精品vⅰdeose4hd| 精品国产免费一区二区三区香蕉| 欧美成人免费网站| 国产精品乱人伦中文| 一区二区三区中文字幕| 日本不卡一区二区| 国产精品一卡二卡在线观看| 暴力调教一区二区三区| 欧美性高清videossexo| 日韩欧美中文字幕公布| 国产精品福利av| 日韩成人午夜精品| 成人亚洲精品久久久久软件| 色欧美片视频在线观看| 日韩精品中文字幕在线不卡尤物| 国产精品天干天干在观线| 亚洲bt欧美bt精品| 高清不卡在线观看| 精品婷婷伊人一区三区三| 久久久久国产精品厨房| 亚洲国产成人porn| 国产jizzjizz一区二区| 欧美精品久久天天躁| 国产精品丝袜一区| 蜜桃视频第一区免费观看| 99热99精品| 26uuuu精品一区二区| 视频一区欧美精品| 91麻豆精品秘密| 不卡的av中国片| 欧美日本乱大交xxxxx| 在线成人av影院| 美女网站在线免费欧美精品| 狠狠色综合日日| 555夜色666亚洲国产免| 亚洲欧美日韩小说| 国产精品一区免费视频| 欧美做爰猛烈大尺度电影无法无天| 久久久久久久久一| 日韩电影在线免费看| 欧美日本在线看| 亚洲成a人在线观看| 91精品麻豆日日躁夜夜躁| 国产精品一品二品| 一本色道久久综合精品竹菊| 国产亚洲精品7777| 蜜臂av日日欢夜夜爽一区| 欧美日韩精品一区二区| 一区二区三区四区不卡在线 | 天堂影院一区二区| 成人黄色大片在线观看| 久久众筹精品私拍模特| 久久精品国产网站| 欧美一区二区三区在| 日韩激情视频在线观看| 欧美日韩视频一区二区| 亚洲高清久久久| 欧美午夜精品理论片a级按摩| 中文字幕在线免费不卡| 不卡视频一二三| 中文字幕成人在线观看| 成人黄色国产精品网站大全在线免费观看 | 欧美无砖砖区免费| 亚洲高清免费视频| 在线观看91精品国产麻豆| 三级一区在线视频先锋|