Control.GiveFeedback É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 pendant une opération de glissement.
public:
event System::Windows::Forms::GiveFeedbackEventHandler ^ GiveFeedback;
public event System.Windows.Forms.GiveFeedbackEventHandler GiveFeedback;
public event System.Windows.Forms.GiveFeedbackEventHandler? GiveFeedback;
member this.GiveFeedback : System.Windows.Forms.GiveFeedbackEventHandler
Public Custom Event GiveFeedback As GiveFeedbackEventHandler
Type d'événement
Exemples
L’exemple de code suivant illustre une opération de glisser-déplacer entre deux contrôles ListBox. L’exemple appelle la méthode DoDragDrop au démarrage de l’action glisser. L’action glisser démarre si la souris a déplacé plus de SystemInformation.DragSize de l’emplacement de la souris pendant l’événement MouseDown. La méthode IndexFromPoint 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 nécessite 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 sont utilisés si la UseCustomCursorsCheck
CheckBox est cochée. Les curseurs personnalisés sont définis dans le gestionnaire d’événements GiveFeedback.
L’état du clavier est évalué dans le gestionnaire d’événements DragOver pour la ListBox
de droite, pour déterminer ce que l’opération glisser sera basée sur l’état des touches Maj, Ctrl, Alt ou Ctrl+Alt. L’emplacement dans l'ListBox
où la suppression se produit est également déterminé pendant l’événement de DragOver
. Si les données à supprimer ne sont pas un String
, la DragEventArgs.Effect est définie sur None
dans DragDropEffects. Enfin, l’état de la suppression s’affiche dans la DropLocationLabel
Label.
Les données à supprimer pour la ListBox
appropriée sont déterminées dans le gestionnaire d’événements DragDrop et la valeur de String
est ajoutée à l’emplacement approprié dans le 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 GiveFeedback. Consultez la méthode DoDragDrop pour obtenir l’exemple de code complet.
void ListDragSource_GiveFeedback( Object^ /*sender*/, System::Windows::Forms::GiveFeedbackEventArgs^ e )
{
// Use custom cursors if the check box is checked.
if ( UseCustomCursorsCheck->Checked )
{
// Sets the custom cursor based upon the effect.
e->UseDefaultCursors = false;
if ( (e->Effect & DragDropEffects::Move) == DragDropEffects::Move )
::Cursor::Current = MyNormalCursor;
else
::Cursor::Current = MyNoDropCursor;
}
}
private void ListDragSource_GiveFeedback(object sender, GiveFeedbackEventArgs e)
{
// Use custom cursors if the check box is checked.
if (UseCustomCursorsCheck.Checked)
{
// Sets the custom cursor based upon the effect.
e.UseDefaultCursors = false;
if ((e.Effect & DragDropEffects.Move) == DragDropEffects.Move)
Cursor.Current = MyNormalCursor;
else
Cursor.Current = MyNoDropCursor;
}
}
Private Sub ListDragSource_GiveFeedback(ByVal sender As Object, ByVal e As GiveFeedbackEventArgs) Handles ListDragSource.GiveFeedback
' Use custom cursors if the check box is checked.
If (UseCustomCursorsCheck.Checked) Then
' Set the custom cursor based upon the effect.
e.UseDefaultCursors = False
If ((e.Effect And DragDropEffects.Move) = DragDropEffects.Move) Then
Cursor.Current = MyNormalCursor
Else
Cursor.Current = MyNoDropCursor
End If
End If
End Sub
Remarques
L’événement GiveFeedback est déclenché lorsqu’une opération de glisser-déplacer est démarrée. Avec l’événement GiveFeedback, la source d’un événement de glisser-déplacer peut modifier l’apparence du pointeur de la souris afin d’envoyer des commentaires visuels à l’utilisateur lors d’une opération de glisser-déplacer.
L’exemple suivant décrit comment et quand les événements liés aux opérations de glisser-déplacer sont déclenchés.
La méthode DoDragDrop 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éplacer, 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 sont suivies.
Si l’utilisateur se déplace hors d’une fenêtre, l’événement DragLeave est déclenché.
Si la souris entre dans un autre contrôle, le DragEnter de ce contrôle est déclenché.
Si la souris se déplace mais reste dans le même contrôle, l’événement DragOver est déclenché.
S’il existe une 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-déplacer, supprimer les données ou annuler l’opération en fonction de la valeur de la propriété Action de l'QueryContinueDragEventArgsde l’événement.
Si la valeur de DragAction est
Continue
, l’événement DragOver est déclenché pour poursuivre 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 suppression valides, consultez l’énumération DragDropEffects.Note
Les événements DragOver et GiveFeedback sont jumelés afin que, lorsque la souris se déplace sur la cible de déplacement, l’utilisateur reçoit les commentaires les plus up-to-date sur la position de la souris.
Si la valeur de DragAction est
Drop
, la valeur d’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, coupez 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, consultez Gestion et déclenchement d’événements.