Control.DragLeave Événement
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Se produit lorsqu'un objet est déplacé en dehors des limites d'un contrôle.
public:
event EventHandler ^ DragLeave;
public event EventHandler DragLeave;
public event EventHandler? DragLeave;
member this.DragLeave : EventHandler
Public Custom Event DragLeave As EventHandler
Type d'événement
Exemples
L’exemple de code suivant illustre une opération de glisser-déplacer entre deux ListBox contrôles. L’exemple appelle la DoDragDrop méthode lorsque l’action de glisser démarre. L’action glisser démarre si la souris s’est déplacée plus que SystemInformation.DragSize de l’emplacement de la souris pendant l’événement MouseDown . La IndexFromPoint méthode est utilisée pour déterminer l’index de l’élément à faire glisser pendant l’événement MouseDown
.
L’exemple montre également l’utilisation de curseurs personnalisés pour l’opération de glisser-déplacer. L’exemple exige que deux fichiers de curseur, 3dwarro.cur
et 3dwno.cur
, existent dans le répertoire de l’application, pour les curseurs de glisser-déplacer personnalisés, respectivement. Les curseurs personnalisés seront utilisés si le UseCustomCursorsCheck
CheckBox est coché. Les curseurs personnalisés sont définis dans le gestionnaire d’événements GiveFeedback .
L’état du clavier est évalué dans le DragOver gestionnaire d’événements pour le droit ListBox
, afin de déterminer l’opération de glissement en fonction de l’état des touches Maj, Ctrl, Alt ou Ctrl+Alt. L’emplacement dans le ListBox
où la suppression se produirait est également déterminé pendant l’événement DragOver
. Si les données à supprimer ne sont pas un String
, le DragEventArgs.Effect est défini sur None
dans DragDropEffects. Enfin, le status de la suppression s’affiche dans .DropLocationLabel
Label
Les données à supprimer pour la droite ListBox
sont déterminées dans le DragDrop gestionnaire d’événements et la String
valeur est ajoutée à l’emplacement approprié dans .ListBox
Si l’opération de glissement se déplace en dehors des limites du formulaire, l’opération de glisser-déplacer est annulée dans le gestionnaire d’événements QueryContinueDrag .
Cet extrait de code illustre l’utilisation de l’événement DragLeave . Consultez la DoDragDrop méthode pour obtenir l’exemple de code complet.
void ListDragTarget_DragLeave( Object^ /*sender*/, System::EventArgs^ /*e*/ )
{
// Reset the label text.
DropLocationLabel->Text = "None";
}
private void ListDragTarget_DragLeave(object sender, EventArgs e)
{
// Reset the label text.
DropLocationLabel.Text = "None";
}
Private Sub ListDragTarget_DragLeave(ByVal sender As Object, ByVal e As EventArgs) Handles ListDragTarget.DragLeave
' Reset the label text.
DropLocationLabel.Text = "None"
End Sub
Remarques
L’événement DragLeave est déclenché lorsque l’utilisateur fait glisser le curseur hors du contrôle ou que l’utilisateur annule l’opération de glisser-déplacer en cours.
Les lignes suivantes décrivent de quelle façon et à quel moment se déclenchent les événements liés aux opérations de glisser-déplacer.
La DoDragDrop méthode détermine le contrôle sous l’emplacement actuel du curseur. Il vérifie ensuite si le contrôle est une cible de suppression valide.
Si le contrôle est une cible de déplacement valide, l’événement GiveFeedback est déclenché avec l’effet glisser-déplacer spécifié. Pour obtenir la liste des effets de glisser-déposer, consultez l’énumération DragDropEffects.
Les modifications apportées à la position du curseur de la souris, à l'état du clavier et à l'état du bouton de la souris font l'objet d'un suivi.
Si l'utilisateur se déplace hors de la fenêtre, l'événement DragLeave est déclenché.
Si la souris entre dans un autre contrôle, l'événement DragEnter du contrôle est déclenché.
Si la souris se déplace uniquement dans les limites du même contrôle, l'événement DragOver est déclenché.
En cas de modification de l’état du clavier ou du bouton de la souris, l’événement QueryContinueDrag est déclenché et détermine s’il faut continuer le glisser, supprimer les données ou annuler l’opération en fonction de la valeur de la Action propriété de l’événement QueryContinueDragEventArgs.
Si la valeur de DragAction est
Continue
, l’événement DragOver est déclenché pour continuer l’opération et l’événement GiveFeedback est déclenché avec le nouvel effet afin que les commentaires visuels appropriés puissent être définis. Pour obtenir la liste des effets de dépôt valides, consultez l’énumération DragDropEffects.Notes
Les DragOver événements et GiveFeedback sont associés de sorte que lorsque la souris se déplace sur la cible de suppression, l’utilisateur reçoit les commentaires les plus à jour sur la position de la souris.
Si la valeur de est
Drop
, la valeur de DragAction l’effet de suppression est retournée à la source, de sorte que l’application source peut effectuer l’opération appropriée sur les données sources ; par exemple, couper les données si l’opération était un déplacement.Si la valeur de DragAction est
Cancel
, l’événement DragLeave est déclenché.
Pour plus d'informations sur la gestion des événements, voir gestion et déclenchement d’événements.
S’applique à
Voir aussi
Commentaires
https://aka.ms/ContentUserFeedback.
Bientôt disponible : Tout au long de 2024, nous allons supprimer progressivement GitHub Issues comme mécanisme de commentaires pour le contenu et le remplacer par un nouveau système de commentaires. Pour plus d’informations, consultezEnvoyer et afficher des commentaires pour