La build 15021 per gli utenti tramite il programma Windows Insider, oppure più comunemente il Creators Update, ha introdotto una nuova modalità di visualizzazione dei contenuti chiamato Picture-In-Picture mode.
Questa nuova modalità consente di vedere i contenuti, seppur magari in finestra di dimensioni ridotte, sempre in cima rispetto alle altre finestre aperte, così si possa tenere un occhio sui contenuti pur lavorando ad altro: ad esempio, potrebbe essere utile per un'applicazione che riproduce video, abilitare la modalità Picture-In-Picture per far sì che i video siano visibili anche mentre l'utente effettua altre operazioni, come leggere le mail oppure scrivere un documento di Word.
Per abilitare questa modalità, anche chiamata CompactOverlay, sono sufficienti un paio di righe di codice:
if (ApplicationView.GetForCurrentView().IsViewModeSupported(ApplicationViewMode.CompactOverlay)) { var hasChangedView = await ApplicationView.GetForCurrentView().TryEnterViewModeAsync(ApplicationViewMode.CompactOverlay); }
All'interno di questo brevissimo esempio abbiamo controllato che la modalità sia attivabile su quel determinato dispositivo con Windows 10 e quindi proviamo ad entrarci: questo metodo verrà probabilmente chiamato da un pulsante ad-hoc all'interno della view che l'utente può abilitare per cambiare modalità di visualizzazione. Per tornare alla modalità "normale", è necessario assegnare ApplicationViewMode.Default.
Eventualmente, è anche possibile passare dei parametri relativi alla finestra della nuova modalità, come ad esempio la dimensione che dovrà avere dopo il cambio:
ViewModePreferences compactOptions = ViewModePreferences.CreateDefault(ApplicationViewMode.CompactOverlay); compactOptions.CustomSize = new Windows.Foundation.Size(320, 200); var hasChangedView = await ApplicationView.GetForCurrentView().TryEnterViewModeAsync(ApplicationViewMode.Default, compactOptions);
Ci sono infine casi in cui potrebbe essere necessario, per via di complessità architetturali o anche più semplicemente per scelta, dedicare una nuova finestra ed un nuovo flusso di navigazione alla modalità CompactOverlay. Questa funzionalità può essere attivata con poche righe di codice che vanno a creare un nuovo Frame:
private async void ShowCompactView() { await CoreApplication.CreateNewView().Dispatcher.RunAsync(CoreDispatcherPriority.Normal, () => { var frame = new Frame(); compactViewId = ApplicationView.GetForCurrentView().Id; frame.Navigate(typeof(MyCompactOverlayPage)); Window.Current.Content = frame; Window.Current.Activate(); }); var hasChangedView = await ApplicationViewSwitcher.TryShowAsViewModeAsync(compactViewId, ApplicationViewMode.CompactOverlay); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Eseguire operazioni con timeout in React
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Eseguire query verso tipi non mappati in Entity Framework Core
Usare lo spread operator con i collection initializer in C#
Generare token per autenicarsi sulle API di GitHub
Usare Refit e Polly in Blazor per creare client affidabili e fortemente tipizzati
Recuperare un elemento inserito nella cache del browser tramite API JavaScript
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Paginare i risultati con QuickGrid in Blazor
Supportare il sorting di dati tabellari in Blazor con QuickGrid
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP