dime  0.9.1
Portable DXF file library
Loading...
Searching...
No Matches
dimeLayerTable Class Reference

The dimeLayerTable class reads and writes LAYER tables. More...

#include <dime/tables/LayerTable.h>

Inheritance diagram for dimeLayerTable:
dimeTableEntry dimeRecordHolder dimeBase

Public Member Functions

 dimeLayerTable ()
 
virtual dimeTableEntrycopy (dimeModel *const model) const
 
virtual int countRecords () const
 
int16 getColorNumber (void) const
 
const char * getLayerName (void) const
 
virtual const char * getTableName () const
 
virtual bool read (dimeInput *const in)
 
void registerLayer (dimeModel *model)
 
void setColorNumber (const int16 colnum)
 
void setLayerName (const char *name, dimeMemHandler *const memhandler)
 
virtual int typeId () const
 
virtual bool write (dimeOutput *const out)
 
- Public Member Functions inherited from dimeTableEntry
 dimeTableEntry ()
 
virtual ~dimeTableEntry ()
 
virtual bool isOfType (const int thetypeid) const
 
- Public Member Functions inherited from dimeRecordHolder
 dimeRecordHolder (const int separator)
 
virtual ~dimeRecordHolder ()
 
dimeRecordfindRecord (const int groupcode, const int index=0)
 
int getNumRecordsInRecordHolder (void) const
 
virtual bool getRecord (const int groupcode, dimeParam &param, const int index=0) const
 
dimeRecordgetRecordInRecordHolder (const int idx) const
 
void setIndexedRecord (const int groupcode, const dimeParam &value, const int index, dimeMemHandler *const memhandler=NULL)
 
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)
 
- Public Member Functions inherited from dimeBase
 dimeBase (void)
 
virtual ~dimeBase ()
 
void operator delete (void *ptr)
 
void * operator new (size_t size, dimeMemHandler *memhandler=NULL, const int alignment=4)
 

Protected Member Functions

virtual bool handleRecord (const int groupcode, const dimeParam &param, dimeMemHandler *const memhandler)
 
- Protected Member Functions inherited from dimeTableEntry
bool copyRecords (dimeTableEntry *const table, dimeModel *const model) const
 
bool preWrite (dimeOutput *const output)
 
- Protected Member Functions inherited from dimeRecordHolder
bool copyRecords (dimeRecordHolder *const rh, dimeMemHandler *const memhandler) const
 
virtual bool shouldWriteRecord (const int groupcode) const
 

Additional Inherited Members

- 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 dimeTableEntry
static dimeTableEntrycreateTableEntry (const char *const name, dimeMemHandler *const memhandler=NULL)
 
- Protected Attributes inherited from dimeRecordHolder
int numRecords
 
dimeRecord ** records
 

Detailed Description

The dimeLayerTable class reads and writes LAYER tables.

Constructor & Destructor Documentation

◆ dimeLayerTable()

dimeLayerTable::dimeLayerTable ( )

Constructor.

Member Function Documentation

◆ copy()

dimeTableEntry * dimeLayerTable::copy ( dimeModel *const model) const
virtual

Implements dimeTableEntry.

◆ countRecords()

int dimeLayerTable::countRecords ( ) const
virtual

Returns the number of records for this table. Tables overloading this function should first count the number of records they will write, then add the return value of this function to get the total number of records.

Reimplemented from dimeTableEntry.

◆ getColorNumber()

int16 dimeLayerTable::getColorNumber ( void ) const

Returns the color number.

◆ getLayerName()

const char * dimeLayerTable::getLayerName ( void ) const

Returns the layer name.

◆ getTableName()

const char * dimeLayerTable::getTableName ( ) const
virtual

Implements dimeTableEntry.

◆ handleRecord()

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

Must be overloaded by entities that directly support 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 dimeTableEntry.

◆ read()

bool dimeLayerTable::read ( dimeInput *const file)
virtual

Reads records from in until the separator group code (specified in constructor) is found. Can be overloaded by subclasses, but in most cases this will not be necessary as dimeRecordHolder::handleRecord() is called for each record found in the stream.

See also
dimeEntity::handleRecord().

Reimplemented from dimeTableEntry.

◆ registerLayer()

void dimeLayerTable::registerLayer ( dimeModel * model)

Should be called once after you've finished setting up your layer (name and color number). Calling this method more than once for a layer might lead to hard-to-find bugs. After calling this method, the layer information (color number) will be available to entities using this layer.

◆ setColorNumber()

void dimeLayerTable::setColorNumber ( const int16 colnum)

Sets the color number.

◆ setLayerName()

void dimeLayerTable::setLayerName ( const char * name,
dimeMemHandler *const memhandler )

Sets the layer name.

◆ typeId()

int dimeLayerTable::typeId ( ) const
virtual

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

Implements dimeTableEntry.

◆ write()

bool dimeLayerTable::write ( dimeOutput *const file)
virtual

Will write the records to file.

Reimplemented from dimeTableEntry.


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