Поделиться через


Control.DragLeave Событие

Определение

Происходит при перетаскивании объекта из границ элемента управления.

public:
 event EventHandler ^ DragLeave;
public event EventHandler DragLeave;
public event EventHandler? DragLeave;
member this.DragLeave : EventHandler 
Public Custom Event DragLeave As EventHandler 

Тип события

Примеры

В следующем примере кода демонстрируется операция перетаскивания между двумя элементами управления ListBox. В примере вызывается метод DoDragDrop при запуске действия перетаскивания. Действие перетаскивания начинается, если мышь перемещает больше SystemInformation.DragSize из расположения мыши во время события MouseDown. Метод IndexFromPoint используется для определения индекса элемента для перетаскивания во время события MouseDown.

В примере также показано использование пользовательских курсоров для операции перетаскивания. В примере требуется, чтобы два файла курсора, 3dwarro.cur и 3dwno.cur, существуют в каталоге приложения для настраиваемых курсоров перетаскивания и без перетаскивания соответственно. Пользовательские курсоры будут использоваться при проверке UseCustomCursorsCheckCheckBox. Пользовательские курсоры задаются в обработчике событий GiveFeedback.

Состояние клавиатуры вычисляется в обработчике событий DragOver для правой ListBox, чтобы определить, какая операция перетаскивания будет зависеть от состояния клавиш SHIFT, CTRL, ALT или CTRL+ALT. Расположение в ListBox, где будет происходить удаление, также определяется во время события DragOver. Если данные для удаления не являются String, DragEventArgs.Effect устанавливается None в DragDropEffects. Наконец, состояние удаления отображается в DropLocationLabelLabel.

Данные, которые нужно удалить для правой ListBox, определяются в обработчике событий DragDrop, а значение String добавляется в соответствующее место в ListBox. Если операция перетаскивания перемещается за пределы формы, операция перетаскивания отменяется в обработчике событий QueryContinueDrag.

Этот фрагмент кода демонстрирует использование события DragLeave. См. метод DoDragDrop для полного примера кода.

void ListDragTarget_DragLeave( Object^ /*sender*/, System::EventArgs^ /*e*/ )
{
  // Reset the label text.
   DropLocationLabel->Text = "None";
}
private void ListDragTarget_DragLeave(object sender, EventArgs e)
{
    // Reset the label text.
    DropLocationLabel.Text = "None";
}
Private Sub ListDragTarget_DragLeave(ByVal sender As Object, ByVal e As EventArgs) Handles ListDragTarget.DragLeave
    ' Reset the label text.
    DropLocationLabel.Text = "None"
End Sub

Комментарии

Событие DragLeave возникает, когда пользователь перетаскивает курсор из элемента управления или пользователь отменяет текущую операцию перетаскивания.

Ниже описывается, как и когда возникают события, связанные с операциями перетаскивания.

Метод DoDragDrop определяет элемент управления в текущем расположении курсора. Затем он проверяет, является ли элемент управления допустимым целевым объектом удаления.

Если элемент управления является допустимым объектом удаления, событие GiveFeedback вызывается с заданным эффектом перетаскивания. Список эффектов перетаскивания см. в перечислении DragDropEffects.

Отслеживаются изменения положения курсора мыши, состояния клавиатуры и кнопки мыши.

  • Если пользователь выходит из окна, вызывается событие DragLeave.

  • Если мышь входит в другой элемент управления, вызывается DragEnter для этого элемента управления.

  • Если мышь перемещается, но остается в одном элементе управления, вызывается событие DragOver.

При изменении состояния клавиатуры или кнопки мыши вызывается событие QueryContinueDrag и определяет, следует ли продолжать перетаскивание, удалять данные или отменять операцию на основе значения свойства ActionQueryContinueDragEventArgsсобытия.

  • Если значение DragAction равно Continue, событие DragOver вызывается для продолжения операции, а событие GiveFeedback вызывается с новым эффектом, чтобы можно было задать соответствующую визуальную обратную связь. Список допустимых эффектов удаления см. в перечислении DragDropEffects.

    Заметка

    События DragOver и GiveFeedback связаны таким образом, чтобы при перемещении мыши по целевому объекту удаления пользователь получил наиболее up-to-date отзыв о положении мыши.

  • Если значение DragAction равно Drop, значение эффекта удаления возвращается источнику, поэтому исходное приложение может выполнить соответствующую операцию с исходными данными; Например, вырезать данные, если операция была перемещением.

  • Если значение DragAction равно Cancel, вызывается событие DragLeave.

Дополнительные сведения об обработке событий см. в обработке и вызове событий.

Применяется к

См. также раздел