Nello script precedente abbiamo visto come aggiungere un Flyout ad un controllo che eredita dalla classe Button. Per impostazione predefinita, il Flyout si chiude solo se l'utente clicca fuori dall'area che occupa. Spesso, per esigenze di UX, è necessario chiudere il Flyout alla pressione di un bottone, chiudendolo programmaticamente.
Nell'esempio che segue utilizziamo un'attached property per recuperare il Popup che contiene il Flyout.
namespace MyApp { public class CloseFlyoutAttachedBehavior : DependencyObject { public static bool GetCloseFlyout(DependencyObject obj) { return (bool)obj.GetValue(CloseFlyoutProperty); } public static void SetCloseFlyout(DependencyObject obj, bool value) { if (obj is Button) { ((Button)obj).Click += CloseFlyoutAttachedBehaviorClick; } } static void CloseFlyoutAttachedBehaviorClick(object sender, RoutedEventArgs e) { var flyout = ((Button)sender).GetFirstAncestorOfType<FlyoutPresenter>(); if (flyout != null) { ((Popup)flyout.Parent).IsOpen = false; } } public static readonly DependencyProperty CloseFlyoutProperty = DependencyProperty.RegisterAttached("CloseFlyout", typeof(bool), typeof(CloseFlyoutAttachedBehavior), new PropertyMetadata(true)); } }
Una volta impostata la proprietà CloseFlyout, viene invocato il metodo SetCloseFlyout, in cui registriamo un handler per l'evento Click del bottone che, useremo per chiudere il Flyout. L'event handler CloseFlyoutAttachedBehaviorClick percorrerà il visual tree fino a recuperare il FlyoutPresenter: a causa della composizione del VisualTree, non è possibile recuperare direttamente il controllo Flyout, quindi dal FlyoutPresenter recuperiamo il Popup che è utilizzato per visualizzare il contenuto del Flyout, utilizzando la proprietà Parent. Per concludere, non ci rimane che impostare la proprietà IsOpen su false.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Anonimizzare i dati sensibili nei log di Azure Front Door
Ottenere un token di accesso per una GitHub App
Configurare e gestire sidecar container in Azure App Service
Fissare una versione dell'agent nelle pipeline di Azure DevOps
Utilizzare l'espressione if inline in una pipeline di Azure DevOps
Utilizzare una qualunque lista per i parametri di tipo params in C#
Ottimizzare le pull con Artifact Cache di Azure Container Registry
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Evitare memory leaks nelle closure JavaScript
.NET Conference Italia 2024
Gestione file Javascript in Blazor con .NET 9
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
I più letti di oggi
- Nuova preview per Visual Studio Orcas con la March 06 CTP
- Gestire le dipendenze dei nostri pacchetti NuGet in Visual Studio 2019
- Documentare i servizi REST con Swagger e OpenAPI con .NET 9
- Commentare il codice
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare le variabili in un file CSS
- Creare applicazioni web native con Electron