ジャンプ先: 概要. 戻り値. フラグ. Python 例.
tabLayout(
[string]
, [annotation=string], [backgroundColor=[float, float, float]], [borderStyle=string], [changeCommand=script], [childArray=boolean], [childResizable=boolean], [defineTemplate=string], [docTag=string], [doubleClickCommand=script], [dragCallback=script], [dropCallback=script], [enable=boolean], [enableBackground=boolean], [exists=boolean], [fullPathName=boolean], [height=int], [highlightColor=[float, float, float]], [horizontalScrollBarThickness=int], [image=string], [imageVisible=boolean], [innerMarginHeight=int], [innerMarginWidth=int], [isObscured=boolean], [manage=boolean], [minChildWidth=int], [moveTab=[int, int]], [newTabCommand=script], [noBackground=boolean], [numberOfChildren=boolean], [numberOfPopupMenus=boolean], [parent=string], [popupMenuArray=boolean], [preSelectCommand=script], [preventOverride=boolean], [scrollable=boolean], [scrollableTabs=boolean], [selectCommand=script], [selectTab=string], [selectTabIndex=int], [showNewTab=boolean], [tabLabel=[string, string]], [tabLabelIndex=[int, string]], [tabsClosable=boolean], [tabsVisible=boolean], [useTemplate=string], [verticalScrollBarThickness=int], [visible=boolean], [visibleChangeCommand=script], [width=int])
注: オブジェクトの名前と引数を表す文字列は、カンマで区切る必要があります。これはシノプシスに示されていません。
tabLayout は、取り消し可能、照会可能、および編集可能です。
このコマンドはタブ グループを作成します。タブ グループは、レイアウトの制御のみを行う特殊な形のコントロール レイアウトのひとつです。タブ グループに制御レイアウトが追加されると、タブが追加され、ほかのタブ化された コントロール グループの中からそれを選択することが可能になります。可視になるのは 一度に 1 つのタブ レイアウトのみです。
照会モードでは、戻り値のタイプは照会されたフラグに基づきます。
annotation, backgroundColor, borderStyle, changeCommand, childArray, childResizable, defineTemplate, docTag, doubleClickCommand, dragCallback, dropCallback, enable, enableBackground, exists, fullPathName, height, highlightColor, horizontalScrollBarThickness, image, imageVisible, innerMarginHeight, innerMarginWidth, isObscured, manage, minChildWidth, moveTab, newTabCommand, noBackground, numberOfChildren, numberOfPopupMenus, parent, popupMenuArray, preSelectCommand, preventOverride, scrollable, scrollableTabs, selectCommand, selectTab, selectTabIndex, showNewTab, tabLabel, tabLabelIndex, tabsClosable, tabsVisible, useTemplate, verticalScrollBarThickness, visible, visibleChangeCommand, width
ロング ネーム(ショート ネーム) |
引数タイプ |
プロパティ |
|
annotation(ann)
|
string
|
|
|
backgroundColor(bgc)
|
[float, float, float]
|
|
|
コントロールのバックグラウンド カラーです。引数は、赤、緑、青のカラー成分に対応しています。それぞれの成分の値は、0.0~1.0 です。 backgroundColor を設定する場合、enableBackground を false に指定していない限り、バックグラウンドは自動的に有効になります。
|
|
borderStyle(bs)
|
string
|
|
|
タブ レイアウトの境界のスタイルを指定します。有効な値は、「none」、「top」、「notop」、「full」です。既定では、タブ レイアウトのボディ領域の周囲に単純なフレームを作成する「full」が使用されます。
- none: タブ レイアウトのボディ領域の周囲に境界を描画しない
- top: タブの下に単純な線を表示
- notop: タブ レイアウトの左/右/下部(上部以外)に単純なフレームを描画
- full: タブ レイアウトのボディ領域の周囲に単純なフレームを描画
|
|
changeCommand(cc)
|
script
|
|
|
タブをインタラクティブに選択したときに実行されるコマンドです。このコマンドは、選択したタブが変更されたときにのみ起動されます。現在のタブを再度選択しても、このコマンドは起動されません。
|
|
childArray(ca)
|
boolean
|
|
|
childResizable(cr)
|
boolean
|
|
|
コントロール レイアウトの子をスクロール領域と同じ幅にしたい場合は、true に設定します。-mcw/minChildWidth フラグを使用して、子の最小の幅を示すこともできます。
|
|
defineTemplate(dt)
|
string
|
|
|
他の任意のフラグと引数を解析し、かつ引数で指定したコマンド テンプレートに追加するモードに、コマンドのモードを変更します。templateName が現在のテンプレートとして設定されていれば、その後コマンドが実行されるたびに、この引数が既定の引数として使用されます。
|
|
docTag(dtg)
|
string
|
|
|
コントロールにドキュメンテーション フラグを追加します。ドキュメンテーション フラグは、階層のようなディレクトリ構造になっています。例: -dt render/multiLister/createNode/material
|
|
doubleClickCommand(dcc)
|
script
|
|
|
タブをダブル クリックしたときに実行されるコマンドです。1 回目のクリックでタブが選択されて、2 回目のクリックでダブル クリック コマンドが実行されます。現在のタブをダブル クリックすると、ダブル クリック コマンドが再起動されます。
|
|
dragCallback(dgc)
|
script
|
|
|
中マウス ボタンを押すとコールされるコールバックを追加します。MEL バージョンのコールバックの書式は次のとおりです。
global proc string[] callbackName(string $dragControl, int $x, int $y, int $mods)
proc はドロップ先に転送される文字配列を返します。規則により、配列の先頭文字列はユーザ設定可能なメッセージ タイプを表しています。アプリケーションで定義されたドラッグ元のコントロールは、このコールバックを無視する可能性があります。$mods で、キー モディファイアである CTL と SHIFT をテストできます。有効な値は、0 == モディファイアなし、1 == SHIFT、2 == CTL、3 == CTL + SHIFT です。
Python でも同様ですが、コールバックの指定方法が 2 つあります。お勧めの方法は、引数として Python 関数オブジェクトを渡すことです。この場合、Python コールバックの書式は次のようになります。
def callbackName( dragControl, x, y, modifiers ):
この引数の値は、上記の MEL バージョンの引数と同じです。
Python でコールバックを指定するもう 1 つの方法では、実行する文字列を指定します。この場合、Python の標準的なフォーマット演算子を介して文字列に値が代入されます。このフォーマットの値は、キー「dragControl」、「x」、「y」、「modifiers」と共に辞書で渡されます。dragControl の値は文字列で、その他の値は整数です(コールバック文字列の例: 「print '%(dragControl)s %(x)d %(y)d %(modifiers)d'」)。
|
|
dropCallback(dpc)
|
script
|
|
|
ドラッグ&ドロップ操作をドロップ位置で解放したときにコールされるコールバックを追加します。MEL バージョンのコールバックの書式は次のとおりです。
global proc callbackName(string $dragControl, string $dropControl, string $msgs[], int $x, int $y, int $type)
proc は、ドラッグ元から転送される文字配列を受け取ります。msgs 配列の先頭文字列はユーザ定義のメッセージ タイプを表します。アプリケーションで定義されたドロップ先のコントロールでは、このコールバックが無視されることがあります。$type の値は、1 == 移動、2 == コピー、3 == リンクのいずれかです。
Python でも同様ですが、コールバックの指定方法が 2 つあります。お勧めの方法は、引数として Python 関数オブジェクトを渡すことです。この場合、Python コールバックの書式は次のようになります。
def pythonDropTest( dragControl, dropControl, messages, x, y, dragType ):
この引数の値は、上記の MEL バージョンの引数と同じです。
Python でコールバックを指定するもう 1 つの方法では、実行する文字列を指定します。この場合、Python の標準的なフォーマット演算子を介して文字列に値が代入されます。このフォーマットの値は、キー「dragControl」、「dropControl」、「messages」、「x」、「y」、「type」と共に辞書で渡されます。dragControl の値は文字列で、その他の値は整数です(コールバック文字列の例: 「print '%(dragControl)s %(dropControl)s %(messages)r %(x)d %(y)d %(type)d'」)。
|
|
enable(en)
|
boolean
|
|
|
コントロールの有効、無効です。既定では true に設定されていて、コントロールは有効になっています。false を指定するとコントロールはグレー表示になって無効になります。
|
|
enableBackground(ebg)
|
boolean
|
|
|
コントロールのバックグラウンド カラーを有効にします。
|
|
exists(ex)
|
boolean
|
|
|
指定したオブジェクトが存在するかどうかを返します。他のフラグは無視されます。
|
|
fullPathName(fpn)
|
boolean
|
|
|
すべての親を含むウィジェットのフル パス名を返します。
|
|
height(h)
|
int
|
|
|
コントロールの高さです。コントロールは親のレイアウトの条件によって無効にされない限り、このサイズを保持しようとします。
|
|
highlightColor(hlc)
|
[float, float, float]
|
|
|
コントロールのハイライト カラーです。引数は、赤、緑、青のカラー成分に対応しています。それぞれの成分の値は、0.0~1.0 です。
|
|
horizontalScrollBarThickness(hst)
|
int
|
|
|
水平スクロール バーの厚みです。0 以上の整数値を指定します。このフラグは Windows システムでは何の効力も持ちません。
|
|
image(i)
|
string
|
|
|
imageVisible(iv)
|
boolean
|
|
|
innerMarginHeight(imh)
|
int
|
|
|
innerMarginWidth(imw)
|
int
|
|
|
isObscured(io)
|
boolean
|
|
|
コントロールが実際に表示されるかどうかを返します。コントロールは、次の場合に隠れた状態になります。非表示の場合、別のコントロールで(完全に、または部分的に)ブロックされた場合、コントロールまたは親のレイアウトを制御できない場合、あるいはコントロールのウィンドウが非表示またはアイコン化されている場合。
|
|
manage(m)
|
boolean
|
|
|
コントロールの状態を管理します。管理されていないコントロールは表示されず、画面の領域も占有しません。既定では、コントロールは管理できるように作成されます。
|
|
minChildWidth(mcw)
|
int
|
|
|
タブ レイアウトの子の最小幅を指定します。ゼロ以外の正の整数値を指定します。このフラグは、-cr/childResizable フラグが true に設定されている場合だけ、有効です。
|
|
moveTab(mt)
|
[int, int]
|
|
|
現在のインデックスから新しいインデックスにタブを移動します。
|
|
newTabCommand(ntc)
|
script
|
|
|
タブ バーにある新規タブ(New Tab)ボタンをクリックしたときに実行されるコマンドです。注: 新規タブ(New Tab)ボタンを表示するには、-snt/showNewTab フラグを使用します。このコマンドを使用すると、新規タブを追加するための内部 Maya ロジックがオーバーライドされます(このコマンドのみが実行されます)。
|
|
noBackground(nbg)
|
boolean
|
|
|
コントロールのバックグラウンドをクリア/リセットします。バックグラウンドは、true を渡すと一切描画されず、false を渡すと描画されます。このフラグの状態は、このコントロールの子に継承されます。
|
|
numberOfChildren(nch)
|
boolean
|
|
|
numberOfPopupMenus(npm)
|
boolean
|
|
|
このコントロールにアタッチされるポップアップ メニューの数を返します。
|
|
parent(p)
|
string
|
|
|
popupMenuArray(pma)
|
boolean
|
|
|
このコントロールにアタッチされる全ポップアップ メニューの名前を返します。
|
|
preSelectCommand(psc)
|
script
|
|
|
コンテンツが可視となる前にタブを選択したときに実行されるコマンドです。現在のタブを再度選択しても、このコマンドは起動されません。-st/selectTab または -sti/selectTabIndex のいずれかのフラグを使用すると、このコマンドは実行されないことに注意してください。
|
|
preventOverride(po)
|
boolean
|
|
|
true の場合、コントロールのコントロールは親のレイアウトの条件によって無効にされ右マウス ボタン メニューを使用したコントロール アトリビュートのオーバーライドは無効です。
|
|
scrollable(scr)
|
boolean
|
|
|
スクロール領域内にこのレイアウトすべての子を入れます。
|
|
scrollableTabs(stb)
|
boolean
|
|
|
true の場合、レイアウト内のアクティブなタブをマウス ホイールでスクロールできます。既定は true です。
|
|
selectCommand(sc)
|
script
|
|
|
タブをインタラクティブに選択したときに実行されるコマンドです。このコマンドは、タブを選択するたびに起動します。すなわち、現在のタブを再び選択すると、このコマンドは起動します。-st/selectTab または -sti/selectTabIndex のいずれかのフラグを使用すると、このコマンドは実行されないことに注意してください。
|
|
selectTab(st)
|
string
|
|
|
選択したタブの名前(略式)です。子のタブがない場合、照会すると空の文字列が返されます。
|
|
selectTabIndex(sti)
|
int
|
|
|
このフラグは、選択したタブを判定するために 1 をベースにしたインデックスをとることを除いては、-st/selectTab フラグと同じです。子のタブがない場合、照会すると 0 の値が返されます。
|
|
showNewTab(snt)
|
boolean
|
|
|
新規タブ(New Tab)ボタンをタブ バーの最後に表示する場合は、true に設定します。注: このボタンをクリックしたときに実行されるコマンドを設定するには、-ntc/newTabCommand フラグを使用します。
|
|
tabLabel(tl)
|
[string, string]
|
|
|
タブ ラベルを設定します。第 1 引数は、タブ レイアウトの子の必要があるコントロールの名前です。2 つめの引数は、子にコネクトされたタブのラベルです。照会されると、このフラグはすべての子のタブ ラベルを返します。
|
|
tabLabelIndex(tli)
|
[int, string]
|
|
|
このフラグは、ラベルを設定するタブを判定するために 1 をベースにしたインデックスをとることを除いては、-tl/tabLabel フラグと同じです。照会されると、このフラグはすべての子のタブ ラベルを返します。
|
|
tabsClosable(tc)
|
boolean
|
|
|
作成したすべてのタブに閉じるボタン アイコンを表示する場合は、true に設定します。
|
|
tabsVisible(tv)
|
boolean
|
|
|
useTemplate(ut)
|
string
|
|
|
コマンドに、現在以外のコマンド テンプレートの使用を強制します。
|
|
verticalScrollBarThickness(vst)
|
int
|
|
|
垂直スクロール バーの厚みです。0 以上の整数値を指定します。このフラグは Windows システムでは何の効力も持ちません。
|
|
visible(vis)
|
boolean
|
|
|
コントロールの可視の状態です。既定では、コントロールは表示されます。コントロールの実際の外見も、その親レイアウトの可視の状態によって異なることに注意してください。
|
|
visibleChangeCommand(vcc)
|
script
|
|
|
コントロールの可視の状態が変更されたときに実行されるコマンドです。
|
|
width(w)
|
int
|
|
|
コントロールの幅を指定します。コントロールは親のレイアウトの条件によって無効にされない限り、このサイズを保持しようとします。
|
|
フラグはコマンドの作成モードで表示できます
|
フラグはコマンドの編集モードで表示できます
|
フラグはコマンドの照会モードで表示できます
|
フラグに複数の引数を指定し、タプルまたはリストとして渡すことができます。
|
import maya.cmds as cmds
cmds.window( widthHeight=(200, 150) )
form = cmds.formLayout()
tabs = cmds.tabLayout(innerMarginWidth=5, innerMarginHeight=5)
cmds.formLayout( form, edit=True, attachForm=((tabs, 'top', 0), (tabs, 'left', 0), (tabs, 'bottom', 0), (tabs, 'right', 0)) )
child1 = cmds.rowColumnLayout(numberOfColumns=2)
cmds.button()
cmds.button()
cmds.button()
cmds.setParent( '..' )
child2 = cmds.rowColumnLayout(numberOfColumns=2)
cmds.button()
cmds.button()
cmds.button()
cmds.setParent( '..' )
cmds.tabLayout( tabs, edit=True, tabLabel=((child1, 'One'), (child2, 'Two')) )
cmds.showWindow()