Control.QueryContinueDrag Событие

Определение

Происходит во время операции перетаскивания и позволяет источнику перетаскивания определить, следует ли отменить эту операцию.Occurs during a drag-and-drop operation and enables the drag source to determine whether the drag-and-drop operation should be canceled.

public:
 event System::Windows::Forms::QueryContinueDragEventHandler ^ QueryContinueDrag;
public event System.Windows.Forms.QueryContinueDragEventHandler QueryContinueDrag;
member this.QueryContinueDrag : System.Windows.Forms.QueryContinueDragEventHandler 
Public Custom Event QueryContinueDrag As QueryContinueDragEventHandler 

Примеры

Этот фрагмент кода демонстрирует использование события QueryContinueDrag для отмены операции перетаскивания, если операция перетаскивания выходит за границы формы.This code excerpt demonstrates using the QueryContinueDrag event to cancel the drag-and-drop operation if the drag operation moves outside the bounds of the form. Полный пример кода см. в описании метода DoDragDrop.See the DoDragDrop method for the complete code example.

void ListDragSource_QueryContinueDrag( Object^ sender, System::Windows::Forms::QueryContinueDragEventArgs^ e )
{
   // Cancel the drag if the mouse moves off the form.
   ListBox^ lb = dynamic_cast<ListBox^>(sender);
   if ( lb != nullptr )
   {
      Form^ f = lb->FindForm();

      // Cancel the drag if the mouse moves off the form. The screenOffset
      // takes into account any desktop bands that may be at the top or left
      // side of the screen.
      if ( ((Control::MousePosition.X - screenOffset.X) < f->DesktopBounds.Left) || ((Control::MousePosition.X - screenOffset.X) > f->DesktopBounds.Right) || ((Control::MousePosition.Y - screenOffset.Y) < f->DesktopBounds.Top) || ((Control::MousePosition.Y - screenOffset.Y) > f->DesktopBounds.Bottom) )
      {
         e->Action = DragAction::Cancel;
      }
   }
}
private void ListDragSource_QueryContinueDrag(object sender, System.Windows.Forms.QueryContinueDragEventArgs e) {
    // Cancel the drag if the mouse moves off the form.
    ListBox lb = sender as ListBox;

    if (lb != null) {

        Form f = lb.FindForm();

        // Cancel the drag if the mouse moves off the form. The screenOffset
        // takes into account any desktop bands that may be at the top or left
        // side of the screen.
        if (((Control.MousePosition.X - screenOffset.X) < f.DesktopBounds.Left) ||
            ((Control.MousePosition.X - screenOffset.X) > f.DesktopBounds.Right) ||
            ((Control.MousePosition.Y - screenOffset.Y) < f.DesktopBounds.Top) ||
            ((Control.MousePosition.Y - screenOffset.Y) > f.DesktopBounds.Bottom)) {

            e.Action = DragAction.Cancel;
        }
    }
}
Private Sub ListDragSource_QueryContinueDrag(ByVal sender As Object, ByVal e As QueryContinueDragEventArgs) Handles ListDragSource.QueryContinueDrag
    ' Cancel the drag if the mouse moves off the form.
    Dim lb as ListBox = CType(sender, System.Windows.Forms.ListBox)

    If (lb isNot nothing) Then

        Dim f as Form = lb.FindForm()

        ' Cancel the drag if the mouse moves off the form. The screenOffset
        ' takes into account any desktop bands that may be at the top or left
        ' side of the screen.
        If (((Control.MousePosition.X - screenOffset.X) < f.DesktopBounds.Left) Or _
            ((Control.MousePosition.X - screenOffset.X) > f.DesktopBounds.Right) Or _
            ((Control.MousePosition.Y - screenOffset.Y) < f.DesktopBounds.Top) Or _
            ((Control.MousePosition.Y - screenOffset.Y) > f.DesktopBounds.Bottom)) Then

            e.Action = DragAction.Cancel
        End If
    End if
End Sub

Комментарии

