WinRT è un Framework relativamente giovane e, anche se nato dall'esperienza maturata con WPF, ha perso alcune comode proprietà di quest'ultimo.
Una delle feature sncanti è la possibilità di tagliare il contenuto che fuoriesce dal suo contenitore.
In pratica, si tratta di una tecnica che permette di impostare la proprietà Clip di un oggetto, creando una RectangleGeometry con le esatte dimensioni dello stesso.
namespace MyCodeNamespace { public class Clip { public static bool GetToBounds(DependencyObject depObj) { return (bool)depObj.GetValue(ToBoundsProperty); } public static void SetToBounds(DependencyObject depObj, bool clipToBounds) { depObj.SetValue(ToBoundsProperty, clipToBounds); } public static readonly DependencyProperty ToBoundsProperty = DependencyProperty.RegisterAttached("ToBounds", typeof(bool), typeof(Clip), new PropertyMetadata(false, OnToBoundsPropertyChanged)); private static void OnToBoundsPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) { FrameworkElement fe = d as FrameworkElement; if (fe != null) { ClipToBounds(fe); fe.Loaded += new RoutedEventHandler(fe_Loaded); fe.SizeChanged += new SizeChangedEventHandler(fe_SizeChanged); } } private static void ClipToBounds(FrameworkElement fe) { if (GetToBounds(fe)) { fe.Clip = new RectangleGeometry() { Rect = new Rect(0, 0, fe.ActualWidth, fe.ActualHeight) }; } else { fe.Clip = null; } } static void fe_SizeChanged(object sender, SizeChangedEventArgs e) { ClipToBounds(sender as FrameworkElement); } static void fe_Loaded(object sender, RoutedEventArgs e) { ClipToBounds(sender as FrameworkElement); } } }
Il cuore di tutto lo script è il metodo ClipToBounds, dove viene creata la RectangleGeometry. L'utilizzo del codice è semplicissimo, grazie alla creazione dell'attached property ToBounds.
<Border myNameSpace:Clip.ToBounds="true"> ... </Border>
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare un webhook in Azure DevOps
Proteggere le risorse Azure con private link e private endpoints
Miglioramenti nelle performance di Angular 16
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Recuperare l'ultima versione di una release di GitHub
Esportare ed analizzare le issue di GitHub con la CLI e GraphQL
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Installare le Web App site extension tramite una pipeline di Azure DevOps
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Usare il colore CSS per migliorare lo stile della pagina
Effettuare il refresh dei dati di una QuickGrid di Blazor
Code scanning e advanced security con Azure DevOps