Lire en anglais

Partager via


FrameworkElement.PredictFocus(FocusNavigationDirection) Méthode

Définition

Détermine l'élément suivant qui recevrait le focus relatif à cet élément pour une direction du déplacement du focus fournie, mais ne déplace pas réellement le focus.

C#
public override sealed System.Windows.DependencyObject PredictFocus(System.Windows.Input.FocusNavigationDirection direction);

Paramètres

direction
FocusNavigationDirection

La direction pour laquelle une future modification de focus doit être déterminée.

Retours

L'élément suivant sur lequel se déplacerait le focus si le focus était parcouru réellement. Peut retourner null si le focus ne peut pas être déplacé par rapport à cet élément pour la direction fournie.

Exceptions

Spécifié l'une des directions suivantes dans le TraversalRequest: Next, Previous, First, Last. Ces sens ne sont pas légaux pour PredictFocus(FocusNavigationDirection) (mais le sont pour MoveFocus(TraversalRequest)).

Exemples

L’exemple suivant implémente un gestionnaire qui gère plusieurs entrées de bouton possibles, chaque bouton représentant un possible FocusNavigationDirection. Le gestionnaire suit l’élément avec le focus clavier actuel et appelle PredictFocus cet élément, puis spécifie le approprié FocusNavigationDirection comme initialisation pour le TraversalRequest paramètre de type fourni. Au lieu de passer à cet élément comme MoveFocus il le ferait, le gestionnaire modifie les dimensions physiques de la destination de focus prédite à des fins de visualisation.

C#
    private void OnPredictFocus(object sender, RoutedEventArgs e)
    {
        DependencyObject predictionElement = null;

        UIElement elementWithFocus = Keyboard.FocusedElement as UIElement;

        if (elementWithFocus != null)
        {
            // Only these four directions are currently supported
            // by PredictFocus, so we need to filter on these only.
            if ((_focusMoveValue == FocusNavigationDirection.Up) ||
                (_focusMoveValue == FocusNavigationDirection.Down) ||
                (_focusMoveValue == FocusNavigationDirection.Left) ||
                (_focusMoveValue == FocusNavigationDirection.Right))
            {

                // Get the element which would receive focus if focus were changed.
                predictionElement = elementWithFocus.PredictFocus(_focusMoveValue);
               
                Control controlElement = predictionElement as Control;

                // If a ContentElement.
                if (controlElement != null)
                {
                    controlElement.Foreground = Brushes.DarkBlue;
                    controlElement.FontSize += 10;
                    controlElement.FontWeight = FontWeights.ExtraBold;

                    // Fields used to reset the UI when the mouse 
                    // button is released.
                    _focusPredicted = true;
                    _predictedControl = controlElement;
                }
            }
        }
    }

Remarques

MoveFocus est la méthode associée qui déplace réellement le focus.

S’applique à

Produit Versions
.NET Framework 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Voir aussi