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


Control.DragEnter Событие

Определение

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

public:
 event System::Windows::Forms::DragEventHandler ^ DragEnter;
public event System.Windows.Forms.DragEventHandler DragEnter;
public event System.Windows.Forms.DragEventHandler? DragEnter;
member this.DragEnter : System.Windows.Forms.DragEventHandler 
Public Custom Event DragEnter As DragEventHandler 

Тип события

Примеры

В следующем примере кода демонстрируется операция перетаскивания между двумя элементами управления 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.

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

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

Комментарии

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

Заметка

В версиях, предшествующих .NET Framework 2.0, если вы помещаете UserControl с DragEnter и DragDrop события в Форме Windows и перетаскиваете что-то на UserControl во время разработки, возникают DropDrop и DropEnter события. Однако при закрытии и повторном открытии решения DragEnter и DragDrop события не вызываются снова.

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

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

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

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

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

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

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

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

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

    Заметка

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

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

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

    Заметка

    Свойства X и YDragEventArgs находятся в координатах экрана, а не в координатах клиента. Следующая строка кода Visual C# преобразует свойства в клиентские Point.

    Point clientPoint = targetControl.PointToClient(new Point(de.X, de.Y));
    

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

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

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