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
Configurare il nome della run di un workflow di GitHub in base al contesto di esecuzione
Routing statico e PreRendering in una Blazor Web App
Filtering sulle colonne in una QuickGrid di Blazor
Utilizzare politiche di resiliency con Azure Container App
Creare un webhook in Azure DevOps
Installare le Web App site extension tramite una pipeline di Azure DevOps
Eseguire operazioni sui blob con Azure Storage Actions
Miglioramenti nelle performance di Angular 16
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Gestire la cancellazione di una richiesta in streaming da Blazor
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Change tracking e composition in Entity Framework
I più letti di oggi
- Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare il metodo CountBy di LINQ per semplificare raggruppamenti e i conteggi
- Creare una libreria CSS universale: Cards
- Eseguire script pre e post esecuzione di un workflow di GitHub