diff options
Diffstat (limited to 'files/fr/web/css/scaling_of_svg_backgrounds')
-rw-r--r-- | files/fr/web/css/scaling_of_svg_backgrounds/index.md | 350 |
1 files changed, 182 insertions, 168 deletions
diff --git a/files/fr/web/css/scaling_of_svg_backgrounds/index.md b/files/fr/web/css/scaling_of_svg_backgrounds/index.md index 8abfc2fcc4..5af2008353 100644 --- a/files/fr/web/css/scaling_of_svg_backgrounds/index.md +++ b/files/fr/web/css/scaling_of_svg_backgrounds/index.md @@ -8,326 +8,340 @@ tags: translation_of: Web/CSS/Scaling_of_SVG_backgrounds original_slug: Web/CSS/Redimensionnement_arrière-plans_SVG --- -<p>Les images SVG sont très flexibles et lorsqu'on les utilise en CSS avec les propriétés {{cssxref("background-image")}} et {{cssxref("background-size")}}, il faut s'assurer de considérer les différents aspects qui leurs sont propres. Dans cet article, on décrit comment les images SVG sont redimensionnées grâce à ces propriétés.</p> +Les images SVG sont très flexibles et lorsqu'on les utilise en CSS avec les propriétés {{cssxref("background-image")}} et {{cssxref("background-size")}}, il faut s'assurer de considérer les différents aspects qui leurs sont propres. Dans cet article, on décrit comment les images SVG sont redimensionnées grâce à ces propriétés. -<h2 id="Un_algorithme_simple">Un algorithme simple</h2> +## Un algorithme simple -<p>Dans la plupart des cas, l'algorithme utilisé pourra être réduit à ces quatre règles. Ces règles ne sont pas exhaustives et ne couvrent pas certains cas aux limites mais cela sera suffisant ici :</p> +Dans la plupart des cas, l'algorithme utilisé pourra être réduit à ces quatre règles. Ces règles ne sont pas exhaustives et ne couvrent pas certains cas aux limites mais cela sera suffisant ici : -<ol> - <li>Si {{cssxref("background-size")}} définit une dimension fixe (des pourcentages ou des unités relatives fixées par le contexte), cette dimension l'emporte.</li> - <li>Si l'image possède des proportions intrinsèques (autrement dit, si le ratio largeur/hauteur est constant : 16:9, 4:3, 2.39:1, 1:1), l'arrière-plan sera affiché en conservant ces proportions.</li> - <li>Si l'image définit une taille et que celle-ci n'est pas modifiée par une contrainte quelconque, cette taille l'emporte.</li> - <li>Dans tous les autres cas, l'image est affichée avec la taille de la zone dédiée à l'arrière-plan.</li> -</ol> +1. Si {{cssxref("background-size")}} définit une dimension fixe (des pourcentages ou des unités relatives fixées par le contexte), cette dimension l'emporte. +2. Si l'image possède des proportions intrinsèques (autrement dit, si le ratio largeur/hauteur est constant : 16:9, 4:3, 2.39:1, 1:1), l'arrière-plan sera affiché en conservant ces proportions. +3. Si l'image définit une taille et que celle-ci n'est pas modifiée par une contrainte quelconque, cette taille l'emporte. +4. Dans tous les autres cas, l'image est affichée avec la taille de la zone dédiée à l'arrière-plan. -<p>On notera ici que l'algorithme ne prend en cas que les dimensions et/ou les proportions de l'image (leur absence éventullement). Ainsi, une image SVG dont les dimensions sont fixées sera traitée comme une image matricielle de la même taille.</p> +On notera ici que l'algorithme ne prend en cas que les dimensions et/ou les proportions de l'image (leur absence éventullement). Ainsi, une image SVG dont les dimensions sont fixées sera traitée comme une image matricielle de la même taille. -<h2 id="Fichiers_dexemples">Fichiers d'exemples</h2> +## Fichiers d'exemples -<p>Avant d'aller plus loin dans l'exploration des résultats avec {{cssxref("background-size")}}, il serait judicieux de disposer de différentes images sources avec différents paramètres de dimensions, proportions, etc.</p> +Avant d'aller plus loin dans l'exploration des résultats avec {{cssxref("background-size")}}, il serait judicieux de disposer de différentes images sources avec différents paramètres de dimensions, proportions, etc. -<p>Pour chaque cas d'exemple fourni ci-après, l'image est affichée dans une boîte carrée de 150 pixels et un lien est fourni vers le fichier SVG correspondant.</p> +Pour chaque cas d'exemple fourni ci-après, l'image est affichée dans une boîte carrée de 150 pixels et un lien est fourni vers le fichier SVG correspondant. -<h3 id="Image_sans_dimension_ni_proportion">Image sans dimension ni proportion</h3> +### Image sans dimension ni proportion -<p>Cette image ne possède ni dimension ni proportion. Quelle que soit sa taille, il n'y aura pas de ratio largeur/hauteur particulier. On a ici une image qui forme un dégradé, quelles que soient les dimensions et la proportion de l'écran.</p> +Cette image ne possède ni dimension ni proportion. Quelle que soit sa taille, il n'y aura pas de ratio largeur/hauteur particulier. On a ici une image qui forme un dégradé, quelles que soient les dimensions et la proportion de l'écran. -<p><img src="no-dimensions-or-ratio.png"></p> +![](no-dimensions-or-ratio.png) -<p><a href="https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3469/6587a382ffb2c944462a6b110b079496/no-dimensions-or-ratio.svg" title="no-dimensions-or-ratio.svg">Fichier SVG source</a></p> -<h3 id="Image_sans_proportion_avec_une_dimension_fixée">Image sans proportion avec une dimension fixée</h3> +[Fichier SVG source](https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3469/6587a382ffb2c944462a6b110b079496/no-dimensions-or-ratio.svg "no-dimensions-or-ratio.svg") -<p>Cette image mesure 100 pixels de large mais n'a pas de hauteur ni de proportion intrinsèque. On a ainsi une bande d'arrière-plan qui peut être étirée sur toute la hauteur d'un bloc.</p> +### Image sans proportion avec une dimension fixée -<p><img src="100px-wide-no-height-or-ratio.png"></p> +Cette image mesure 100 pixels de large mais n'a pas de hauteur ni de proportion intrinsèque. On a ainsi une bande d'arrière-plan qui peut être étirée sur toute la hauteur d'un bloc. -<p><a href="https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3468/af73bea307a10ffe2559df42fad199e3/100px-wide-no-height-or-ratio.svg" title="100px-wide-no-height-or-ratio.svg">Fichier SVG source</a></p> +![](100px-wide-no-height-or-ratio.png) -<h3 id="Image_avec_une_dimension_fixée_et_des_proportions_intrinsèques">Image avec une dimension fixée et des proportions intrinsèques</h3> +[Fichier SVG source](https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3468/af73bea307a10ffe2559df42fad199e3/100px-wide-no-height-or-ratio.svg "100px-wide-no-height-or-ratio.svg") -<p>Cette image mesure 100 pixels de haut mais n'a pas de largeur fixée. Elle définit également une proportion de 3:4. Ainsi, le rapport largeur/hauteur sera toujours 3/4.</p> +### Image avec une dimension fixée et des proportions intrinsèques -<p>On a ici un cas très proche de l'image pour laquelle on définit une largeur et une hauteur car, une fois qu'on a une dimension et une proportion, la deuxième dimension est implicite. Cela n'en reste pas moins un exemple utile.</p> +Cette image mesure 100 pixels de haut mais n'a pas de largeur fixée. Elle définit également une proportion de 3:4. Ainsi, le rapport largeur/hauteur sera toujours 3/4. -<p><img src="100px-height-3x4-ratio.png"></p> +On a ici un cas très proche de l'image pour laquelle on définit une largeur et une hauteur car, une fois qu'on a une dimension et une proportion, la deuxième dimension est implicite. Cela n'en reste pas moins un exemple utile. -<p><a href="https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3467/fd0c534c506be06d52f0a954a59863a6/100px-height-3x4-ratio.svg" title="100px-height-3x4-ratio.svg">Fichier SVG source</a></p> +![](100px-height-3x4-ratio.png) -<h3 id="Image_sans_largeur_ni_hauteur_mais_avec_des_proportions_intrinsèques">Image sans largeur ni hauteur mais avec des proportions intrinsèques</h3> +[Fichier SVG source](https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3467/fd0c534c506be06d52f0a954a59863a6/100px-height-3x4-ratio.svg "100px-height-3x4-ratio.svg") -<p>Cette image n'indique pas de hauteur ou de largeur mais un ratio intrinsèque de 1:1. On obtiendra toujours un carré (qui pourra être utilisé comme une icône) pour n'importe quelle taille : 32x32, 128x128, or 512x512.</p> +### Image sans largeur ni hauteur mais avec des proportions intrinsèques -<p><img src="no-dimensions-1x1-ratio.png"></p> +Cette image n'indique pas de hauteur ou de largeur mais un ratio intrinsèque de 1:1. On obtiendra toujours un carré (qui pourra être utilisé comme une icône) pour n'importe quelle taille : 32x32, 128x128, or 512x512. -<p><a href="https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3466/a3398e03c058d99fb2b7837167cdbc26/no-dimensions-1x1-ratio.svg" title="no-dimensions-1x1-ratio.svg">Fichier SVG source</a></p> +![](no-dimensions-1x1-ratio.png) -<h2 id="Exemples_de_redimensionnement">Exemples de redimensionnement</h2> +[Fichier SVG source](https://media.prod.mdn.mozit.cloud/attachments/2012/07/09/3466/a3398e03c058d99fb2b7837167cdbc26/no-dimensions-1x1-ratio.svg "no-dimensions-1x1-ratio.svg") -<p>Appliquons maintenant différents redimensionnements sur ces images. Pour chacun des exemples qui suivent, les rectangles dessinés font 300 pixels de large et 200 pixels de haut. De plus, on utilise {{cssxref("background-repeat")}} avec <code>no-repeat</code> pour plus de clarté..</p> +## Exemples de redimensionnement -<div class="note"> - <p><strong>Note :</strong> Les images montrées ci-après illustrent le rendu <strong>attendu</strong>. Les navigateurs peuvent ne pas produire le bon résultat.</p> -</div> +Appliquons maintenant différents redimensionnements sur ces images. Pour chacun des exemples qui suivent, les rectangles dessinés font 300 pixels de large et 200 pixels de haut. De plus, on utilise {{cssxref("background-repeat")}} avec `no-repeat` pour plus de clarté.. -<h3 id="Indiquer_des_dimensions_fixées_sur_les_deux_axes">Indiquer des dimensions fixées sur les deux axes</h3> +> **Note :** Les images montrées ci-après illustrent le rendu **attendu**. Les navigateurs peuvent ne pas produire le bon résultat. -<p>Si on utilise {{cssxref("background-size")}} pour indiquer la longueur et la largeur de l'image, celles-ci seront toujours utilisées (cf. la règle n°1 précédemment énoncée). Autrement dit, l'image sera toujours étirée pour obtenir ces dimensions, quelles que soient les dimensions initiales de l'image ou ses proportions.</p> +### Indiquer des dimensions fixées sur les deux axes -<h4 id="SVG_source_Aucune_dimension_ni_proportion">SVG source : Aucune dimension ni proportion</h4> +Si on utilise {{cssxref("background-size")}} pour indiquer la longueur et la largeur de l'image, celles-ci seront toujours utilisées (cf. la règle n°1 précédemment énoncée). Autrement dit, l'image sera toujours étirée pour obtenir ces dimensions, quelles que soient les dimensions initiales de l'image ou ses proportions. -<p>Avec ces déclarations CSS :</p> +#### SVG source : Aucune dimension ni proportion -<pre class="brush: css">background: url(no-dimensions-or-ratio.svg); +Avec ces déclarations CSS : + +```css +background: url(no-dimensions-or-ratio.svg); background-size: 125px 175px; -</pre> +``` -<p>On doit obtenir un résultat semblable à :</p> +On doit obtenir un résultat semblable à : -<p><img src="fixed-no-dimensions-or-ratio.png"></p> +![](fixed-no-dimensions-or-ratio.png) -<h4 id="SVG_source_Une_dimension_définie_et_aucune_proportion">SVG source : Une dimension définie et aucune proportion</h4> +#### SVG source : Une dimension définie et aucune proportion -<p>Avec ces déclarations CSS :</p> +Avec ces déclarations CSS : -<pre class="brush: css">background: url(100px-wide-no-height-or-ratio.svg); +```css +background: url(100px-wide-no-height-or-ratio.svg); background-size: 250px 150px; -</pre> +``` -<p>On doit obtenir un résultat semblable à :</p> +On doit obtenir un résultat semblable à : -<p><img src="fixed-100px-wide-no-height-or-ratio.png"></p> +![](fixed-100px-wide-no-height-or-ratio.png) -<h4 id="SVG_source_Une_dimension_définie_et_des_proportions_intrinsèques">SVG source : Une dimension définie et des proportions intrinsèques</h4> +#### SVG source : Une dimension définie et des proportions intrinsèques -<p>Avec ces déclarations CSS :</p> +Avec ces déclarations CSS : -<pre class="brush: css">background: url(100px-height-3x4-ratio.svg); +```css +background: url(100px-height-3x4-ratio.svg); background-size: 275px 125px; -</pre> +``` -<p>On doit obtenir un résultat semblable à :</p> +On doit obtenir un résultat semblable à : -<p><img src="fixed-100px-height-3x4-ratio.png"></p> +![](fixed-100px-height-3x4-ratio.png) -<h4 id="SVG_source_Aucune_largeur_ni_hauteur_définie_mais_des_proportions_intrinsèques">SVG source : Aucune largeur ni hauteur définie mais des proportions intrinsèques</h4> +#### SVG source : Aucune largeur ni hauteur définie mais des proportions intrinsèques -<p>Avec ces déclarations CSS :</p> +Avec ces déclarations CSS : -<pre class="brush: css">background: url(no-dimensions-1x1-ratio.svg); +```css +background: url(no-dimensions-1x1-ratio.svg); background-size: 250px 100px; -</pre> +``` -<p>On doit obtenir un résultat semblable à :</p> +On doit obtenir un résultat semblable à : -<p><img src="fixed-no-dimensions-1x1-ratio.png"></p> +![](fixed-no-dimensions-1x1-ratio.png) -<h3 id="Utiliser_contain_ou_cover">Utiliser <code>contain</code> ou <code>cover</code></h3> +### Utiliser `contain` ou `cover` -<p>En utilisant la valeur <code>cover</code> pour {{cssxref("background-size")}}, l'image sera réduite au maximum pour couvrir toute la zone de l'arrière-plan. <code>contain</code> fonctionne de façon symétrique, l'image est agrandie autant que possible sans être rognée par la zone de l'arrière-plan.</p> +En utilisant la valeur `cover` pour {{cssxref("background-size")}}, l'image sera réduite au maximum pour couvrir toute la zone de l'arrière-plan. `contain` fonctionne de façon symétrique, l'image est agrandie autant que possible sans être rognée par la zone de l'arrière-plan. -<p>Pour une image avec des proportions intrinsèques, une seule dimension suffira à déterminer la taille pour <code>cover</code>/<code>contain</code>. En revanche, sans ratio, ce n'est pas suffisant et il faut donc utiliser les contraintes de la zone de l'arrière-plan.</p> +Pour une image avec des proportions intrinsèques, une seule dimension suffira à déterminer la taille pour `cover`/`contain`. En revanche, sans ratio, ce n'est pas suffisant et il faut donc utiliser les contraintes de la zone de l'arrière-plan. -<h4 id="SVG_source_Aucune_dimension_ni_proportion_2">SVG source : Aucune dimension ni proportion</h4> +#### SVG source : Aucune dimension ni proportion -<p>Si une image n'a ni dimensions définie, ni proportions définies, les règles 2 ou 3 ne pourront pas s'appliquer. La règle 4 est donc utilisée et l'image couvre toute la zone (ce qui satisfait d'ailleurs les différentes contraintes).</p> +Si une image n'a ni dimensions définie, ni proportions définies, les règles 2 ou 3 ne pourront pas s'appliquer. La règle 4 est donc utilisée et l'image couvre toute la zone (ce qui satisfait d'ailleurs les différentes contraintes). -<pre class="brush: css">background: url(no-dimensions-or-ratio.svg); +```css +background: url(no-dimensions-or-ratio.svg); background-size: contain; -</pre> +``` -<p>Le résultat obtenu sera :</p> +Le résultat obtenu sera : -<p><img src="no-dimensions-or-ratio-contain.png"></p> +![](no-dimensions-or-ratio-contain.png) -<h4 id="SVG_source_Une_dimension_définie_et_aucune_proportion_2">SVG source : Une dimension définie et aucune proportion</h4> +#### SVG source : Une dimension définie et aucune proportion -<p>De même si l'image possède une dimension mais aucune proportion, la règle 4 sera appliquée : l'image est ainsi redimensionnée pour couvrir toute la zone.</p> +De même si l'image possède une dimension mais aucune proportion, la règle 4 sera appliquée : l'image est ainsi redimensionnée pour couvrir toute la zone. -<pre class="brush: css">background: url(100px-wide-no-height-or-ratio.svg); +```css +background: url(100px-wide-no-height-or-ratio.svg); background-size: contain; -</pre> +``` -<p>Le résultat obtenu sera :</p> +Le résultat obtenu sera : -<p><img src="100px-wide-no-height-or-ratio-contain.png"></p> +![](100px-wide-no-height-or-ratio-contain.png) -<h4 id="SVG_source_Une_dimension_définie_et_des_proportions_intrinsèques_2">SVG source : Une dimension définie et des proportions intrinsèques</h4> +#### SVG source : Une dimension définie et des proportions intrinsèques -<p>Ici, on a des proportions intrinsèques. Dans ce cas, la règle 1 n'est pas pertinente et on utilise donc la règle 2 : le ratio est conservé (tout en respectant les consignes de <code>contain</code> ou <code>cover</code>). Ainsi, avec <code>contain</code>, la boîte de 300x200 et le ratio de 3:4 entraîneront le dessin d'un arrière-plan de 150x200.</p> +Ici, on a des proportions intrinsèques. Dans ce cas, la règle 1 n'est pas pertinente et on utilise donc la règle 2 : le ratio est conservé (tout en respectant les consignes de `contain` ou `cover`). Ainsi, avec `contain`, la boîte de 300x200 et le ratio de 3:4 entraîneront le dessin d'un arrière-plan de 150x200. -<h5 id="contain"><code>contain</code></h5> +##### `contain` -<pre class="brush: css">background: url(100px-height-3x4-ratio.svg); +```css +background: url(100px-height-3x4-ratio.svg); background-size: contain; -</pre> +``` -<p>Le résultat obtenu sera :</p> +Le résultat obtenu sera : -<p><img src="100px-height-3x4-ratio-contain.png"></p> +![](100px-height-3x4-ratio-contain.png) -<p>On voit ici que toute l'image est affichée et est contenue dans la boîte sans être rognée.</p> +On voit ici que toute l'image est affichée et est contenue dans la boîte sans être rognée. -<h5 id="cover"><code>cover</code></h5> +##### `cover` -<pre class="brush: css">background: url(100px-height-3x4-ratio.svg); +```css +background: url(100px-height-3x4-ratio.svg); background-size: cover; -</pre> +``` -<p>Le résultat obtenu sera :</p> +Le résultat obtenu sera : -<p><img src="100px-height-3x4-ratio-cover.png"></p> +![](100px-height-3x4-ratio-cover.png) -<p>Dans ce cas, le ratio 3:4 est conservé et l'image est étirée Here, the 3:4 ratio is preserved while still stretching the image to fill the entire box. That causes the bottom of the image to be clipped away.</p> +Dans ce cas, le ratio 3:4 est conservé et l'image est étirée Here, the 3:4 ratio is preserved while still stretching the image to fill the entire box. That causes the bottom of the image to be clipped away. -<h4 id="SVG_source_Aucune_dimension_mais_des_proportions_intrinsèques">SVG source : Aucune dimension mais des proportions intrinsèques</h4> +#### SVG source : Aucune dimension mais des proportions intrinsèques -<p>On obtient des résultats analogues lorsqu'on manipule une image sans dimension intrinsèque mais avec des proportions intrinsèques.</p> +On obtient des résultats analogues lorsqu'on manipule une image sans dimension intrinsèque mais avec des proportions intrinsèques. -<h5 id="contain_2"><code>contain</code></h5> +##### `contain` -<pre class="brush: css">background: url(no-dimensions-1x1-ratio.svg); +```css +background: url(no-dimensions-1x1-ratio.svg); background-size: contain; -</pre> +``` -<p>Le résultat ressemblera à :</p> +Le résultat ressemblera à : -<p><img src="no-dimensions-1x1-ratio-contain.png"></p> +![](no-dimensions-1x1-ratio-contain.png) -<p>On voit ici que l'image est redimensionnée à la plus petite taille tout en conservant le ratio 1:1.</p> +On voit ici que l'image est redimensionnée à la plus petite taille tout en conservant le ratio 1:1. -<h5 id="cover_2"><code>cover</code></h5> +##### `cover` -<pre class="brush: css">background: url(no-dimensions-1x1-ratio.svg); +```css +background: url(no-dimensions-1x1-ratio.svg); background-size: cover; -</pre> +``` -<p>Le résultat ressemblera à :</p> +Le résultat ressemblera à : -<p><img src="no-dimensions-1x1-ratio-cover.png"></p> +![](no-dimensions-1x1-ratio-cover.png) -<p>Ici, l'image est dimensionnée afin de couvrir la plus grande surface avec le ratio 1:1.</p> +Ici, l'image est dimensionnée afin de couvrir la plus grande surface avec le ratio 1:1. -<h3 id="Utiliser_auto_pour_les_deux_axes">Utiliser <code>auto</code> pour les deux axes</h3> +### Utiliser `auto` pour les deux axes -<p>Si {{cssxref("background-size")}} vaut <code>auto</code> ou <code>auto auto</code>, ce sera la règle n°2 qui s'appliquera : les proportions intrinsèques devront être conservées.</p> +Si {{cssxref("background-size")}} vaut `auto` ou `auto auto`, ce sera la règle n°2 qui s'appliquera : les proportions intrinsèques devront être conservées. -<h4 id="SVG_source_Aucune_dimension_ni_proportion_intrinsèque">SVG source : Aucune dimension ni proportion intrinsèque</h4> +#### SVG source : Aucune dimension ni proportion intrinsèque -<p>Lorsque l'image n'a aucune proportion ni dimension, ce sera la dernière règle qui s'appliquera : l'image couvrira toute la surface de la zone.</p> +Lorsque l'image n'a aucune proportion ni dimension, ce sera la dernière règle qui s'appliquera : l'image couvrira toute la surface de la zone. -<pre class="brush: css">background: url(no-dimensions-or-ratio.svg); +```css +background: url(no-dimensions-or-ratio.svg); background-size: auto auto; -</pre> +``` -<p>Voici le résultat obtenu :</p> +Voici le résultat obtenu : -<p><img src="auto-no-dimensions-or-ratio.png"></p> +![](auto-no-dimensions-or-ratio.png) -<h4 id="SVG_source_une_dimension_mais_aucune_proportion_intrinsèque">SVG source : une dimension mais aucune proportion intrinsèque</h4> +#### SVG source : une dimension mais aucune proportion intrinsèque -<p>S'il n'y a aucune proportion définie mais qu'une dimension est fournie, la règle n°3 s'appliquera et l'image sera affichée avec ces dimensions.</p> +S'il n'y a aucune proportion définie mais qu'une dimension est fournie, la règle n°3 s'appliquera et l'image sera affichée avec ces dimensions. -<pre class="brush: css">background: url(100px-wide-no-height-or-ratio.svg); +```css +background: url(100px-wide-no-height-or-ratio.svg); background-size: auto auto; -</pre> +``` -<p>Voici le résultat obtenu :</p> +Voici le résultat obtenu : -<p><img src="auto-100px-wide-no-height-or-ratio.png"></p> +![](auto-100px-wide-no-height-or-ratio.png) -<p>Ici, on voit que la largeur définie par le fichier SVG (100 pixels) est respectée. L'image s'étend sur toute la hauteur de la zone de l'arrière-plan car elle n'est pas définie (explicitement dans les déclarations ou intrinsèquement via l'image).</p> +Ici, on voit que la largeur définie par le fichier SVG (100 pixels) est respectée. L'image s'étend sur toute la hauteur de la zone de l'arrière-plan car elle n'est pas définie (explicitement dans les déclarations ou intrinsèquement via l'image). -<h4 id="SVG_source_une_dimension_et_des_proportions_intrinsèques">SVG source : une dimension et des proportions intrinsèques</h4> +#### SVG source : une dimension et des proportions intrinsèques -<p>Si on dispose de proportions intrinsèques et d'une dimension fixée, les deux dimensions sont alors définies.</p> +Si on dispose de proportions intrinsèques et d'une dimension fixée, les deux dimensions sont alors définies. -<pre class="brush: css">background: url(100px-height-3x4-ratio.svg); +```css +background: url(100px-height-3x4-ratio.svg); background-size: auto auto; -</pre> +``` -<p>Le résultat sera le suivant :</p> +Le résultat sera le suivant : -<p><img src="auto-100px-height-3x4-ratio.png"></p> +![](auto-100px-height-3x4-ratio.png) -<p>Cette image mesure 100 pixels de haut et possède des proportions intrinsèques avec un ratio de 3:4. La largeur vaut donc 75 pixels et c'est ainsi qu'elle est affichée avec <code>auto</code>.</p> +Cette image mesure 100 pixels de haut et possède des proportions intrinsèques avec un ratio de 3:4. La largeur vaut donc 75 pixels et c'est ainsi qu'elle est affichée avec `auto`. -<h4 id="SVG_source_Aucune_dimension_définie_mais_des_proportions_intrinsèques">SVG source : Aucune dimension définie mais des proportions intrinsèques</h4> +#### SVG source : Aucune dimension définie mais des proportions intrinsèques -<p>Lorsqu'un ratio s'applique sans dimension, c'est la règle n°2 qui s'applique. L'image est affichée comme pour <code>contain</code>.</p> +Lorsqu'un ratio s'applique sans dimension, c'est la règle n°2 qui s'applique. L'image est affichée comme pour `contain`. -<pre class="brush: css">background: url(no-dimensions-1x1-ratio.svg); +```css +background: url(no-dimensions-1x1-ratio.svg); background-size: auto auto; -</pre> +``` -<p>Le résultat ressemblera à :</p> +Le résultat ressemblera à : -<p><img src="auto-no-dimensions-1x1-ratio.png"></p> +![](auto-no-dimensions-1x1-ratio.png) -<h3 id="Utiliser_auto_et_une_dimension_fixée">Utiliser <code>auto</code> et une dimension fixée</h3> +### Utiliser `auto` et une dimension fixée -<p>Avec la première règle, les dimensions définies sont toujours utilisées et il faut donc utiliser les autres règles pour déterminer la seconde dimension.</p> +Avec la première règle, les dimensions définies sont toujours utilisées et il faut donc utiliser les autres règles pour déterminer la seconde dimension. -<h4 id="SVG_source_aucune_dimension_ni_proportion_intrinsèque">SVG source : aucune dimension ni proportion intrinsèque</h4> +#### SVG source : aucune dimension ni proportion intrinsèque -<p>Si l'image ne possède ni dimension ni proportion intrinsèque, c'est la règle 4 qui s'applique et les dimensions de la zone pour l'arrière-plan seront utilisées pour <code>auto</code>.</p> +Si l'image ne possède ni dimension ni proportion intrinsèque, c'est la règle 4 qui s'applique et les dimensions de la zone pour l'arrière-plan seront utilisées pour `auto`. -<pre class="brush: css">background: url(no-dimensions-or-ratio.svg); +```css +background: url(no-dimensions-or-ratio.svg); background-size: auto 140px; -</pre> +``` -<p><img src="1auto-no-dimensions-or-ratio.png"></p> +![](1auto-no-dimensions-or-ratio.png) -<p>Ici, la largeur est déterminée grâce à la zone dédiée à l'arrière-plan (règle n°4) et la hauteur est indiquée via la feuille de style (140px).</p> +Ici, la largeur est déterminée grâce à la zone dédiée à l'arrière-plan (règle n°4) et la hauteur est indiquée via la feuille de style (140px). -<h4 id="SVG_source_une_dimension_intrinsèque_mais_pas_de_proportion_intrinsèque">SVG source : une dimension intrinsèque mais pas de proportion intrinsèque</h4> +#### SVG source : une dimension intrinsèque mais pas de proportion intrinsèque -<p>Si l'image possède une dimension implicite mais pas de ratio, la dimension définie sera utilisée selon la règle n°3 si elle vaut <code>auto</code> dans le code CSS.</p> +Si l'image possède une dimension implicite mais pas de ratio, la dimension définie sera utilisée selon la règle n°3 si elle vaut `auto` dans le code CSS. -<pre class="brush: css">background: url(100px-wide-no-height-or-ratio.svg); +```css +background: url(100px-wide-no-height-or-ratio.svg); background-size: 200px auto; -</pre> +``` -<p><img src="100px-wide-no-height-or-ratio-length-auto.png"></p> +![](100px-wide-no-height-or-ratio-length-auto.png) -<p>Ici, la valeur de 200px fournie dans la feuille de style surcharge la valeur de 100px définie dans le fichier SVG. Puisqu'il n'y a aucune proportion intrinsèque ni hauteur de définie et qu'on utilise la valeur <code>auto</code>, l'image fera la même hauteur que la zone pour l'arrière-plan.</p> +Ici, la valeur de 200px fournie dans la feuille de style surcharge la valeur de 100px définie dans le fichier SVG. Puisqu'il n'y a aucune proportion intrinsèque ni hauteur de définie et qu'on utilise la valeur `auto`, l'image fera la même hauteur que la zone pour l'arrière-plan. -<pre class="brush: css">background: url(100px-wide-no-height-or-ratio.svg); +```css +background: url(100px-wide-no-height-or-ratio.svg); background-size: auto 125px; -</pre> +``` -<p><img src="100px-wide-no-height-or-ratio-auto-length.png"></p> +![](100px-wide-no-height-or-ratio-auto-length.png) -<p>Ici, c'est la largeur qui vaut <code>auto</code> et ce sera donc la valeur définie dans l'image SVG (100px) qui sera utilisée. La hauteur est fixée à 125 pixels via la feuille de style.</p> +Ici, c'est la largeur qui vaut `auto` et ce sera donc la valeur définie dans l'image SVG (100px) qui sera utilisée. La hauteur est fixée à 125 pixels via la feuille de style. -<h4 id="SVG_source_une_dimension_définie_et_des_proportions_intrinsèques">SVG source : une dimension définie et des proportions intrinsèques</h4> +#### SVG source : une dimension définie et des proportions intrinsèques -<p>Lorsqu'une dimension est indiquée, la première règle s'applique et la dimension du fichier SVG est utilisée sauf si le CSS la redéfinit. Lorsqu'un ratio est indiqué, celui-ci est utilisé pour déterminer la deuxième dimension.</p> +Lorsqu'une dimension est indiquée, la première règle s'applique et la dimension du fichier SVG est utilisée sauf si le CSS la redéfinit. Lorsqu'un ratio est indiqué, celui-ci est utilisé pour déterminer la deuxième dimension. -<pre class="brush: css">background: url(100px-height-3x4-ratio.svg); +```css +background: url(100px-height-3x4-ratio.svg); background-size: 150px auto; -</pre> +``` -<p><img src="1auto-100px-height-3x4-ratio.png"></p> +![](1auto-100px-height-3x4-ratio.png) -<p>Ici, la hauteur de l'image a été surchargée pour valoir 150px. Les proportions intrinsèques permettent ensuite de définir la largeur (<code>auto</code> dans la feuille de style).</p> +Ici, la hauteur de l'image a été surchargée pour valoir 150px. Les proportions intrinsèques permettent ensuite de définir la largeur (`auto` dans la feuille de style). -<h4 id="SVG_source_aucune_dimension_mais_des_proportions_intrinsèques">SVG source : aucune dimension mais des proportions intrinsèques</h4> +#### SVG source : aucune dimension mais des proportions intrinsèques -<p>Si aucune dimension n'est définie dans l'image SVG, ce sera celle du CSS qui sera appliquée. Les proportions intrinsèques sont ensuite utilisées pour déterminer l'autre dimension (selon la rgèle n°2).</p> +Si aucune dimension n'est définie dans l'image SVG, ce sera celle du CSS qui sera appliquée. Les proportions intrinsèques sont ensuite utilisées pour déterminer l'autre dimension (selon la rgèle n°2). -<pre class="brush: css">background: url(no-dimensions-1x1-ratio.svg); +```css +background: url(no-dimensions-1x1-ratio.svg); background-size: 150px auto; -</pre> +``` -<p><img src="1auto-no-dimensions-1x1-ratio.png"></p> +![](1auto-no-dimensions-1x1-ratio.png) -<p>La largeur est définie à 150 pixels via la feuille de style et la hauteur est calculée à partir de cette largeur en utilisant le ratio 1:1, elle vaudra donc 150px ce qui donnera le résultat ci-dessus.</p> +La largeur est définie à 150 pixels via la feuille de style et la hauteur est calculée à partir de cette largeur en utilisant le ratio 1:1, elle vaudra donc 150px ce qui donnera le résultat ci-dessus. -<h2 id="Voir_aussi">Voir aussi</h2> +## Voir aussi -<ul> - <li>{{cssxref("background-size")}}</li> - <li>{{cssxref("background-image")}}</li> - <li>Billet de blog de Jeff Walden : <a href="https://whereswalden.com/2011/10/21/properly-resizing-vector-image-backgrounds/">Properly resizing vector image backgrounds (en anglais)</a></li> -</ul> +- {{cssxref("background-size")}} +- {{cssxref("background-image")}} +- Billet de blog de Jeff Walden : [Properly resizing vector image backgrounds (en anglais)](https://whereswalden.com/2011/10/21/properly-resizing-vector-image-backgrounds/) |