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
Evitare la command injection in un workflow di GitHub
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Definire stili a livello di libreria in Angular
Potenziare Azure AI Search con la ricerca vettoriale
Utilizzare gli snapshot con Azure File shares
Usare una container image come runner di GitHub Actions
Creare un'applicazione React e configurare Tailwind CSS
Creare alias per tipi generici e tuple in C#
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Eseguire operazioni sui blob con Azure Storage Actions
Routing statico e PreRendering in una Blazor Web App
Eseguire le GitHub Actions offline
I più letti di oggi
- Aggiungere il metodo SelectMany alla classe Array in TypeScript
- Usare gateway dedicati con Azure Cosmos DB per migliorare le prestazioni
- Recuperare i Popup aperti in una Windows Store app
- AI&ML Conf 2020 - Online
- Preview 4 per ASP.NET MVC
- Speciale Windows Store app: costruire app con WinRT per Windows 8
- Microsoft Security Bulletin MS02-050
- Microsoft Security Bulletin MS04-033
- Attivare l'output caching su ASP.NET Web API
- Ottimizzare l'utilizzo di banda tramite ETag in ASP.NET Core Web API