arsa  2.7
Public Member Functions | List of all members
irr::scene::IColladaMeshWriterNames Class Referenceabstract

Callback interface to use custom names on collada writing. More...

#include <IColladaMeshWriter.h>

Inheritance diagram for irr::scene::IColladaMeshWriterNames:
irr::IReferenceCounted

Public Member Functions

virtual ~IColladaMeshWriterNames ()
 
virtual irr::core::stringc nameForMesh (const scene::IMesh *mesh, int instance)=0
 Return a unique name for the given mesh. More...
 
virtual irr::core::stringc nameForNode (const scene::ISceneNode *node)=0
 Return a unique name for the given node. More...
 
virtual irr::core::stringc nameForMaterial (const video::SMaterial &material, int materialId, const scene::IMesh *mesh, const scene::ISceneNode *node)=0
 Return a name for the material. More...
 
- Public Member Functions inherited from irr::IReferenceCounted
 IReferenceCounted ()
 Constructor. More...
 
virtual ~IReferenceCounted ()
 Destructor. More...
 
void grab () const
 Grabs the object. Increments the reference counter by one. More...
 
bool drop () const
 Drops the object. Decrements the reference counter by one. More...
 
s32 getReferenceCount () const
 Get the reference count. More...
 
const c8getDebugName () const
 Returns the debug name of the object. More...
 

Additional Inherited Members

- Protected Member Functions inherited from irr::IReferenceCounted
void setDebugName (const c8 *newName)
 Sets the debug name of the object. More...
 

Detailed Description

Callback interface to use custom names on collada writing.

You can either modify names and id's written to collada or you can use this interface to just find out which names are used on writing. Names are often used later as xs:anyURI, so avoid whitespace, '#' and '' in the names.

Definition at line 159 of file IColladaMeshWriter.h.

Constructor & Destructor Documentation

◆ ~IColladaMeshWriterNames()

virtual irr::scene::IColladaMeshWriterNames::~IColladaMeshWriterNames ( )
inlinevirtual

Definition at line 163 of file IColladaMeshWriter.h.

163 {}

Member Function Documentation

◆ nameForMaterial()

virtual irr::core::stringc irr::scene::IColladaMeshWriterNames::nameForMaterial ( const video::SMaterial material,
int  materialId,
const scene::IMesh mesh,
const scene::ISceneNode node 
)
pure virtual

Return a name for the material.

There is one material created in the writer for each unique name. So you can use this to control the number of materials which get written. For example Irrlicht does by default write one material for each material instanced by a node. So if you know that in your application material instances per node are identical between different nodes you can reduce the number of exported materials using that knowledge by using identical names for such shared materials. Names must follow the xs:NCName standard to be valid, you can run them through IColladaMeshWriter::toNCName to ensure that.

◆ nameForMesh()

virtual irr::core::stringc irr::scene::IColladaMeshWriterNames::nameForMesh ( const scene::IMesh mesh,
int  instance 
)
pure virtual

Return a unique name for the given mesh.

Note that names really must be unique here per mesh-pointer, so mostly it's a good idea to return the nameForMesh from IColladaMeshWriter::getDefaultNameGenerator(). Also names must follow the xs:NCName standard to be valid, you can run them through IColladaMeshWriter::toNCName to ensure that.

Parameters
meshPointer to the mesh which needs a name
instanceWhen E_COLLADA_GEOMETRY_WRITING is not ECGI_PER_MESH then several instances of the same mesh can be written and this counts them.

◆ nameForNode()

virtual irr::core::stringc irr::scene::IColladaMeshWriterNames::nameForNode ( const scene::ISceneNode node)
pure virtual

Return a unique name for the given node.

Note that names really must be unique here per node-pointer, so mostly it's a good idea to return the nameForNode from IColladaMeshWriter::getDefaultNameGenerator(). Also names must follow the xs:NCName standard to be valid, you can run them through IColladaMeshWriter::toNCName to ensure that.


The documentation for this class was generated from the following file: