Scegli il formato dell'immagine corretto

La prima domanda che dovresti porti è se un'immagine sia, anzi, necessarie per ottenere l'effetto che stai cercando. Un buon design è semplice e garantisce sempre le prestazioni migliori. Se puoi eliminare una risorsa immagine, che spesso richiedono un numero elevato di byte rispetto a HTML, CSS, JavaScript e altri asset presenti sulla pagina, questa è sempre la strategia di ottimizzazione migliore. Detto questo, un'immagine ben posizionata può comunicare più informazioni di mille parole, quindi spetta a te trovare questo equilibrio.

Successivamente, devi valutare se esiste una tecnologia alternativa in grado di fornire i risultati desiderati. ma in modo più efficiente:

  • Effetti CSS (come ombre o sfumature) e animazioni CSS può essere utilizzato per produrre asset indipendenti dalla risoluzione che sono sempre nitidi a ogni risoluzione e livello di zoom, spesso solo una frazione dei byte richiesti da un file immagine.
  • I caratteri web consentono l'utilizzo di caratteri tipografici originali mantenendo la capacità di selezionare, cercare e ridimensionarlo, un miglioramento significativo nell'usabilità.

Se ti capita di non riuscire a codificare un testo in un asset immagine, interrompi la codifica e riconsidera la procedura. Un'ottima tipografia è fondamentale per un design, un branding e una leggibilità ottimali, ma il testo nelle immagini offre un'esperienza utente scadente: il testo non sia selezionabile, non disponibile per la ricerca o zoomabile, non accessibili e non adatte ai dispositivi con una risoluzione elevata di DPI. L'utilizzo dei caratteri web richiede un proprio insieme di ottimizzazioni, ma risolve tutti questi problemi ed è sempre la scelta migliore per la visualizzazione del testo.

Scegli il formato dell'immagine giusto

Se sei sicuro che un'immagine sia l'opzione corretta, devi selezionare con attenzione il tipo di immagine più adatto al lavoro.

Immagini raster e vettoriali con zoom aumentato
Immagine raster dell'immagine vettoriale con zoom aumentato (L) (R)
  • Grafica vettoriale utilizzare linee, punti e poligoni per rappresentare un'immagine.
  • Grafica raster rappresentare un'immagine codificando i singoli valori di ciascun pixel all'interno di una griglia rettangolare.

Ogni formato ha i suoi pro e i suoi contro. I formati vettoriali sono ideali per immagini costituite da semplici forme geometriche come loghi, testo o icone. Garantiscono risultati nitidi con ogni risoluzione e impostazione di zoom, il che li rende un formato ideale per gli schermi e le risorse ad alta risoluzione che devono essere visualizzate in varie dimensioni.

Tuttavia, i formati vettoriali non sono soddisfacenti quando la scena è complicata (ad esempio, una foto): la quantità di markup SVG per descrivere tutte le forme può essere elevata e l'output potrebbe comunque non essere "fotorealistico". In questo caso è consigliabile utilizzare un formato immagine raster come PNG, JPEG, WebP o AVIF.

Le immagini raster non hanno le stesse proprietà di risoluzione o zoom indipendenti Quando fai lo scale up di un'immagine raster, vedrai elementi grafici frastagliati e sfocati. Potrebbe quindi essere necessario salvare più versioni di un'immagine raster a diverse risoluzioni. per offrire agli utenti un'esperienza ottimale.

Implicazioni degli schermi ad alta risoluzione

Esistono due diversi tipi di pixel: pixel CSS e pixel del dispositivo. Un singolo pixel CSS può corrispondere direttamente a un singolo pixel del dispositivo oppure essere supportato da più pixel del dispositivo. Qual è il punto? Beh, maggiore è il numero di pixel del dispositivo, più dettagliati saranno i dettagli dei contenuti visualizzati sullo schermo.

Tre immagini che mostrano la differenza tra i pixel CSS e i pixel del dispositivo.
La differenza tra i pixel CSS e i pixel del dispositivo.

Gli schermi con elevato DPI (HiDPI) producono risultati stupendi, ma c'è un ovvio compromesso: gli asset immagine richiedono più dettagli per sfruttare il numero di pixel più elevato. La buona notizia è che le immagini vettoriali sono ideale per questo compito, poiché possono essere visualizzati a qualsiasi risoluzione con risultati nitidi, potresti incorrere in costi di elaborazione più elevati per eseguire il rendering di dettagli più piccoli, ma la risorsa sottostante è la stessa ed è indipendente dalla risoluzione.

D'altra parte, le immagini raster rappresentano una sfida molto più grande perché codificano i dati immagine in base al pixel. Pertanto, maggiore è il numero di pixel, maggiore sarà la dimensione del file di un'immagine raster. Consideriamo, ad esempio, la differenza tra un asset foto visualizzato a 100 x 100 pixel (CSS):

Risoluzione dello schermo Pixel totali Dimensioni file non compresse (4 byte per pixel)
1x 100 x 100 = 10.000 40.000 byte
2x 100 x 100 x 4 = 40.000 160.000 byte
3 100 x 100 x 9 = 90.000 360.000 byte

