Unityの各コンポーネント間でのやり取り

ただのメモ。

UnityのScriptは未だにどういう設計が良いのかよくわからない。変な挙動を起こさないためにMonobehaviorを継承しないでクラスを作ったりもしたんだけど、Monobehaviorの恩恵に与るとしたらどんな方法があるのか最近調べている。

1つの制御クラスから他のクラスへ処理を伝搬させたい時、Unityの機能を駆使すると以下の4つ方法があるらしい。
コンポーネント間のメソッド呼び出しとパフォーマンス

1. GetComponent() + TargetMethod()
2. SendMessage(“TargetMethod”)
3. BroadcastMessage(“TargetMethod”)
4. static TargetMethod() な感じで静的メソッドを使用する。

システム屋的な発想だと4しか思いつかないんだけど、ゲーム開発系の人はまた違う発想なのかな。1の処理が重そうなのはなんとなく分かるので、2,3を検証してきたいところ。

関連記事

ディープラーニング

PythonでMayaのShapeノードプラグインを作る

Cartographer:オープンソースのSLAMライブラリ

オープンソースの顔認識フレームワーク『OpenBR』

フォトンの放射から格納までを可視化した動画

UnityからROSを利用できる『ROS#』

Unityの薄い本

動的なメモリの扱い

Super Resolution:OpenCVの超解像処理モ...

TensorFlowでCGを微分できる『TensorFlow...

ブログをGoogle App EngineからAmazon ...

iOSデバイスのためのフィジカル・コンピューティングツールキ...

Raspberry Pi

映像ビジネスの未来

組み込み向けのWindows OS 『Windows Emb...

Google App Engine上のWordPressでA...

ZBrushで作った3Dモデルを立体視で確認できるVRアプリ...

iPhone・iPod touchで動作する知育ロボット『R...

NeuralNetwork.NET:.NETで使えるTens...

COLMAP:オープンソースのSfM・MVSツール

Google Chromecast

チャットツール用bot開発フレームワーク『Hubot』

WordPress on Google App Engine...

ZBrushのZScript入門

ドラマ『ファーストクラス』のモーショングラフィックス

UnityプロジェクトをGitHubで管理する

東京オリンピックと案内表示

WebGL開発に関する情報が充実してきている

Google App EngineでWordPress

adskShaderSDK

Faster R-CNN:ディープラーニングによる一般物体検...

OpenCV 3.3.0-RCでsfmモジュールをビルド

BlenderProc:Blenderで機械学習用の画像デー...

UnityでOpenCVを使うには?

OpenCVの顔検出過程を可視化した動画

Google製オープンソース機械学習ライブラリ『Tensor...

PGGAN:段階的に解像度を上げて学習を進めるGAN

UnityでLight Shaftを表現する

Iterator

Unityで強化学習できる『Unity ML-Agents』

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

KelpNet:C#で使える可読性重視のディープラーニングラ...

コメント