如何制作可隨處拖放的工具欄
發(fā)表時間:2024-06-20 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]在我們經(jīng)常使用的軟件,比如photoshop,office,delphi等等,我們經(jīng)常可以對工具欄進(jìn)行拖拽操作----將相關(guān)的工具欄拖拉出來,形成獨立的小窗口;或者將幾個工具欄進(jìn)行互相的組合。ㄟ@些就是我們常說的DOCK功能). 其實,利用DELPHI或是其它的可視化編程工具(如c++ buil...
在我們經(jīng)常使用的軟件,比如photoshop,office,delphi等等,我們經(jīng)?梢詫ぞ邫谶M(jìn)行拖拽操作----將相關(guān)的工具欄拖拉出來,形成獨立的小窗口;或者將幾個工具欄進(jìn)行互相的組合。ㄟ@些就是我們常說的DOCK功能).
其實,利用DELPHI或是其它的可視化編程工具(如c++ builder等)很容易實現(xiàn)上面的功能!下面,我們通過一個小例子來看看它是如何實現(xiàn)的,這里使用的編程工具為Delphi!
開始實例前,先要說明些東東。ㄖv些廢話先^_^)
可視化的VCL元件皆支持DOCK功能!
在delphi中,所有繼承自Tcontrol及TWinControl的VCL元件,都支持dock功能。
基本上,要進(jìn)行dock動作至少需要兩個元件,一個是被附著的dock site元件,另一個是附著在dock site的元件。DELPHI所提供的可視化元件中只有繼承自TWinControl的VCL元件才具有dock site的功能,而只要是繼承自Tcontrol的VCL元件則都具有附著在dock site的功能。
* 如果你希望某個繼承自TWinControl的元件具有dock site的功能,只要把該元件的屬性DockSite設(shè)成true即可;
* 若是要把某個繼承自TControl的元件附著在dock site上,只要把屬性Drag kind設(shè)成dkDock、屬性DragMode設(shè)成dmAutomatic即可,
當(dāng)程序執(zhí)行后,你就可以利用鼠標(biāo)把后者元件拖拉到前者元件上,進(jìn)行dock動作。至于dock的實際動作都被封裝在元件內(nèi),用戶根本不用管這些動作是如何進(jìn)行的。
馬上開始我們的實例!
新建一個普通的工程(project1),從win32控件頁中拖拉一個CoolBar,一個ToolBar,一個ImageList到form1窗體中,屬性設(shè)置如下:
Form1
.Caption: 實例一DOCK功能的實現(xiàn);
CoolBar1(被附著的dock site元件)
.AutoSize: true;
.DockSite: true;
為了一些更好的效果,你可以對BorderWidth,EdgeBorders,EdgeInner, EdgeOuter,進(jìn)行相關(guān)的設(shè)置!
ToolBar1(附著在dock site的元件)
在ToolBar1元件上點擊右鍵,選擇New Button,新建一些按鈕,它們之間可以通過New Separator,進(jìn)行相關(guān)組的分隔!
.Caption: 工具欄(獨立出來時窗口顯示的標(biāo)題)
.AutoSize: true;
.DockKind: dkDock;
.DragMode: dmAutomatic;
.Flat: ture;(這樣好看些)
.Images: ImageList1;
同樣為了一些更好的效果,你可以對BorderWidth,EdgeBorders,EdgeInner, EdgeOuter,進(jìn)行相關(guān)的設(shè)置!
ImageList1,
雙擊該控件,選擇Add…,添加幾幅圖片。這樣,可以很方便地將這些圖片賦于ToolBar中的Button!
點擊運行按鈕,你拖拽下你的工具欄,是不是馬上就可以看到效果啦?我們還沒有編寫一行代碼呢????這就是Delphi的強大之處!
為了更好地進(jìn)行拖拽操作,我們添加下面幾行代碼!(主要是CoolBar1的onDragOver、onDockDrop和UnDock事件);
unit sample1;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
ImgList, ComCtrls, ToolWin;
type
TForm1 = class(TForm)
ImageList1: TImageList;
CoolBar1: TCoolBar;
ToolBar1: TToolBar;
ToolButton1: TToolButton;
ToolButton2: TToolButton;
ToolButton3: TToolButton;
ToolButton4: TToolButton;
ToolButton5: TToolButton;
ToolButton6: TToolButton;
ToolButton7: TToolButton;
procedure CoolBar1DragOver(Sender, Source: TObject; X, Y: Integer;
State: TDragState; var Accept: Boolean);
procedure CoolBar1DockDrop(Sender: TObject; Source: TDragDockObject; X,
Y: Integer);
procedure CoolBar1UnDock(Sender: TObject; Client: TControl;
NewTarget: TWinControl; var Allow: Boolean);
procedure ToolButton1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.DFM}
procedure TForm1.CoolBar1DragOver(Sender, Source: TObject; X, Y: Integer;
State: TDragState; var Accept: Boolean);
begin
Accept:=(source=ToolBar1); //指定接受拖拽操作的條件是拖拽對象為ToolBar1;
end;
procedure TForm1.CoolBar1DockDrop(Sender: TObject; Source: TDragDockObject;
X, Y: Integer);
begin
ToolBar1.AutoSize:=false; //當(dāng)元件拖到dock site元件上面,并且放開鼠標(biāo)左鍵之后,此事件就會被執(zhí)行
ToolBar1.Align:=altop; //為了便于拖拽,將toolbar1的寬度與coolbar1相近.
ToolBar1.Width:=CoolBar1.Width-1;
end;
procedure TForm1.CoolBar1UnDock(Sender: TObject; Client: TControl;
NewTarget: TWinControl; var Allow: Boolean);
begin
ToolBar1.AutoSize:=true; //當(dāng)元件一拖離dock site元件時,此事就會被執(zhí)行
ToolBar1.Caption:='工具欄'; //設(shè)定獨立工具欄窗口的大小和標(biāo)題
end;
procedure TForm1.ToolButton1Click(Sender: TObject);
begin
Close; //退出程序
end;
end.
下面列出與DOCK功能有關(guān)的事件:
OnDragDrop: 當(dāng)元件被拖動時,此事件被執(zhí)行;
OnDragOver: 用于指定元件可以被拖動的條件;
OnDockDrop: 當(dāng)元件拖到dock site元件上面,并且放開鼠標(biāo)左鍵之后,此事件就會被執(zhí)行;
OnDockOver:當(dāng)元件一拖到dock site元件上,此事件就會被執(zhí)行;
OnUnDock:當(dāng)元件一拖離dock site元件時,此事就會被執(zhí)行;
OnGetSiteInfo:取得dock site元件的一些信息。
好了,通過一個小小的拖放工具欄的例子,我們馬上就可以體會到Delphi的易用與強大之處!以后我會繼續(xù)寫一些關(guān)于用Delphi進(jìn)行實例編程的文章!各位Delphi愛好者,大家將Delphi進(jìn)行到底吧!小生水平有限,如有不對之處,請各位網(wǎng)友指出!謝謝! aatun@163.net