UnityのTransformクラスについて調べてみた

珍しくCG系だけどレンダリングからはちょっと遠い話。

UnityのTransformクラスについて最近知ったこと。

Transformクラス

オブジェクトの位置、回転、スケールを扱うクラス

シーン内のすべてのオブジェクトはTransformを持ちます。 Transformはオブジェクトの位置、回転、スケールを格納し、操作するために使用されます。 全てのTransformは親を持ち、階層的に位置、回転、スケールを適用することが出来ます。これはヒエラルキーウィンドウで階層を見ることが出来ます。

3DCGので空間に配置されるオブジェクトがTransform(変換行列)を持つのは他のアプリケーションでも同じだから大体同じように扱えると思ってたんだけど、オイラがUnityのTransformでちょっと誤解してたことがあった。

このクラスから取得できるオブジェクトのposition(ワールド空間での位置座標)とlocalPosition(ローカル空間での位置座標)の値について公式ドキュメントにはこう説明がある。↓

position: ワールド空間のTransformの位置
localPosition: 親のTransformオブジェクトから見た相対的な位置



localPositionの「親のTransformオブジェクトから見た相対的な位置」は、親のTransformオブジェクトのローカル座標軸(X, Y, Z)で表されているものだと思ったけど、普通にワールド座標軸(X, Y, Z)と同じ直交座標で表されてた。
個人的には親のTransformオブジェクトのローカル座標軸で表されていた方が計算する際に都合が良いと思うんだけどなぁ。

で、そんな「ちょっとだけ機能が足りない」みたいな場合、既存のクラスメソッドを拡張できるC#の拡張メソッド(Extensions)機能が便利らしいということを知った。↓
http://qiita.com/shinoyu/items/7dec4bbd0282ae6755e6

これで座標軸を親のTransformオブジェクトのローカル座標軸へ変換してから取得できるメソッドをTransformクラスに追加することができる。
定番の便利機能は大体みんな同じような書き方になるよね。
https://qiita.com/MunenaoMiyata/items/24d0675861744c827668
https://github.com/mminer/unity-extensions

ちょっと調べたら、Translateメソッドではローカルの軸をそのまま使えるのね。↓

Transform.Translate

/translation/ の方向と距離に移動します

/relativeTo/ を設定しない、またはSpace.Selfを設定した場合は、移動はTransformのローカル軸で適用されます。(シーンビュー内でオブジェクトを選択している時に見えているX,Y,Z軸) /relativeTo/ がSpace.Worldの場合、移動はワールド座標を基準に適用されます。

関連記事

ZBrushでアヴァン・ガメラを作ってみる

定数

PyTorch3D:3Dコンピュータービジョンライブラリ

ZBrushのUV MasterでUV展開

MFnMeshクラスのsplit関数

ZBrushでアヴァン・ガメラを作ってみる 全体のバランス調...

Raspberry Piでセンサーの常時稼働を検討する

布のモデリング

OpenFace:Deep Neural Networkによ...

iPhone 3GSがますます欲しくなる動画

仮想関数

『スター・ウォーズ フォースの覚醒』のVFXブレイクダウン ...

なんかすごいサイト

MeshLab:3Dオブジェクトの確認・変換に便利なフリーウ...

MetaHumanの頭部をBlenderで編集できるアドオン

Swark:コードからアーキテクチャ図を作成できるVSCod...

iPhoneアプリ開発 Xcode 5のお作法

ZBrushで仮面ライダー3号を造る 仮面編 横顔のシルエッ...

geometry3Sharp:Unity C#で使えるポリゴ...

頭蓋骨からの顔復元と進化過程の可視化

昔Mayaでモデリングしたモデルをリファインしてみようか

3分の動画でプログラミングを学習できるサイト『ドットインスト...

ZBrushでアヴァン・ガメラを作ってみる 頬の突起を作り始...

ラクガキの立体化 目標設定

プログラムによる景観の自動生成

WinSCP

日立のフルパララックス立体ディスプレイ

Theia:オープンソースのStructure from M...

OpenCVで顔のランドマークを検出する『Facemark ...

『シン・ゴジラ』のコンセプトアニメーションのメイキング動画が...

株式会社ヘキサドライブの研究室ページ

Mayaのプラグイン開発

スクレイピング

Google App Engineのデプロイ失敗

池袋パルコで3Dのバーチャルフィッティング『ウェアラブル ク...

AmazonEC2のインスタンスをt1.microからt2....

テスト

Structure from Motion (多視点画像から...

TeleSculptor:空撮動画からPhotogramme...

書籍『データビジュアライゼーションのデザインパターン20』読...

GAN (Generative Adversarial Ne...

ニューラルネットワークで画像分類

コメント