forked from PixarAnimationStudios/OpenUSD
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathschema.usda
2043 lines (1766 loc) · 95.7 KB
/
schema.usda
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
#usda 1.0
(
"This file describes the USD Geometric schemata for code generation."
subLayers = [
@usd/schema.usda@
]
)
over "GLOBAL" (
customData = {
string libraryName = "usdGeom"
string libraryPath = "pxr/usd/usdGeom"
# string libraryPrefix = "UsdGeom"
# string tokensPrefix = "UsdGeom"
dictionary libraryTokens = {
dictionary interpolation = {
string doc = """UsdGeomPrimvar - How a Primvar interpolates
across a primitive; equivalent to RenderMan's \\ref Usd_InterpolationVals "class specifier" """
}
dictionary elementSize = {
string doc = """UsdGeomPrimvar - The number of values in the
value array that must be aggregated for each element on the
primitive."""
}
dictionary unauthoredValuesIndex = {
string doc = """UsdGeomPrimvar - The index that represents
unauthored values in the indices array of an indexed primvar."""
}
dictionary constant ={
string doc = """Possible value for UsdGeomPrimvar::SetInterpolation.
Default value for UsdGeomPrimvar::GetInterpolation. One value
remains constant over the entire surface primitive."""
}
dictionary uniform = {
string doc = """Possible value for UsdGeomPrimvar::SetInterpolation.
One value remains constant for each uv patch segment of the
surface primitive (which is a \\em face for meshes)."""
}
dictionary varying = {
string doc = """Possible value for UsdGeomPrimvar::SetInterpolation.
Four values are interpolated over each uv patch segment of the
surface. Bilinear interpolation is used for interpolation
between the four values."""
}
dictionary vertex = {
string doc = """Possible value for UsdGeomPrimvar::SetInterpolation.
Values are interpolated between each vertex in the surface
primitive. The basis function of the surface is used for
interpolation between vertices."""
}
dictionary faceVarying = {
string doc = """Possible value for UsdGeomPrimvar::SetInterpolation.
For polygons and subdivision surfaces, four values are
interpolated over each face of the mesh. Bilinear interpolation
is used for interpolation between the four values."""
}
dictionary extentsHint = {
string doc = """Name of the attribute used to author extents
hints at the root of leaf models. Extents hints are stored by purpose
as a vector of GfVec3f values. They are ordered based on the order
of purpose tokens returned by
UsdGeomImageable::GetOrderedPurposeTokens."""
}
dictionary upAxis = {
string doc = """Stage-level metadata that encodes a scene's
orientation as a token whose value can be "Y" or "Z"."""
}
dictionary metersPerUnit = {
string doc = """Stage-level metadata that encodes a scene's
linear unit of measure as meters per encoded unit."""
}
dictionary inactiveIds = {
string doc = """int64listop prim metadata that specifies
the PointInstancer ids that should be masked (unrenderable)
over all time."""
}
dictionary partition = {
string doc = """A type of family of GeomSubsets. It implies
that every element appears exacly once in only one of the
subsets in the family."""
}
dictionary nonOverlapping = {
string doc = """A type of family of GeomSubsets. It implies that
the elements in the various subsets belonging to the family are
mutually exclusive, i.e., an element that appears in one
subset may not belong to any other subset in the family."""
}
dictionary unrestricted = {
string doc = """A type of family of GeomSubsets. It implies that
there are no restrictions w.r.t. the membership of elements in
the subsets. There could be overlapping members in subsets
belonging to the family and the union of all subsets in the
family may not contain all the elements."""
}
}
}
)
{
}
class "Imageable" (
inherits = </Typed>
doc = """Base class for all prims that may require rendering or
visualization of some sort. The primary attributes of Imageable
are \\em visibility and \\em purpose, which each provide instructions for
what geometry should be included for processing by rendering and other
computations.
\\deprecated Imageable also provides API for accessing primvars, which
has been moved to the UsdGeomPrimvarsAPI schema, because primvars can now
be applied on non-Imageable prim types. This API is planned
to be removed, UsdGeomPrimvarsAPI should be used directly instead."""
customData = {
string extraIncludes = """
#include "pxr/base/gf/bbox3d.h"
#include "pxr/usd/usdGeom/primvar.h" """
}
) {
token visibility = "inherited" (
allowedTokens = ["inherited", "invisible"]
doc = """Visibility is meant to be the simplest form of "pruning"
visibility that is supported by most DCC apps. Visibility is
animatable, allowing a sub-tree of geometry to be present for some
segment of a shot, and absent from others; unlike the action of
deactivating geometry prims, invisible geometry is still
available for inspection, for positioning, for defining volumes, etc."""
)
uniform token purpose = "default" (
allowedTokens = ["default", "render", "proxy", "guide"]
doc = """Purpose is a concept we have found useful in our pipeline for
classifying geometry into categories that can each be independently
included or excluded from traversals of prims on a stage, such as
rendering or bounding-box computation traversals. The fallback
purpose, \\em default indicates that a prim has "no special purpose"
and should generally be included in all traversals. Subtrees rooted
at a prim with purpose \\em render should generally only be included
when performing a "final quality" render. Subtrees rooted at a prim
with purpose \\em proxy should generally only be included when
performing a lightweight proxy render (such as openGL). Finally,
subtrees rooted at a prim with purpose \\em guide should generally
only be included when an interactive application has been explicitly
asked to "show guides".
In the previous paragraph, when we say "subtrees rooted at a prim",
we mean the most ancestral or tallest subtree that has an authored,
non-default opinion. If the purpose of </RootPrim> is set to
"render", then the effective purpose of </RootPrim/ChildPrim> will
be "render" even if that prim has a different authored value for
purpose. <b>See ComputePurpose() for details of how purpose
inherits down namespace</b>.
As demonstrated in UsdGeomBBoxCache, a traverser should be ready to
accept combinations of included purposes as an input.
Purpose \\em render can be useful in creating "light blocker"
geometry for raytracing interior scenes. Purposes \\em render and
\\em proxy can be used together to partition a complicated model
into a lightweight proxy representation for interactive use, and a
fully realized, potentially quite heavy, representation for rendering.
One can use UsdVariantSets to create proxy representations, but doing
so requires that we recompose parts of the UsdStage in order to change
to a different runtime level of detail, and that does not interact
well with the needs of multithreaded rendering. Purpose provides us with
a better tool for dynamic, interactive complexity management."""
)
rel proxyPrim (
doc = """The \\em proxyPrim relationship allows us to link a
prim whose \\em purpose is "render" to its (single target)
purpose="proxy" prim. This is entirely optional, but can be
useful in several scenarios:
\\li In a pipeline that does pruning (for complexity management)
by deactivating prims composed from asset references, when we
deactivate a purpose="render" prim, we will be able to discover
and additionally deactivate its associated purpose="proxy" prim,
so that preview renders reflect the pruning accurately.
\\li DCC importers may be able to make more aggressive optimizations
for interactive processing and display if they can discover the proxy
for a given render prim.
\\li With a little more work, a Hydra-based application will be able
to map a picked proxy prim back to its render geometry for selection.
\\note It is only valid to author the proxyPrim relationship on
prims whose purpose is "render"."""
)
}
class "PrimvarsAPI" (
inherits = </APISchemaBase>
doc = """UsdGeomPrimvarsAPI encodes geometric "primitive variables",
as UsdGeomPrimvar, which interpolate across a primitive's topology,
can override shader inputs, and inherit down namespace.
\\section usdGeom_PrimvarFetchingAPI Which Method to Use to Retrieve Primvars
While creating primvars is unambiguous (CreatePrimvar()), there are quite
a few methods available for retrieving primvars, making it potentially
confusing knowing which one to use. Here are some guidelines:
\\li If you are populating a GUI with the primvars already available for
authoring values on a prim, use GetPrimvars().
\\li If you want all of the "useful" (e.g. to a renderer) primvars
available at a prim, including those inherited from ancestor prims, use
FindPrimvarsWithInheritance(). Note that doing so individually for many
prims will be inefficient.
\\li To find a particular primvar defined directly on a prim, which may
or may not provide a value, use GetPrimvar().
\\li To find a particular primvar defined on a prim or inherited from
ancestors, which may or may not provide a value, use
FindPrimvarWithInheritance().
\\li To *efficiently* query for primvars using the overloads of
FindPrimvarWithInheritance() and FindPrimvarsWithInheritance(), one
must first cache the results of FindIncrementallyInheritablePrimvars() for
each non-leaf prim on the stage. """
customData = {
token apiSchemaType = "nonApplied"
string extraIncludes = """
#include "pxr/usd/usdGeom/primvar.h" """
}
) {
}
class "Xformable" (
inherits = </Imageable>
customData = {
string extraIncludes = """
#include "pxr/usd/usdGeom/xformOp.h"
#include <vector> """
}
doc = """Base class for all transformable prims, which allows arbitrary
sequences of component affine transformations to be encoded.
\\note
You may find it useful to review \\ref UsdGeom_LinAlgBasics while reading
this class description.
<b>Supported Component Transformation Operations</b>
UsdGeomXformable currently supports arbitrary sequences of the following
operations, each of which can be encoded in an attribute of the proper
shape in any supported precision:
\\li translate - 3D
\\li scale - 3D
\\li rotateX - 1D angle in degrees
\\li rotateY - 1D angle in degrees
\\li rotateZ - 1D angle in degrees
\\li rotateABC - 3D where ABC can be any combination of the six principle
Euler Angle sets: XYZ, XZY, YXZ, YZX, ZXY, ZYX. See
\\ref usdGeom_rotationPackingOrder "note on rotation packing order"
\\li orient - 4D (quaternion)
\\li transform - 4x4D
<b>Creating a Component Transformation</b>
To add components to a UsdGeomXformable prim, simply call AddXformOp()
with the desired op type, as enumerated in \\ref UsdGeomXformOp::Type,
and the desired precision, which is one of \\ref UsdGeomXformOp::Precision.
Optionally, you can also provide an "op suffix" for the operator that
disambiguates it from other components of the same type on the same prim.
Application-specific transform schemas can use the suffixes to fill a role
similar to that played by AbcGeom::XformOp's "Hint" enums for their own
round-tripping logic.
We also provide specific "Add" API for each type, for clarity and
conciseness, e.g. AddTranslateOp(), AddRotateXYZOp() etc.
AddXformOp() will return a UsdGeomXformOp object, which is a schema on a
newly created UsdAttribute that provides convenience API for authoring
and computing the component transformations. The UsdGeomXformOp can then
be used to author any number of timesamples and default for the op.
Each successive call to AddXformOp() adds an operator that will be applied
"more locally" than the preceding operator, just as if we were pushing
transforms onto a transformation stack - which is precisely what should
happen when the operators are consumed by a reader.
\\note
If you can, please try to use the UsdGeomXformCommonAPI, which wraps
the UsdGeomXformable with an interface in which Op creation is taken
care of for you, and there is a much higher chance that the data you
author will be importable without flattening into other DCC's, as it
conforms to a fixed set of Scale-Rotate-Translate Ops.
\\sa \\ref usdGeom_xformableExamples "Using the Authoring API"
<b>Data Encoding and Op Ordering</b>
Because there is no "fixed schema" of operations, all of the attributes
that encode transform operations are dynamic, and are scoped in
the namespace "xformOp". The second component of an attribute's name provides
the \\em type of operation, as listed above. An "xformOp" attribute can
have additional namespace components derived from the \\em opSuffix argument
to the AddXformOp() suite of methods, which provides a preferred way of
naming the ops such that we can have multiple "translate" ops with unique
attribute names. For example, in the attribute named
"xformOp:translate:maya:pivot", "translate" is the type of operation and
"maya:pivot" is the suffix.
The following ordered list of attribute declarations in usda
define a basic Scale-Rotate-Translate with XYZ Euler angles, wherein the
translation is double-precision, and the remainder of the ops are single,
in which we will:
<ol>
<li> Scale by 2.0 in each dimension
<li> Rotate about the X, Y, and Z axes by 30, 60, and 90 degrees, respectively
<li> Translate by 100 units in the Y direction
</ol>
\\code
float3 xformOp:rotateXYZ = (30, 60, 90)
float3 xformOp:scale = (2, 2, 2)
double3 xformOp:translate = (0, 100, 0)
uniform token[] xformOpOrder = [ "xformOp:translate", "xformOp:rotateXYZ", "xformOp:scale" ]
\\endcode
The attributes appear in the dictionary order in which USD, by default,
sorts them. To ensure the ops are recovered and evaluated in the correct
order, the schema introduces the **xformOpOrder** attribute, which
contains the names of the op attributes, in the precise sequence in which
they should be pushed onto a transform stack. **Note** that the order is
opposite to what you might expect, given the matrix algebra described in
\\ref UsdGeom_LinAlgBasics. This also dictates order of op creation,
since each call to AddXformOp() adds a new op to the end of the
\\b xformOpOrder array, as a new "most-local" operation. See
\\ref usdGeom_xformableExamples "Example 2 below" for C++ code that could
have produced this USD.
If it were important for the prim's rotations to be independently
overridable, we could equivalently (at some performance cost) encode
the transformation also like so:
\\code
float xformOp:rotateX = 30
float xformOp:rotateY = 60
float xformOp:rotateZ = 90
float3 xformOp:scale = (2, 2, 2)
double3 xformOp:translate = (0, 100, 0)
uniform token[] xformOpOrder = [ "xformOp:translate", "xformOp:rotateZ", "xformOp:rotateY", "xformOp:rotateX", "xformOp:scale" ]
\\endcode
Again, note that although we are encoding an XYZ rotation, the three
rotations appear in the **xformOpOrder** in the opposite order, with Z,
followed, by Y, followed by X.
Were we to add a Maya-style scalePivot to the above example, it might
look like the following:
\\code
float3 xformOp:rotateXYZ = (30, 60, 90)
float3 xformOp:scale = (2, 2, 2)
double3 xformOp:translate = (0, 100, 0)
double3 xformOp:translate:scalePivot
uniform token[] xformOpOrder = [ "xformOp:translate", "xformOp:rotateXYZ", "xformOp:translate:scalePivot", "xformOp:scale" ]
\\endcode
<b>Paired "Inverted" Ops</b>
We have been claiming that the ordered list of ops serves as a set
of instructions to a transform stack, but you may have noticed in the last
example that there is a missing operation - the pivot for the scale op
needs to be applied in its inverse-form as a final (most local) op! In the
AbcGeom::Xform schema, we would have encoded an actual "final" translation
op whose value was authored by the exporter as the negation of the pivot's
value. However, doing so would be brittle in USD, given that each op can
be independently overridden, and the constraint that one attribute must be
maintained as the negation of the other in order for successful
re-importation of the schema cannot be expressed in USD.
Our solution leverages the **xformOpOrder** member of the schema, which,
in addition to ordering the ops, may also contain one of two special
tokens that address the paired op and "stack resetting" behavior.
The "paired op" behavior is encoded as an "!invert!" prefix in
\\b xformOpOrder, as the result of an AddXformOp(isInverseOp=True) call.
The \\b xformOpOrder for the last example would look like:
\\code
uniform token[] xformOpOrder = [ "xformOp:translate", "xformOp:rotateXYZ", "xformOp:translate:scalePivot", "xformOp:scale", "!invert!xformOp:translate:scalePivot" ]
\\endcode
When asked for its value via UsdGeomXformOp::GetOpTransform(), an
"inverted" Op (i.e. the "inverted" half of a set of paired Ops) will fetch
the value of its paired attribute and return its negation. This works for
all op types - an error will be issued if a "transform" type op is singular
and cannot be inverted. When getting the authored value of an inverted op
via UsdGeomXformOp::Get(), the raw, uninverted value of the associated
attribute is returned.
For the sake of robustness, <b>setting a value on an inverted op is disallowed.</b>
Attempting to set a value on an inverted op will result in a coding error
and no value being set.
<b>Resetting the Transform Stack</b>
The other special op/token that can appear in \\em xformOpOrder is
\\em "!resetXformStack!", which, appearing as the first element of
\\em xformOpOrder, indicates this prim should not inherit the transformation
of its namespace parent. See SetResetXformStack()
<b>Expected Behavior for "Missing" Ops</b>
If an importer expects Scale-Rotate-Translate operations, but a prim
has only translate and rotate ops authored, the importer should assume
an identity scale. This allows us to optimize the data a bit, if only
a few components of a very rich schema (like Maya's) are authored in the
app.
\\anchor usdGeom_xformableExamples
<b>Using the C++ API</b>
#1. Creating a simple transform matrix encoding
\\snippet examples.cpp CreateMatrixWithDefault
#2. Creating the simple SRT from the example above
\\snippet examples.cpp CreateExampleSRT
#3. Creating a parameterized SRT with pivot using UsdGeomXformCommonAPI
\\snippet examples.cpp CreateSRTWithDefaults
#4. Creating a rotate-only pivot transform with animated
rotation and translation
\\snippet examples.cpp CreateAnimatedTransform
"""
) {
uniform token[] xformOpOrder (
doc = """Encodes the sequence of transformation operations in the
order in which they should be pushed onto a transform stack while
visiting a UsdStage's prims in a graph traversal that will effect
the desired positioning for this prim and its descendant prims.
You should rarely, if ever, need to manipulate this attribute directly.
It is managed by the AddXformOp(), SetResetXformStack(), and
SetXformOpOrder(), and consulted by GetOrderedXformOps() and
GetLocalTransformation()."""
)
}
class Scope "Scope" (
inherits = </Imageable>
doc = """Scope is the simplest grouping primitive, and does not carry the
baggage of transformability. Note that transforms should inherit down
through a Scope successfully - it is just a guaranteed no-op from a
transformability perspective."""
) {
}
class Xform "Xform" (
inherits = </Xformable>
doc = """Concrete prim schema for a transform, which implements Xformable """
) {
}
class "Boundable" (
inherits = </Xformable>
doc = """Boundable introduces the ability for a prim to persistently
cache a rectilinear, local-space, extent.
\\section UsdGeom_Boundable_Extent Why Extent and not Bounds ?
Boundable introduces the notion of "extent", which is a cached computation
of a prim's local-space 3D range for its resolved attributes <b>at the
layer and time in which extent is authored</b>. We have found that with
composed scene description, attempting to cache pre-computed bounds at
interior prims in a scene graph is very fragile, given the ease with which
one can author a single attribute in a stronger layer that can invalidate
many authored caches - or with which a re-published, referenced asset can
do the same.
Therefore, we limit to precomputing (generally) leaf-prim extent, which
avoids the need to read in large point arrays to compute bounds, and
provides UsdGeomBBoxCache the means to efficiently compute and
(session-only) cache intermediate bounds. You are free to compute and
author intermediate bounds into your scenes, of course, which may work
well if you have sufficient locks on your pipeline to guarantee that once
authored, the geometry and transforms upon which they are based will
remain unchanged, or if accuracy of the bounds is not an ironclad
requisite.
When intermediate bounds are authored on Boundable parents, the child prims
will be pruned from BBox computation; the authored extent is expected to
incorporate all child bounds."""
)
{
# XXX: Note this is really a GfRange3f, which is not fully supported
# in Vt I/O.
float3[] extent (
doc = """Extent is a three dimensional range measuring the geometric
extent of the authored gprim in its own local space (i.e. its own
transform not applied), \\em without accounting for any shader-induced
displacement. Whenever any geometry-affecting attribute is authored
for any gprim in a layer, extent must also be authored at the same
timesample; failure to do so will result in incorrect bounds-computation.
\\sa \\ref UsdGeom_Boundable_Extent.
An authored extent on a prim which has children is expected to include
the extent of all children, as they will be pruned from BBox computation
during traversal."""
)
}
class "Gprim" (
inherits = </Boundable>
doc = """Base class for all geometric primitives.
Gprim encodes basic graphical properties such as \\em doubleSided and
\\em orientation, and provides primvars for "display color" and "display
opacity" that travel with geometry to be used as shader overrides. """
) {
color3f[] primvars:displayColor (
customData = {
string apiName = "displayColor"
}
doc = """It is useful to have an "official" colorSet that can be used
as a display or modeling color, even in the absence of any specified
shader for a gprim. DisplayColor serves this role; because it is a
UsdGeomPrimvar, it can also be used as a gprim override for any shader
that consumes a \\em displayColor parameter."""
)
float[] primvars:displayOpacity (
customData = {
string apiName = "displayOpacity"
}
doc = """Companion to \\em displayColor that specifies opacity, broken
out as an independent attribute rather than an rgba color, both so that
each can be independently overridden, and because shaders rarely consume
rgba parameters."""
)
uniform bool doubleSided = false (
doc = """Although some renderers treat all parametric or polygonal
surfaces as if they were effectively laminae with outward-facing
normals on both sides, some renderers derive significant optimizations
by considering these surfaces to have only a single outward side,
typically determined by control-point winding order and/or
\\em orientation. By doing so they can perform "backface culling" to
avoid drawing the many polygons of most closed surfaces that face away
from the viewer.
However, it is often advantageous to model thin objects such as paper
and cloth as single, open surfaces that must be viewable from both
sides, always. Setting a gprim's \\em doubleSided attribute to
\\c true instructs all renderers to disable optimizations such as
backface culling for the gprim, and attempt (not all renderers are able
to do so, but the USD reference GL renderer always will) to provide
forward-facing normals on each side of the surface for lighting
calculations."""
)
uniform token orientation = "rightHanded" (
allowedTokens = ["rightHanded", "leftHanded"]
doc = """Orientation specifies whether the gprim's surface normal
should be computed using the right hand rule, or the left hand rule.
Please see \\ref UsdGeom_WindingOrder for a deeper explanation and
generalization of orientation to composed scenes with transformation
hierarchies."""
)
}
class Cube "Cube" (
inherits = </Gprim>
doc = """Defines a primitive rectilinear cube centered at the origin.
The fallback values for Cube, Sphere, Cone, and Cylinder are set so that
they all pack into the same volume/bounds."""
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
double size = 2.0 (
doc = """Indicates the length of each edge of the cube. If you
author \\em size you must also author \\em extent.
\\sa GetExtentAttr()"""
)
float3[] extent = [(-1.0, -1.0, -1.0), (1.0, 1.0, 1.0)] (
doc = """Extent is re-defined on Cube only to provide a fallback value.
\\sa UsdGeomGprim::GetExtentAttr()."""
)
}
class Sphere "Sphere" (
inherits = </Gprim>
doc = """Defines a primitive sphere centered at the origin.
The fallback values for Cube, Sphere, Cone, and Cylinder are set so that
they all pack into the same volume/bounds."""
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
double radius = 1.0 (
doc = """Indicates the sphere's radius. If you
author \\em radius you must also author \\em extent.
\\sa GetExtentAttr()"""
)
float3[] extent = [(-1.0, -1.0, -1.0), (1.0, 1.0, 1.0)] (
doc = """Extent is re-defined on Sphere only to provide a fallback
value. \\sa UsdGeomGprim::GetExtentAttr()."""
)
}
class Cylinder "Cylinder" (
inherits = </Gprim>
doc = """Defines a primitive cylinder with closed ends, centered at the
origin, whose spine is along the specified \\em axis.
The fallback values for Cube, Sphere, Cone, and Cylinder are set so that
they all pack into the same volume/bounds."""
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
double height = 2 (
doc = """The size of the cylinder's spine along the specified
\\em axis. If you author \\em height you must also author \\em extent.
\\sa GetExtentAttr()"""
)
double radius = 1.0 (
doc = """The radius of the cylinder. If you author \\em radius
you must also author \\em extent.
\\sa GetExtentAttr()"""
)
uniform token axis = "Z" (
allowedTokens = ["X", "Y", "Z"]
doc = """The axis along which the spine of the cylinder is aligned"""
)
float3[] extent = [(-1.0, -1.0, -1.0), (1.0, 1.0, 1.0)] (
doc = """Extent is re-defined on Cylinder only to provide a fallback
value. \\sa UsdGeomGprim::GetExtentAttr()."""
)
}
class Capsule "Capsule" (
inherits = </Gprim>
doc = """Defines a primitive capsule, i.e. a cylinder capped by two half
spheres, centered at the origin, whose spine is along the specified
\\em axis."""
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
double height = 1.0 (
doc = """The size of the capsule's spine along the specified
\\em axis excluding the size of the two half spheres, i.e.
the size of the cylinder portion of the capsule.
If you author \\em height you must also author \\em extent.
\\sa GetExtentAttr()"""
)
double radius = 0.5 (
doc = """The radius of the capsule. If you
author \\em radius you must also author \\em extent.
\\sa GetExtentAttr()"""
)
uniform token axis = "Z" (
allowedTokens = ["X", "Y", "Z"]
doc = """The axis along which the spine of the capsule is aligned"""
)
float3[] extent = [(-0.5, -0.5, -1.0), (0.5, 0.5, 1.0)] (
doc = """Extent is re-defined on Capsule only to provide a fallback
value. \\sa UsdGeomGprim::GetExtentAttr()."""
)
}
class Cone "Cone" (
inherits = </Gprim>
doc = """Defines a primitive cone, centered at the origin, whose spine
is along the specified \\em axis, with the apex of the cone pointing
in the direction of the positive axis.
The fallback values for Cube, Sphere, Cone, and Cylinder are set so that
they all pack into the same volume/bounds."""
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
double height = 2.0 (
doc = """The size of the cone's spine along the specified
\\em axis. If you author \\em height you must also author \\em extent.
\\sa GetExtentAttr()"""
)
double radius = 1.0 (
doc = """The radius of the cone. If you
author \\em radius you must also author \\em extent.
\\sa GetExtentAttr()"""
)
uniform token axis = "Z" (
allowedTokens = ["X", "Y", "Z"]
doc = """The axis along which the spine of the cone is aligned"""
)
float3[] extent = [(-1.0, -1.0, -1.0), (1.0, 1.0, 1.0)] (
doc = """Extent is re-defined on Cone only to provide a fallback
value. \\sa UsdGeomGprim::GetExtentAttr()."""
)
}
class "PointBased" (
doc = """Base class for all UsdGeomGprims that possess points,
providing common attributes such as normals and velocities."""
inherits = </Gprim>
customData = {
dictionary extraPlugInfo = {
bool implementsComputeExtent = true
}
}
) {
# positional
point3f[] points (
doc = """The primary geometry attribute for all PointBased
primitives, describes points in (local) space."""
)
vector3f[] velocities (
doc = """If provided, 'velocities' should be used by renderers to
compute positions between samples for the 'points' attribute, rather
than interpolating between neighboring 'points' samples. This is the
only reasonable means of computing motion blur for topologically
varying PointBased primitives. It follows that the length of each
'velocities' sample must match the length of the corresponding
'points' sample. Velocity is measured in position units per second,
as per most simulation software. To convert to position units per
UsdTimeCode, divide by UsdStage::GetTimeCodesPerSecond().
See also \\ref UsdGeom_VelocityInterpolation ."""
)
# shaping
normal3f[] normals (
doc = """Provide an object-space orientation for individual points,
which, depending on subclass, may define a surface, curve, or free
points. Note that 'normals' should not be authored on any Mesh that
is subdivided, since the subdivision algorithm will define its own
normals. 'normals' is not a generic primvar, but the number of elements
in this attribute will be determined by its 'interpolation'. See
\\ref SetNormalsInterpolation() . If 'normals' and 'primvars:normals'
are both specified, the latter has precedence."""
)
}
class Mesh "Mesh" (
inherits = </PointBased>
customData = {
string extraIncludes = """
#include "pxr/usd/usd/timeCode.h" """
}
doc="""Encodes a mesh surface whose definition and feature-set
will converge with that of OpenSubdiv, http://graphics.pixar.com/opensubdiv/docs/subdivision_surfaces.html. Current exceptions/divergences include:
1. Certain interpolation ("tag") parameters not yet supported
2. Does not (as of 9/2014) yet support hierarchical edits. We do intend
to provide some encoding in a future version of the schema.
A key property of this mesh schema is that it encodes both subdivision
surfaces, and non-subdived "polygonal meshes", by varying the
\\em subdivisionScheme attribute.
\\section UsdGeom_Mesh_Normals A Note About Normals
Normals should not be authored on a subdivided mesh, since subdivision
algorithms define their own normals. They should only be authored for
polygonal meshes.
The 'normals' attribute inherited from UsdGeomPointBased is not a generic
primvar, but the number of elements in this attribute will be determined by
its 'interpolation'. See \\ref UsdGeomPointBased::GetNormalsInterpolation() .
If 'normals' and 'primvars:normals' are both specified, the latter has
precedence."""
) {
#
# Common Properties
#
int[] faceVertexIndices (
doc = """Flat list of the index (into the 'points' attribute) of each
vertex of each face in the mesh. If this attribute has more than
one timeSample, the mesh is considered to be topologically varying."""
)
int[] faceVertexCounts (
doc = """Provides the number of vertices in each face of the mesh,
which is also the number of consecutive indices in 'faceVertexIndices'
that define the face. The length of this attribute is the number of
faces in the mesh. If this attribute has more than
one timeSample, the mesh is considered to be topologically varying."""
)
#
# Subdiv Properties
#
uniform token subdivisionScheme = "catmullClark" (
allowedTokens = ["catmullClark", "loop", "bilinear", "none"]
doc = """The subdivision scheme to be applied to the surface.
Valid values are "catmullClark" (the default), "loop", "bilinear", and
"none" (i.e. a polymesh with no subdivision - the primary difference
between schemes "bilinear" and "none" is that bilinearly subdivided
meshes can be considered watertight, whereas there is no such guarantee
for un-subdivided polymeshes, and more mesh features (e.g. holes) may
apply to bilinear meshes but not polymeshes. Polymeshes \\em may be
lighterweight and faster to render, depending on renderer and render
mode.)""")
token interpolateBoundary = "edgeAndCorner" (
allowedTokens = ["none", "edgeAndCorner", "edgeOnly"]
doc = """Specifies how interpolation boundary face edges are
interpolated. Valid values are "none",
"edgeAndCorner" (the default), or "edgeOnly".""")
token faceVaryingLinearInterpolation = "cornersPlus1" (
allowedTokens = ["all", "none", "boundaries", "cornersOnly",
"cornersPlus1", "cornersPlus2"]
doc = """Specifies how face varying data is interpolated. Valid values
are "all" (no smoothing), "cornersPlus1" (the default, Smooth UV),
"none" (Same as "cornersPlus1" but does not infer the presence
of corners where two faceVarying edges meet at a single face), or
"boundaries" (smooth only near vertices that are not at a
discontinuous boundary).
See http://graphics.pixar.com/opensubdiv/docs/subdivision_surfaces.html#face-varying-interpolation-rules""")
token triangleSubdivisionRule = "catmullClark" (
allowedTokens = ["catmullClark", "smooth"]
doc = """Specifies what weights are used during triangle subdivision for
the Catmull-Clark scheme. Valid values are "catmullClark" (the default)
and "smooth".
See http://graphics.pixar.com/opensubdiv/docs/subdivision_surfaces.html#triangle-subdivision-rule""")
int[] holeIndices = [] (
doc = """The face indices (indexing into the 'faceVertexCounts'
attribute) of all faces that should be made invisible.""")
int[] cornerIndices = [] (
doc = """The vertex indices of all vertices that are sharp corners.""")
float[] cornerSharpnesses = [] (
doc = """The sharpness values for corners: each corner gets a single
sharpness value (Usd.Mesh.SHARPNESS_INFINITE for a perfectly sharp
corner), so the size of this array must match that of
'cornerIndices'""")
int[] creaseIndices = [] (
doc = """The indices of all vertices forming creased edges. The size of
this array must be equal to the sum of all elements of the
'creaseLengths' attribute.""")
int[] creaseLengths = [] (
doc = """The length of this array specifies the number of creases on the
surface. Each element gives the number of (must be adjacent) vertices in
each crease, whose indices are linearly laid out in the 'creaseIndices'
attribute. Since each crease must be at least one edge long, each
element of this array should be greater than one.""")
float[] creaseSharpnesses = [] (
doc = """The per-crease or per-edge sharpness for all creases
(Usd.Mesh.SHARPNESS_INFINITE for a perfectly sharp crease). Since
'creaseLengths' encodes the number of vertices in each crease, the
number of elements in this array will be either len(creaseLengths) or
the sum over all X of (creaseLengths[X] - 1). Note that while
the RI spec allows each crease to have either a single sharpness
or a value per-edge, USD will encode either a single sharpness
per crease on a mesh, or sharpnesses for all edges making up
the creases on a mesh.""")
}
class GeomSubset "GeomSubset" (
inherits = </Typed>
doc = """Encodes a subset of a piece of geometry (i.e. a UsdGeomImageable)
as a set of indices. Currently only supports encoding of face-subsets, but
could be extended in the future to support subsets representing edges,
segments, points etc.
To apply to a geometric prim, a GeomSubset prim must be defined as a
child of it in namespace. This restriction makes it easy and efficient
to discover subsets of a prim. We might want to relax this restriction if
it's common to have multiple <b>families</b> of subsets on a gprim and if
it's useful to be able to organize subsets belonging to a </b>family</b>
under a common scope. See 'familyName' attribute for more info on defining
a family of subsets.
Note that a GeomSubset isn't an imageable (i.e. doesn't derive from
UsdGeomImageable). So, you can't author <b>visibility</b> for it or
override its <b>purpose</b>.
Materials are bound to GeomSubsets just as they are for regular
geometry using API available in UsdShade (UsdShadeMaterial::Bind).
"""
customData = {
string className = "Subset"
string extraIncludes = """
#include "pxr/base/tf/token.h"
#include "pxr/usd/usdGeom/imageable.h"
"""
}
)
{
uniform token elementType = "face" (
allowedTokens = ["face"]
doc = """The type of element that the indices target. Currently only
allows "face" and defaults to it."""
)
int[] indices = [] (
doc = """The set of indices included in this subset. The indices need not
be sorted, but the same index should not appear more than once."""
)
uniform token familyName = "" (
doc = """The name of the family of subsets that this subset belongs to.
This is optional and is primarily useful when there are multiple
families of subsets under a geometric prim. In some cases, this could
also be used for achieving proper roundtripping of subset data between
DCC apps.
When multiple subsets belonging to a prim have the same familyName, they
are said to belong to the family. A <i>familyType</i> value can be
encoded on the owner of a family of subsets as a token using the static
method UsdGeomSubset::SetFamilyType(). "familyType" can have one of the
following values:
<ul><li><b>UsdGeomTokens->partition</b>: implies that every element of
the whole geometry appears exactly once in only one of the subsets
belonging to the family.</li>
<li><b>UsdGeomTokens->nonOverlapping</b>: an element that appears in one
subset may not appear in any other subset belonging to the family.</li>
<li><b>UsdGeomTokens->unrestricted</b>: implies that there are no
restrictions w.r.t. the membership of elements in the subsets. They
could be overlapping and the union of all subsets in the family may
not represent the whole.</li>
</ul>
\\note The validity of subset data is not enforced by the authoring
APIs, however they can be checked using UsdGeomSubset::ValidateFamily().
"""
)
}
class NurbsPatch "NurbsPatch" (
inherits = </PointBased>
doc = """Encodes a rational or polynomial non-uniform B-spline
surface, with optional trim curves.
The encoding mostly follows that of RiNuPatch and RiTrimCurve:
https://renderman.pixar.com/resources/current/RenderMan/geometricPrimitives.html#rinupatch , with some minor renaming and coalescing for clarity.
The layout of control vertices in the \\em points attribute inherited
from UsdGeomPointBased is row-major with U considered rows, and V columns.
\\anchor UsdGeom_NurbsPatch_Form
<b>NurbsPatch Form</b>
The authored points, orders, knots, weights, and ranges are all that is
required to render the nurbs patch. However, the only way to model closed
surfaces with nurbs is to ensure that the first and last control points
along the given axis are coincident. Similarly, to ensure the surface is
not only closed but also C2 continuous, the last \\em order - 1 control
points must be (correspondingly) coincident with the first \\em order - 1
control points, and also the spacing of the last corresponding knots
must be the same as the first corresponding knots.
<b>Form</b> is provided as an aid to interchange between modeling and
animation applications so that they can robustly identify the intent with
which the surface was modelled, and take measures (if they are able) to
preserve the continuity/concidence constraints as the surface may be rigged
or deformed.
\\li An \\em open-form NurbsPatch has no continuity constraints.
\\li A \\em closed-form NurbsPatch expects the first and last control points
to overlap
\\li A \\em periodic-form NurbsPatch expects the first and last
\\em order - 1 control points to overlap.
<b>Nurbs vs Subdivision Surfaces</b>
Nurbs are an important modeling primitive in CAD/CAM tools and early
computer graphics DCC's. Because they have a natural UV parameterization
they easily support "trim curves", which allow smooth shapes to be
carved out of the surface.