属性名 | transform |
---|---|
値 | none | <transform-function>+ |
初期値 | none |
適用可能要素 | トランスフォーム可能な要素 |
継承 | 継承しない |
メディア | visual |
アニメーション | トランスフォームとして可能 |
CSS | IE/Edge | Firefox | Chrome | Opera | Safari | |
---|---|---|---|---|---|---|
基本 | CSS3 | 9(-ms) 10 | 3.5(-moz) 16 | 4(-webkit) 36 | 15(-webkit) 23 | 3.1(-webkit) 9 |
3D | CSS3 | 10(制限有) | 10(-moz) 16 | 12(-webkit) 36 | 15(-webkit) 23 | 4(-webkit) 9 |
transform 属性を用いて、要素を右方向(X軸方向)、下方向(Y軸方向)に、移動、拡大、縮小、傾斜、回転させたりすることができます。また、3D 関数を用いると、画面に対して手前方向(Z軸方向)方向に移動、拡大、縮小、回転させ、三次元的な描写を行うことが可能となります。3D 効果を出すには、親要素に transform-style: preserve-3d を指定し、perspective で遠近法の視点を設定する必要があります。
下記の例では、要素(画像)を、X軸方向に 100px、Y軸方向に 10px 移動し、時計方向に 10度回転させています。
.test { transform: translate(100px, 10px) rotate(10deg); }
<img src="./image/yuki.gif" width=60 height=80 class="test" alt="Yuki">
要素を X軸方向に tx、Y軸方向に ty、Z軸方向に tz の長さ分移動させます。
.test-translate { transform: translate(10px, 10px); }
要素を X軸方向に sx倍、Y軸方向に sy倍、Z軸方向に sz倍拡大・縮小します。1.0 より大きな値を指定すると拡大、1.0 より小さな値を指定すると縮小になります。
.test-scale { transform: scale(0.7, 0.7); }
rotate(angle) は、要素を angle だけ時計方向に回転させます。角度の指定方法は angle を参照してください。負の値を指定すると反時計回りに回転させます。rotate3d() は、[ 0, 0, 0 ] から [ rx, ry, rz ] に向かう直線を軸とし、角度 angle 分三次元回転させます。rotateX(angle) は X方向を軸とする回転で rotate3d(1, 0, 0, angle) と同じ、rotateY(angle) は Y方向を軸とする回転で rotate3d(0, 1, 0, angle) と同じ、rotateZ(angle) は Z方向を軸とする回転で rotate3d(0, 0, 1, angle) と同じ意味を持ちます。
.test-rotate { transform: rotate(10deg); }
skew() は、要素を横方向に ax、縦方向に ay だけ傾斜させます。ay は省略可能で、省略した場合は X方向のみ傾斜させます。skewX() は横方向のみ、skewY() は縦方向のみ傾斜させます。角度の指定方法は angle を参照してください。負の値を指定すると反時計回りに回転させます。
.test-skew { transform: skew(0deg, -15deg); }
三次元変換を行った際の、Z軸=0 の面から視点までの距離を指定します。perspective() 関数の場合、指定した要素自体に適用されるのに対し、perspective プロパティの場合は、指定した要素の子要素に適用されます。視点の X座標、Y座標は perspective-origin で指定します。
translate(), scale(), skew() を同時に指定したような行列変換を行います。sx, ay, ax, sy, tx, ty には 10px や 30deg などの長さや角度ではなく、0.7 や 1.2 などの数値を指定します。tx, ty には translate() で指定するようなX方向、Y方向への移動距離を指定します。sx, sy には scale() で指定するような拡大・縮小率を指定します。ax, ay には、skew() で指定するような傾斜率を指定します。matrix(1, 0, 0, 1, 0, 0) を指定すると何も変換されません。具体的には、下記のベクトル演算を行い、返還後の座標を算出しています。
X | sx | ax | tx | X' | ||
Y | × | ay | sy | ty | = | Y' |
1 | 0 | 0 | 1 | W' |
.test-matrix { transform: matrix(0.8, 0, -0.5, 0.8, 20, 10); }
元要素の X, Y, Z座標上の位置を、下記の 4x4 ベクトル演算を用いて変換した場所に表示します。
X | a1 | b1 | c1 | d1 | X' | ||
Y | × | a2 | b2 | c2 | d2 | = | Y' |
Z | a3 | b3 | c3 | d3 | Z' | ||
1 | a4 | b4 | c4 | d4 | W' |
matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1) は下記の演算となり、何も変換が行われません。
X | 1 | 0 | 0 | 0 | X | ||
Y | × | 0 | 1 | 0 | 0 | = | Y |
Z | 0 | 0 | 1 | 0 | Z | ||
1 | 0 | 0 | 0 | 1 | 1 |
matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, tx, ty, tz, 1) は下記の演算となり、translate3d(tx, ty, tz) と同じ効果となります。
X | 1 | 0 | 0 | tx | X + tx | ||
Y | × | 0 | 1 | 0 | ty | = | Y + ty |
Z | 0 | 0 | 1 | tz | Z + tz | ||
1 | 0 | 0 | 0 | 1 | 1 |
matrix3d(sx, 0, 0, 0, 0, sy, 0, 0, 0, 0, sz, 0, 0, 0, 0, 1) は下記の演算となり、scale3d(sx, sy, sz) と同じ効果となります。
X | sx | 0 | 0 | 0 | X * sx | ||
Y | × | 0 | sy | 0 | 0 | = | Y * sy |
Z | 0 | 0 | sz | 0 | Z * sz | ||
1 | 0 | 0 | 0 | 1 | 1 |
rotateX(rx) は下記の演算となります。
X | 1 | 0 | 0 | 0 | X | ||
Y | × | 0 | cos(rx) | -sin(rx) | 0 | = | Y*cos(rx) + Z*sin(rx) |
Z | 0 | sin(rx) | cos(rx) | 0 | -Y*sin(rx) + Z*cos(rx) | ||
1 | 0 | 0 | 0 | 1 | 1 |
.test-matrix3d { transform: matrix3d(0.7, 0, 0, 0, 0, 0.7, 0, 0, 0, 0, 1, 0, 20, 20, 0, 1); }
X | Y | Z | |
---|---|---|---|
translate: | |||
rotate: | |||
scale: | |||
skew: | |||
perspective: |
※ Chrome, Firefox, Opera, Edge の最新版で表示するとサイコロが動きます。IE11 では 2の面のみが表示されます。
.cube-container { position: relative; width: 40px; height: 40px; perspective: 1000px; } .cube { position: absolute; width: 40px; height: 40px; margin-top: 20px; margin-left: 20px; transform-style: preserve-3d; animation: roll-over 1s linear infinite; } .cube .side { position: absolute; box-sizing: border-box; width: 40px; height: 40px; border: 1px solid #666; text-align: center; font-size: 20pt; } .side1 { background: #f66; transform: rotateY(0deg) translateZ(20px); } .side2 { background: #6f6; transform: rotateY(180deg) translateZ(20px); } .side3 { background: #66f; transform: rotateY(90deg) translateZ(20px); } .side4 { background: #6ff; transform: rotateY(-90deg) translateZ(20px); } .side5 { background: #f6f; transform: rotateX(90deg) translateZ(20px); } .side6 { background: #ff6; transform: rotateX(-90deg) translateZ(20px); } @keyframes roll-over { from { transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg); } to { transform: rotateX(360deg) rotateY(360deg) rotateZ(360deg); } }
<div class="cube-container"> <div class="cube"> <div class="side side1">1</div> <div class="side side2">2</div> <div class="side side3">3</div> <div class="side side4">4</div> <div class="side side5">5</div> <div class="side side6">6</div> </div> </div>