PopulationMask(OpenMasked)について
Universal Scene Description 5 日目は、USD のファイルオープンの 機能の1つ、PopulationMask(OpenMasked)について紹介します。
USD は、コンポジションを使用することで巨大なシーンを扱うことができますが、 巨大なシーンを毎回すべて開くと時間がかかるので 指定した一部分だけをロードしたい...ということが多々あります。
その場合、Payload を使用してアンロードしておいた状態から指定 Prim をロードする事もできますが それ以外にも UsdStagePopulationMask という機能を使用することで 部分的なロードができるようになります。
使い方
まず、普通にロードした場合。
from pxr import Usd
stage = Usd.Stage.Open(r"D:/Kitchen_set/Kitchen_set.usd")
Usd.Stage.Open(ファイルパス)をすることで、ロードすることができます。 この場合は、すべての Prim がロードされます。
stage = Usd.Stage.Open(r"D:/Kitchen_set/Kitchen_set.usd",Usd.Stage.LoadNone)
次に Unload 状態でロードした場合。 この場合は、すべての Payload がアンロードされた状態になります。
では、実際に PopulationMask を使用し た場合について。
Kitchen_set のうち、冷蔵庫だけをロードしてみます。
mask = Usd.StagePopulationMask().Add('/Kitchen_set/Props_grp/North_grp/FridgeArea_grp/Refridgerator_1')
stage = Usd.Stage.OpenMasked(r"D:/Kitchen_set/Kitchen_set.usd",mask)
この場合は、ロードしたい SdfPath を PopulationMask に追加して Usd.Stage.Open のかわりに OpenMasked を使用します。 こうすると、 冷蔵庫の指定 Path 以下にある Prim だけがロードされます。
usdview D:\Kitchen_set\Kitchen_set.usd --mask /Kitchen_set/Props_grp/North_grp/FridgeArea_grp/Refridgerator_1
PopulationMask は usdview で使用することができて、引数に --mask PrimPath を追加すれば 指定の Path 以下の Prim だけロードされた状態になります。
現在の Stage の PopulationMask を取得
次に、取得方法。
mask = stage.GetPopulationMask()
for path in mask.GetPaths():
print(path)
現在の Stage の PopulationMask がどうなっているか、またどんな Path が含まれているのかも確認が可能です。
PopulationMask を変更する
PopulationMask はロード時だけではなく、ロード後にも変更ができます。
#usda 1.0
def "a"{}
def "b"{}
def "c"{}
このようなシンプルな USD ファイルを用意して、 sample.usda という名前で保存しておきます。
mask = Usd.StagePopulationMask(['/a'])
stage = Usd.Stage.OpenMasked("D:/sample.usda",mask)
print(stage.ExportToString())
maskB = Usd.StagePopulationMask(['/b'])
stage.SetPopulationMask(maskB)
print(stage.ExportToString())
最初に a Prim だけを PopulationMask を使用してロードしたときは、Prim は a のみになります。 そのあと、 b Prim の PopulationMask をセットすると Stage は再構築され、b のみロードされたシーンになります。
PopulationMask のさらなる使い方
PopulationMask を使用すれば Stage の一部だけをロードできることがわかりました。
今までは、Add 等で1つあるいは複数の Path を追加するだけの使い方でしたが、 PopulationMask は、それ以外にも SdfPath を Set(集合)として扱うことができます。
先度帆の simple.usda で動作をみていきます。
このファイルのうち、 a Prim だけをロードしたい場合は、
mask = Usd.StagePopulationMask().Add('/a')
stage = Usd.Stage.OpenMasked("D:/sample.usda",mask)
print(stage.ExportToString())