Coin Logo http://www.coin3d.org/
http://www.kongsberg.com/kogt/

dimeFaceEntity Class Reference

The dimeFaceEntity class is an abstract class that handles one-face entity classes. More...

#include <dime/entities/FaceEntity.h>

Inheritance diagram for dimeFaceEntity:
dimeEntity dimeRecordHolder dimeBase dime3DFace dimeSolid dimeTrace

Public Member Functions

bool isQuad () const
virtual bool getRecord (const int groupcode, dimeParam &param, const int index=0) const
void setVertex (const int idx, const dimeVec3f &v)
void setTriangle (const dimeVec3f &v0, const dimeVec3f &v1, const dimeVec3f &v2)
void setQuad (const dimeVec3f &v0, const dimeVec3f &v1, const dimeVec3f &v2, const dimeVec3f &v3)
const dimeVec3fgetVertex (const int idx) const
void getVertices (dimeVec3f &v0, dimeVec3f &v1, dimeVec3f &v2, dimeVec3f &v3) const
virtual dxfdouble getThickness () const
virtual void getExtrusionDir (dimeVec3f &ed) const
GeometryType extractGeometry (dimeArray< dimeVec3f > &verts, dimeArray< int > &indices, dimeVec3f &extrusionDir, dxfdouble &thickness)
virtual int typeId () const
virtual bool isOfType (const int thetypeid) const
virtual int countRecords () const
Public Member Functions inherited from dimeEntity
 dimeEntity ()
virtual ~dimeEntity ()
int16 getEntityFlags () const
void setEntityFlags (const int16 flags)
int16 getColorNumber () const
void setColorNumber (const int16 c)
virtual void setLayer (const dimeLayer *const layer)
virtual const char * getEntityName () const =0
const dimeLayergetLayer () const
const char * getLayerName () const
virtual dimeEntitycopy (dimeModel *const model) const =0
virtual bool read (dimeInput *const in)
virtual bool write (dimeOutput *const out)
virtual void print () const
bool isDeleted () const
void setDeleted (const bool onOff=true)
bool isTagged () const
void setTagged (const bool onOff=true)
Public Member Functions inherited from dimeRecordHolder
 dimeRecordHolder (const int separator)
virtual ~dimeRecordHolder ()
void setRecord (const int groupcode, const dimeParam &value, dimeMemHandler *const memhandler=NULL)
void setRecords (const int *const groupcodes, const dimeParam *const params, const int numrecords, dimeMemHandler *const memhandler=NULL)
void setIndexedRecord (const int groupcode, const dimeParam &value, const int index, dimeMemHandler *const memhandler=NULL)
dimeRecordfindRecord (const int groupcode, const int index=0)
int getNumRecordsInRecordHolder (void) const
dimeRecordgetRecordInRecordHolder (const int idx) const
Public Member Functions inherited from dimeBase
 dimeBase (void)
virtual ~dimeBase ()
void * operator new (size_t size, dimeMemHandler *memhandler=NULL, const int alignment=4)
void operator delete (void *ptr)

Protected Member Functions

virtual bool swapQuadCoords () const
virtual bool handleRecord (const int groupcode, const dimeParam &param, dimeMemHandler *const memhandler)
void copyCoords (const dimeFaceEntity *const entity)
bool writeCoords (dimeOutput *const file)
Protected Member Functions inherited from dimeEntity
bool preWrite (dimeOutput *const file)
virtual bool traverse (const dimeState *const state, dimeCallback callback, void *userdata)
virtual void fixReferences (dimeModel *const model)
virtual bool shouldWriteRecord (const int groupcode) const
bool copyRecords (dimeEntity *const entity, dimeModel *const model) const
Protected Member Functions inherited from dimeRecordHolder
bool copyRecords (dimeRecordHolder *const rh, dimeMemHandler *const memhandler) const

Protected Attributes

dimeVec3f coords [4]
Protected Attributes inherited from dimeRecordHolder
dimeRecord ** records
int numRecords

Additional Inherited Members

