ToolStripItem.DragOver ToolStripItem.DragOver ToolStripItem.DragOver ToolStripItem.DragOver Event

Definizione

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

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

Esempi

Esempio di codice seguente viene illustrato l'utilizzo di questo membro.The following code example demonstrates the use of this member. Nell'esempio, un gestore dell'evento segnala l'occorrenza del DragOver evento.In the example, an event handler reports on the occurrence of the DragOver event. Questo report consente di capire quando l'evento si verifica e può agevolare il debug.This report helps you to learn when the event occurs and can assist you in debugging. Per creare report su più eventi o sugli eventi che si verificano di frequente, prendere in considerazione la sostituzione MessageBox.Show con Console.WriteLine o aggiungere il messaggio a una proprietà multiline TextBox.To report on multiple events or on events that occur frequently, consider replacing MessageBox.Show with Console.WriteLine or appending the message to a multiline TextBox.

Per eseguire l'esempio di codice, incollarlo in un progetto che contiene un'istanza di un tipo che eredita da ToolStripItem, ad esempio un ToolStripButton o ToolStripMenuItem.To run the example code, paste it into a project that contains an instance of a type that inherits from ToolStripItem, such as a ToolStripButton or ToolStripMenuItem. Quindi assegnare un nome istanza ToolStripItem1 e assicurarsi che il gestore dell'evento è associato il DragOver evento.Then name the instance ToolStripItem1 and ensure that the event handler is associated with the DragOver event.

private void ToolStripItem1_DragOver(Object sender, DragEventArgs e) {

System.Text.StringBuilder messageBoxCS = new System.Text.StringBuilder();
messageBoxCS.AppendFormat("{0} = {1}", "Data", e.Data );
messageBoxCS.AppendLine();
messageBoxCS.AppendFormat("{0} = {1}", "KeyState", e.KeyState );
messageBoxCS.AppendLine();
messageBoxCS.AppendFormat("{0} = {1}", "X", e.X );
messageBoxCS.AppendLine();
messageBoxCS.AppendFormat("{0} = {1}", "Y", e.Y );
messageBoxCS.AppendLine();
messageBoxCS.AppendFormat("{0} = {1}", "AllowedEffect", e.AllowedEffect );
messageBoxCS.AppendLine();
messageBoxCS.AppendFormat("{0} = {1}", "Effect", e.Effect );
messageBoxCS.AppendLine();
MessageBox.Show(messageBoxCS.ToString(), "DragOver Event" );
}
Private Sub ToolStripItem1_DragOver(sender as Object, e as DragEventArgs) _ 
     Handles ToolStripItem1.DragOver

    Dim messageBoxVB as New System.Text.StringBuilder()
    messageBoxVB.AppendFormat("{0} = {1}", "Data", e.Data)
    messageBoxVB.AppendLine()
    messageBoxVB.AppendFormat("{0} = {1}", "KeyState", e.KeyState)
    messageBoxVB.AppendLine()
    messageBoxVB.AppendFormat("{0} = {1}", "X", e.X)
    messageBoxVB.AppendLine()
    messageBoxVB.AppendFormat("{0} = {1}", "Y", e.Y)
    messageBoxVB.AppendLine()
    messageBoxVB.AppendFormat("{0} = {1}", "AllowedEffect", e.AllowedEffect)
    messageBoxVB.AppendLine()
    messageBoxVB.AppendFormat("{0} = {1}", "Effect", e.Effect)
    messageBoxVB.AppendLine()
    MessageBox.Show(messageBoxVB.ToString(),"DragOver Event")

End Sub

Commenti

Il DragOver evento viene generato quando il cursore del mouse viene spostato all'interno del controllo durante un'operazione di trascinamento e rilascio.The DragOver event is raised when the mouse cursor moves within the bounds of the control 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.

Si applica a