Quando raddoppiamo la risoluzione dello schermo fisico, il numero totale di pixel aumenta di un fattore di quattro: il doppio dei pixel orizzontali è moltiplicato per il doppio dei pixel verticali. Pertanto, un valore "2x" lo schermo non solo raddoppia, ma quadruplica il numero di pixel necessari.

Ma cosa significa nella pratica? Gli schermi ad alta risoluzione consentono di creare immagini stupende, il che può essere un'ottima caratteristica del prodotto. Tuttavia, gli schermi ad alta risoluzione richiedono anche immagini ad alta risoluzione, quindi:

  • Scegli la preferenza per le immagini vettoriali, quando possibile, in quanto sono indipendenti dalla risoluzione e garantiscono sempre risultati nitidi.
  • Se è necessaria un'immagine raster, pubblica immagini adattabili.

Caratteristiche dei diversi formati di immagini raster

Oltre a diversi algoritmi di compressione con perdita di dati e perdita, formati di immagine diversi supportano diverse funzioni, come canali di animazione e trasparenza (alfa). Di conseguenza, la scelta del "formato giusto" per una determinata immagine è la combinazione di risultati visivi e requisiti funzionali desiderati.

Formato Trasparenza Animazione Browser
PNG No Tutte
JPEG No No Tutte
WebP Tutti i browser moderni. Vedi la sezione Posso utilizzare?
AVIF No. Vedi la sezione Posso utilizzare?

Esistono due formati di immagine raster universalmente supportati: PNG e JPEG. Oltre a questi formati, i browser moderni supportano il nuovo formato WebP, mentre solo alcuni supportano il nuovo formato AVIF. Entrambi i formati più recenti offrono una compressione complessiva migliore e un maggior numero di funzionalità. Allora, quale formato dovresti usare?

WebP e AVIF forniscono generalmente una compressione migliore rispetto ai formati precedenti, e devono essere utilizzati ove possibile. Puoi utilizzare immagini WebP o AVIF insieme a un'immagine JPEG o PNG come alternativa. Per maggiori dettagli, vedi Utilizzare immagini WebP.

Per quanto riguarda i formati delle immagini meno recenti, considera quanto segue:

  1. Hai bisogno di animazioni? Utilizza gli elementi <video>.
    • E le GIF? La GIF limita la tavolozza dei colori a un massimo di 256 colori, e crea file di dimensioni notevolmente maggiori rispetto agli elementi <video>. Consulta Sostituisci le GIF animate con un video.
  2. Hai bisogno di preservare i dettagli con la massima risoluzione? Usa un file PNG o WebP senza perdita di dati.
    • Il formato PNG non applica algoritmi di compressione con perdita di dati, oltre alla scelta della dimensione della tavolozza dei colori. Di conseguenza, produrrà immagini della massima qualità, ma con un costo decisamente maggiore rispetto ad altri formati. Da usare con accortezza.
    • WebP ha una modalità di codifica senza perdita di dati che potrebbe essere più efficiente di PNG.
    • Se l'asset immagine contiene immagini composte da forme geometriche, valuta la possibilità di convertirlo in un formato vettoriale (SVG).
    • Se l'asset immagine contiene testo, interrompi e riconsidera. Il testo nelle immagini non è selezionabile, disponibile per la ricerca o zoomabile. Se devi dare un look personalizzato (per il branding o per altri motivi), usa un carattere web.
  3. Stai ottimizzando una foto, uno screenshot o un asset immagine simile? Utilizza JPEG, WebP con perdita di dati o AVIF con perdita di dati.
    • JPEG utilizza una combinazione di ottimizzazione con perdita e senza perdita di dati per ridurre le dimensioni del file dell'asset immagine. Prova diversi livelli di qualità JPEG per trovare il miglior compromesso tra qualità e dimensione del file per il tuo asset.
    • WebP con perdita di dati o AVIF con perdita di dati possono essere alternative JPEG accettabili, ma tieni presente che la modalità con perdita di dati di WebP in particolare tralascia alcune informazioni sulla crominanza per ottenere immagini più piccole. Ciò significa che i colori selezionati potrebbero non essere uguali a un file JPEG equivalente.

Infine, tieni presente che se utilizzi un componente WebView per eseguire il rendering dei contenuti nella tua applicazione specifica per la piattaforma, avrai il controllo completo del client e potrai utilizzare esclusivamente WebP! Facebook e molti altri utilizzano WebP per distribuire tutte le loro immagini all'interno delle loro applicazioni: il risparmio è davvero valsa la pena.

Impatto sulla visualizzazione più grande con contenuti (LCP)

Le immagini potrebbero essere candidati LCP. Ciò significa che le dimensioni di un'immagine influiscono sul tempo di caricamento. Quando un'immagine è una candidata LCP, è fondamentale codificarla in modo efficiente per migliorarla.

Ti consigliamo di applicare i consigli contenuti in questo articolo in modo che il rendimento percettivo di una pagina sia il più rapido possibile per tutti gli utenti. L'LCP fa parte del rendimento percettivo poiché misura la velocità di visualizzazione dell'elemento più grande (e quindi più percepibile) sulla pagina.