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

Esempio di codice seguente viene illustrato come convertire le X e Y delle proprietà a un client Point.The following code example shows how to convert the X and Y properties to a client Point. Questo esempio di codice è parte di un esempio più esaustivo disponibile per il ToolStripRenderer 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

Il DragEnter evento viene generato quando l'utente trascina il cursore del mouse sull'elemento durante un'operazione di trascinamento e rilascio.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 viene descritto come e quando vengono generati gli eventi correlati alle operazioni di trascinamento e rilascio.The following remarks describe how and when events related to drag-and-drop operations are raised.

Il DoDragDrop metodo determina l'elemento in corrispondenza della posizione del cursore corrente.The DoDragDrop method determines the item under the current cursor location. Quindi controlla 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, il GiveFeedback evento viene generato con l'effetto di trascinamento e rilascio 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.

Modifiche di posizione del cursore del mouse, lo stato della tastiera e stato dei pulsanti del mouse vengono registrate 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 elemento, il DragEnter per tale controllo viene generato.If the mouse enters another item, the DragEnter for that control is raised.

  • Se il puntatore del mouse viene spostato ma sempre all'interno dell'elemento stesso, il DragOver viene generato l'evento.If the mouse moves but stays within the same item, the DragOver event is raised.

Se si verifica un cambiamento nello stato dei pulsanti mouse o tastiera, il QueryContinueDrag evento viene generato e verrà determinato se continuare l'operazione di trascinamento, rilasciare i dati, o per annullare l'operazione in base al valore della Action proprietà dell'evento 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.

Se il valore di DragAction viene Continue, il DragOver evento viene generato per continuare l'operazione e GiveFeedback evento viene generato con il nuovo effetto per consentire risposta visiva appropriata può essere impostata.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.

Il DragOver e GiveFeedback gli eventi vengono abbinati in modo che, mentre il puntatore del mouse viene spostato sull'obiettivo di rilascio, l'utente riceva il più aggiornate 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, viene restituito il valore dell'effetto di rilascio per l'origine, in modo che l'applicazione di origine può eseguire l'operazione appropriata sui dati di origine, ad esempio il taglio dei dati se l'operazione è un'operazione di spostamento.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 viene Cancel, il DragLeave viene generato l'evento.If the value of DragAction is Cancel, the DragLeave event is raised.

Nota

Il X e Y delle proprietà del DragEventArgs sono nelle coordinate dello schermo, non delle coordinate 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