1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
---
title: scale3d()
slug: Web/CSS/transform-function/scale3d()
tags:
- CSS
- Fonction
- Reference
- Transformations CSS
translation_of: Web/CSS/transform-function/scale3d()
---
<div>{{CSSRef}}</div>
<p>La fonction <strong><code>scale3d()</code></strong> permet de modifier la taille d'un élément en appliquant une homothétie définie par un vecteur. Les composantes de ce vecteur permettent d'appliquer des échelles différentes selon les différentes dimensions.</p>
<div>{{EmbedInteractiveExample("pages/css/function-scale3d.html")}}</div>
<p class="hidden">Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> et à envoyer une <em>pull request</em> !</p>
<p>La transformation appliquée est définie par un vecteur dont les coordonnées définissent l'amplitude de l'homothétie dans chaque direction. Si les trois coordonnées du vecteur sont égales, la transformation est isotropique et la forme de l'élément est conservée.</p>
<p>Lorsque les composantes du vecteurs sont en dehors de l'intervalle <code>[-1, 1]</code>, la transformation agrandit l'élément dans le sens des coordonnées. Lorsque les composantes sont dans cet intervalle, cela réduit l'élément.</p>
<h2 id="Syntaxe">Syntaxe</h2>
<pre class="syntaxbox">scale3d(<em>sx</em>, <em>sy</em>, <em>sz</em>)
</pre>
<h3 id="Valeurs">Valeurs</h3>
<dl>
<dt><code>sx</code></dt>
<dd>Une valeur de type {{cssxref("<number>")}} qui représente l'abscisse du vecteur définissant l'homothétie.</dd>
<dt><code>sy</code></dt>
<dd>Une valeur de type {{cssxref("<number>")}} qui représente l'ordonnée du vecteur définissant l'homothétie</dd>
<dt><code>sz</code></dt>
<dd>Une valeur de type {{cssxref("<number>")}} qui représente la composante, selon l'axe Z, du vecteur définissant l'homothétie</dd>
</dl>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Coordonnées cartésiennes sur ℝ<sup>2</sup></th>
<th scope="col">Coordonnées homogènes sur ℝℙ<sup>2</sup></th>
<th scope="col">Coordonnées cartésiennes sur ℝ<sup>3</sup></th>
<th scope="col">Coordonnées homogènes sur ℝℙ<sup>3</sup></th>
</tr>
</thead>
<tbody>
<tr>
<td colspan="2" rowspan="2">Cette transformation s'applique dans en 3 dimensions et ne peut pas être représentée sur le plan.</td>
<td colspan="1" rowspan="2"><math> <mfenced><mtable><mtr>sx<mtd>0</mtd><mtd>0</mtd></mtr><mtr>0<mtd>sy</mtd><mtd>0</mtd></mtr><mtr><mtd>0</mtd><mtd>0</mtd><mtd>sz</mtd></mtr></mtable> </mfenced> </math></td>
<td colspan="1" rowspan="2"><math> <mfenced><mtable><mtr>sx<mtd>0</mtd><mtd>0</mtd><mtd>0</mtd></mtr><mtr>0<mtd>sy</mtd><mtd>0</mtd><mtd>0</mtd></mtr><mtr><mtd>0</mtd><mtd>0</mtd><mtd>sz</mtd><mtd>0</mtd></mtr><mtr><mtd>0</mtd><mtd>0</mtd><mtd>0</mtd><mtd>1</mtd></mtr></mtable> </mfenced> </math></td>
</tr>
</tbody>
</table>
<h2 id="Exemples">Exemples</h2>
<h3 id="Avec_origine_non_modifiée">Avec origine non modifiée</h3>
<h4 id="HTML">HTML</h4>
<pre class="brush: html"><p>foo</p>
<p class="transformation">bar</p></pre>
<h4 id="CSS">CSS</h4>
<pre class="brush: css">p {
width: 50px;
height: 50px;
background-color: teal;
}
.transformation {
transform: perspective(500px) scale3d(0.8, 2, 0.2) translateZ(100px);
background-color: blue;
}
</pre>
<h4 id="Résultat">Résultat</h4>
<p>{{EmbedLiveSample("Avec_origine_non_modifiée","100%","200")}}</p>
<h3 id="Avec_origine_translatée">Avec origine translatée</h3>
<h4 id="HTML_2">HTML</h4>
<pre class="brush: html"><p>toto</p>
<p class="transformation">truc</p></pre>
<h4 id="CSS_2">CSS</h4>
<pre class="brush: css">p {
width: 50px;
height: 50px;
background-color: teal;
}
.transformation {
transform: scale3d(2, 3, 0);
transform-origin: center;
background-color: blue;
}
</pre>
<h4 id="Résultat_2">Résultat</h4>
<p>{{EmbedLiveSample("Avec_origine_translatée","100%","200")}}</p>
<h2 id="Spécifications">Spécifications</h2>
<table class="standard-table">
<thead>
<tr>
<th scope="col">Spécification</th>
<th scope="col">État</th>
<th scope="col">Commentaires</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName("CSS Transforms 2", "#funcdef-scale3d", "scale3d()")}}</td>
<td>{{Spec2("CSS Transforms 2")}}</td>
<td>Définition initiale.</td>
</tr>
</tbody>
</table>
<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2>
<p>Voir la page sur le type de donnée <code><a href="/fr/docs/Web/CSS/transform-function#Compatibilité_des_navigateurs"><transform-function></a></code> pour les informations de compatibilité associées.</p>
<h2 id="Voir_aussi">Voir aussi</h2>
<ul>
<li>{{cssxref("transform")}}</li>
<li>{{cssxref("<transform-function>")}}</li>
<li><code><a href="/fr/docs/Web/CSS/transform-function/scaleZ">scaleZ()</a></code></li>
<li><code><a href="/fr/docs/Web/CSS/transform-function/translate3d">translate3d()</a></code></li>
<li><code><a href="/fr/docs/Web/CSS/transform-function/rotate3d">rotate3d()</a></code></li>
</ul>
|