rotate3d()
Quick Summary for rotate3d()
The rotate3d() CSS function defines a transformation that rotates an element around a fixed axis in 3D space, without deforming it. Its result is a <transform-function> data type.
Code Usage for rotate3d()
rotate3d(x, y, z, a) 
More Details for rotate3d()

rotate3d()

The rotate3d() CSS function defines a transformation that rotates an element around a fixed axis in 3D space, without deforming it. Its result is a <transform-function> data type.

In 3D space, rotations have three degrees of liberty, which together describe a single axis of rotation. The axis of rotation is defined by an [x, y, z] vector and pass by the origin (as defined by the transform-origin property). If, as specified, the vector is not normalized (i.e., if the sum of the square of its three coordinates is not 1), the user agent will normalize it internally. A non-normalizable vector, such as the null vector, [0, 0, 0], will cause the rotation to be ignored, but without invaliding the whole CSS property.

Note: Unlike rotations in the 2D plane, the composition of 3D rotations is usually not commutative. In other words, the order in which the rotations are applied impacts the result.

Syntax

The amount of rotation created by rotate3d() is specified by three <number>s and one <angle>. The <number>s represent the x-, y-, and z-coordinates of the vector denoting the axis of rotation. The <angle> represents the angle of rotation; if positive, the movement will be clockwise; if negative, it will be counter-clockwise.

rotate3d(x, y, z, a) 

Values

x

Is a <number> describing the x-coordinate of the vector denoting the axis of rotation which could between 0 and 1.

y

Is a <number> describing the y-coordinate of the vector denoting the axis of rotation which could between 0 and 1.

z

Is a <number> describing the z-coordinate of the vector denoting the axis of rotation which could between 0 and 1.

a

Is an <angle> representing the angle of the rotation. A positive angle denotes a clockwise rotation, a negative angle a counter-clockwise one.

Cartesian coordinates on ℝ^2 This transformation applies to the 3D space and can't be represented on the plane.
Homogeneous coordinates on ℝℙ^2
Cartesian coordinates on ℝ^3 ( 1 + ( 1 - cos ( a ) ) ( x 2 - 1 ) z · sin ( a ) + x y ( 1 - cos ( a ) ) - y · sin ( a ) + x z · ( 1 - cos ( a ) ) - z · sin ( a ) + x y · ( 1 - cos ( a ) ) 1 + ( 1 - cos ( a ) ) ( y2 - 1 ) x · sin ( a ) + y z · ( 1 - cos ( a ) ) y sin ( a ) + xz ( 1 - cos ( a ) ) - x sin ( a ) + yz ( 1 - cos ( a ) ) 1 + ( 1 - cos ( a ) ) ( z2 - 1 ) t 0 0 0 1 )
Homogeneous coordinates on ℝℙ^3

Examples

Rotating on the y-axis

HTML
<div>Normal</div> <div class="rotated">Rotated</div> 
CSS
body {   perspective: 800px; }  div {   width: 80px;   height: 80px;   background-color: skyblue; }  .rotated {   transform: rotate3d(0, 1, 0, 60deg);   background-color: pink; } 
Result

Rotating on a custom axis

HTML
<div>Normal</div> <div class="rotated">Rotated</div> 
CSS
body {   perspective: 800px; }  div {   width: 80px;   height: 80px;   background-color: skyblue; }  .rotated {   transform: rotate3d(1, 2, -1, 192deg);   background-color: pink; } 
Result

Specifications

Specification
CSS Transforms Module Level 2 # funcdef-rotate3d

See also

transform <transform-function>

Last modified: Jan 31, 2022, by MDN contributors

Select your preferred language English (US)EspañolFrançais日本語Português (do Brasil)Русский中文 (简体) Change language

No Items Found.

Add Comment
Type in a Nick Name here
 
Other Categories in CSS
css
Search CSS
Search CSS by entering your search text above.
Welcome

This is my test area for webdev. I keep a collection of code here, mostly for my reference. Also if i find a good link, i usually add it here and then forget about it. more...

Subscribe to weekly updates about things i have added to the site or thought interesting during the last week.

You could also follow me on twitter or not... does anyone even use twitter anymore?

If you found something useful or like my work, you can buy me a coffee here. Mmm Coffee. ☕

❤️👩‍💻🎮

🪦 2000 - 16 Oct 2022 - Boots
Random Quote
For a long time it had seemed to me that life was about to begin - real life. But there was always some obstacle in the way, something to be gotten through first, some unfinished business, time still to be served, or a debt to be paid. Then life would begin. At last it dawned on me that these obstacles were my life.
Alfred D. Souza
Random CSS Property

<display-inside>

These keywords specify the element's inner display type, which defines the type of formatting context that lays out its contents (assuming it is a non-replaced element). These keywords are used as values of the display property, and can be used for legacy purposes as a single keyword, or as defined in the Level 3 specification alongside a value from the <display-outside> keywords.
<display-inside> css reference