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
Creare espressioni riutilizzabili nelle query LINQ per Entity Framework
Le cron expression di un workflow di GitHub
Supportare la sessione affinity di Azure App Service con Application Gateway
Simulare Azure Cosmos DB in locale con Docker
Implementare il throttle in JavaScript
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Utilizzare WebJobs su Linux con Azure App Service
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Utilizzare il metodo ExceptBy per eseguire operazione di sottrazione tra liste
Escludere alcuni file da GitHub Secret Scanning
Utilizzare Containers in .NET Aspire
Creare un agente A2Acon Azure Logic Apps


