ジャンプ先: 概要. 戻り値.
キーワード. 関連項目.
フラグ. Python 例.
addExtension([attributeType=string], [binaryTag=string], [cachedInternally=boolean],
[category=string], [dataType=string], [defaultValue=float], [enumName=string], [exists=boolean], [fromPlugin=boolean], [hasMaxValue=boolean], [hasMinValue=boolean], [hasSoftMaxValue=boolean],
[hasSoftMinValue=boolean],
[hidden=boolean], [indexMatters=boolean], [internalSet=boolean], [keyable=boolean], [longName=string], [maxValue=float], [minValue=float], [multi=boolean], [niceName=string], [nodeType=string], [numberOfChildren=uint],
[parent=string], [readable=boolean], [shortName=string], [softMaxValue=float], [softMinValue=float], [storable=boolean], [usedAsColor=boolean], [usedAsFilename=boolean], [writable=boolean])
注意:
オブジェクト名や引数を表す文字列はカンマで区切ります。これは概要には示されていません。
addExtension は 「元に戻す」が不可能、「照会」が可能、「編集」が可能 です。
ノード タイプに拡張子アトリビュートを追加します。longName か shortName
のどちらか一方またはその両方を指定する必要があります。 dataType と attributeType
のどちらも指定しないと、double アトリビュートが追加されます。dataType
フラグを複数回指定すると、指定したすべてのタイプが許可されます(論理和)。 double
以外のアトリビュートを追加する場合、次の基準を使用して dataType フラグと attributeType
フラグのどちらが適切か判断することができます。double3 など、タイプによってはどちらも使用できる場合があります。
このような場合は、データにアトミック エンティティとしてのみアクセスする(つまり、double3 を構成する 3
つの個々の値にはアクセスしない)場合には、-dt フラグを使用します。一般的には、柔軟性を高めるために
-at を使用するのが最良です。-dt バージョンはアトミック
タイプで個々の部分を変更できないため、ほとんどの場合はアトリビュート エディタ(Attribute
Editor)に表示されません。下記の「(複合)」が付いたすべてのアトリビュートまたは複合アトリビュート自体は、すべての子が定義されるまで(「-p」フラグを使用して作成された複合をその親に設定)、実際にはノードに追加されません。詳細については、例を参照してください。
アトリビュートのタイプ |
使用するフラグと引数 |
ブーリアン |
-at bool |
32 ビット整数 |
-at long |
16 ビット整数 |
-at short |
8 ビット整数 |
-at byte |
char |
-at char |
enum |
-at enum(enumName フラグを使用して enum 名を指定) |
float |
-at "float"(float は MEL キーワードのため引用符を使用) |
double |
-at double |
角度値 |
-at doubleAngle |
リニア値 |
-at doubleLinear |
文字列 |
-dt "string"(string は MEL キーワードのため引用符を使用) |
文字配列 |
-dt stringArray |
複合 |
-at compound |
メッセージ(データなし) |
-at message |
時間 |
-at time |
4x4 二次元行列 |
-dt "matrix"(matrix は MEL キーワードのため引用符を使用) |
4x4 float 行列 |
-at fltMatrix |
反射率 |
-dt reflectanceRGB |
反射率(複合) |
-at reflectance |
スペクトラム |
-dt spectrumRGB |
スペクトラム(複合) |
-at spectrum |
2 float |
-dt float2 |
2 float(複合) |
-at float2 |
3 float |
-dt float3 |
3 float(複合) |
-at float3 |
2 double |
-dt double2 |
2 double(複合) |
-at double2 |
3 double |
-dt double3 |
3 double(複合) |
-at double3 |
2 x 32 ビット整数 |
-dt long2 |
2 x 32 ビット整数(複合) |
-at long2 |
3 x 32 ビット整数 |
-dt long3 |
3 x 32 ビット整数(複合) |
-at long3 |
2 x 16 ビット整数 |
-dt short2 |
2 x 16 ビット整数(複合) |
-at short2 |
3 x 16 ビット整数 |
-dt short3 |
3 x 16 ビット整数(複合) |
-at short3 |
二次元配列 |
-dt doubleArray |
32 ビット整数の配列 |
-dt Int32Array |
vector 型の配列 |
-dt vectorArray |
NURBS カーブ |
-dt nurbsCurve |
NURBS サーフェス |
-dt nurbsSurface |
ポリゴン メッシュ |
-dt mesh |
ラティス |
-dt lattice |
二次元 4D ポイントの配列 |
-dt pointArray |
なし
戻り値の型は照会モードでは照会フラグが基になります。
attribute, dependency, graph, add, dynamic, create
addAttr, aliasAttr, attributeInfo, connectAttr, deleteAttr, disconnectAttr, getAttr, getClassification, nodeType, objExists, objectType, renameAttr, setAttr
attributeType, binaryTag, cachedInternally, category, dataType,
defaultValue, enumName, exists,
fromPlugin, hasMaxValue, hasMinValue, hasSoftMaxValue, hasSoftMinValue, hidden, indexMatters, internalSet, keyable, longName,
maxValue, minValue, multi,
niceName, nodeType, numberOfChildren, parent, readable,
shortName, softMaxValue, softMinValue, storable, usedAsColor, usedAsFilename, writable
ロング ネーム(ショート ネーム) |
引数型 |
プロパティ |
nodeType(nt) |
string |
|
|
アトリビュートを追加するノードのタイプを指定します。異なるノード タイプの名前については、nodeType
コマンドを参照してください。 |
|
longName(ln) |
string |
|
|
shortName(sn) |
string |
|
|
niceName(nn) |
string |
|
|
UI に表示するアトリビュートのナイス ネームを設定します。アトリビュートのナイス
ネームに空でない文字列を設定すると、Maya の文字列カタログからナイス
ネームを検索するデフォルト動作が無効になります。(カタログにあるアトリビュートのナイス ネームを検索するには、MEL
コマンド「attributeNiceName」と「attributeQuery -niceName」を使用します)。 |
|
binaryTag(bt) |
string |
|
|
このフラグはサポートしていません。いかなる動作もしません。 |
|
attributeType(at) |
string |
|
|
アトリビュート タイプを指定します。詳細は上の表を参照してください。注意が必要なのは、アトリビュート タイプ
「float」、「matrix」、「string」は MEL キーワードでもあるため、引用符で囲む必要があることです。 |
|
dataType(dt) |
string |
|
|
データ型を指定します。データ型の名前の詳細については、「setAttr」を参照してください。 |
|
defaultValue(dv) |
float |
|
|
アトリビュートのデフォルト値を指定します(数値アトリビュートでのみ使用可能)。 |
|
multi(m) |
boolean |
|
|
新しいアトリビュートをマルチ アトリビュートにします。 |
|
indexMatters(im) |
boolean |
|
|
マルチ アトリビュートにコネクトするときに、インデックスを使用する必要があるかどうかを設定します。indexMatters を
false に設定すると、アトリビュートは強制的に読み取り不可になります。 |
|
minValue(min) |
float |
|
|
アトリビュートに最小値を指定します(数値アトリビュートでのみ使用可能)。 |
|
hasMinValue(hnv) |
boolean |
|
|
アトリビュートに最小値があるかどうかを示すフラグです(数値アトリビュートでのみ使用可能)。 |
|
maxValue(max) |
float |
|
|
アトリビュートの最大値を指定します(数値アトリビュートでのみ使用可能)。 |
|
hasMaxValue(hxv) |
boolean |
|
|
アトリビュートに最大値があるかどうかを示すフラグです(数値アトリビュートでのみ使用可能)。 |
|
cachedInternally(ci) |
boolean |
|
|
アトリビュート
データをノード内部にキャッシュするかどうかを指定します。このフラグは現在サポートしていません(常にデフォルト値の true
に設定されます)。 |
|
internalSet(internalSet) |
boolean |
|
|
このアトリビュート値が変更されたときに内部にキャッシュされた値にセットするかどうかを指定します。これは UI
要素の更新に使用する内部フラグです。 |
|
parent(p) |
string |
|
|
新しいアトリビュートの親になるアトリビュートです。 |
|
numberOfChildren(nc) |
uint |
|
|
新しいアトリビュートには子が何個あるかを指定します。 |
|
usedAsColor(uac) |
boolean |
|
|
アトリビュートをカラー定義として使用します。このフラグを使用するには、3 DOUBLE または 3 FLOAT
の子が必要です。アトリビュートタイプ「-at」は必要に応じて「double3」または「float3」にする必要があります。また、このフラグを「double3」または「float3」としたデータ型「-dt」とともに使用してエフェクトを小さくすることもできますが、コードの部分によってはこの代替をサポートしないことがあります。特別なアトリビュート
タイプ/データである「スペクトラム」と「反射率」はカラー フラグもサポートしており、この上ではデフォルトでカラー
フラグが設定されます。 |
|
usedAsFilename(uaf) |
boolean |
|
|
アトリビュートをファイル名定義として扱います。このフラグはデータ型が「string」の「-dt」フラグを持つアトリビュートでのみサポートされます。 |
|
hidden(h) |
boolean |
|
|
このアトリビュートは UI から非表示になります。 |
|
readable(r) |
boolean |
|
|
このアトリビュートからの出力コネクションを作成できます。 |
|
writable(w) |
boolean |
|
|
このアトリビュートへの入力コネクションを作成できます。 |
|
storable(s) |
boolean |
|
|
keyable(k) |
boolean |
|
|
fromPlugin(fp) |
boolean |
|
|
元はプラグンで作成したアトリビュートですか?API コールが行われた場合、通常は自動的に設定されます -
作成プラグインとは関係ないファイル内でのソートをサポートするために追加されました。 |
|
softMinValue(smn) |
float |
|
|
ソフト最小値、数値アトリビュートにのみ有効です。このアトリビュート用のスライダで使用するデフォルトの上限値を指定します。 |
|
hasSoftMinValue(hsn) |
boolean |
|
|
数値アトリビュートがソフト最小値を持つかどうかを示すフラグです。 |
|
softMaxValue(smx) |
float |
|
|
ソフト最大値、数値アトリビュートにのみ有効。このアトリビュート用のスライダで使用するデフォルトの上限値を指定します。 |
|
hasSoftMaxValue(hsx) |
boolean |
|
|
数値アトリビュートがソフト最大値を持つかどうかを示すフラグです。 |
|
category(ct) |
string |
|
|
アトリビュート
カテゴリは、識別するためにアトリビュートに関連付けられています(アトリビュートを作成したプラグインの名前、バージョン情報など)。任意のアトリビュートを任意の数のカテゴリに関連付けすることが可能です。ただし、一度関連付けしたカテゴリを削除することはできません。 |
|
enumName(en) |
string |
|
|
enum 値に対応する UI
名を指定するために使用するフラグです。指定する文字列には、コロンで区切った名前のリストとオプション値を含めます。値を指定しないと、0
で始まる連続した整数として扱われます。例:-enumName "A:B:C" が生成するオプション値は、A、B、C の順に 0、1、2
で、-enumName "zero:one:two:thousand=1000" は、値 0、1、2、1000 の 4
つのオプションを生成し、-enumName "solo=1:triplet=3:quintet=5" は、値が 1、3、5 の 3
つのオプションを生成します。(現時点でのチャンネル ボックス(Channel
Box)に関する制限事項として、列挙型アトリビュートのプルダウン
メニューが正しく表示されない場合があります。オプション値が連続していない場合に、その間の数がメニュー項目として余分に表示される可能性があります。この制限事項を回避するために、チャンネル
ボックスで表示する列挙型アトリビュートのオプションには連続した値を指定してください。例:"solo=1:triplet=2:quintet=3")。 |
|
exists(ex) |
boolean |
|
|
照会されたアトリビュートがユーザが追加したダイナミック アトリビュートであれば true を、そうでない場合には false
を返します。 |
|
: コマンドの作成モードで使用可能なフラグ |
: コマンドの編集モードで使用可能なフラグ |
: コマンドの照会モードで使用可能なフラグ |
: タプルまたはリストとして渡された複数の引数を持てるフラグ |
import maya.cmds as cmds
# Add an attribute named ms/mass with a default value of 1 and a
# minimum value of 0.001 and a maximum of 10000 to all mesh shapes.
#
cmds.addExtension( nodeType='meshShape', shortName='ms', longName='mass', defaultValue=1.0, minValue=0.001, maxValue=10000 )
# Add a multi attribute named ff/forcefield of type double3 to all mesh shapes.
#
cmds.addExtension( nodeType='meshShape', shortName='ff', longName='forcefield', dataType='double3', multi=True )
# Add a compound attribute named sampson with children homeboy, midge,
# damien, elizabeth, and sweetpea of varying types to all choice nodes.
#
cmds.addExtension( nodeType='choice', longName='sampson', numberOfChildren=5, attributeType='compound' )
cmds.addExtension( nodeType='choice', longName='homeboy', attributeType='matrix', parent='sampson' )
cmds.addExtension( nodeType='choice', longName='midge', attributeType='message', parent='sampson' )
cmds.addExtension( nodeType='choice', longName='damien', attributeType='double', parent='sampson' )
cmds.addExtension( nodeType='choice', longName='elizabeth', attributeType='double', parent='sampson' )
cmds.addExtension( nodeType='choice', longName='sweetpea', attributeType='double', parent='sampson' )
# To add an attribute that is to be interpreted as a color the
# following attribute group must be used.
#
# Note that the word "float" must be in quotations since it is a
# MEL keyword.
#
cmds.addExtension( nodeType='phong', longName='rainbow', usedAsColor=True, attributeType='float3' )
cmds.addExtension( nodeType='phong', longName='redBow', attributeType='float', parent='rainbow' )
cmds.addExtension( nodeType='phong', longName='greenBow', attributeType='float', parent='rainbow' )
cmds.addExtension( nodeType='phong', longName='blueBow', attributeType='float', parent='rainbow' )
# Other legal attribute types that can be interpreted as colors need
# not specify the "-usedAsColor" flag as it will be assumed. These
# include "-attributeType spectrum", "-attributeType reflectance",
# "-dataType spectrumRGB", and "-dataType reflectanceRGB".
#
cmds.addExtension( nodeType='phong', longName='implColor', dataType='spectrumRGB' )
cmds.addExtension( nodeType='phong', '.implColor', query=True, usedAsColor=True )
# Result: 1 #
# Add a double3 attribute named sanders with children bess, les and wes
# to all dag nodes, including shapes, transforms, and joints.
#
cmds.addExtension( nodeType='dagObject', longName='sanders', attributeType='double3' )
cmds.addExtension( nodeType='dagObject', longName='bess', attributeType='double', parent='sanders' )
cmds.addExtension( nodeType='dagObject', longName='les', attributeType='double', parent='sanders' )
cmds.addExtension( nodeType='dagObject', longName='wes', attributeType='double', parent='sanders' )