Public Types inherited from dimeEntity
enum  GeometryType { NONE , POLYGONS , LINES , POINTS }
Public Types inherited from dimeBase
enum  {
  dimeBaseType = 1 , dimeRecordType , dimeStringRecordType , dimeFloatRecordType ,
  dimeDoubleRecordType , dimeInt8RecordType , dimeInt16RecordType , dimeInt32RecordType ,
  dimeHexRecordType , dimeRecordHolderType , dimeClassType , dimeUnknownClassType ,
  dimeObjectType , dimeUnknownObjectType , dimeEntityType , dimeUnknownEntityType ,
  dimePolylineType , dimeVertexType , dimeFaceEntityType , dimeExtrusionEntityType ,
  dime3DFaceType , dimeSolidType , dimeTraceType , dimeLineType ,
  dimeTextType , dimePointType , dimeBlockType , dimeInsertType ,
  dimeCircleType , dimeArcType , dimeLWPolylineType , dimeEllipseType ,
  dimeSplineType , dimeSectionType , dimeUnknownSectionType , dimeEntitiesSectionType ,
  dimeBlocksSectionType , dimeTablesSectionType , dimeHeaderSectionType , dimeClassesSectionType ,
  dimeObjectsSectionType , dimeTableType , dimeTableEntryType , dimeUnknownTableType ,
  dimeUCSTableType , dimeLayerTableType , dimeLastTypeTag
}
Static Public Member Functions inherited from dimeEntity
static dimeEntitycreateEntity (const char *const name, dimeMemHandler *const memhandler=NULL)
static bool readEntities (dimeInput *const file, dimeArray< dimeEntity * > &array, const char *const stopat)
static bool copyEntityArray (const dimeEntity *const *const array, const int nument, dimeModel *const model, dimeArray< dimeEntity * > &destarray)
static dimeEntity ** copyEntityArray (const dimeEntity *const *const array, int &nument, dimeModel *const model)
static void arbitraryAxis (const dimeVec3f &givenaxis, dimeVec3f &newaxis)
static void generateUCS (const dimeVec3f &givenaxis, dimeMatrix &m)

Detailed Description

The dimeFaceEntity class is an abstract class that handles one-face entity classes.

Member Function Documentation

◆ copyCoords()

void dimeFaceEntity::copyCoords ( const dimeFaceEntity *const entity)
protected

Copies the coordinates from entity.

Referenced by dime3DFace::copy(), dimeSolid::copy(), and dimeTrace::copy().

◆ countRecords()

int dimeFaceEntity::countRecords ( ) const
virtual

Returns the number of records in the record holder. Should be overloaded by subclasses which should count their records, and then call the parent's method. This method is used to precalculate the number of records to be written. Very useful when progress information is needed during write().

Reimplemented from dimeEntity.

Reimplemented in dime3DFace, dimeSolid, and dimeTrace.

References dimeEntity::countRecords().

Referenced by dime3DFace::countRecords(), dimeSolid::countRecords(), and dimeTrace::countRecords().

◆ extractGeometry()

dimeEntity::GeometryType dimeFaceEntity::extractGeometry ( dimeArray< dimeVec3f > & verts,
dimeArray< int > & indices,
dimeVec3f & extrusionDir,
dxfdouble & thickness )
virtual

A special convenience function, included for your pleasure. Enables the user to ignore the type of entity, and just call this method when extracting geometry. Very useful for 3D viewers that need DXF support. Check out the dxf2vrml directory for an example on how to convert a DXF file to VRML.

Should be overloaded by all subclasses that have geometry, default function returns no geometry. Don't forget to transform vertices by the current transformation matrix if used in a callback from dimeEntity::traverse().

If there are coordinates, but no indices, this means running indices for the entire vertex array.

Different faces and/or line segments are separated by a -1 in the indices array, just as in VRML files.

If thickness != 0.0, the data should, before transformation, be extruded by that length along the extrusion direction. Hence, a point becomes a line, a line becomes a quad, and a polygon becomes an object with a volume.

If thickness == 0.0 and extrusionDir != (0,0,1) all the vertices should be transformed by a matrix that can be created using dimeEntity::generateUCS(). If you are using dimeModel::traverseEntities() to extract the geometry, simply right-multiply the UCS matrix with the matrix found in dimeState to get the correct transformation.

Reimplemented from dimeEntity.

References getExtrusionDir(), getThickness(), dimeArray< T >::setCount(), and swapQuadCoords().

◆ getExtrusionDir()

void dimeFaceEntity::getExtrusionDir ( dimeVec3f & ed) const
virtual

Default method returns (0,0,1). Should be overloaded if this is not correct for all cases.

