In Silverlight 4 abbiamo la possibilità di personalizzare il tipo di interfaccia della finestra Windows che ospita l'applicazione.
Oltre all'impostazione standard, demandata al sistema operativo, con l'aiuto di Visual Studio possiamo scegliere di rimuovere completamente tutto il layout della finestra (valore No Border) o anche di avere angoli arrotondati (Borderless Round Corner). La maschera corrispondente alla seguente immagine si apre dalle proprietà del progetto, attraverso il pulsante delle impostazioni Out Of Browser (Out-of-Browser Settings..).

Per poter modificare il tipo di layout è necessario che l'applicazione abbia privilegi full-trust e che sia, quindi, autorizzata dall'utente.
La possibilità di rimuovere completamente il layout della finestra ci permette di creare layout completamente personalizzati e maggiormente adatti alla grafica dell'applicazione. L'onere di questa possibilità è quello di dover implementare manualmente i consueti pulsanti di gestione della finestra quali chiusura, riduzione ad icona e massimizzazione oltre alle funzioni di spostamento e ridimensionamento della finestra stessa.
Nonostante possa sembrare molto impegnativo, grazie all'oggetto MainWindow (di tipo Window), esposto da Application, queste implementazioni si riducono ad utilizzare i metodi specifici, con poche righe di codice; di seguito è riportato un esempio in cui sono richiamati nei gestori degli eventi del mouse su specifici oggetti grafici.
private void Minimize_MouseLeftButtonUp(object sender, MouseButtonEventArgs e) { if (Application.Current.IsRunningOutOfBrowser && Application.Current.HasElevatedPermissions) Application.Current.MainWindow.WindowState = WindowState.Minimized; } private void Close_MouseLeftButtonUp(object sender, MouseButtonEventArgs e) { if (Application.Current.IsRunningOutOfBrowser && Application.Current.HasElevatedPermissions) Application.Current.MainWindow.Close(); } private void Maximize_MouseLeftButtonUp(object sender, MouseButtonEventArgs e) { if (Application.Current.IsRunningOutOfBrowser && Application.Current.HasElevatedPermissions) { Application.Current.MainWindow.WindowState = Application.Current.MainWindow.WindowState == WindowState.Normal ? WindowState.Maximized : WindowState.Normal; } } private void Resize_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) { if (Application.Current.IsRunningOutOfBrowser && Application.Current.HasElevatedPermissions) Application.Current.MainWindow.DragResize(WindowResizeEdge.BottomRight); } private void Bar_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) { if (Application.Current.IsRunningOutOfBrowser && Application.Current.HasElevatedPermissions) Application.Current.MainWindow.DragMove(); }
Il layout è simile a quello della seguente immagine.

La logica può essere facilmente incapsulata in un custom control, in modo che la grafica possa essere personalizzata con Style e Template e possa così essere riutilizzata in più applicazioni.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Utilizzare Azure AI Studio per testare i modelli AI
Effettuare il refresh dei dati di una QuickGrid di Blazor
Utilizzare una qualunque lista per i parametri di tipo params in C#
Gestione degli stili CSS con le regole @layer
Disabilitare automaticamente un workflow di GitHub (parte 2)
Creare una libreria CSS universale: i bottoni
Aprire una finestra di dialogo per selezionare una directory in WPF e .NET 8
Usare il colore CSS per migliorare lo stile della pagina
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database