Abbiamo già discusso in passato di come la Universal Windows Platform fornisca la possibilità a tutti gli sviluppatori di creare applicazioni più accattivanti e funzionali, anche grazie all'introduzione di paradigmi come il Fluent Design Language (rivisitato proprio a Microsoft Build in questi giorni) che permette di sfruttare luce e colori per rendere le applicazioni più "vive".
Per quanto riguarda la gestione dei colori, in alcuni script precedenti abbiamo visto come possiamo recuperare, ad esempio, il colore predefinito, piuttosto che il tema (chiaro/scuro), in Windows, così da creare applicazioni dinamiche e costruite su misura per gli utenti che ne faranno uso. Un altro aspetto, ad esempio per le applicazioni che si occupano di scrittura del testo, piuttosto che di elaborazioni di immagini, riguarda il cambio del tema a seconda del colore prevalente all'interno di un'immagine caricata.
Per recuperare il colore prevalente, è necessario lavorare un po' con le trasformazioni della classe BitmapDecoder, come mostrato nell'esempio seguente:
private async Task<Color> GetDominantColorAsync(Uri imageUri) { // apertura dell'immagine var file = await StorageFile.GetFileFromApplicationUriAsync(imageUri); // caricamento dello stream using (var stream = await file.OpenAsync(FileAccessMode.Read)) { // creazione del decoder var decoder = await BitmapDecoder.CreateAsync(stream); // creazione di una trasformazione per recuperare un'immagine 1x1 var myTransform = new BitmapTransform { ScaledHeight = 1, ScaledWidth = 1 }; // ricalcolo dei pixel var pixels = await decoder.GetPixelDataAsync( BitmapPixelFormat.Rgba8, BitmapAlphaMode.Ignore, myTransform, ExifOrientationMode.IgnoreExifOrientation, ColorManagementMode.DoNotColorManage); // recupero dei byte sull'immagine scalata var bytes = pixels.DetachPixelData(); // lettura del colore return Color.FromArgb(255, bytes[0], bytes[1], bytes[2]); } }
Come si può notare, infatti, una volta aperto il file viene trasformata l'immagine in ingresso per trattarla come se fosse un unico grande pixel, e da qui è sufficiente ricostruire il colore semplicemente recuperando le varie tonalità RGB a cui viene poi applicato un canale alpha (di trasparenza) al massimo, così da renderlo visibile.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Cambiare la chiave di partizionamento di Azure Cosmos DB
Gestire la cancellazione di una richiesta in streaming da Blazor
Supportare il sorting di dati tabellari in Blazor con QuickGrid
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
Creazione di plugin per Tailwind CSS: espandere le Funzionalità del Framework
Introduzione alle Container Queries
Evitare il flickering dei componenti nel prerender di Blazor 8
Eseguire i worklow di GitHub su runner potenziati
Effettuare il binding di date in Blazor
Utilizzare QuickGrid di Blazor con Entity Framework
Change tracking e composition in Entity Framework
Eseguire script pre e post esecuzione di un workflow di GitHub
I più letti di oggi
- Build 2015: segui con noi tutte le novità per gli sviluppatori in diretta da San Francisco
- Speciale Windows Live Services: come integrarli nelle proprie applicazioni
- Rilasciata la RTM di SQL Server 2012, la versione Express subito in download
- Build 2014: tutte le novità per gli sviluppatori in diretta da San Francisco
- .NET Managed provider per MySQL
- WS-I approva Basic Profile 1.0
- Due regali dal Tech-Ed USA 2004: WSE 2.0 e VS 2005 Team System
- VS 2005 e SQL Server 2005 Express da scaricare
- Microsoft aggiorna WinFS beta 1 per VS 2005
- Utilizzare CLEditor per consentire l'input di HTML in ASP.NET MVC