aboutsummaryrefslogtreecommitdiff
path: root/files/fr/web/svg/tutorial/basic_shapes/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'files/fr/web/svg/tutorial/basic_shapes/index.html')
-rw-r--r--files/fr/web/svg/tutorial/basic_shapes/index.html156
1 files changed, 156 insertions, 0 deletions
diff --git a/files/fr/web/svg/tutorial/basic_shapes/index.html b/files/fr/web/svg/tutorial/basic_shapes/index.html
new file mode 100644
index 0000000000..aa75f0c0ed
--- /dev/null
+++ b/files/fr/web/svg/tutorial/basic_shapes/index.html
@@ -0,0 +1,156 @@
+---
+title: Formes de base
+slug: Web/SVG/Tutoriel/Formes_de_base
+tags:
+ - SVG
+translation_of: Web/SVG/Tutorial/Basic_Shapes
+---
+<p>{{ PreviousNext("SVG/Tutoriel/Positionnement", "Web/SVG/Tutoriel/Paths") }}</p>
+
+<p>Il existe tout un ensemble de formes de base utilisées pour faire du dessin via SVG. Le but de ces formes assez transparent, si on regarde attentivement les noms de chaque élément. Des attributs permettent de configurer leur position et leur taille, mais vous pourrez retrouver les détails de chaque élément avec tous ses attributs à <a href="/fr/SVG/Element" title="fr/SVG/Element">la page des références SVG</a>. Nous nous contenterons ici de couvrir les fonctions de base qui nous sont nécessaires, car elles sont utilisées dans la plupart des documents SVG.</p>
+
+<h3 id="Ajout_de_formes">Ajout de formes</h3>
+
+<p>Pour insérer une forme, vous devez ajouter un élément dans un document. Des éléments différents  correspondent à des formes différentes et ont des attributs différents pour décrire leur taille et leur position. Certaines déclarations sont très fortement redondantes en ce qu'elles peuvent être créées par d'autres formes, mais elles sont toutes là de manière à faciliter votre vie et à rendre le document SVG aussi court et lisible que possible. Toutes les formes de bases sont affichées sur l'image de gauche. Le code pour générer tout cela ressemble à cela :</p>
+
+<p><img alt="" class="internal" src="/@api/deki/files/359/=Shapes.png" style="float: right;"></p>
+
+<pre class="brush: xml">&lt;?xml version="1.0" standalone="no"?&gt;
+&lt;svg width="200" height="250" version="1.1" xmlns="http://www.w3.org/2000/svg"&gt;
+
+ &lt;rect x="10" y="10" width="30" height="30" stroke="black" fill="transparent" stroke-width="5"/&gt;
+ &lt;rect x="60" y="10" rx="10" ry="10" width="30" height="30" stroke="black" fill="transparent" stroke-width="5"/&gt;
+
+ &lt;circle cx="25" cy="75" r="20" stroke="red" fill="transparent" stroke-width="5"/&gt;
+ &lt;ellipse cx="75" cy="75" rx="20" ry="5" stroke="red" fill="transparent" stroke-width="5"/&gt;
+
+ &lt;line x1="10" x2="50" y1="110" y2="150" stroke="orange" fill="transparent" stroke-width="5"/&gt;
+ &lt;polyline points="60 110 65 120 70 115 75 130 80 125 85 140 90 135 95 150 100 145"
+ stroke="orange" fill="transparent" stroke-width="5"/&gt;
+
+ &lt;polygon points="50 160 55 180 70 180 60 190 65 205 50 195 35 205 40 190 30 180 45 180"
+ stroke="green" fill="transparent" stroke-width="5"/&gt;
+
+ &lt;path d="M20,230 Q40,205 50,230 T90,230" fill="none" stroke="blue" stroke-width="5"/&gt;
+&lt;/svg&gt;
+</pre>
+
+<div class="note"><strong>Note :</strong> les attributs <code>stroke</code>, <code>stroke-width</code> et <code>fill</code> sont détaillés plus loin dans ce tutoriel.</div>
+
+<h3 id="Figures_de_bases">Figures de bases</h3>
+
+<h4 id="Rectangles">Rectangles</h4>
+
+<p>L'élément <a href="/fr/SVG/Element/rect" title="rect">rect</a>, comme son nom ne l'indique peut-être pas, dessine à l'écran des rectangles. Il existe 6 attributs de base qui contrôlent la position et la forme du rectangle dessiné ici. L'image précédente affichait 2 rectangles, ce qui est un peu répétitif. Celui de droite possède des attributs <code>rx</code> et <code>ry</code> définis, ce qui lui donne des coins arrondis. Si ces attributs ne sont pas définis, leur valeur par défaut est de 0, ce qui a pour résultats d'afficher un rectangle avec des angles droits.</p>
+
+<pre class="brush: xml"> &lt;rect x="10" y="10" width="30" height="30"/&gt;
+ &lt;rect x="60" y="10" rx="10" ry="10" width="30" height="30"/&gt;
+</pre>
+
+<dl>
+ <dt>x</dt>
+ <dd>Position du rectangle sur l'axe horizontal par rapport au coin supérieur gauche.</dd>
+ <dt>y</dt>
+ <dd>Position du rectangle sur l'axe vertical par rapport au coin supérieur gauche.</dd>
+ <dt>width</dt>
+ <dd>Largeur du rectangle.</dd>
+ <dt>height</dt>
+ <dd>Hauteur du rectangle.</dd>
+ <dt>rx</dt>
+ <dd>Rayon x des coins du rectangle.</dd>
+ <dt>ry</dt>
+ <dd>Rayon y des coins du rectangle.</dd>
+</dl>
+
+<h4 id="Cercles">Cercles</h4>
+
+<p>De la même manière, il est facile de deviner la fonction de l'élément <a href="/fr/SVG/Element/circle" title="circle">circle</a>. Il dessine à l'écran un cercle. Seuls 3 attributs peuvent être définis pour cet élément.</p>
+
+<pre class="brush: xml"> &lt;circle cx="25" cy="75" r="20"/&gt;
+</pre>
+
+<dl>
+ <dt>r</dt>
+ <dd>Rayon du cercle.</dd>
+ <dt>cx</dt>
+ <dd>Position x du centre du cercle.</dd>
+ <dt>cy</dt>
+ <dd>Position y du centre du cercle.</dd>
+</dl>
+
+<h4 id="Ellipses">Ellipses</h4>
+
+<p>Les <a href="/fr/SVG/Element/ellipse" title="ellipse">ellipse</a>s sont juste des sortes de cercles bien particuliers, où l'on peut modifier les rayons x et y séparemment l'un de l'autre (les matheux appellent ces rayons le grand axe et le petit axe).</p>
+
+<pre class="brush: xml"> &lt;ellipse cx="75" cy="75" rx="20" ry="5"/&gt;
+</pre>
+
+<dl>
+ <dt>rx</dt>
+ <dd>Rayon x de l'ellipse.</dd>
+ <dt>ry</dt>
+ <dd>Rayon y de l'ellipse.</dd>
+ <dt>cx</dt>
+ <dd>Position x du centre de l'ellipse.</dd>
+ <dt>cy</dt>
+ <dd>Position y du centre de l'ellipse.</dd>
+</dl>
+
+<h3 id="Figures_complexes">Figures complexes</h3>
+
+<h4 id="Lignes">Lignes</h4>
+
+<p>Les lignes droites permettent de créer des figures plus complexes, en les additionnant les unes avec les autres. L'élément <a href="/fr/docs/Web/SVG/Element/line">line</a> en SVG correspond au segment que l'on apprend en géométrie traditionnelle : c'est une portion de droite délimitée par 2 points. Donc pour définir une droite en SVG, il va falloir lui donner pour attribut les coordonnées des deux points qui la définissent.</p>
+
+<pre class="brush: xml"> &lt;line x1="10" x2="50" y1="110" y2="150"/&gt;
+</pre>
+
+<dl>
+ <dt>x1</dt>
+ <dd>Position x du premier point.</dd>
+ <dt>x2</dt>
+ <dd>Position x du deuxième point.</dd>
+ <dt>y1</dt>
+ <dd>Position y du premier point.</dd>
+ <dt>y2</dt>
+ <dd>Position y du deuxième point.</dd>
+</dl>
+
+<h4 id="Lignes_brisées">Lignes brisées</h4>
+
+<p>Les lignes brisées, aussi appelées lignes polygonales, sont définies par l'élément <a href="/fr/docs/Web/SVG/Element/polyline">polyline</a> en SVG. Elles sont constituées d'un ensemble de lignes droites connectées entre elles, donc d'un ensemble de points se reliant entre eux suivant un ordre défini. Comme ce lot de points peut être assez conséquent à déclarer, un seul attribut est utilisé pour déclarer l'ensemble de points :</p>
+
+<pre class="brush: xml"> &lt;polyline points="60 110, 65 120, 70 115, 75 130, 80 125, 85 140, 90 135, 95 150, 100 145"/&gt;
+</pre>
+
+<dl>
+ <dt>points</dt>
+ <dd>Liste des points, chaque pair de nombres correspondant aux coordonnées x et y de chaque point. Chaque position x est séparée de la position y par un espace. Chaque ensemble de coordonnées est séparé du suivant par une virgule.</dd>
+</dl>
+
+<h4 id="Polygones">Polygones</h4>
+
+<p>Le <a href="/fr/docs/web/SVG/Element/polygon">polygon</a>e fonctionne exactement de la même manière que la ligne brisée. Au final, un polygone n'est rien d'autre qu'une ligne brisée qui relie une série de points. Toutefois, pour les polygones, le chemin de cette ligne retourne automatiquement au point de départ, créant ainsi une forme fermée. Il est à noter que le rectangle est un type de polygone particulier. Il est donc possible, pour des besoins de flexibilité, de déclarer un rectangle en utilisant l'élément <code>polygon</code>.</p>
+
+<pre class="brush: xml">&lt;polygon points="50 160, 55 180, 70 180, 60 190, 65 205, 50 195, 35 205, 40 190, 30 180, 45 180"/&gt;</pre>
+
+<dl>
+ <dt>points</dt>
+ <dd>Idem que l'attribut <code>points</code> de l'élément <code>polyline</code>. Liste des points, chaque paire de nombres correspondant aux coordonnées x et y de chaque point. Chaque position x est séparée de la position y par un espace, chaque ensemble de coordonnées est séparé du suivant par une virgule. Une dernière ligne ferme automatiquement la forme en retournant au point de départ.</dd>
+</dl>
+
+<h4 id="Chemins">Chemins</h4>
+
+<p>L'élément pour tracer les chemins, très logiquement nommé <a href="/fr/docs/Web/SVG/Tutorial/Paths">path</a>, est sûrement la forme la plus généraliste qui peut être utilisée en SVG. Avec un élément <code>path</code>, vous pouvez dessiner un rectangle (avec ou sans coins arrondis), des cercles, des ellipses, des lignes brisées et des polygones. De manière plus basique, il est aussi possible de dessiner d'autres types de formes, comme des courbes de Bézier, des paraboles, et bien plus encore. Pour cette raison, l'élément <code>path</code> en lui même sera un chapitre entier de ce tutoriel, mais pour le moment, nous allons juste voir comment définir cet élément.</p>
+
+<pre class="brush: xml"> &lt;path d="M 20 230 Q 40 205, 50 230 T 90230"/&gt;
+</pre>
+
+<dl>
+ <dt>d</dt>
+ <dd>Un ensemble d'information définissant le chemin à dessiner. Pour en savoir plus, allez à la page à propos des <a href="/fr/docs/Web/SVG/Tutorial/Paths">Chemins</a>.</dd>
+</dl>
+
+<p>{{ PreviousNext("SVG/Tutoriel/Positionnement", "Web/SVG/Tutoriel/Paths") }}</p>
+
+<p><span class="comment">Interwiki Languages Links</span></p>