Control.DragOver Control.DragOver Control.DragOver Control.DragOver Event

Definition

Tritt ein, wenn ein Objekt über die Begrenzungen des Steuerelements gezogen wird.Occurs when an object is dragged over the control's bounds.

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

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, ein Drag & Drop-Vorgang zwischen zwei ListBox Steuerelemente.The following code example demonstrates a drag-and-drop operation between two ListBox controls. Im Beispiel wird die DoDragDrop Methode, wenn die Ziehaktion gestartet wird.The example calls the DoDragDrop method when the drag action starts. Die Ziehaktion gestartet wird, wenn die Maus bewegt wurde mehr als SystemInformation.DragSize aus die Position des Mauszeigers während der MouseDown Ereignis.The drag action starts if the mouse has moved more than SystemInformation.DragSize from the mouse location during the MouseDown event. Die IndexFromPoint Methode wird verwendet, um zu bestimmen, den Index des Elements, das beim Ziehen die MouseDown Ereignis.The IndexFromPoint method is used to determine the index of the item to drag during the MouseDown event.

Das Beispiel veranschaulicht außerdem die Verwendung von benutzerdefiniertem Cursor für den Drag & Drop-Vorgang.The example also demonstrates using custom cursors for the drag-and-drop operation. Das Beispiel erfordert, dass zwei Cursordateien 3dwarro.cur und 3dwno.cur, im Verzeichnis der Anwendung für den benutzerdefinierten vorhanden und Drop bzw. den Cursor.The example requires that two cursor files, 3dwarro.cur and 3dwno.cur, exist in the application directory, for the custom drag and no-drop cursors, respectively. Die benutzerdefinierten Cursor verwendet werden, wenn die UseCustomCursorsCheck CheckBox aktiviert ist.The custom cursors will be used if the UseCustomCursorsCheckCheckBox is checked. In benutzerdefinierten Cursor festgelegt sind das GiveFeedback -Ereignishandler.The custom cursors are set in the GiveFeedback event handler.

Der Tastaturzustand wird ausgewertet, der DragOver -Ereignishandler für das Recht ListBox, um zu bestimmen, welche des Ziehvorgangs werden basierend auf den Zustand von UMSCHALTTASTE, STRG, ALT oder STRG + ALT +.The keyboard state is evaluated in the DragOver event handler for the right ListBox, to determine what the drag operation will be based on state of the SHIFT, CTRL, ALT, or CTRL+ALT keys. Die Position in der ListBox der Ablegevorgang richtet auch während der DragOver Ereignis.The location in the ListBox where the drop would occur is also determined during the DragOver event. Ist die abzulegenden Daten kein String, und klicken Sie dann die DragEventArgs.Effect nastaven NA hodnotu None in DragDropEffects.If the data to drop is not a String, then the DragEventArgs.Effect is set to None in DragDropEffects. Abschließend wird der Status der Dropdownliste angezeigt, der DropLocationLabel Label.Finally, the status of the drop is displayed in the DropLocationLabelLabel.

Die Daten für den rechten löschen ListBox wird bestimmt, der DragDrop -Ereignishandler und die String Wert hinzugefügt wird, an der entsprechenden Stelle in der ListBox.The data to drop for the right ListBox is determined in the DragDrop event handler and the String value is added at the appropriate place in the ListBox. Wenn Sie der Ziehvorgang entsteht, die außerhalb der Begrenzungen des Formulars verschoben wird, und klicken Sie dann der Drag & Drop-Vorgang wird abgebrochen, der QueryContinueDrag -Ereignishandler.If the drag operation moves outside the bounds of the form, then the drag-and-drop operation is canceled in the QueryContinueDrag event handler.

Dieser Code veranschaulicht die Verwendung der DragOver Ereignis.This code excerpt demonstrates using the DragOver event. Finden Sie unter den DoDragDrop -Methode für das gesamte Codebeispiel dargestellt.See the DoDragDrop method for the complete code example.