Reimplemented in dimeSolid, and dimeTrace.

Referenced by extractGeometry().

◆ getRecord()

bool dimeFaceEntity::getRecord ( const int groupcode,
dimeParam & param,
const int index = 0 ) const
virtual

Will return the value of the record with group code groupcode. false is returned if the record could not be found. Subclasses should overload this method if one or several records are stored in the class. If the groupcode queried is not stored internally, the subclass should call its parent's method.

Reimplemented from dimeEntity.

Reimplemented in dime3DFace, dimeSolid, and dimeTrace.

References dimeEntity::getRecord().

Referenced by dime3DFace::getRecord(), dimeSolid::getRecord(), and dimeTrace::getRecord().

◆ getThickness()

dxfdouble dimeFaceEntity::getThickness ( ) const
virtual

Default method return 0.0. Should be overloaded if this is not correct for all cases.

Reimplemented in dimeSolid, and dimeTrace.

Referenced by extractGeometry().

◆ getVertex()

const dimeVec3f & dimeFaceEntity::getVertex ( const int idx) const
inline

Returns vertex nr idx.

◆ getVertices()

void dimeFaceEntity::getVertices ( dimeVec3f & v0,
dimeVec3f & v1,
dimeVec3f & v2,
dimeVec3f & v3 ) const

Returns all four vertices.

◆ handleRecord()

bool dimeFaceEntity::handleRecord ( const int groupcode,
const dimeParam & param,
dimeMemHandler *const memhandler )
protectedvirtual

Must be overloaded by entities that directly supports a record type. During dimeRecordHolder::read(), dimeRecordHolder::setRecord and dimeRecordHolder::setRecords, this function is called for every record found, and it is up to the subclass if the record should be stored internally, or if a generic record should be created and stored in this superclass. A subclass should return \true when it will handle the record, false otherwise. Default function does nothing, and returns false.

For entities, records with group codes 8 (layer name) and 62 (color number) are automatically handled by the dimeEntity class.

See also
dimeRecordHolder::read()
dimeRecordHolder::setRecord()

Reimplemented from dimeEntity.

Reimplemented in dime3DFace, dimeSolid, and dimeTrace.

References dimeEntity::handleRecord().

Referenced by dime3DFace::handleRecord(), dimeSolid::handleRecord(), and dimeTrace::handleRecord().

◆ isOfType()

bool dimeFaceEntity::isOfType ( const int thetypeid) const
virtual

Returns true if the object is of type typeid or is inherited from it. Function in base class checks whether thetypeid equals the virtual dimeBase::typeId() value or equals dimeBaseType. Must be implemented by all subclasses that are superclasses of other classes, and should check if thetypeid equals its typeId, and then call its parent's isOfType function. Leaf-classes do not have to implement this method.

Reimplemented from dimeEntity.

References dimeEntity::isOfType().

◆ setQuad()

void dimeFaceEntity::setQuad ( const dimeVec3f & v0,
const dimeVec3f & v1,
const dimeVec3f & v2,
const dimeVec3f & v3 )

Sets vertices to create a quad.

◆ setTriangle()

void dimeFaceEntity::setTriangle ( const dimeVec3f & v0,
const dimeVec3f & v1,
const dimeVec3f & v2 )

Sets vertices to create a triangle.

◆ swapQuadCoords()

bool dimeFaceEntity::swapQuadCoords ( ) const
protectedvirtual

Default function returns false. If true is returned, the last two vertices will be swapped before returning geometry in extractGeometry().

Reimplemented in dimeSolid, and dimeTrace.

Referenced by extractGeometry().

◆ typeId()

int dimeFaceEntity::typeId ( ) const
virtual

Must be implemented by all subclasses, and should return an unique id for that class.

Implements dimeBase.

Reimplemented in dime3DFace, dimeSolid, and dimeTrace.

◆ writeCoords()

bool dimeFaceEntity::writeCoords ( dimeOutput *const file)
protected

Will write the coordinate data to out. Should be called by subclasses at some time during write.

References dimeOutput::writeDouble(), and dimeOutput::writeGroupCode().

Referenced by dime3DFace::write(), dimeSolid::write(), and dimeTrace::write().


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

Copyright © by Kongsberg Oil & Gas Technologies. All rights reserved.

Generated on for Dime by Doxygen 1.15.0.