ToolStripItem.DragEnter ToolStripItem.DragEnter ToolStripItem.DragEnter ToolStripItem.DragEnter Event

Definizione

Si verifica quando l'utente trascina un elemento nell'area client di questo elemento.Occurs when the user drags an item into the client area of this item.

public:
 event System::Windows::Forms::DragEventHandler ^ DragEnter;
[System.ComponentModel.Browsable(false)]
public event System.Windows.Forms.DragEventHandler DragEnter;
member this.DragEnter : System.Windows.Forms.DragEventHandler 
Public Custom Event DragEnter As DragEventHandler 
Attributi

Esempi

Nell'esempio di codice riportato di seguito viene illustrato X come Y convertire le proprietà e Pointin un client.The following code example shows how to convert the X and Y properties to a client Point. Questo esempio di codice fa parte di un esempio più ampio fornito ToolStripRenderer per la classe.This code example is part of a larger example provided for the ToolStripRenderer class.

// This method defines the DragOver event behavior. 
protected override void OnDragOver(DragEventArgs dea)
{
    base.OnDragOver(dea);

    // Get the ToolStripButton control 
    // at the given mouse position.
    Point p = new Point(dea.X, dea.Y);
    ToolStripButton item = this.GetItemAt(
        this.PointToClient(p)) as ToolStripButton;

    // If the ToolStripButton control is the empty cell,
    // indicate that the move operation is valid.
    if( item == this.emptyCellButton )
    {
        // Set the drag operation to indicate a valid move.
        dea.Effect = DragDropEffects.Move;
    }
}
' This method defines the DragOver event behavior. 
Protected Overrides Sub OnDragOver(dea As DragEventArgs)
   MyBase.OnDragOver(dea)
   
   ' Get the ToolStripButton control 
   ' at the given mouse position.
   Dim p As New Point(dea.X, dea.Y)
   Dim item As ToolStripButton = CType(Me.GetItemAt(Me.PointToClient(p)), ToolStripButton)
   
   
   ' If the ToolStripButton control is the empty cell,
   ' indicate that the move operation is valid.
     If item Is Me.emptyCellButton Then
         ' Set the drag operation to indicate a valid move.
         dea.Effect = DragDropEffects.Move
     End If
 End Sub

Commenti

L' DragEnter evento viene generato quando l'utente trascina prima di tutto il cursore del mouse sull'elemento durante un'operazione di trascinamento della selezione.The DragEnter event is raised when the user first drags the mouse cursor over the item during a drag-and-drop operation.

Le osservazioni seguenti descrivono come e quando vengono generati gli eventi relativi alle operazioni di trascinamento della selezione.The following remarks describe how and when events related to drag-and-drop operations are raised.

Il DoDragDrop metodo determina l'elemento sotto la posizione corrente del cursore.The DoDragDrop method determines the item under the current cursor location. Verifica quindi se l'elemento è un obiettivo di rilascio valido.It then checks to see if the item is a valid drop target.

Se l'elemento è un obiettivo di rilascio valido, GiveFeedback l'evento viene generato con l'effetto di trascinamento della selezione specificato.If the item is a valid drop target, the GiveFeedback event is raised with the drag-and-drop effect specified. Per un elenco degli effetti di trascinamento e rilascio, vedere l'enumerazione DragDropEffects.For a list of drag-and-drop effects, see the DragDropEffects enumeration.

Le modifiche apportate alla posizione del cursore del mouse, allo stato della tastiera e al pulsante del mouse vengono rilevate nel modo seguente:Changes in the mouse cursor position, keyboard state, and mouse button state are tracked in the following manner:

  • Se l'utente si sposta al di fuori di una finestra, verrà generato un evento DragLeave.If the user moves out of a window, the DragLeave event is raised.

  • Se il mouse viene spostato su un altro DragEnter elemento, viene generato l'oggetto per il controllo.If the mouse enters another item, the DragEnter for that control is raised.

  • Se il mouse viene spostato ma rimane nello stesso elemento, viene DragOver generato l'evento.If the mouse moves but stays within the same item, the DragOver event is raised.

Se viene apportata una modifica allo stato della tastiera o del pulsante QueryContinueDrag del mouse, viene generato l'evento e viene determinato se continuare il trascinamento, eliminare i dati o annullare l'operazione in base al Action valore della QueryContinueDragEventArgsproprietà dell'oggetto dell'evento.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.

Se il valore di DragAction è Continue, viene DragOver generato l'evento per continuare l'operazione e l' GiveFeedback evento viene generato con il nuovo effetto, in modo che sia possibile impostare un feedback visivo appropriato.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. Per un elenco degli effetti di trascinamento validi, vedere l'enumerazione DragDropEffects.For a list of valid drop effects, see the DragDropEffects enumeration.

Gli DragOver eventi GiveFeedback e vengono abbinati in modo che, mentre il mouse viene spostato sull'obiettivo di rilascio, l'utente disponga dei commenti più aggiornati sulla posizione del mouse, come indicato di seguito: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, as follows:

  • Se il valore di DragAction è Drop, il valore dell'effetto di rilascio viene restituito all'origine, quindi l'applicazione di origine può eseguire l'operazione appropriata sui dati di origine. ad esempio, tagliare i dati se l'operazione è stata spostata.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.

  • Se il valore di DragAction è Cancel, viene DragLeave generato l'evento.If the value of DragAction is Cancel, the DragLeave event is raised.

Nota

Le X proprietà Y e diDragEventArgs sono nelle coordinate dello schermo, non nelle coordinate del client.The X and Y properties of the DragEventArgs are in screen coordinates, not client coordinates.

Per ulteriori informazioni sulla gestione degli eventi, consultare gestione e generazione di eventi.For more information about handling events, see Handling and Raising Events.

Si applica a