Control.DragLeave 事件

在将对象拖出控件的边界时发生。

**命名空间:**System.Windows.Forms
**程序集:**System.Windows.Forms(在 system.windows.forms.dll 中)

语法

声明
Public Event DragLeave As EventHandler
用法
Dim instance As Control
Dim handler As EventHandler

AddHandler instance.DragLeave, handler
public event EventHandler DragLeave
public:
event EventHandler^ DragLeave {
    void add (EventHandler^ value);
    void remove (EventHandler^ value);
}
/** @event */
public void add_DragLeave (EventHandler value)

/** @event */
public void remove_DragLeave (EventHandler value)
JScript 支持使用事件,但不支持进行新的声明。

备注

当用户将光标拖出控件或取消当前的拖放操作时,会引发 DragLeave 事件。

下面描述与拖放操作相关的事件的引发方式以及引发时间。

DoDragDrop 方法确定当前光标位置下的控件。然后它将检查该控件是否是有效的放置目标。

如果该控件是有效的放置目标,则 GiveFeedback 事件以指定的拖放效果引发。有关拖放效果的列表,请参阅 DragDropEffects 枚举。

跟踪鼠标光标位置、键盘状态和鼠标按钮状态的更改。

  • 如果用户移出一个窗口,则引发 DragLeave 事件。

  • 如果鼠标进入另一个控件,则引发该控件的 DragEnter

  • 如果鼠标移动但停留在同一个控件中,则引发 DragOver 事件。

如果更改了键盘或鼠标按钮状态,则引发 QueryContinueDrag 事件并根据事件的 QueryContinueDragEventArgsAction 属性值确定是否继续拖动、放置数据或取消操作。

  • 如果 DragAction 的值为 Continue,将引发 DragOver 事件以继续该操作,并引发 GiveFeedback 事件,同时产生新效果,以便能够设置适当的可视反馈。有关有效放置效果的列表,请参见 DragDropEffects 枚举。

    提示

    DragOverGiveFeedback 事件成对出现,从而当鼠标从放置目标上移动时,就能够为用户提供有关鼠标位置的最新反馈。

  • 如果 DragAction 的值为 Drop,放置效果值将恢复成源值,以便源应用程序可以对源数据执行适当的操作;例如,如果是移动操作,则剪切数据。

  • 如果 DragAction 的值为 Cancel,将引发 DragLeave 事件。

有关处理事件的更多信息,请参见 使用事件

示例

下面的代码示例演示在两个 ListBox 控件之间的拖放操作。当拖动动作启动时,该示例调用 DoDragDrop 方法。在 MouseDown 事件期间,如果从鼠标位置起鼠标移动的距离大于 SystemInformation.DragSize,则启动拖动动作。IndexFromPoint 方法用于在 MouseDown 事件期间确定要拖动的项的索引。

该示例同时演示了对拖放操作使用自定义光标。该示例要求应用程序目录中存在两个光标文件:3dwarro.cur3dwno.cur,分别用于自定义拖动光标和禁止停放光标。如果选中 UseCustomCursorsCheckCheckBox,则使用自定义光标。自定义光标在 GiveFeedback 事件处理程序中设置。

键盘状态在右 ListBoxDragOver 事件处理程序中计算,以确定基于 Shift、Ctrl、Alt 或 Ctrl+Alt 键的状态将发生哪种拖动操作。放置动作在 ListBox 中发生的位置也在 DragOver 事件期间确定。如果要放置的数据不是 String,则 DragDropEffects 中将把 DragEventArgs.Effect 设置为 None。最后,停放状态在 DropLocationLabelLabel 中显示。

要放置的用于右 ListBox 的数据在 DragDrop 事件处理程序中确定,并且在 ListBox 中的适当位置添加该 String 值。如果拖动操作移动到窗体边框的外面,则 QueryContinueDrag 事件处理程序中将取消拖放操作。

这段代码摘录演示了 DragLeave 事件的用法。有关完整的代码实例,请参见 DoDragDrop 方法。

Private Sub ListDragTarget_DragLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles ListDragTarget.DragLeave

    ' Reset the label text.
    DropLocationLabel.Text = "None"
End Sub
private void ListDragTarget_DragLeave(object sender, System.EventArgs e) {
    // Reset the label text.
    DropLocationLabel.Text = "None";
}
void ListDragTarget_DragLeave( Object^ /*sender*/, System::EventArgs^ /*e*/ )
{
  // Reset the label text.
   DropLocationLabel->Text = "None";
}
private void listDragTarget_DragLeave(Object sender, System.EventArgs e)
{
    // Reset the label text.
    dropLocationLabel.set_Text("None");
} //listDragTarget_DragLeave

平台

Windows 98、Windows 2000 SP4、Windows CE、Windows Millennium Edition、Windows Mobile for Pocket PC、Windows Mobile for Smartphone、Windows Server 2003、Windows XP Media Center Edition、Windows XP Professional x64 Edition、Windows XP SP2、Windows XP Starter Edition

.NET Framework 并不是对每个平台的所有版本都提供支持。有关受支持版本的列表,请参见系统要求

版本信息

.NET Framework

受以下版本支持:2.0、1.1、1.0

请参见

参考

Control 类
Control 成员
System.Windows.Forms 命名空间
OnDragLeave