参考ビデオ:Rotation And Relative Rotation (A-Frame Tutorial – WebVR) から
自身のUdemyのA-Frameコースのコンテンツの一部を、YouTubeチャンネルに公開されている方の”Learn A-Frame (WebVR)”プレイリストを見ながら進めています。詳しくはリンク先をご覧ください。
<a-box color="#689F38"
width="4"
height="2"
depth="0.2"
position="0 1 -7">
<a-circle color="#333333"
side="double"
position="2 0 0">
</a-circle>
</a-box>
<a-circle color="#FFC107"
side="double"
position="-2 1 -7">
</a-circle>
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double">
</a-cylinder>
data:image/s3,"s3://crabby-images/c5999/c599915a0dd9558cfa8b55c36d3be34738703fea" alt=""
すべてのエンティティは、positionコンポーネント同様、rotationコンポーネントを持ち合わせていて、デフォルトはrotation=”0 0 0″。
各軸に対して、どちらがプラス方向の回転になるかを確認するにも、やはり右手座標系のルールを使うことができ、Y軸に関しては、下記のリンク先の図で確認できる。
https://www.quora.com/profile/Shubham-Agrawal-141/answers
親指をY軸のプラス方向に向けた際に、親指以外の指が握るように曲がる方向がプラスの回転になる。A-Frameのエンティティの角度の単位は、degree(度)。
ここで、X軸周りにプラス方向の回転を知りたい場合は、親指をX軸方向に向ける。他の指が手前に回るこの方向がプラスになる。グレーの円をプラス方向に30度回転させる。
data:image/s3,"s3://crabby-images/f6696/f66962d1099a80606f3106ba02ccaf23339baa1a" alt=""
グレーの円をプラス方向に90度回転させた場合。
data:image/s3,"s3://crabby-images/baaaf/baaafffd686799080943971a8d50e7e1db122839" alt=""
子のエンティティは、positon、rotation、scaleなど、すべてのタイプの変形を、親のエンティティから引き継ぐ。
その為、親である緑色パネルに回転を与えると、親(緑のパネル)と子(黄色の円)の両方が、回転するのが確認できる。
data:image/s3,"s3://crabby-images/9bcff/9bcff23dfdf3c862b02c897884e7923d67149857" alt=""
data:image/s3,"s3://crabby-images/de0f9/de0f9c0f8c73ce397c8275162ab9d9f88dd34ba0" alt=""
今度は、シリンダの方にアトリビュートを追加してみる。Z軸を考える場合、親指を自分の方向に向けた時、他の指が曲がる方向は、反時計回りになる。Zの値を増やしていく。
data:image/s3,"s3://crabby-images/50ddb/50ddbb37b8bd4a3b9ef068749b1b595a2771caee" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
rotation="0 0 0">
</a-cylinder>
data:image/s3,"s3://crabby-images/ac1f9/ac1f9e7683b0b96eaca1359a82bc8f74ea493e76" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
rotation="0 0 30">
</a-cylinder>
data:image/s3,"s3://crabby-images/2290e/2290e482db4061794710e0909e48b76413f08206" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
rotation="0 0 90">
</a-cylinder>
今度は、Y軸周りにマイナスの方向に90度回転させてみる。
親指を下に向けることで回転方向が確認でき、Y軸を中心に、時計回りにまわる。
data:image/s3,"s3://crabby-images/f4dd5/f4dd5369107a6b77ef2cae48a85f7edb13ea9797" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
rotation="0 -30 90">
</a-cylinder>
data:image/s3,"s3://crabby-images/11044/11044469d559a496ba63915bf5e6f688fe6bdd17" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
rotation="0 -90 90">
</a-cylinder>
シリンダを1m上に移動してみる。(position=”0 1 0″)
data:image/s3,"s3://crabby-images/dc8cd/dc8cdfbcab16d9b84cf8616d1c79c89cdf9b90a5" alt=""
<a-cylinder color="#616161"
height="2"
radius="2"
segments-radial="6"
open-ended="true"
side="double"
position="0 1 0"
rotation="0 -90 90">
</a-cylinder>
次回はスケールです。