このページはコミュニティーの尽力で英語から翻訳されました。MDN Web Docsコミュニティーについてもっと知り、仲間になるにはこちらから。
scaleZ()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
scaleZ() はCSS の関数で、要素を Z 軸に沿って変倍する座標変換を定義します。結果は<transform-function> データ型になります。
In this article
試してみましょう
transform: scaleZ(1);transform: scaleZ(1.4);transform: scaleZ(0.5);transform: scaleZ(-1.4);<section> <div> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> </div></section>#default-example { background: linear-gradient(skyblue, khaki); perspective: 800px; perspective-origin: 150% 150%;}#example-element { width: 100px; height: 100px; perspective: 550px; transform-style: preserve-3d;}.face { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; position: absolute; backface-visibility: inherit; font-size: 60px; color: white;}.front { background: rgb(90 90 90 / 0.7); transform: translateZ(50px);}.back { background: rgb(0 210 0 / 0.7); transform: rotateY(180deg) translateZ(50px);}.right { background: rgb(210 0 0 / 0.7); transform: rotateY(90deg) translateZ(50px);}.left { background: rgb(0 0 210 / 0.7); transform: rotateY(-90deg) translateZ(50px);}.top { background: rgb(210 210 0 / 0.7); transform: rotateX(90deg) translateZ(50px);}.bottom { background: rgb(210 0 210 / 0.7); transform: rotateX(-90deg) translateZ(50px);}これは要素のそれぞれの点の Z 座標を一定の係数で修正しますが、係数が 1 である場合はこの関数が恒等変換になるので例外です。変倍は等方性ではなく、要素の角度は保存されません。scaleZ(-1) は軸の線対称を定義し、Z 軸は (transform-origin プロパティの指定通りに) 原点を通過します。
上記のデモでは、perspective: 550px; (三次元空間を作るため) とtransform-style: preserve-3d; (立方体の 6 つの面である子を三次元空間に配置) を立方体に設定しました。
メモ:scaleZ(sz) はscale3d(1, 1, sz) と等価です。
構文
css
scaleZ(s)値
形式文法
<scaleZ()> =
scaleZ([<number>|<percentage>])
例
>HTML
html
<div>通常</div><div>平行移動</div><div>変倍</div>CSS
css
div { width: 80px; height: 80px; background-color: skyblue;}.perspective { /* 3D 空間を生成するために視点を含める */ transform: perspective(400px) translateZ(-100px); background-color: limegreen;}.scaled-translated { /* 3D 空間を生成するために視点を含める */ transform: perspective(400px) scaleZ(2) translateZ(-100px); background-color: pink;}結果
仕様書
| Specification |
|---|
| CSS Transforms Module Level 2> # funcdef-scalez> |