--- title: transform-origin slug: Web/CSS/transform-origin translation_of: Web/CSS/transform-origin --- {{CSSRef}} La propriété **`transform-origin`** permet de modifier l'origine du repère pour les opérations de transformation d'un élément. {{EmbedInteractiveExample("pages/css/transform-origin.html")}} Par exemple, l'origine par défaut pour la fonction `rotate()` est le centre de la rotation. Cette propriété est utilisée en : 1. Translatant l'élément avec l'opposé de la valeur fournie 2. Appliquant la transformation souhaitée sur l'élément 3. Translatant l'élément avec la valeur fournie pour cette propriété. Les valeurs qui ne sont pas définies explicitement sont réinitialisées avec les valeurs correspondantes. Par défaut, l'origine d'une transformation est `center`. ## Syntaxe ```css /* Utilisation d'une seule valeur */ transform-origin: 2px; transform-origin: bottom; /* x-offset y-offset */ transform-origin: 3cm 2px; /* y-offset x-offset-keyword */ transform-origin: 2px left; /* x-offset-keyword y-offset */ transform-origin: left 2px; /* x-offset-keyword y-offset-keyword */ transform-origin: right top; /* y-offset-keyword x-offset-keyword */ transform-origin: top right; /* x-offset y-offset z-offset */ transform-origin: 2px 30% 10px; /* y-offset x-offset-keyword z-offset */ transform-origin: 2px left 10px; /* x-offset-keyword y-offset z-offset */ transform-origin: left 5px -3px; /* x-offset-keyword y-offset-keyword z-offset */ transform-origin: right bottom 2cm; /* y-offset-keyword x-offset-keyword z-offset */ transform-origin: bottom right 2cm; /* Valeurs globales */ transform-origin: inherit; transform-origin: initial; transform-origin: unset; ``` La propriété `transform-origin` peut être définie en utiisant une, deux ou trois valeurs. - Avec une valeur, celle-ci doit être : - Une longueur (type {{cssxref("<length>")}}) - Un pourcentage (type {{cssxref("<percentage>")}} - Un mot-clé parmi `left`, `center`, `right`, `top`, `bottom`. - Avec deux valeurs - La première valeur doit être une longueur (type {{cssxref("<length>")}}), un pourcentage (type {{cssxref("<percentage>")}} ou un mot-clé parmi `left`, `center`, `right` - La seconde valeur doit être une longueur (type {{cssxref("<length>")}}), un pourcentage (type {{cssxref("<percentage>")}} ou un mot-clé parmi `top`, `center`, `bottom`. - Avec trois valeurs - Les deux premières valeurs doivent être structurées comme la syntaxe avec deux valeurs - La troisième valeur doit être une longueur (type {{cssxref("length")}} ### Valeur - `x-offset` - : Une valeur du type {{cssxref("<length>")}} ou {{cssxref("<percentage>")}} qui décrit la distance, depuis le bord gauche de la boîte, à laquelle l'origine de la transformation sera placée. - `offset-keyword` - : Un mot-clé parmi `left`, `right`, `top`, `bottom` ou `center` qui décrit le décalage correspondant. - `y-offset` - : Une valeur du type {{cssxref("<length>")}} ou {{cssxref("<percentage>")}} qui décrit la distance, depuis le bord haut de la boîte, à laquelle l'origine de la transformation sera placée. - `x-offset-keyword` - : Un mot-clé parmi `left`, `right` ou `center` qui décrit la distance, depuis le bord gauche de la boîte, à laquelle l'origine de la transformation sera placée. - `y-offset-keyword` - : Un mot-clé parmi `top`, `bottom` ou `center` qui décrit la distance, depuis le bord haut de la boîte, à laquelle l'origine de la transformation sera placée. - `z-offset` - : Une valeur du type {{cssxref("<length>")}} (et jamais une valeur du type {{cssxref("<percentage>")}}, sinon la déclaration serait invalide) qui décrit la distance, depuis l'œil de l'utilisateur, de l'origine de la transformation sur l'axe de profondeur (z).. Les mots-clés sont des raccourcis qui correspondent aux valeurs {{cssxref("<percentage>")}} suivantes : | Mot-clé | Valeur | | -------- | ------ | | `left` | `0%` | | `center` | `50%` | | `right` | `100%` | | `top` | `0%` | | `bottom` | `100%` | ### Syntaxe formelle {{csssyntax}} ## Exemples Voir la page sur [l'utilisation des transformations CSS](/fr/docs/Web/CSS/CSS_Transforms/Using_CSS_transforms) pour des exemples supplémentaires. ### Illustrations des différentes valeurs de transform Cet exemple illustre ce que donnent les différentes valeurs de `transform-origin` pour différentes fonctions de transformation. ```html hidden
 
 
transform: none;
 
 
transform: rotate(30deg);
 
 
transform: rotate(30deg);
transform-origin: 0 0;
 
 
transform: rotate(30deg);
transform-origin: 100% 100%;
 
 
transform: rotate(30deg);
transform-origin: -1em -3em;
 
 
transform: scale(1.7);
 
 
transform: scale(1.7);
transform-origin: 0 0;
 
 
transform: scale(1.7);
transform-origin: 100% -30%;
 
 
transform: skewX(50deg);
transform-origin: 100% -30%;
 
 
transform: skewY(50deg);
transform-origin: 100% -30%;
``` ```css hidden .container { display: grid; grid-template-columns: 200px 100px; gap: 20px; } .example { position: relative; margin: 0 2em 4em 5em; } .box { display: inline-block; width: 3em; height: 3em; border: solid 1px; background-color: palegreen; } .original { position: absolute; left: 0; opacity: 20%; } .box1 { transform: none; } .box2 { transform: rotate(30deg); } .box3 { transform: rotate(30deg); transform-origin: 0 0; } .box4 { transform: rotate(30deg); transform-origin: 100% 100%; } .box5 { transform: rotate(30deg); transform-origin: -1em -3em; } .box6 { transform: scale(1.7); } .box7 { transform: scale(1.7); transform-origin: 0 0; } .box8 { transform: scale(1.7); transform-origin: 100% -30%; } .box9 { transform: skewX(50deg); transform-origin: 100% -30%; } .box10 { transform: skewY(50deg); transform-origin: 100% -30%; } ``` {{EmbedLiveSample('Exemples', '', 1350) }} ## Spécifications | Spécification | État | Commentaires | | ------------------------------------------------------------------------------------------------------------ | ------------------------------------ | -------------------- | | {{SpecName('CSS3 Transforms', '#transform-origin-property', 'transform-origin')}} | {{Spec2('CSS3 Transforms')}} | Définition initiale. | {{cssinfo}} ## Compatibilité des navigateurs {{Compat("css.properties.transform-origin")}} ## Voir aussi - [Utiliser les transformations CSS](/fr/docs/Web/CSS/CSS_Transforms/Using_CSS_transforms) -