Scalable Vector Graphics

{{#ifeq:||Un article de Ziki, l'encyclopédie libre.|Une page de Ziki, l'encyclopédie libre.}}

Modèle:Titre en italique Modèle:Redirect Modèle:Méta bandeau d'avertissement{{#ifeq:

       |
       | {{#if:
           |
           |[[{{#ifexist:Catégorie:Article à recycler{{#if:informatique|/informatique}}|Catégorie:Article à recycler{{#if:informatique|/informatique}}|Catégorie:Article à recycler}}|Scalable Vector Graphics]]{{#if: novembre 2009||}}
         }}

}} Modèle:Infobox Format de données

Fichier:Bitmap VS SVG Fr.svg
Différence conceptuelle entre les images matricielles et vectorielles.
Les images vectorielles peuvent être agrandies à l’infini.

Le Modèle:Langue (en français « graphique vectoriel adaptable<ref>Dénomination adoptée entre autres par Fréderic Delhoume pour la traduction du livre SVG de J. David Eisenberg, aux éditions O'Reilly.</ref> »), ou SVG, est un format de données ASCII conçu pour décrire des ensembles de graphiques vectoriels et basé sur XML. Ce format inspiré directement du VML et du PGML est spécifié par le Modèle:Lang.

Historique

SVG a été développé à partir de 1999 par un groupe de sociétés au sein du W3C après la mise en concurrence des propositions Modèle:Lang (PGML) proposé par Adobe à partir de PostScript et Modèle:Lang (VML) proposé par Microsoft à partir de Modèle:Lang (RTF). À cette base se sont ajoutées différentes influences, en particulier les feuilles de style en cascade (CSS)<ref>Modèle:Lien web.</ref>.

En Modèle:Date-, le W3C publie la « Modèle:Lang »<ref>Modèle:Lien web.</ref>. En Modèle:Date-, le standard évolue vers la recommandation en Modèle:Nobr avec une seconde édition en Modèle:Date-, qui est la version actuelle.

En parallèle apparaît en Modèle:Date- la recommandation « Modèle:Langue » dont le but est d'être utilisable sur les appareils mobiles (téléphone mobile, assistant personnel…). Il se présente comme un sous ensemble du « Modèle:Langue »<ref>Modèle:Lien web.</ref>.

La Modèle:Nobr du langage est en cours de définition au sein du W3C depuis 2012<ref>Modèle:Lien web</ref>,<ref>Modèle:Lien web.</ref>, et est stabilisée en version candidate à la validation depuis octobre 2018<ref>Modèle:Lien web</ref> (en date de mars 2023).

SVG : le dessin et les cartes

Le SVG est très utilisé dans le monde de la cartographie et du téléphone mobile.Modèle:Référence nécessaire

Caractéristiques

Les coordonnées, dimensions et structures des objets vectoriels sont indiquées sous forme numérique dans le document XML. Un système spécifique de style (CSS ou XSL) permet d’indiquer les couleurs et les polices de caractères à utiliser. Ce format gère quelques formes géométriques de base (rectangles, ellipsesModèle:Etc.), mais aussi des chemins (Modèle:Lang<ref>Modèle:Lien web.</ref>), qui utilisent les courbes de Bézier et permettent ainsi d’obtenir presque n’importe quelle forme. Le remplissage peut se faire à l’aide de dégradés (Modèle:Lang) de couleurs, de motifs (Modèle:Lang) qui sont des objets SVG quelconques, ou de filtres (appelés Modèle:Lang en imagerie 3D). On peut également appliquer des motifs le long des chemins (Modèle:Lang) et utiliser les fonctions de remplissage. Le canal alpha, pour la transparence, est géré à tous les niveaux.

Comme dans tout document XML, les objets sont organisés sous forme d’arbre. Le format permet l’intégration d’animations, ou la manipulation des objets graphiques par programmation, notamment grâce à des scripts qui peuvent être intégrés dans le SVG.

SVG peut être inclus dans d’autres documents XML, comme des documents XHTML ou des documents XML devant être traités par XSL-FO. Respectant la norme XML, une image SVG peut également être manipulée par l’intermédiaire du modèle Modèle:Lang (DOM).

SVG peut être visualisé nativement avec certains navigateurs web, ou avec un Modèle:Lang (voir : les navigateurs SVG).

Certains environnements graphiques l’utilisent pour la gestion et l’affichage d’icônes, et d’interface, comme X.org, GNOME, KDE ou certains téléphones portables.

Des logiciels graphiques permettent de modifier facilement chaque forme, par exemple en déplaçant des points, ou en changeant la couleur des traits… Il en est de même pour le texte qui peut être modifié sans toucher aux formes, ce qui facilite grandement la modification de schémas, par exemple pour les traductions.

Exemples

Le code suivant permet d’afficher un rectangle, un segment, un cercle et un texte :

Code XML

<syntaxhighlight lang="xml"> <?xml version="1.0" encoding="utf-8"?> <svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="300" height="200">

 <title>Exemple simple de figure SVG</title>
 <desc>
   Cette figure est constituée d'un rectangle,
   d'un segment de droite et d'un cercle.
 </desc>

 <rect width="100" height="80" x="0" y="70" fill="green" />
 <line x1="5" y1="5" x2="250" y2="95" stroke="red" />
 <circle cx="90" cy="80" r="50" fill="blue" />
 <text x="180" y="60">Un texte</text>

</svg> </syntaxhighlight>

Image correspondante

Fichier:ExempleSimple.svg

Il est possible d’utiliser le format SVG pour des images plus complexes (illustration de la Tectonique des plaques).

Fichier:Plates tect2 fr.svg

Mises en œuvre

Le support du SVG est possible à différents niveaux : Modèle:Lang dans le navigateur, au niveau applicatif (navigateur ou logiciel d’édition SVG), au niveau de l'environnement de bureau (KDE, par exemple) ou du « matériel » (téléphone).

Logiciel d’édition

Fichier:MediaWikiExternalEditorImage.png
Manipulation d’image SVG avec Inkscape.

Certains éditeurs visuels sont fournis avec un éditeur en mode texte. Parfois ce mode texte supporte la complétion et la coloration syntaxique pour aider à écrire du SVG.

Mode textuel XML

  • Spket IDE (gratuit pour une utilisation non commerciale) supporte JavaScript (coloration) et le SVG. Existe sous forme de Modèle:Lang ou non pour Eclipse.
  • XMLSpy (gratuit ou commercial) sous Windows
  • oXygen (commercial) supporte XSLT et le rendu SVG

Mode graphique

  • Modèle:Lang
  • Modèle:Lang importe le SVG
  • CorelDraw import création / export édition
  • DRAW SVG, éditeur en ligne libre avec une interface aussi en SVG et de nombreuses fonctionnalités.
  • FontForge : logiciel libre d’édition de fontes, permet d’importer/exporter les fontes SVG ainsi que les chemins SVG pour créer des fontes dans différents formats.
  • GIMP Logiciel libre de dessin et animation orienté bitmap, gérant l’import et l’export des Modèle:Lang au format SVG, et la transformation d’images au format SVG, vers un bitmap grâce à la bibliothèque librsvg
  • Gournal<ref name="2vo">Modèle:Lien web.</ref> et Notelab<ref name="3vo">Modèle:Lien web.</ref>, deux logiciels libres de prises de notes (au stylet, doigts sur tablettes, ainsi qu’à la souris et au clavier) qui utilisent le format SVG comme format de sauvegarde.
  • ImageMagick permet la manipulation et la conversion de fichiers SVG par scripts, en ligne de commande et dans de nombreux langages.
  • Inkscape (logiciel libre sous Licence GNU) et ses deux ancêtres ; Sodipodi et Gill (logiciels libres), supportent complètement SVG (les animations n'étant cependant pas encore supportées sans l'ajout d'extensions<ref>L'extension libre Modèle:Lien vue sur sozi.baierouge.fr permet de faire des présentations animées SVG à la Prezi sur Inskape.</ref>)
  • Karbon14 (logiciel libre)
  • Labography : permet l'ouverture et l'édition du format SVG.
  • OpenOffice.org Draw / LibreOffice, logiciel libre de dessin vectoriel, gère le format SVG.
  • Scribus importe SVG
  • Skitch permet d'enregistrer sous format SVG
  • svg-edit éditeur libre utilisé notamment par BlueGriffon ou en ligne par Framavectoriel

Éditeurs incluant des graphiques SVG

  • CaRMetal exporte au format SVG.
  • Dia : logiciel libre d’édition de diagrammes qui utilise des objets au format SVG et permet l’export des diagrammes au format SVG.
  • [[DOT (langage)|Modèle:Lang]], outil d'affichage de graphes en ligne de commande, supporte l'export au format SVG.
  • Modèle:Lang : logiciel libre qui se décrit comme une application du concept des cartes mentales à l'interface homme-machine. Les cartes ainsi créées peuvent être exportées au format SVG.
  • Fritzing : logiciel libre de dessin de circuits imprimés qui utilise SVG pour l'image des composants et permet l'export au format SVG.
  • GeoGebra exporte au format SVG.
  • JetPunk utilise des cartes du monde SVG pour la plupart de ses quiz, notamment le plus populaire du site, « Pays du monde ».
  • Maple et Mathematica supportent l'export des formules, des feuilles de travail, des figures et des animations au format SVG.
  • Matlab, et GNU Octave (via Gnuplot) supportent l'export des figures et des animations au format SVG.
  • MediaWiki : logiciel libre de documentation collaboratif (notamment utilisé par Wikipédia) qui accepte les illustrations au format SVG, comme on peut le voir sur cette page.
  • Scribus : logiciel libre de mise en page qui permet d’insérer et de manipuler des illustrations au format SVG.
  • Scilab exporte au format SVG.

Logiciel de vectorisation

La création d'un document image vectorielle à partir d'une image raster peut s'effectuer de différentes manières qui correspondent à des usages différents. Elle peut être réalisée de manière simple et automatique quand il ne s'agit que de conserver l'apparence d'une image « au trait ». La création d'un document image vectorielle peut nécessiter le recours à un logiciel spécialisé avec, éventuellement, l'intervention d'un opérateur, s'il s'agit de créer un document image vectoriel où les composantes de l'image (les segments composant les tracés par exemple) peuvent avoir des significations différentes. C'est le cas de la vectorisation d'une carte scannée comportant des objets dont il est intéressant de conserver la différenciation : limite de cours d'eau, limites de voirie, limites de forêtsModèle:Etc.

Logiciel de rastérisation

En ligne

Environnements graphiques supportant SVG

Des environnements graphiques utilisent le format SVG : X.Org, GNOME et KDE, ainsi que de nombreux téléphones cellulaires, tels que les Sony Ericsson. Acorn RISC OS incluent également un support natif d'un format vectoriel nommé Modèle:Lang, proche de SVG.

Les navigateurs SVG

Le rendu SVG est intégré dans HTML5 (balises <svg> et </svg>) et est supporté nativement par la plupart des navigateurs Web depuis 2010<ref>Modèle:Lien web.</ref>.

Support natif du SVG

Support SVG par Modèle:Lang

Les Modèle:Lang pour SVG ne sont plus maintenus actuellement, du moins pour le navigateur Internet Explorer. Seul reste maintenu le Modèle:Lang KSVG.

Visualisateurs de vignettes SVG

  • ShareCAD.org<ref>[2].</ref> visionneuse gratuite en ligne.
  • ABViewer<ref>[3].</ref> permet la visualisation, l'édition et la conversion des fichiers SVG.
  • Nautilus de l'environnement de bureau libre GNOME permet la visualisation de vignettes des fichiers SVG (Linux, Solaris, BSD).
  • Dolphin et Konqueror de l'environnement de bureau libre KDE permettent la visualisation de vignettes des fichiers SVG (Linux, Solaris, BSD).
  • Le gratuiciel RENESIS Player fournit un visualisateur ainsi qu'un visualisateur de vignettes pour l'explorateur de fichiers Windows<ref>{{#invoke:Langue|indicationDeLangue}} Modèle:Lang.</ref>.

Support mobile

La mise en œuvre du rendu SVG pour les périphériques mobiles (PDA, téléphones portables) est faite de façon native (Ikivo, Bitflash Adobe), ou par logiciel de navigation (navigateurs Java Sun, Opera Mini et iPhone Safari).

La norme supportée par ces périphériques dépend du fabricant de téléphone et de la version installée. La plupart des versions supportent la norme Modèle:Lang et parfois 1.1+ avec le support de module annexe (gradient et opacité).

Nokia supporte le rendu SVG en interne pour ses plates-formes des Nokia S60 ou en s'appuyant sur Java et les normes Modèle:Nobr, Java ME pour la plate-forme des S60 (Modèle:3e Modèle:Nobr). D'autres séries comme le 6280 supportent aussi le SVG.

La plupart des téléphones Sony Ericsson phones commencent à supporter le Modèle:Lang comme le K700 et le 1.1+ comme le Modèle:Lien, C905, Modèle:Lien et W995.

Les périphériques supportant la plate-forme java ME et la norme Modèle:Nobr supportent aussi un rendu Modèle:Nobr.

SVG est aussi supporté par des modèles fabriqués par Motorola, Samsung, LG ou Siemens, Sony.

Critiques

La norme SVG ne permet pas de créer des points d'articulationsModèle:Pas clair, tels des nœuds dans un graphe. La notion de pointeur n'existe pas en SVGModèle:Pas clair, ce qui rend la description de scènes dynamiques complexe.

SVG n'a pas hérité de toutes les propriétés de son parent direct VML, tel le dégradé « GradientTitle », l'ombre de type « Perspective », l’« Extrusion » 3D, l'Modèle:Lang, l'Modèle:Lang, l'Modèle:LangModèle:Etc. Des alternatives factices existent, mais elles rendent les fichiers SVG plus lourds et plus lents à l'affichage.

Enfin, SVG n'est en majorité supporté par les navigateurs que dans sa Modèle:Nobr, ce qui ne permet pas d'employer de contrôle de flux (flowRoot, flowRegion) et ne permet donc pas par exemple de faire du texte qui s'adapte à son conteneur et qui effectue des retours à la ligne automatiquement.

Notes et références

Modèle:Références

Annexes

Modèle:Autres projets

Liens externes

Modèle:Palette Modèle:Portail