La personalizzazione è da sempre uno dei punti di forza di Windows, in quanto tramite le API abbiamo accesso a tutto il sistema operativo e possiamo permetterci di customizzare l'esperienza utente in mille modi differenti, anche all'esterno dell'applicazione stessa. Una funzionalità presente sin dalla prima versione di Windows 10, ovvero dalla build 10240, consiste nella possibilità di modificare l'immagine di sfondo del Desktop o della lockscreen, come mostrato nell'esempio seguente:
using Windows.System.UserProfile; private async Task SetLockscreenAsync(string localAppDataFileName) { if (UserProfilePersonalizationSettings.IsSupported()) { var uri = new Uri("ms-appx:///Local/" + localAppDataFileName); var file = await StorageFile.GetFileFromApplicationUriAsync(uri); await UserProfilePersonalizationSettings.Current.TrySetLockScreenImageAsync(file); } }
La classe UserProfilePersonalizationSettings ci permette infatti di accedere alle impostazioni relative all'utente attualmente loggato in Windows e, se il device supporta la personalizzazione della lockscreen, allora di cambiare l'immagine di sfondo attraverso la chiamata a TrySetLockScreenImageAsync. Il codice è molto simile anche nel caso in cui vogliamo modificare l'immagine di sfondo del Desktop, in quanto sarà sufficiente chiamare TrySetWallpaperImageAsync.
Le due chiamate hanno la particolarità di ritornare un valore booleano che indica se l'immagine passata in ingresso è stata sostituita oppure no: sono infatti presenti determinati constraint che dipendono dal device (alcuni sono headless e non hanno il Desktop), oppure di dimensioni fisiche dell'immagine stessa (2MB è il massimo consentito su mobile). Per entrambe le personalizzazioni, però, è bene fare in modo che i nomi delle immagini da impostare siano sempre diversi, altrimenti se il nome della nuova immagine è identico alla precedente già impostata (anche se fisicamente sono differenti), non verrà sostituita.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Modificare i metadati nell'head dell'HTML di una Blazor Web App
Utilizzare Tailwind CSS all'interno di React: installazione
Eseguire operazioni con timeout in React
Gestire liste di tipi semplici con Entity Framework Core
Potenziare Azure AI Search con la ricerca vettoriale
Gestire i null nelle reactive form tipizzate di Angular
Controllare gli accessi IP alle app con Azure Container Apps
Eseguire le GitHub Actions offline
Sfruttare al massimo i topic space di Event Grid MQTT
Creazione di componenti personalizzati in React.js con Tailwind CSS
Short-circuiting della Pipeline in ASP.NET Core
Installare le Web App site extension tramite una pipeline di Azure DevOps
I più letti di oggi
- Utilizzare WebAssembly con .NET, ovunque
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- Utilizzare il trigger SQL con le Azure Function
- Disabilitare automaticamente un workflow di GitHub (parte 2)
- Paginare i risultati con QuickGrid in Blazor
- Ottimizzazione dei block template in Angular 17