Dal 2001 il consorzio W3C ha messo a disposizione uno standard di nome SVG, acronimo di Scalable Vector Graphics, il cui intento è permettere la definizione di immagini vettoriali attraverso un linguaggio di markup basato su XML.
L'uso delle immagini vettoriali si contrappone a quelle bitmap per via di importanti vantaggi:
- Permette una definizione infinta perché le immagini sono descritte invece di essere rappresentate da punti;
- Essendo basato su markup la figura può essere indicizzata e contenere metadati.
Questo formato è in genere rappresentato dai file .svg e viene trattato principalmente da strumenti di disegno come Adobe Illustrator o CorelDraw. Con l'avvento di HTML5 è stato però introdotto anche la possibilità di incorporare tali file all'interno di una pagina HTML e un nuovo apposito tag svg.
Questo permette di inserire facilmente piccole figure o di interagirvi tramite DOM e linguaggi di scripting, dando soprattutto una spinta ai browser per far sì che implementino questo standard ormai presente da molti anni. Le ultime versioni dei browser sono infatti pressoché allineate alla versione 1.1.
Di seguito ecco quindi un esempio di SVG all'interno di una pagina HTML5 per la visualizzazione di un grafico a torta.
<!DOCTYPE HTML> <html> <head> <title>Esempio</title> </head> <body> <svg width="500" height="450"> <path fill="blue" d="M 310,402 L 213,214 L 326,35 C 454,111 468,319 310,402 z " /> <path fill="red" d="M 3,208 L 213,214 L 326,35 C 202,-46 8,30 3,208 z "/> <path fill="yellow" d="M 3,208 L 213,214 L 311,400 C 177,467 3,380 3,208 z" /> </svg> </body> </html>
Come si può vedere il markup SVG si integra con la struttura DOM di una normale pagina HTML e produce il risultato visibile nella figura.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Inizializzare i container in Azure Container Apps
Load test di ASP.NET Core con k6
Accesso sicuro ai secrets attraverso i file in Azure Container Apps
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Effettuare il binding di date in Blazor
Reactive form tipizzati con modellazione del FormBuilder in Angular
Potenziare Azure AI Search con la ricerca vettoriale
Personalizzare l'errore del rate limiting middleware in ASP.NET Core
Implementare il throttling in ASP.NET Core
Miglioramenti nell'accessibilità con Angular CDK
Evitare la command injection in un workflow di GitHub
I più letti di oggi
- Vuoi incontrare Bill Gates? Viaggia con ASPItalia.com!
- Customizzare il pager del DataGrid
- Stabilire un collegamento VPN tra una Web App e una Virtual Network
- Documentare ASP.NET Web API con Swagger
- Usare i servizi REST di BING per ottenere informazioni sulla posizione dell'utente
- Visual Studio 2005 CTP May