CSS辞典 perspective-originプロパティ解説
3Dで変形する要素の視点の位置を指定する「perspective-originプロパティ」の使用方法を記載
CSS3/2.1
対応ブラウザ
data:image/s3,"s3://crabby-images/07604/07604da0bff51214124e04f13efc27bfe59a21be" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:chrome"
data:image/s3,"s3://crabby-images/fb3b4/fb3b46372d27f0bc36d573c070dca31d88bb5221" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:firefox"
data:image/s3,"s3://crabby-images/fedeb/fedebedc0dfca9b8099f518641a50dbb266e894c" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:safari"
data:image/s3,"s3://crabby-images/0dd5d/0dd5d3b6580f8a095a0ef724d993fbbdc8e618db" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms edge"
data:image/s3,"s3://crabby-images/4db8d/4db8d0f6cb6284560934a9604e71d1897441e865" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms ie"
data:image/s3,"s3://crabby-images/d1039/d1039816042d60fbbdbe7b912a5f228019b26f9b" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:opera"
初期値 | 50% 50% |
適用される要素 | 変形可能な要素 |
モジュール | CSS Transforms Level2 |
継承 | なし |
概要・使用方法
{ perspective-origin: 視点の位置;}
「perspective-originプロパティ」は奥行の表した要素に対する始点の位置を指定します。通常、奥行は対象要素を正面から見た時の状態で表されますが、始点の位置を変更することで、様々な角度から見た場合の奥行を表現できます。
対象要素の左上端「0 0」を始点としてx、y座標を半角スペースで区切って指定します。1つだけ指定した場合は、2つ目の値はcenterが適用されます。
data:image/s3,"s3://crabby-images/75875/758758186f9486ccf1d9be8927a83378abe986d5" alt="perspective-originプロパティの基準点の解説"
指定できる値(視点の位置)
数値+単位 | 視点の位置を単位付きの数値で指定します。 |
% | %値を指定します。値は要素の幅、高さに対する割合になります。 |
left | 視点のx座標を0%(左端)にします。 |
right | 視点のx座標を100%(右端)にします。 |
top | 視点のy座標を0%(上端)にします。 |
bottom | 視点のy座標を100%(下端)にします。 |
center | 視点のx,y座標を50%(中央)にします。 |
サンプルコード
<!DOCTYPE html>
<html lang="ja">
<head>
<title>perspective-originプロパティCSSフォントサンプルページ</title>
<meta charset="uft-8">
<style>
.transform-rotate{
transform:rotateY(30deg);
}
.perspective-right-bottom{
margin:5em 0;
perspective:400px;
perspective-origin: right bottom;
border:solid 1px red;
}
.perspective-top-left{
margin:5em 0;
perspective:400px;
perspective-origin: top left;
border:solid 1px red;
}
.perspective-none{
margin:5em 0;
perspective:400px;
border:solid 1px red;
}
</style>
</head>
<body>
<div class="perspective-right-bottom">
<h1>perspective-origin: right bottom;</h1>
<img class="transform-rotate" width="30%" height="30%" src="https://kcfran.com/sample/1856020_s.jpg">
</div>
<div class="perspective-top-left">
<h1>perspective-origin: top left;</h1>
<img class="transform-rotate" width="30%" height="30%" src="https://kcfran.com/sample/1856020_s.jpg">
</div>
<div class="perspective-none">
<h1>perspective-origin なし</h1>
<img class="transform-rotate" width="30%" height="30%" src="https://kcfran.com/sample/1856020_s.jpg">
</div>
</body>
</html>
実行結果
perspective-origin: right bottom;
data:image/s3,"s3://crabby-images/eed7e/eed7ee94b020c14ebf293ae4c052f6f58e3aa979" alt=""
perspective-origin: top left;
data:image/s3,"s3://crabby-images/eed7e/eed7ee94b020c14ebf293ae4c052f6f58e3aa979" alt=""
perspective-origin なし
data:image/s3,"s3://crabby-images/eed7e/eed7ee94b020c14ebf293ae4c052f6f58e3aa979" alt=""
chromeブラウザ実行結果
data:image/s3,"s3://crabby-images/0df1d/0df1dbfa90915895c7e0e00ef3861afe065df577" alt="chrome"
Firefox ブラウザ実行結果
data:image/s3,"s3://crabby-images/7e97f/7e97f3b712176c3a1c5d1e0ecbba97cbc0b79236" alt="Firefox"
edgeブラウザ実行結果
data:image/s3,"s3://crabby-images/d01fa/d01faa82e33e035ae995c92d73a0376db95ac897" alt="edge"
operaブラウザ実行結果
data:image/s3,"s3://crabby-images/f41e9/f41e910e1618bbd190ca99f1df0bee39f9816146" alt="opera"