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

以前、C++でLocatorノードやShaderノードを作ったことはあったけど、C++はビルドの依存関係が結構面倒。もっと手軽に作りたくて、最近はPythonで書く方法を調べてる。
プラグイン開発の大枠はすでに理解してるんで、まあ、できるだろうと。書籍Maya Python 完全リファレンスも出てるし。

とりあえずロケーター作成の記事を見てみたら、やっぱり全体像はC++と同じみたい。
https://dftalk.jp/?p=3175

そんで、MayaのPython APIはバージョン1.0と2.0があることを知った。2.0はMaya 2012から使えるようになったらしい。
大きな違いはOpenMaya周りっぽい。→Maya Python API 2.0 Reference



今回はShapeノードを作ってみたいんだけど、公開されているサンプルコードはAPI 1.0で書かれていたので、それに倣って今回はAPI 1.0で作ることにする。
ShapeノードのPythonサンプルコードは以下2つ。(C++のリファレンスに混じってて見つけにくい)

さて、試しにこれらのサンプルをロードしてみると、一応Shapeノードとしてロードされるが、compute関数が空なので、ジオメトリはビューポート上に表示されるだけでレンダラには渡されない。つまり、Locatorと大差ないってこと。
全てのMayaノードはcompute関数を心臓部としていて、ここでoutputとなる情報を生成して出力のプラグに繋いでやる必要がある。Shaderの場合は、この出力がレンダラに渡す色になるわけ。
ということで、ちゃんとShapeノードとして機能させるには、ジオメトリのoutputアトリビュートを作ってcompute関数で値を生成してやる必要がある。
ここで参考になるのはC++の方のShapeノードのサンプル。apiMeshShape/~で始まるサンプルコードね。

結局C++を読む羽目になってるけど気にしない。
今日はここまで。

ところで、この手の書籍って何でノードよりもコマンドプラグインの解説が充実してるんだろう。

Maya Python 完全リファレンス (Maya Python for Games and Film)

関連記事

動的なメモリの扱い

UnityでPoint Cloudを表示する方法

手を動かしながら学ぶデータマイニング

Webサイトのワイヤーフレームが作成できるオンラインツール

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

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

BlenderのRigifyでリギング

Mitsuba 3:オープンソースの研究向けレンダラ

Open3D:3Dデータ処理ライブラリ

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

OpenCVのバージョン3が正式リリースされたぞ

FCN (Fully Convolutional Netwo...

ZBrushでアヴァン・ガメラを作ってみる おでこ(?)のバ...

OpenCVで動画の手ぶれ補正

SONY製のニューラルネットワークライブラリ『NNabla』

布のモデリング

openMVG:複数視点画像から3次元形状を復元するライブラ...

Gource:バージョン管理の履歴を可視化するツール

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

iOSで使えるJetpac社の物体認識SDK『DeepBel...

ゴジラ三昧

3Dグラフィックスの入門書

オープンソースの物理ベースGIレンダラ『appleseed』

書籍『ROSプログラミング』

2012のメイキングまとめ(途中)

Unity Scriptコーディング→Unreal Engi...

書籍『メイキング・オブ・ピクサー 創造力をつくった人々』を読...

ラクガキの立体化 進捗

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

2D→3D復元技術で使われる用語まとめ

Blendify:コンピュータービジョン向けBlenderラ...

Unreal Engine Tokyo MeetUp!へ行っ...

『ピクサー展』へ行ってきた

Python.NET:Pythonと.NETを連携させるパッ...

イタリアの自動車ブランドFiatとゴジラがコラボしたCMのメ...

Unreal Engineの薄い本

映画『ジュラシック・ワールド/炎の王国』のVFXブレイクダウ...

マルコフ連鎖モンテカルロ法

デザインのリファイン再び

Unityで360度ステレオVR動画を作る

ZBrush 2018へのアップグレード

Multi-View Environment:複数画像から3...

コメント