KiCad PCB EDA Suite
|
Define a generic index interface for a scenegraph object. More...
#include <sg_index.h>
Public Member Functions | |
SGINDEX (SGNODE *aParent) | |
virtual | ~SGINDEX () |
virtual bool | SetParent (SGNODE *aParent, bool notify=true) override |
Set the parent SGNODE of this object. | |
SGNODE * | FindNode (const char *aNodeName, const SGNODE *aCaller) noexcept override |
Search the tree of linked nodes and return a reference to the first node found with the given name. | |
bool | AddRefNode (SGNODE *aNode) noexcept override |
bool | AddChildNode (SGNODE *aNode) noexcept override |
void | unlinkChildNode (const SGNODE *aCaller) noexcept override |
Remove references to an owned child. | |
void | unlinkRefNode (const SGNODE *aCaller) noexcept override |
Remove pointers to a referenced node. | |
bool | GetIndices (size_t &nIndices, int *&aIndexList) |
Retrieve the number of indices and a pointer to the list. | |
void | SetIndices (size_t nIndices, int *aIndexList) |
Set the number of indices and creates a copy of the given index data. | |
void | AddIndex (int aIndex) |
Add a single index to the list. | |
void | ReNameNodes (void) override |
Rename a node and all its child nodes in preparation for write operations. | |
bool | WriteVRML (std::ostream &aFile, bool aReuseFlag) override |
Writes this node's data to a VRML file. | |
bool | WriteCache (std::ostream &aFile, SGNODE *parentNode) override |
Write this node's data to a binary cache file. | |
bool | ReadCache (std::istream &aFile, SGNODE *parentNode) override |
Reads binary format data from a cache file. | |
S3D::SGTYPES | GetNodeType (void) const noexcept |
Return the type of this node instance. | |
SGNODE * | GetParent (void) const noexcept |
Returns a pointer to the parent SGNODE of this object or NULL if the object has no parent (ie. | |
bool | SwapParent (SGNODE *aNewParent) |
Swap the ownership with the given parent. | |
const char * | GetName (void) |
void | SetName (const char *aName) |
const char * | GetNodeTypeName (S3D::SGTYPES aNodeType) const noexcept |
void | AssociateWrapper (SGNODE **aWrapperRef) noexcept |
Associate this object with a handle to itself. | |
void | DisassociateWrapper (SGNODE **aWrapperRef) noexcept |
Remove the association between an IFSG* wrapper object and this object. | |
void | ResetNodeIndex (void) noexcept |
Reset the global SG* node indices in preparation for write operations. | |
void | addNodeRef (SGNODE *aNode) |
Add a pointer to a node which references this node, but does not own. | |
void | delNodeRef (const SGNODE *aNode) |
Remove a pointer to a node which references this node, but does not own. | |
bool | isWritten (void) noexcept |
Return true if the object had already been written to a cache file or VRML file. | |
Public Attributes | |
std::vector< int > | index |
Protected Member Functions | |
bool | writeCoordIndex (std::ostream &aFile) |
bool | writeColorIndex (std::ostream &aFile) |
bool | writeIndexList (std::ostream &aFile) |
Protected Attributes | |
std::list< SGNODE * > | m_BackPointers |
nodes which hold a reference to this. | |
SGNODE * | m_Parent |
Pointer to parent node; may be NULL for top level transform. | |
S3D::SGTYPES | m_SGtype |
Type of Scene Graph node. | |
std::string | m_Name |
name to use for referencing the entity by name. | |
bool | m_written |
Set to true when the object has been written after a ReNameNodes(). | |
Private Attributes | |
SGNODE ** | m_Association |
Handle to the instance held by a wrapper. | |
Define a generic index interface for a scenegraph object.
Definition at line 38 of file sg_index.h.
SGINDEX::SGINDEX | ( | SGNODE * | aParent | ) |
Definition at line 32 of file sg_index.cpp.
References SGNODE::GetNodeType(), SGNODE::m_Parent, and S3D::SGTYPE_FACESET.
|
virtual |
Definition at line 46 of file sg_index.cpp.
References index.
|
overridevirtualnoexcept |
Implements SGNODE.
Definition at line 117 of file sg_index.cpp.
void SGINDEX::AddIndex | ( | int | aIndex | ) |
Add a single index to the list.
aIndex | is the index to add. |
Definition at line 155 of file sg_index.cpp.
References index.
|
inherited |
Add a pointer to a node which references this node, but does not own.
Such back-pointers are required to ensure that invalidated references are removed when a node is deleted.
aNode | is the node holding a reference to this object. |
Definition at line 170 of file sg_node.cpp.
References SGNODE::m_BackPointers.
Referenced by SGFACESET::addNode(), SGSHAPE::addNode(), SGFACESET::ReadCache(), and SGSHAPE::ReadCache().
|
overridevirtualnoexcept |
Implements SGNODE.
Definition at line 108 of file sg_index.cpp.
|
noexceptinherited |
Associate this object with a handle to itself.
The handle is typically held by an IFSG* wrapper and the pointer which it refers to is set to NULL upon destruction of this object. This mechanism provides a scheme by which a wrapper can be notified of the destruction of the object which it wraps.
Definition at line 207 of file sg_node.cpp.
Referenced by S3D::AssociateSGNodeWrapper(), IFSG_APPEARANCE::Attach(), IFSG_COLORS::Attach(), IFSG_COORDINDEX::Attach(), IFSG_COORDS::Attach(), IFSG_FACESET::Attach(), IFSG_NORMALS::Attach(), IFSG_SHAPE::Attach(), IFSG_TRANSFORM::Attach(), IFSG_APPEARANCE::IFSG_APPEARANCE(), IFSG_COLORS::IFSG_COLORS(), IFSG_COORDINDEX::IFSG_COORDINDEX(), IFSG_COORDS::IFSG_COORDS(), IFSG_FACESET::IFSG_FACESET(), IFSG_NORMALS::IFSG_NORMALS(), IFSG_SHAPE::IFSG_SHAPE(), IFSG_TRANSFORM::IFSG_TRANSFORM(), IFSG_APPEARANCE::NewNode(), IFSG_COLORS::NewNode(), IFSG_COORDINDEX::NewNode(), IFSG_COORDS::NewNode(), IFSG_FACESET::NewNode(), IFSG_NORMALS::NewNode(), IFSG_SHAPE::NewNode(), and IFSG_TRANSFORM::NewNode().
|
inherited |
Remove a pointer to a node which references this node, but does not own.
aNode | is the node holding a reference to this object. |
Definition at line 185 of file sg_node.cpp.
References SGNODE::GetNodeType(), SGNODE::m_BackPointers, and SGNODE::m_SGtype.
Referenced by SGFACESET::unlinkNode(), SGSHAPE::unlinkNode(), SGFACESET::~SGFACESET(), and SGSHAPE::~SGSHAPE().
|
noexceptinherited |
Remove the association between an IFSG* wrapper object and this object.
Definition at line 225 of file sg_node.cpp.
Referenced by IFSG_APPEARANCE::Attach(), IFSG_COLORS::Attach(), IFSG_COORDINDEX::Attach(), IFSG_COORDS::Attach(), IFSG_FACESET::Attach(), IFSG_NORMALS::Attach(), IFSG_SHAPE::Attach(), IFSG_TRANSFORM::Attach(), IFSG_NODE::Destroy(), IFSG_APPEARANCE::NewNode(), IFSG_COLORS::NewNode(), IFSG_COORDINDEX::NewNode(), IFSG_COORDS::NewNode(), IFSG_FACESET::NewNode(), IFSG_NORMALS::NewNode(), IFSG_SHAPE::NewNode(), IFSG_TRANSFORM::NewNode(), and IFSG_NODE::~IFSG_NODE().
|
overridevirtualnoexcept |
Search the tree of linked nodes and return a reference to the first node found with the given name.
The reference is then typically added to another node via AddRefNode().
aNodeName | is the name of the node to search for. |
aCaller | is a pointer to the node invoking this function. |
Implements SGNODE.
Definition at line 82 of file sg_index.cpp.
Referenced by SGFACESET::FindNode().
bool SGINDEX::GetIndices | ( | size_t & | nIndices, |
int *& | aIndexList | ||
) |
Retrieve the number of indices and a pointer to the list.
nIndices | will hold the number of indices in the list. |
aIndexList | will store a pointer to the data. |
Definition at line 126 of file sg_index.cpp.
References index.
Referenced by SGSHAPE::Prepare(), and SGFACESET::validate().
|
inherited |
Definition at line 146 of file sg_node.cpp.
References getNodeName(), SGNODE::m_Name, and SGNODE::m_SGtype.
Referenced by SCENEGRAPH::addNode(), SGFACESET::addNode(), SGSHAPE::addNode(), IFSG_NODE::GetName(), SCENEGRAPH::ReNameNodes(), SGAPPEARANCE::ReNameNodes(), SGCOLORS::ReNameNodes(), SGCOORDS::ReNameNodes(), SGFACESET::ReNameNodes(), ReNameNodes(), SGNORMALS::ReNameNodes(), SGSHAPE::ReNameNodes(), SCENEGRAPH::WriteCache(), SGAPPEARANCE::WriteCache(), SGCOLORS::WriteCache(), SGCOORDS::WriteCache(), SGFACESET::WriteCache(), WriteCache(), SGNORMALS::WriteCache(), SGSHAPE::WriteCache(), SCENEGRAPH::WriteVRML(), SGAPPEARANCE::WriteVRML(), SGCOLORS::WriteVRML(), SGCOORDS::WriteVRML(), SGFACESET::WriteVRML(), SGNORMALS::WriteVRML(), and SGSHAPE::WriteVRML().
|
noexceptinherited |
Return the type of this node instance.
Definition at line 104 of file sg_node.cpp.
Referenced by SCENEGRAPH::addNode(), SGFACESET::addNode(), SGSHAPE::addNode(), IFSG_APPEARANCE::Attach(), IFSG_COLORS::Attach(), IFSG_COORDINDEX::Attach(), IFSG_COORDS::Attach(), IFSG_FACESET::Attach(), IFSG_NORMALS::Attach(), IFSG_SHAPE::Attach(), IFSG_TRANSFORM::Attach(), SGNODE::delNodeRef(), S3D::GetMatIndex(), S3D::GetModel(), IFSG_NODE::GetNodeType(), S3D::GetSGNodeType(), IFSG_APPEARANCE::NewNode(), IFSG_COLORS::NewNode(), IFSG_COORDINDEX::NewNode(), IFSG_COORDS::NewNode(), IFSG_FACESET::NewNode(), IFSG_NORMALS::NewNode(), IFSG_SHAPE::NewNode(), IFSG_TRANSFORM::NewNode(), SCENEGRAPH::ReadCache(), SGFACESET::ReadCache(), SGSHAPE::ReadCache(), SCENEGRAPH::SCENEGRAPH(), SCENEGRAPH::SetParent(), SGAPPEARANCE::SetParent(), SGCOLORS::SetParent(), SGCOORDS::SetParent(), SGFACESET::SetParent(), SetParent(), SGNORMALS::SetParent(), SGSHAPE::SetParent(), SGAPPEARANCE::SGAPPEARANCE(), SGCOLORS::SGCOLORS(), SGCOORDINDEX::SGCOORDINDEX(), SGCOORDS::SGCOORDS(), SGFACESET::SGFACESET(), SGINDEX(), SGNORMALS::SGNORMALS(), SGSHAPE::SGSHAPE(), SGNODE::SwapParent(), SCENEGRAPH::unlinkNode(), and S3D::WriteVRML().
|
noexceptinherited |
Definition at line 164 of file sg_node.cpp.
References node_names.
Referenced by IFSG_NODE::GetNodeTypeName(), IFSG_APPEARANCE::NewNode(), IFSG_COLORS::NewNode(), IFSG_COORDINDEX::NewNode(), IFSG_COORDS::NewNode(), IFSG_FACESET::NewNode(), IFSG_NORMALS::NewNode(), IFSG_SHAPE::NewNode(), and IFSG_TRANSFORM::NewNode().
|
noexceptinherited |
Returns a pointer to the parent SGNODE of this object or NULL if the object has no parent (ie.
top level transform).
Definition at line 110 of file sg_node.cpp.
Referenced by IFSG_NODE::GetParent(), S3D::GetSGNodeParent(), IFSG_APPEARANCE::NewNode(), IFSG_COLORS::NewNode(), IFSG_COORDINDEX::NewNode(), IFSG_COORDS::NewNode(), IFSG_FACESET::NewNode(), IFSG_NORMALS::NewNode(), IFSG_SHAPE::NewNode(), IFSG_TRANSFORM::NewNode(), SCENEGRAPH::WriteCache(), SGAPPEARANCE::WriteCache(), SGCOLORS::WriteCache(), SGCOORDS::WriteCache(), SGFACESET::WriteCache(), WriteCache(), SGNORMALS::WriteCache(), and SGSHAPE::WriteCache().
|
inlinenoexceptinherited |
Return true if the object had already been written to a cache file or VRML file.
For internal use only.
Definition at line 220 of file sg_node.h.
References SGNODE::m_written.
Referenced by SCENEGRAPH::WriteCache(), SGFACESET::WriteCache(), and SGSHAPE::WriteCache().
|
overridevirtual |
Reads binary format data from a cache file.
To read a cache file, open the file for reading and invoke this function from a new SCENEGRAPH node.
Implements SGNODE.
Definition at line 307 of file sg_index.cpp.
References index.
Referenced by SGFACESET::ReadCache().
|
overridevirtual |
Rename a node and all its child nodes in preparation for write operations.
Implements SGNODE.
Definition at line 161 of file sg_index.cpp.
References SGNODE::GetName(), SGNODE::m_Name, and SGNODE::m_written.
Referenced by SGFACESET::ReNameNodes().
|
noexceptinherited |
Reset the global SG* node indices in preparation for write operations.
Definition at line 238 of file sg_node.cpp.
References node_counts, and S3D::SGTYPE_END.
Referenced by S3D::ResetNodeIndex(), SCENEGRAPH::WriteCache(), and S3D::WriteVRML().
void SGINDEX::SetIndices | ( | size_t | nIndices, |
int * | aIndexList | ||
) |
Set the number of indices and creates a copy of the given index data.
nIndices | the number of indices to be stored. |
aIndexList | the index data. |
Definition at line 141 of file sg_index.cpp.
References index.
|
inherited |
Definition at line 155 of file sg_node.cpp.
References getNodeName(), SGNODE::m_Name, and SGNODE::m_SGtype.
Referenced by SCENEGRAPH::ReadCache(), SGFACESET::ReadCache(), SGSHAPE::ReadCache(), and IFSG_NODE::SetName().
|
overridevirtual |
Set the parent SGNODE of this object.
aParent | [in] is the desired parent node |
Implements SGNODE.
Definition at line 52 of file sg_index.cpp.
References SGNODE::AddChildNode(), SGNODE::GetNodeType(), SGNODE::m_Parent, S3D::SGTYPE_FACESET, and SGNODE::unlinkChildNode().
Referenced by SGFACESET::addNode(), and SGFACESET::~SGFACESET().
|
inherited |
Swap the ownership with the given parent.
This operation may be required when reordering nodes for optimization.
aNewParent | will become the new parent to the object; it must be the same type as the parent of this instance. |
Definition at line 116 of file sg_node.cpp.
References SGNODE::AddChildNode(), SGNODE::AddRefNode(), SGNODE::GetNodeType(), SGNODE::m_Parent, SGNODE::unlinkChildNode(), and SGNODE::unlinkRefNode().
Referenced by SGFACESET::WriteCache(), and SGSHAPE::WriteCache().
|
overridevirtualnoexcept |
Remove references to an owned child.
This is invoked by the child upon destruction to ensure that the parent has no invalid references.
aNode | is the child which is being deleted. |
Implements SGNODE.
Definition at line 94 of file sg_index.cpp.
|
overridevirtualnoexcept |
Remove pointers to a referenced node.
This is invoked by the referenced node upon destruction to ensure that the referring node has no invalid references.
aNode | is the node which is being deleted. |
Implements SGNODE.
Definition at line 101 of file sg_index.cpp.
|
overridevirtual |
Write this node's data to a binary cache file.
The data includes all data of children and references to children. If this function is invoked by the user, parentNode must be set to NULL in order to ensure coherent data.
Implements SGNODE.
Definition at line 262 of file sg_index.cpp.
References SGNODE::GetName(), SGNODE::GetParent(), index, SGNODE::m_Parent, SGNODE::m_written, and SGNODE::WriteCache().
Referenced by SGFACESET::WriteCache().
|
protected |
Definition at line 226 of file sg_index.cpp.
References writeIndexList().
Referenced by WriteVRML().
|
protected |
|
protected |
|
overridevirtual |
Writes this node's data to a VRML file.
This includes all data of child and referenced nodes.
Implements SGNODE.
Definition at line 171 of file sg_index.cpp.
References index, SGNODE::m_SGtype, S3D::SGTYPE_COORDINDEX, writeColorIndex(), and writeCoordIndex().
Referenced by SGFACESET::WriteVRML().
std::vector< int > SGINDEX::index |
Definition at line 95 of file sg_index.h.
Referenced by AddIndex(), SGCOORDINDEX::GatherCoordIndices(), GetIndices(), ReadCache(), SetIndices(), WriteCache(), writeCoordIndex(), writeIndexList(), WriteVRML(), and ~SGINDEX().
|
privateinherited |
Handle to the instance held by a wrapper.
Definition at line 233 of file sg_node.h.
Referenced by SGNODE::SGNODE(), and SGNODE::~SGNODE().
|
protectedinherited |
nodes which hold a reference to this.
Definition at line 226 of file sg_node.h.
Referenced by SGNODE::addNodeRef(), SGCOORDS::CalcNormals(), SGNODE::delNodeRef(), and SGNODE::~SGNODE().
|
protectedinherited |
name to use for referencing the entity by name.
Definition at line 229 of file sg_node.h.
Referenced by SCENEGRAPH::FindNode(), SGFACESET::FindNode(), SGSHAPE::FindNode(), SGNODE::GetName(), SCENEGRAPH::ReadCache(), SCENEGRAPH::ReNameNodes(), SGAPPEARANCE::ReNameNodes(), SGCOLORS::ReNameNodes(), SGCOORDS::ReNameNodes(), SGFACESET::ReNameNodes(), ReNameNodes(), SGNORMALS::ReNameNodes(), SGSHAPE::ReNameNodes(), and SGNODE::SetName().
|
protectedinherited |
Pointer to parent node; may be NULL for top level transform.
Definition at line 227 of file sg_node.h.
Referenced by SGCOORDS::CalcNormals(), SCENEGRAPH::FindNode(), SGFACESET::FindNode(), SGSHAPE::FindNode(), SCENEGRAPH::SCENEGRAPH(), SCENEGRAPH::SetParent(), SGAPPEARANCE::SetParent(), SGCOLORS::SetParent(), SGCOORDS::SetParent(), SGFACESET::SetParent(), SetParent(), SGNORMALS::SetParent(), SGSHAPE::SetParent(), SGAPPEARANCE::SGAPPEARANCE(), SGCOLORS::SGCOLORS(), SGCOORDINDEX::SGCOORDINDEX(), SGCOORDS::SGCOORDS(), SGFACESET::SGFACESET(), SGINDEX(), SGNODE::SGNODE(), SGNORMALS::SGNORMALS(), SGSHAPE::SGSHAPE(), SGNODE::SwapParent(), SCENEGRAPH::WriteCache(), SGAPPEARANCE::WriteCache(), SGCOLORS::WriteCache(), SGCOORDS::WriteCache(), SGFACESET::WriteCache(), WriteCache(), SGNORMALS::WriteCache(), SGSHAPE::WriteCache(), and SGNODE::~SGNODE().
|
protectedinherited |
Type of Scene Graph node.
Definition at line 228 of file sg_node.h.
Referenced by SGNODE::delNodeRef(), SGNODE::GetName(), SCENEGRAPH::SCENEGRAPH(), SGNODE::SetName(), SGAPPEARANCE::SGAPPEARANCE(), SGCOLORS::SGCOLORS(), SGCOORDINDEX::SGCOORDINDEX(), SGCOORDS::SGCOORDS(), SGFACESET::SGFACESET(), SGNODE::SGNODE(), SGNORMALS::SGNORMALS(), SGSHAPE::SGSHAPE(), and WriteVRML().
|
protectedinherited |
Set to true when the object has been written after a ReNameNodes().
Definition at line 230 of file sg_node.h.
Referenced by SGNODE::isWritten(), SCENEGRAPH::ReNameNodes(), SGAPPEARANCE::ReNameNodes(), SGCOLORS::ReNameNodes(), SGCOORDS::ReNameNodes(), SGFACESET::ReNameNodes(), ReNameNodes(), SGNORMALS::ReNameNodes(), SGSHAPE::ReNameNodes(), SGNODE::SGNODE(), SCENEGRAPH::WriteCache(), SGAPPEARANCE::WriteCache(), SGCOLORS::WriteCache(), SGCOORDS::WriteCache(), SGFACESET::WriteCache(), WriteCache(), SGNORMALS::WriteCache(), SGSHAPE::WriteCache(), SCENEGRAPH::WriteVRML(), SGAPPEARANCE::WriteVRML(), SGCOLORS::WriteVRML(), SGCOORDS::WriteVRML(), SGFACESET::WriteVRML(), SGNORMALS::WriteVRML(), and SGSHAPE::WriteVRML().