当前位置:萝卜系统下载站 > 技术开发教程 > 详细页面

第9章 Delphi拖放编程

第9章 Delphi拖放编程

更新时间:2022-07-12 文章作者:未知 信息来源:网络 阅读次数:

拖放(DragDrop)是Windows提供的一种快捷的操作方式。作为基于Windows的开发工具,Delphi同样支持拖放操作,而且开发应用系统的拖放功能十分方便,真正体现了Delphi的强大功能和方便性。
  Delphi提供的所有控件(Control,即能获得输入焦点的部件)都支持拖放操作,并有相应的拖放属性、拖放事件和拖放方法。下面我们先介绍控件的拖放支持,而后再给出开发拖放操作的一般步骤和应用实例。 

  9.1 控件的拖放支持 

  拖放操作中控件可以分为源控件和目标控件两类。绝大部分控件既可以作为源控件也可以作为目标控件。但也有一部分控件只能支持其中的一种。 

  9.1.1 拖放属性 

  拖放属性主要有两个:

  ● DragMode : 拖动模式

  ● DragCursor : 拖动光标 

  它们都是在拖放的源控件中设置。DragMode控制用户在运行时间内当在控件上按下鼠标时控件如何反应。如果DragMode置为dmAutomatic,那么当用户在控件上按下鼠标时拖动自动开始;如果DragMode置为dmManual(这是缺省值),则将通过处理鼠标事件来判断一个拖动是否可以开始。

  DragCursor用于选择拖动时显示的光标,缺省值是CrDrag,一般不要去修改它。在程序设计过程中通用的界面规范应该得到开发者的尊重。但有时候为了特定的目的,开发者也可以把自己设计的光标赋给DragCursor。 

  9.1.2 拖放事件 

  拖放事件主要有三个:

  ●OnDragOver:拖动经过时激发

  ●OnDragDrop:拖动放下时激发

  ●OnEndDrop :拖动结束时激发 

  前两个事件由目标控件响应,后一个事件由源控件响应。

  OnDragOver事件最主要的功能是确定当用户就地放下拖动时控件是否可以接受。它的参数包括: 

  Source : TObject;  {源控件}

  X,Y : Integer; {光标位置}

  State : TDragState; {拖动状态}

  var Accept : Boolean {能否接受} 

  TDragState是一个枚举类型,表示拖放项目与目标控件的关系。 

   type

  TDragState = (dsDragEnter, dsDragLeave, dsDragMove);

  不同取值的意义如下表:

  表9.1 DragState 的取值与意义

  ━━━━━━━━━━━━━━━━━━━━━━━━━━━

  取 值 意 义

  ───────────────────────────

  dsDragEnter 拖动对象进入一个允许拖动对象放下

  的控件中。为缺省状态。

  dsDragLeave 拖动对象离开一个允许拖动对象放下

  的控件。

  dsDragMove 拖动对象在一个允许拖动对象放下的

  控件内移动。

  ━━━━━━━━━━━━━━━━━━━━━━━━━━━  

  用户可以利用提供的参数来确定放下的拖动是否可被接受,如:

  ● 判断源控件类型: 

   Accept := Source is TLabel;

  ● 判断源控件对象: 

   Accept := (Source = TabSet1);

  ● 判断光标位置:

  见(9.2),(9.3)中的例程。 

  ● 判断拖动状态: 

   If (Source is TLabel) and (State = dsDragMove) then

   begin

  source.DragIcon := ' New.Ico ';

  Accept := True;

   end

   else

   Accept := False;

  当Accept=True时,目标控件可以响应OnDragDrop事件,用于确定拖动被放下后程序如何进行处理。

  OnDragDrop事件处理过程的参数包括源控件和光标位置。这些信息可用于处理方式的确定。

  OnEndDrag事件是在拖动操作结束后由源控件来进行响应的,用于源控件进行相应的处理。拖动操作结束既包括拖动放下被接受,也包括用户在一个不能接受放下的控件上释放了鼠标。该事件处理过程的参数包括目标控件(Target)和放下位置的坐标。如果Target=nil, 表示拖动项目没有被任何控件接受。

  在第3节将介绍的文件拖放移动、拖放拷贝操作中,如果操作成功,则文件列表框应更新显示内容。下面这段程序用于实现这一功能。 

  procedure TFMForm.FileListEndDrag(Sender, Target: TObject; X, Y: Integer);

  begin

  if Target <> nil then FileList.Update;

  end;

  除以上介绍的三个事件外,还有一个事件onMouseDown 也常用于拖放操作的响应。onMouseDown虽然不是一个专门的拖放事件,但在人工模式下拖动的开始是在这一事件的处理过程中实现的。 

  9.1.3 拖放方法 

  拖放方法有三个:

  ●BeginDrag : 人工方式下开始一个拖动

  ●EndDrag : 结束一个拖动

  ●Dragging : 判断一个控件是否正被拖动 

  这三个方法都被源控件使用。

  当DragMode置为dmManual时,拖动必须调用控件的BeginDrag方法才能开始。BeginDrag有一个布尔参数Immediate。如果输入参数为True,拖动立即开始,光标改变到DragCursor的设置。如果输入参数为False,直到用户将光标移动了一定的距离(5个象素点)后才改变光标,开始拖动。这就允许控件接受一个onClick事件而并不开始拖动操作。

  EndDrag方法中止一个对象的被拖动状态。它有一个布尔参数Drop。如果Drop设置为True,被拖动的对象在当前位置放下(能否被接受由目标控件决定);如果Drop设置为False,则拖动就地被取消。

  下面一段程序表明当拖动进入一控制面板时拖动被取消。     

  procedure TForm1.Panel1DragOver(Sender, Source: TObject; X, Y: Integer;

  State: TDragState; var Accept: Boolean);

  begin

  Accept := False;

  if (Source is TLabel) and (State = dsDragEnter) then

  (Source as TLabel).EndDrag(False);

  end;

  Draging方法判断一个控件是否正被拖动。在下面的例子中当用户拖动不同的检查框时窗口改变为不同的颜色。 

  procedure TForm1.FormActivate(Sender: TObject);

  begin

  CheckBox1.DragMode := dmAutomatic;

  CheckBox2.DragMode := dmAutomatic;

  CheckBox3.DragMode := dmAutomatic;

  end; 

  procedure TForm1.FormDragOver(Sender, Source: TObject; X, Y: Integer;

  State: TDragState; var Accept: Boolean);

  begin

  if CheckBox1.Dragging then

  Color := clAqua;

  if CheckBox2.Dragging then

  Color := clYellow;

  if CheckBox3.Dragging then

  Color := clLime;

  end; 

  9.2 开发拖放功能的一般步骤 

  拖放作为Windows提供的一种方便操作对象的功能,在Delphi中可以很容易地开发出来。根据拖放操作的过程可以把开发步骤划分为四个阶段,即:

  ● 开始拖动操作

  ● 接收拖动项目

  ● 放下拖动项目

  ● 终止拖动操作 

  在介绍过程中我们将结合一个TabSet(标签集)的拖放操作实例。界面设计如图。在运行时当用户把一个标签拖动到另一个标签的位置时,该标签将移动到该位置并引起标签集的重新布置。

  9.2.1 开始拖动操作 

  当拖动模式(DragMode)设置为dmAutomatic时,用户在源控件上按下鼠标时拖动自动开始;当设置为dmManual时通过处理鼠标事件来决定拖动是否开始。如果想开始拖动调用BeginDrag方法。

  在TabSet拖放中,我们用下面的MouseDown事件处理过程来开始一个标签的拖动。首先判断按下的是否是左键,而后再判断项目是否合法。 

  procedure TForm1.TabSet1MouseDown(Sender: TObject; Button: TMouseButton;

  Shift: TShiftState; X, Y: Integer);

  var

  DragItem: Integer;

  begin

  if Button = mbLeft then

  begin

  DragItem := TabSet1.ItemAtPos(Point(X, Y));

  if (DragItem > -1) and (DragItem < tabset1.tabs.count)="" then="">

  TabSet1.BeginDrag(False);

  end;

  end; 

  

[1] [2]  下一页

温馨提示:喜欢本站的话,请收藏一下本站!

本类教程下载

系统下载排行

网站地图xml | 网站地图html