MFnMeshクラスのsplit関数

誰にも頼まれてないけど仕様を日本語に訳しておくよ。

MFnMeshクラスのsplit関数

MStatus MFnMesh::split( MIntArray & placements,
MIntArray & edgeList,
MFloatArray & edgeFactors,
MFloatPointArray & internalPoints
)


この関数は、エッジとフェースを連続的に分割します。placements配列の要素は、列挙型SplitPlacementでなければなりません。placements配列中でSplitPlacement::kOnEdgeと設定された要素は、対応するエッジIDとファクターがedgeList配列とedgeFactors配列にもそれぞれ含まれている必要があります。SplitPlacement::kInternalPointと設定された要素についても同様に、internalPoints配列にも含まれている必要があります。それぞれの要素は、3つの配列全て同じ順序で指定する必要がありますから、placements配列の最初にあるSplitPlacement::kOnEdgeと設定されている要素は、edgeList配列とedgeFactors配列の最初の要素と対応させます。

もしも頂点の内1つでも作成出来ない場合、アルゴリズム全体が失敗します。同じエッジを2回以上分割することはできません。分割の開始・終了もエッジ上である必要があります。これはつまり、placements配列の最初と最後の要素は必ずSplitPlacement::kOnEdgeに設定されていなければならないということです。placements配列がエッジ上で開始・終了しない場合、コードは「成功」ステータスを返しますがメッシュは分割されません。。

NOTE:このメソッドで使用されるアルゴリズムはpolySplitコマンドと同じで、同様の制限があります。

引数:

  • [in] placements

列挙型SplitPlacementが設定された要素を格納する配列。これは、分割で新しい頂点を配置する場所(エッジ上かフェース上か)を表しています。

  • [in] edgeList

分割するエッジのIDを分割順に格納する配列。この配列には、placements配列のSplitPlacement::kOnEdgeに設定されている要素と同じ数だけの要素が必要です。

  • [in] edgeFactors

エッジ上の分割位置を表す内分比ファクター(範囲0~1)、を格納する配列。この配列の持つ要素の数は、edgeList配列が持つ要素の数と同じである必要があります。

  • [in] internalPoints

既存のフェース上に新しく追加する頂点の位置座標を格納する配列。この配列には、placements配列のSplitPlacement::kInternalPointに設定されている要素と同じ数だけの要素が必要です。この配列は空でもかまいません。追加する頂点は、前のエッジIDと次のエッジIDの間にあるフェース上で指定する必要があります。

返り値:

Status Code

Status Codes:

  • MS::kSuccess

The method was successful.

  • MS::kInvalidParameter

One of the following parameter errors

  • MS::kIndexOutOfRange

One or more of the edge IDs are not on the mesh.

  • MS::kValueOutOfRange

One or more of the edge factors are not within the [0,1] range

  • MS::kInvalidParameter

The split algorithm could not be completed successfully or the array sizes are not appropriate.

  • MS::kNotFound

The given placements list is empty.

  • MS::kFailure

An object error has occurred.

  • MS::kObjectDoesNotExist

The base stucture was not initialized properly

  • MS::kShapeHasNoGeometry

The mesh shape has no geometry to work on

Examples:

meshOpFtyAction.cpp.

そんで分割方法のフラグとなる列挙型。(intにキャストしてMIntArrayに入れる)

SplitPlacement

<span class="synType">enum</span> MFnMesh::SplitPlacement

分割点の決定方法を指定するフラグ。

Enumerator:

  • kOnEdge

エッジに沿って新しい頂点を配置し、エッジを 2 つの新しいエッジに分割する。

  • kInternalPoint

フェース内の特定座標に新しい頂点を挿入する。

  • kInvalid

無効

今まで知らなかったんだけど、C++の列挙型ってintと相互にキャストできるのね。(内部では整数が回るらしい)

コーディングミスを防ぐ目的でenumを使うって感じみたい。

関連記事

OpenGV:画像からカメラの3次元位置・姿勢を推定するライ...

スターウォーズ エピソードVIIの予告編

ZBrushのハードサーフェイス用ブラシ

BSDF: (Bidirectional scatterin...

オープンソースのネットワーク可視化ソフトウェアプラットフォー...

『ローグ・ワン/スター・ウォーズ・ストーリー』のVFXブレイ...

C++の抽象クラス

Mayaのポリゴン分割ツールの進化

BlenderのRigifyでリギング

Unityをレンダラとして活用する

OpenGVの用語

アニゴジ関連情報

C++ 標準テンプレートライブラリ (STL)

3Dスキャンに基づくプロシージャルフェイシャルアニメーション

ヒーローに変身なりきりアーケードゲーム『ナレルンダー』

2012 昨日のクローズアップ現代を見た

実写と実写の合成時の色の馴染ませテクニック

『スター・ウォーズ/スカイウォーカーの夜明け』のVFXブレイ...

トランスフォーマー :リベンジのメイキング (デジタルドメイ...

bpy-renderer:レンダリング用Pythonパッケー...

Unreal Engine Tokyo MeetUp!へ行っ...

ZBrushCore

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

Blenderでよく使うaddon

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

Vancouver Film Schoolのデモリール

ZBrushからBlenderへモデルをインポート

ZBrushで人型クリーチャー

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

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

海外ドラマのChromaKey

CGALDotNet:計算幾何学ライブラリ CGALのC#ラ...

BlenderでPhotogrammetryできるアドオン

書籍『The Art of Mystical Beasts』...

AndroidもopenGLも初心者さ (でもJavaは知っ...

Javaで作られたオープンソースの3DCGレンダラ『Sunf...

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

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

Leap MotionでMaya上のオブジェクトを操作できる...

OpenCVでPhotoshopのプラグイン開発

OpenCVでカメラ画像から自己位置認識 (Visual O...

VCG Library:C++のポリゴン操作ライブラリ

コメント