Nell'articolo di introduzione all'uso di PRISM per realizzare Windows Store app (https://www.winrtitalia.com/articoli/windows8/XAML-Windows-8.1-WinRT-PRISM.aspx) abbiamo introdotto la logica della classe MvvmAppBase, da cui far ereditare App, per comprenderne il ciclo di startup.
Tra i vari punti di estensibilità di tale classe figura la possibilità di inserire una view come splash screen personalizzata attraverso la proprietà ExtendedSplashScreenFactory.
this.ExtendedSplashScreenFactory = (splashscreen) => new ExtendedSplashScreen(splashscreen);
Tale proprietà deve essere valorizzata nel costruttore di App con un delegato che passa in ingresso il riferimento all'oggetto SplashScreen definto nel manifest, e restituisce l'istanza di una Page che vogliamo usare come custom splash screen.
Durante lo startup, quando questa proprietà non è null, viene invocato il delegato e la Page restituita viene inserita come Content del rootFrame. Al termine dello startup il Content viene definitivamente valorizzato con la view iniziale.
La view che possiamo usare come splash screen custom può essere del tutto personale; poichè l'oggetto SplashScreen definito nel manifest viene passato come parametro possiamo usarlo se vogliamo creare un effetto visivo continuo con la splash screen di base.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare i primary constructor di C# per inizializzare le proprietà
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Creare gruppi di client per Event Grid MQTT
Cambiare la chiave di partizionamento di Azure Cosmos DB
Utilizzare database e servizi con gli add-on di Container App
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Creare un'applicazione React e configurare Tailwind CSS
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Utilizzare Model as a Service su Microsoft Azure
Creare un webhook in Azure DevOps
Routing statico e PreRendering in una Blazor Web App