Событие QueryContinueDrag возникает при изменении состояния клавиатуры или кнопки мыши во время операции перетаскивания.The QueryContinueDrag event is raised when there is a change in the keyboard or mouse button state during a drag-and-drop operation. Событие QueryContinueDrag позволяет источнику перетаскивания определить, следует ли отменить операцию перетаскивания.The QueryContinueDrag event enables the drag source to determine whether the drag-and-drop operation should be canceled.

Далее описывается, как и когда возникают события, связанные с операциями перетаскивания.The following describes how and when events related to drag-and-drop operations are raised.

Метод DoDragDrop определяет элемент управления под текущим местоположением курсора.The DoDragDrop method determines the control under the current cursor location. Затем он проверяет, является ли элемент управления допустимым целевым объектом перетаскивания.It then checks to see if the control is a valid drop target.

Если элемент управления является допустимым целевым объектом перетаскивания, то событие GiveFeedback вызывается с указанными действиями перетаскивания.If the control is a valid drop target, the GiveFeedback event is raised with the drag-and-drop effect specified. Список эффектов перетаскивания см. в перечислении DragDropEffects.For a list of drag-and-drop effects, see the DragDropEffects enumeration.

Отслеживаются изменения позиции указателя мыши, состояния клавиатуры и кнопки мыши.Changes in the mouse cursor position, keyboard state, and mouse button state are tracked.

  • Если пользователь перемещает указатель мыши за пределы окна, происходит событие DragLeave.If the user moves out of a window, the DragLeave event is raised.

  • Если указатель мыши перемещается на другой элемент управления, для этого элемента вызывается событие DragEnter.If the mouse enters another control, the DragEnter for that control is raised.

  • При перемещении мыши в пределах одного элемента управления возникает событие DragOver.If the mouse moves but stays within the same control, the DragOver event is raised.

При изменении состояния клавиатуры или кнопки мыши возникает событие QueryContinueDrag и определяет, следует ли продолжить перетаскивание, для удаления данных или отмены операции на основе значения свойства Action события QueryContinueDragEventArgs.If there is a change in the keyboard or mouse button state, the QueryContinueDrag event is raised and determines whether to continue the drag, to drop the data, or to cancel the operation based on the value of the Action property of the event's QueryContinueDragEventArgs.

  • Если значение DragAction равно Continue, возникает событие DragOver для продолжения операции, а событие GiveFeedback вызывается с новым действием, чтобы можно было установить соответствующую визуальную обратную связь.If the value of DragAction is Continue, the DragOver event is raised to continue the operation and the GiveFeedback event is raised with the new effect so appropriate visual feedback can be set. Список допустимых эффектов сброса см. в перечислении DragDropEffects.For a list of valid drop effects, see the DragDropEffects enumeration.

    Примечание

    События DragOver и GiveFeedback сопряжены таким образом, что при перемещении мыши по направлению перетаскивания пользователь получает наиболее актуальную информацию о положении мыши.The DragOver and GiveFeedback events are paired so that as the mouse moves across the drop target, the user is given the most up-to-date feedback on the mouse's position.

  • Если значение DragAction равно Drop, то значение результата перетаскивания возвращается в источник, поэтому исходное приложение может выполнить соответствующую операцию с исходными данными. Например, если операция была перемещена, вырежьте данные.If the value of DragAction is Drop, the drop effect value is returned to the source, so the source application can perform the appropriate operation on the source data; for example, cut the data if the operation was a move.

  • Если значение DragAction равно Cancel, возникает событие DragLeave.If the value of DragAction is Cancel, the DragLeave event is raised.

По умолчанию событие QueryContinueDrag задает Action для Cancel в DragAction, если нажата клавиша ESC, и задает для Action значение Drop в DragAction при нажатии левой, средней или правой кнопки мыши.By default, the QueryContinueDrag event sets Action to Cancel in DragAction if the ESC key was pressed and sets Action to Drop in DragAction if the left, middle, or right mouse button is pressed.

Дополнительные сведения об обработке событий см. в разделе обработка и вызов событий.For more information about handling events, see Handling and Raising Events.

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

Дополнительно