Scene Graph Generator Plug-ins¶
-
namespace
Foundry
¶ -
namespace
Katana
¶ -
class
ScenegraphGenerator
¶ - #include <FnScenegraphGenerator.h>
The main entry point for the plug-in. Any new plug-in must extend this interface (once per plug-in). It tells Katana which arguments the plug-in takes and what is the ScenegraphContext responsible for generating the root Location.
Public Functions
-
ScenegraphGenerator
()¶
-
virtual
~ScenegraphGenerator
()¶
-
virtual bool
setArgs
(GroupAttribute args) = 0¶ Prior to running the plug-in, this method defines which arguments this plug-in listens for and can therefore be sent in through Katana.
Note: Katana reserves the top-level “system” argument for the arguments passed in automatically. Adding an expected arg beginning with “system.” produces an error. Here the arguments defined by getArgumentTemplate are received from Katana where they can be used at runtime by the plug-in.
- Parameters
args
-The arguments defined in getArgumentTemplate
-
virtual bool
checkArgs
(GroupAttribute args)¶ ...
-
virtual ScenegraphContext *
getRoot
() = 0¶ Returns a context to the root node in the scenegraph.
This is the first step of traversing the contexts in order to create a scenegraph structure where the subsequent steps will involve retrieving the child and sibling nodes.
Public Static Functions
-
static GroupAttribute
getArgumentTemplate
()¶ A static function that allows Katana to query the AMP about which arguments it expects. This should return a GroupAttribute with the same structure as the one that is passed to the constructor, in which the Attribute values will be the default values of the correspondent AMP argument.
-
-
class
ScenegraphContext
¶ - #include <FnScenegraphGenerator.h>
Class responsible for providing Katana the information needed to generate a Location.
Each context implemented in a custom plug-in must extend this class. Typically, at least two contexts are required where the first context is used for the root node which is appended to the scenegraph, while the second context (and others) is used for a specific node type that is required to create the necessary node types (structures, geometry, etc.).
Public Functions
-
ScenegraphContext
()¶
-
virtual
~ScenegraphContext
()¶
-
virtual ScenegraphContext *
getFirstChild
() const = 0¶ Returns a context to the first child node in the scenegraph.
Note: Returning a null context is done through ‘return 0x0;’ such as in the case for the context for a leaf node.
-
virtual ScenegraphContext *
getNextSibling
() const = 0¶ Returns a context to the next sibling in the scenegraph.
Note: Returning a null context is done through ‘return 0x0;’ such as in the case for the context for a root node.
-
virtual void
getLocalAttrNames
(std::vector<std::string> *names) const = 0¶ Prior to using the plug-in, this method defines which attributes this context has defined and will be generated at runtime (through getLocalAttrNames).
- Parameters
names
-A reference to the vector that will contain the attributes for this context
-
virtual Attribute
getLocalAttr
(const std::string &name) const = 0¶ Set the attribute values.
The API calls this method with the attribute names that were set using getLocalAttrNames (called as many times as the number of defined attributes). The method should return a Attribute object based on what attribute was passed in.
- Parameters
name
-An arbitrary attribute name which forms a subset of the attributes defined using getLocalAttrNames for this context.
-
-
class
-
namespace