Una delle novità forse più rilevanti del Creators Update di Windows 10, è la possibilità di creare sofisticate animazioni di transizione tra una pagina e l'altra. Questo tipo di animazioni non sono una novità e sono state una parte fondamentale della UX di Windows fin dalla versione 8.
La novità consiste nel poter agire sui singoli elementi dell'interfaccia grafica in modo tale che l'animazione crei l'effetto di spostamento degli stessi da una pagina all'altra.
Questa tecnica permette di enfatizzare determinati elementi dell'interfaccia grafica, così che l'utente seguendo il percorso dell'animazione presti maggior attenzione a questi elementi.
Il cuore di questa tecnica è la classe ConnectedAnimation, recuperabile traminte ConnectedAnimationService. Per prima cosa, abbiamo bisogno di un elemento grafico da animare: per questo esempio è sufficiente una semplice immagine nella pagina di partenza.
<Image x:Name="MySourceImage" Width="200" Height="200" Stretch="Fill" Source="Assets/MyImage.png" />
E una nella pagina di destinazione:
<Image x:Name="MyDestinationImage" Width="400" Height="400" Stretch="Fill" Source="Assets/MyImage.png" />
Iniziamo a preparare l'animazione e, poco prima di navigare alla pagina di destinazione, eseguiamo la seguente riga di codice per richiamare il metodo PrepareToAnimate:
ConnectedAnimationService.GetForCurrentView().PrepareToAnimate("image", MySourceImage);
E poi proseguiamo con la navigazione:
Frame.Navigate(typeof(MyDestinationPage));
Nella pagina di destinazione eseguiamo l'override del metodo OnNavigatedTo e richiamiamo il metodo GetAnimation, per recuperare l'animazione:
protected override void OnNavigatedTo(NavigationEventArgs e) { base.OnNavigatedTo(e); ConnectedAnimation imageAnimation = ConnectedAnimationService.GetForCurrentView().GetAnimation("Myimage"); if (imageAnimation != null) { imageAnimation.TryStart(DestinationImage); } }
E, infine, richiamiamo il metodo TryStart per eseguire l'animazione.
In questo modo, le due immagini, di due pagine differenti, grazie all'animazione sembreranno una sola immagine che, all'atto di navigare alla nuova pagina, ha cambiato posizione e dimensioni.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare agenti facilmente con Azure AI Agent Service
Ottenere un token di accesso per una GitHub App
Integrare un servizio esterno con .NET Aspire
Utilizzare Container Queries nominali
Il nuovo controllo Range di Blazor 9
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Ridurre il reflow ottimizzando il CSS
Gestire codice JavaScript con code splitting e lazy loading
Gestire progetti .NET + React in .NET Aspire
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Gestione degli eventi nei Web component HTML
Recuperare l'ultima versione di una release di GitHub
I più letti di oggi
- Novità nella gestione del modello asincrono in C# 5 e VB 11
- Eseguire query con LINQ to SQL
- Conoscere il rendering Server o WebAssembly a runtime in Blazor
- Gestione file Javascript in Blazor con .NET 9
- Migliorare la velocità delle connessioni ai database
- #vs2017 sarà rilasciato il 07/03, in concomitanza con i suoi 20 anni https://aspit.co/bfn
- #VS2017 Community è già disponibile al download da questa pagina https://aspit.co/bgb
- #VS2017 non ha un'ISO, ma è possibile creare un installer offline seguendo la guida ufficiale: https://aspit.co/bgd
- 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!