Control.DragEnter Evento
Definizione
Importante
Alcune informazioni sono relative alla release non definitiva del prodotto, che potrebbe subire modifiche significative prima della release definitiva. Microsoft non riconosce alcuna garanzia, espressa o implicita, in merito alle informazioni qui fornite.
Si verifica quando un oggetto viene trascinato nei limiti del controllo.
public:
event System::Windows::Forms::DragEventHandler ^ DragEnter;
public event System.Windows.Forms.DragEventHandler DragEnter;
public event System.Windows.Forms.DragEventHandler? DragEnter;
member this.DragEnter : System.Windows.Forms.DragEventHandler
Public Custom Event DragEnter As DragEventHandler
Tipo evento
Esempio
Nell'esempio di codice seguente viene illustrata un'operazione di trascinamento della selezione tra due ListBox controlli. Nell'esempio viene chiamato il DoDragDrop metodo all'avvio dell'azione di trascinamento. L'azione di trascinamento inizia se il mouse è stato spostato più che SystemInformation.DragSize dalla posizione del mouse durante l'evento MouseDown . Il IndexFromPoint metodo viene usato per determinare l'indice dell'elemento da trascinare durante l'evento MouseDown
.
L'esempio illustra anche l'uso di cursori personalizzati per l'operazione di trascinamento. L'esempio richiede che due file 3dwarro.cur
di cursore e 3dwno.cur
, esistano rispettivamente nella directory dell'applicazione, per il trascinamento personalizzato e i cursori senza rilascio. I cursori personalizzati verranno usati se viene UseCustomCursorsCheck
CheckBox controllato. I cursori personalizzati vengono impostati nel GiveFeedback gestore eventi.
Lo stato della tastiera viene valutato nel DragOver gestore eventi per il diritto ListBox
, per determinare quale operazione di trascinamento sarà in base allo stato dei tasti MAIUSC, CTRL, ALT o CTRL+ALT. La posizione in ListBox
cui si verificherebbe l'eliminazione viene determinata anche durante l'evento DragOver
. Se i dati da eliminare non sono un String
oggetto , l'oggetto DragEventArgs.Effect è impostato su None
in DragDropEffects. Infine, lo stato dell'eliminazione DropLocationLabel
Labelviene visualizzato in .
I dati da eliminare per il diritto ListBox
sono determinati nel DragDrop gestore eventi e il String
valore viene aggiunto al posto appropriato in ListBox
. Se l'operazione di trascinamento si sposta all'esterno dei limiti del modulo, l'operazione di trascinamento viene annullata nel QueryContinueDrag gestore eventi.
Questo estratto di codice illustra l'uso dell'evento DragEnter . Vedere il metodo per l'esempio DoDragDrop di codice completo.
void ListDragTarget_DragEnter( Object^ /*sender*/, System::Windows::Forms::DragEventArgs^ /*e*/ )
{
// Reset the label text.
DropLocationLabel->Text = "None";
}
private void ListDragTarget_DragEnter(object sender, DragEventArgs e)
{
// Reset the label text.
DropLocationLabel.Text = "None";
}
Private Sub ListDragTarget_DragEnter(ByVal sender As Object, ByVal e As DragEventArgs) Handles ListDragTarget.DragEnter
' Reset the label text.
DropLocationLabel.Text = "None"
End Sub
Commenti
L'evento DragEnter viene generato quando l'utente trascina prima il cursore del mouse sul controllo durante un'operazione di trascinamento della selezione.
Nota
Nelle versioni precedenti a .NET Framework 2.0, se si inserisce un UserControl oggetto con DragEnter ed DragDrop eventi in un Windows Form e si trascina un elemento nella UserControl fase di progettazione, vengono generati gli DropDrop
eventi e DropEnter
. Tuttavia, quando si chiude e si riapri la soluzione, gli DragEnter eventi e DragDrop non vengono generati di nuovo.
Di seguito vengono illustrate le modalità e le circostanze in cui vengono generati eventi relativi a operazioni di trascinamento.
Il DoDragDrop metodo determina il controllo nella posizione del cursore corrente. Verifica quindi se il controllo è una destinazione di rilascio valida.
Se il controllo è una destinazione di rilascio valida, l'evento GiveFeedback viene generato con l'effetto trascinamento specificato. Per un elenco degli effetti di trascinamento e rilascio, vedere l'enumerazione DragDropEffects.
Viene tenuta traccia delle modifiche apportate alla posizione del cursore del mouse, allo stato della tastiera e allo stato dei pulsanti del mouse.
Se l'utente si sposta al di fuori di una finestra, verrà generato un evento DragLeave.
Se il mouse viene spostato su un altro controllo, verrà generato l'evento DragEnter per tale controllo.
Se il mouse viene spostato ma sempre all'interno dello stesso controllo, verrà generato l'evento DragOver.
Se si verifica una modifica nello stato del pulsante della tastiera o del mouse, l'evento QueryContinueDrag viene generato e determina se continuare il trascinamento, eliminare i dati o annullare l'operazione in base al valore della Action proprietà dell'evento QueryContinueDragEventArgs.
Se il valore di DragAction è
Continue
, l'evento DragOver viene generato per continuare l'operazione e l'evento GiveFeedback viene generato con il nuovo effetto in modo che sia possibile impostare commenti visivi appropriati. Per un elenco degli effetti di trascinamento validi, vedere l'enumerazione DragDropEffects.Nota
Gli DragOver eventi e GiveFeedback vengono associati in modo che, quando il mouse si sposta attraverso la destinazione di rilascio, l'utente riceve il feedback più aggiornato sulla posizione del mouse.
Se il valore di è
Drop
, il valore dell'effetto drop viene restituito all'origine, in modo che l'applicazione di origine possa eseguire l'operazione appropriata sui dati di DragAction origine, ad esempio tagliare i dati se l'operazione è stata spostata.Se il valore di DragAction è
Cancel
, viene generato l'evento DragLeave .Nota
Le X proprietà e Y dell'oggetto DragEventArgs sono in coordinate dello schermo, non coordinate client. La riga seguente del codice Visual C# converte le proprietà in un client Point.
Point clientPoint = targetControl.PointToClient(new Point(de.X, de.Y));
Per ulteriori informazioni sulla gestione degli eventi, consultare gestione e generazione di eventi.
Si applica a
Vedi anche
Commenti e suggerimenti
https://aka.ms/ContentUserFeedback.
Presto disponibile: Nel corso del 2024 verranno gradualmente disattivati i problemi di GitHub come meccanismo di feedback per il contenuto e ciò verrà sostituito con un nuovo sistema di feedback. Per altre informazioni, vedereInvia e visualizza il feedback per