ジャンプ先: 概要. 戻り値. フラグ. Python 例.
reverseSurface(
surface
, [caching=boolean], [constructionHistory=boolean], [direction=int], [name=string], [nodeState=int], [object=boolean], [replaceOriginal=boolean])
注: オブジェクトの名前と引数を表す文字列は、カンマで区切る必要があります。これはシノプシスに示されていません。
reverseSurface は、取り消し可能、照会可能、および編集可能です。
サーフェスの一方向または両方向を反転するか、U 方向と V 方向を入れ替える(サーフェス法線を反転する効果)場合に使用できます。新しく反転したサーフェスの名前、および作成されたディペンデンシーノード名が返されます。反転したサーフェスのパラメータ範囲は、オリジナルのサーフェスと同じです。
このコマンドは、選択したサーフェスのアイソパラムも処理します。選択したアイソパラムについて、アイソパラム カーブが操作後に反転されるところを想像してみてください。たとえば、reverseSurface surface.v[0.1] は U 方向に反転します。
照会モードでは、戻り値のタイプは照会されたフラグに基づきます。
caching, constructionHistory, direction, name, nodeState, object, replaceOriginal
| ロング ネーム(ショート ネーム) |
引数タイプ |
プロパティ |
|
caching(cch)
|
boolean
|
 
|
|
すべてのアトリビュートのキャッシングを切り替えることで、再計算を不要にします。
|
|
direction(d)
|
int
|
 
|
|
サーフェスを反転する方向です。0 - U、1 - V、2 - U と V の両方、3 - 入れ替え。 既定: 0
|
|
nodeState(nds)
|
int
|
 
|
|
Maya のディペンデンシー ノードには 6 種類の設定可能な状態があります。通常(Normal)(0)、エフェクトなし(HasNoEffect)(1)、ブロッキング(Blocking)(2)ステータスは、グラフの評価方法を変更するために使用されます。
待機 - 通常(Waiting-Normal)(3)、待機 - エフェクトなし(Waiting-HasNoEffect)(4)、待機 - ブロッキング(Waiting-Blocking)(5)は、内部でのみ使用されます。これらは、インタラクション(例: 操作)の実行中にグラフのパーツを一時的に遮断します。操作が完了すると、ステータスは適切にリセットされます(例: 待機 - ブロッキング(Waiting-Blocking) は ブロッキング(Blocking) にリセットされます)。
通常(Normal)およびブロッキング(Blocking)のケースはすべてのノードに適用できますが、エフェクトなし(HasNoEffect)はノード特定です。多くのノードはこのオプションをサポートしていません。プラグインは状態を MPxNode::state アトリビュートに保存します。誰もがこのアトリビュートを設定したり確認したりすることができます。これらの 3 つの状態に関するその他の詳細は次の通りです。
| 状態 |
説明 |
| 通常(Normal) |
通常のノードの状態です。これが既定の設定です。 |
| エフェクトなし(HasNoEffect) |
エフェクトなし(HasNoEffect)オプション(別名: 通過)は、同じデータ タイプの出力を生成する入力を操作している場合に使用されます。 ほぼすべてのデフォーマが、他のいくつかのノードと同様に、この状態をサポートします。前に説明したように、すべてのノードでサポートされるわけではありません。
ノードの計算メソッドでエフェクトなし(HasNoEffect)状態のサポートを実装し、適切な操作を実行することが一般的です。プラグインはエフェクトなし(HasNoEffect)もサポートします。
この状態を普通に実装するには、ノードにアルゴリズムを適用しないで、適合する出力に直接入力をコピーします。デフォーマの場合は、この状態を適用することにより、入力ジオメトリが出力でデフォーム解除されたままになります。
|
| ブロッキング(Blocking) |
これはディペンデンシー ノードのベース クラスで実装され、すべてのノードに適用されます。ブロッキング(Blocking)は評価フェーズ中に接続に適用されます。 ブロックされた接続に対する評価要求が失敗を返すと、目的プラグが現在の値を保持します。 ダーティな伝播はこの状態の間接的な影響を受けますが、ブロックされた接続がクリーンアップされることはありません。
ノードをブロッキング(Blocking)に設定すると、すべての送信接続が解除されたのと同じ動作になる可能性があります。 ブロックされたノードの評価を直接要求しない限り、その後に再評価されることはありません。ブロックされたノードは getAttr 要求に引き続き応答しますが、下流ノードの getAttr は、ブロックされたノードを再評価しないことに注意してください。
ブロッキング(Blocking)に対して階層のルート変換を設定しても、自動的にはこの階層の子変換に影響しません。これを実行するには、ブロッキング(Blocking)状態に対してすべての子ノードを明示的に設定する必要があります。
たとえば、すべての子トランスフォームをブロッキング(Blocking)に設定するには、次のスクリプトを使用します。 import maya.cmds as cmds def blockTree(root): nodesToBlock = [] for node in {child:1 for child in cmds.listRelatives( root, path=True, allDescendents=True )}.keys(): nodesToBlock += cmds.listConnections(node, source=True, destination=True ) for node in {source:1 for source in nodesToBlock}.keys(): cmds.setAttr( '%s.nodeState' % node, 2 )
このスクリプトを適用してオブジェクトの描画を継続できますが、アニメートは行えません。
|
既定: kdnNormal
|
|
| 共通のフラグ |
constructionHistory(ch)
|
boolean
|
|
|
コンストラクション ヒストリをオンまたはオフにします。
|
|
name(n)
|
string
|
|
|
新しく作成するノードの名前を設定します。ネームスペース パスを含む場合、指定されたネームスペースの下に新しいノードが作成されます。ネームスペースが存在しない場合は、ネームスペースが作成されます。
|
|
object(o)
|
boolean
|
|
|
結果のオブジェクト、またはディペンデンシー ノードのみを作成します。
|
|
replaceOriginal(rpo)
|
boolean
|
|
|
|
フラグはコマンドの作成モードで表示できます
|
フラグはコマンドの編集モードで表示できます
|
フラグはコマンドの照会モードで表示できます
|
フラグに複数の引数を指定し、タプルまたはリストとして渡すことができます。
|
import maya.cmds as cmds
cmds.reverseSurface( 'surface1', ch=True, d=0 )
cmds.reverseSurface( 'surface1.v[0.1]', ch=True )
# Reverses surface1 with construction history in the U direction.
# The name of the new surface and the name of the new dependency node
# are returned.
cmds.reverseSurface( 'surface1', ch=False, rpo=True, d=1 )
cmds.reverseSurface( 'surface1.u[0.1]', ch=True )
# Reverses surface1 without history, with replace original on,
# in the V direction. Because the "-rpo" flag is on, the name of
# the original surface is returned as well as the new dependency node.
# The reversed surface will <em>replace</em> the original surface.
cmds.reverseSurface( 'surface1', ch=False, rpo=True, d=2 )
# Reverses surface1 without history, with replace original on,
# in both the U and V directions.
cmds.reverseSurface( 'surface1', ch=False, rpo=True, d=3 )
# Swaps the U and V directions of surface1 with history, with replace
# original on. This has the effect of reversing the surface normal.