void ListDragTarget_DragOver( Object^ /*sender*/, System::Windows::Forms::DragEventArgs^ e )
{
   // Determine whether string data exists in the drop data. If not, then
   // the drop effect reflects that the drop cannot occur.
   if (  !e->Data->GetDataPresent( System::String::typeid ) )
   {
      e->Effect = DragDropEffects::None;
      DropLocationLabel->Text = "None - no string data.";
      return;
   }

   // Set the effect based upon the KeyState.
   if ( (e->KeyState & (8 + 32)) == (8 + 32) && ((e->AllowedEffect & DragDropEffects::Link) == DragDropEffects::Link) )
   {
      // KeyState 8 + 32 = CTL + ALT
      // Link drag-and-drop effect.
      e->Effect = DragDropEffects::Link;
   }
   else
   if ( (e->KeyState & 32) == 32 && ((e->AllowedEffect & DragDropEffects::Link) == DragDropEffects::Link) )
   {
      // ALT KeyState for link.
      e->Effect = DragDropEffects::Link;
   }
   else
   if ( (e->KeyState & 4) == 4 && ((e->AllowedEffect & DragDropEffects::Move) == DragDropEffects::Move) )
   {
      // SHIFT KeyState for move.
      e->Effect = DragDropEffects::Move;
   }
   else
   if ( (e->KeyState & 8) == 8 && ((e->AllowedEffect & DragDropEffects::Copy) == DragDropEffects::Copy) )
   {
      // CTL KeyState for copy.
      e->Effect = DragDropEffects::Copy;
   }
   else
   if ( (e->AllowedEffect & DragDropEffects::Move) == DragDropEffects::Move )
   {
      // By default, the drop action should be move, if allowed.
      e->Effect = DragDropEffects::Move;
   }
   else
            e->Effect = DragDropEffects::None;





   
   // Get the index of the item the mouse is below.
   // The mouse locations are relative to the screen, so they must be
   // converted to client coordinates.
   indexOfItemUnderMouseToDrop = ListDragTarget->IndexFromPoint( ListDragTarget->PointToClient( Point(e->X,e->Y) ) );
   
   // Updates the label text.
   if ( indexOfItemUnderMouseToDrop != ListBox::NoMatches )
   {
      DropLocationLabel->Text = String::Concat( "Drops before item # ", (indexOfItemUnderMouseToDrop + 1) );
   }
   else
            DropLocationLabel->Text = "Drops at the end.";
}
private void ListDragTarget_DragOver(object sender, System.Windows.Forms.DragEventArgs e) 
{

    // Determine whether string data exists in the drop data. If not, then
    // the drop effect reflects that the drop cannot occur.
    if (!e.Data.GetDataPresent(typeof(System.String))) {

        e.Effect = DragDropEffects.None;
        DropLocationLabel.Text = "None - no string data.";
        return;
    }

    // Set the effect based upon the KeyState.
    if ((e.KeyState & (8+32)) == (8+32) && 
        (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link) {
        // KeyState 8 + 32 = CTL + ALT

        // Link drag-and-drop effect.
        e.Effect = DragDropEffects.Link;

    } else if ((e.KeyState & 32) == 32 && 
        (e.AllowedEffect & DragDropEffects.Link) == DragDropEffects.Link) {

        // ALT KeyState for link.
        e.Effect = DragDropEffects.Link;

    } else if ((e.KeyState & 4) == 4 && 
        (e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move) {

        // SHIFT KeyState for move.
        e.Effect = DragDropEffects.Move;

    } else if ((e.KeyState & 8) == 8 && 
        (e.AllowedEffect & DragDropEffects.Copy) == DragDropEffects.Copy) {

        // CTL KeyState for copy.
        e.Effect = DragDropEffects.Copy;

    } else if ((e.AllowedEffect & DragDropEffects.Move) == DragDropEffects.Move)  {

        // By default, the drop action should be move, if allowed.
        e.Effect = DragDropEffects.Move;

    } else
        e.Effect = DragDropEffects.None;
        
    // Get the index of the item the mouse is below. 

    // The mouse locations are relative to the screen, so they must be 
    // converted to client coordinates.

    indexOfItemUnderMouseToDrop = 
        ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(new Point(e.X, e.Y)));

    // Updates the label text.
    if (indexOfItemUnderMouseToDrop != ListBox.NoMatches){

        DropLocationLabel.Text = "Drops before item #" + (indexOfItemUnderMouseToDrop + 1);
    } else
        DropLocationLabel.Text = "Drops at the end.";

}
Private Sub ListDragTarget_DragOver(ByVal sender As Object, ByVal e As DragEventArgs) Handles ListDragTarget.DragOver
    ' Determine whether string data exists in the drop data. If not, then
    ' the drop effect reflects that the drop cannot occur.
    If Not (e.Data.GetDataPresent(GetType(System.String))) Then

        e.Effect = DragDropEffects.None
        DropLocationLabel.Text = "None - no string data."
        Return
    End If

    ' Set the effect based upon the KeyState.
    If ((e.KeyState And (8 + 32)) = (8 + 32) And _
        (e.AllowedEffect And DragDropEffects.Link) = DragDropEffects.Link) Then
        ' KeyState 8 + 32 = CTL + ALT

        ' Link drag-and-drop effect.
        e.Effect = DragDropEffects.Link

    ElseIf ((e.KeyState And 32) = 32 And _
        (e.AllowedEffect And DragDropEffects.Link) = DragDropEffects.Link) Then

        ' ALT KeyState for link.
        e.Effect = DragDropEffects.Link

    ElseIf ((e.KeyState And 4) = 4 And _
        (e.AllowedEffect And DragDropEffects.Move) = DragDropEffects.Move) Then

        ' SHIFT KeyState for move.
        e.Effect = DragDropEffects.Move

    ElseIf ((e.KeyState And 8) = 8 And _
        (e.AllowedEffect And DragDropEffects.Copy) = DragDropEffects.Copy) Then

        ' CTL KeyState for copy.
        e.Effect = DragDropEffects.Copy

    ElseIf ((e.AllowedEffect And DragDropEffects.Move) = DragDropEffects.Move) Then

        ' By default, the drop action should be move, if allowed.
        e.Effect = DragDropEffects.Move

    Else
        e.Effect = DragDropEffects.None
    End If

    ' Gets the index of the item the mouse is below. 

    ' The mouse locations are relative to the screen, so they must be 
    ' converted to client coordinates.

    indexOfItemUnderMouseToDrop = _
        ListDragTarget.IndexFromPoint(ListDragTarget.PointToClient(New Point(e.X, e.Y)))

    ' Updates the label text.
    If (indexOfItemUnderMouseToDrop <> ListBox.NoMatches) Then

        DropLocationLabel.Text = "Drops before item #" & (indexOfItemUnderMouseToDrop + 1)
    Else
        DropLocationLabel.Text = "Drops at the end."
    End If

End Sub

Hinweise

Die DragOver Ereignis wird ausgelöst, wenn der Mauszeiger während eines Drag & Drop-Vorgangs innerhalb der Grenzen des Steuerelements bewegt wird.The DragOver event is raised when the mouse cursor moves within the bounds of the control during a drag-and-drop operation.

Nachfolgend wird beschrieben, wie und wann Ereignisse für Drag & Drop-Vorgänge ausgelöst werden.The following describes how and when events related to drag-and-drop operations are raised.

Die DoDragDrop Methode bestimmt das Steuerelement an der aktuellen Cursorposition.The DoDragDrop method determines the control under the current cursor location. Er überprüft dann um festzustellen, ob das Steuerelement ein gültiges Ablageziel ist.It then checks to see if the control is a valid drop target.

Wenn das Steuerelement ein gültiges Ablageziel, ist die GiveFeedback Ereignis wird ausgelöst, mit dem angegebenen Drag & Drop-Effekt.If the control is a valid drop target, the GiveFeedback event is raised with the drag-and-drop effect specified. Eine Liste der Drag & Drop-Effekte finden Sie unter der DragDropEffects-Enumeration.For a list of drag-and-drop effects, see the DragDropEffects enumeration.

Änderungen der Mauszeigerposition, des Tastaturzustands und des Zustands der Maustasten werden verfolgt.Changes in the mouse cursor position, keyboard state, and mouse button state are tracked.

  • Wenn die Benutzeraktion das Fenster verlässt, wird das DragLeave-Ereignis ausgelöst.If the user moves out of a window, the DragLeave event is raised.

  • Wenn der Mauszeiger in ein anderes Steuerelement bewegt wird, wird das DragEnter-Ereignis für dieses Steuerelement ausgelöst.If the mouse enters another control, the DragEnter for that control is raised.

  • Wenn die Maus bewegt wird, ohne das Steuerelement zu verlassen, wird das DragOver-Ereignis ausgelöst.If the mouse moves but stays within the same control, the DragOver event is raised.

Wenn eine in der Tastatur- oder Maustastenzustands Änderung der QueryContinueDrag Ereignis wird ausgelöst, und bestimmt, ob den Ziehvorgang, die Daten abgelegt fortgesetzt oder zum Abbrechen des Vorgangs basierend auf den Wert der Action Eigenschaft des Ereignisses 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.

  • Wenn der Wert des DragAction Wert Continue, wird die DragOver -Ereignis wird ausgelöst, um den Vorgang fortzusetzen und die GiveFeedback -Ereignis mit dem neuen Effekt ausgelöst, damit entsprechende visuelle Rückmeldung festgelegt werden kann.If the value of DragAction value 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. Eine Liste der gültigen Ablageeffekte finden Sie unter der DragDropEffects-Enumeration.For a list of valid drop effects, see the DragDropEffects enumeration.

    Hinweis

    Die DragOver und GiveFeedback -Ereignis werden zusammengefasst, sodass der Benutzer mit dem Mauszeiger über das Ablageziel verschoben, aktuelle Rückmeldung von der Maus auf die Position angegeben ist.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.

  • Wenn der Wert des DragAction ist Drop, ist der Wert des Ablageeffekts an die Quelle zurückgegeben, damit die quellanwendung den entsprechenden Vorgang für die Quelldaten ausführen, kann z. B. die Daten Ausschneiden, wenn der Vorgang einen Verschiebevorgang handelt.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.

  • Wenn der Wert des DragAction ist Cancel, DragLeave Ereignis wird ausgelöst.If the value of DragAction is Cancel, the DragLeave event is raised.

    Hinweis

    Die X und Y Eigenschaften der DragEventArgs befinden sich in Bildschirmkoordinaten, nicht die Clientkoordinaten.The X and Y properties of the DragEventArgs are in screen coordinates, not client coordinates. Die folgende Codezeile c#-Code konvertiert die Eigenschaften für einen Client Point:The following line of C# code converts the properties to a client Point:

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

Weitere Informationen zur Behandlung von Ereignissen finden Sie unter behandeln und Auslösen von Ereignissen.For more information about handling events, see Handling and Raising Events.

Gilt für:

Siehe auch