In alcuni casi può capitare di dover spostare il focus da un elemento dell'UI all'altro. Nel momento in cui si assegna il focus, ad esempio ad una TextBox, viene immediatamente mostrata la keyboard associata.
Per esigenze di UX e UI, l'elemento che deve ricevere il focus può non essere sempre visibile, e, magari, deve entrare nella view con una breve animazione.
Per evitare di assegnare troppo presto il focus all'elemento, dobbiamo attendere la conclusione dello StoryBoard con l'animazione.
Possiamo creare un Behavior per assegnare il focus solo quando lo StoryBoard assegnato termina e l'oggetto è ormai in posizione.
public class FocusOnCompleStoryBoardBehavior : Behavior<TextBox> { public static readonly DependencyProperty StoryboardProperty = DependencyProperty.Register("Storyboard", typeof(Storyboard),typeof(FocusOnCompleStoryBoardBehavior),new PropertyMetadata(new PropertyChangedCallback(FocusOnCompleStoryBoardBehavior.OnStoryboardChanged))); protected static void OnStoryboardChanged(DependencyObject sender, DependencyPropertyChangedEventArgs args) { FocusOnCompleStoryBoardBehavior action = sender as FocusOnCompleStoryBoardBehavior; if (action.Storyboard != null) action.Storyboard.Completed += action.StoryboardOnCompleted; } [CustomPropertyValueEditor(System.Windows.Interactivity.CustomPropertyValueEditor.Storyboard)] public Storyboard Storyboard { get { return (Storyboard)base.GetValue(StoryboardProperty); } set { base.SetValue(StoryboardProperty, value); } } private void StoryboardOnCompleted(object sender, EventArgs eventArgs) { AssociatedObject.Focus(); } }
Abbiamo creato una nuova classe che estende Behavior<T> e sostituiamo T con il tipo TextBox. Questo vuol dire che il Behavior è assegnabile solo alle TextBox.
Infine, creiamo un nuova DependencyProperty chiamata Storyboard, come il tipo. Nel callback invocato quando il valore della proprietà cambia, ci registriamo per l'evento Completed dello Storyboard. Quando quest'event handler viene invocato, non facciamo altro che spostare il focus sulla TextBox associata.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Proteggere le risorse Azure con private link e private endpoints
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Utilizzare l nesting nativo dei CSS
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Ottimizzare le pull con Artifact Cache di Azure Container Registry
Gestione CSS in Blazor con .NET 9
Managed deployment strategy in Azure DevOps
Gestione file Javascript in Blazor con .NET 9
Eseguire query per recuperare il padre di un record che sfrutta il tipo HierarchyID in Entity Framework
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT