dime
0.9.1
Portable DXF file library
|
The dimePolyline class handles a POLYLINE entity. More...
#include <dime/entities/Polyline.h>
Public Types | |
enum | Flags { CLOSED = 0x01 , POLYMESH_CLOSED_M = 0x01 , CURVE_FIT = 0x02 , SPLINE_FIT = 0x04 , IS_POLYLINE_3D = 0x08 , IS_POLYMESH_3D = 0x10 , POLYMESH_CLOSED_N = 0x20 , IS_POLYFACE_MESH = 0x40 , CONTINOUS_PATTERN = 0x80 } |
enum | SurfaceType { NONE = 0 , QUADRIC_BSPLINE = 5 , CUBIC_BSPLINE = 6 , BEZIER = 8 } |
enum | Type { POLYLINE , POLYFACE_MESH , POLYGON_MESH } |
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 } |
Public Member Functions | |
dimePolyline () | |
virtual | ~dimePolyline () |
void | clearSurfaceData () |
virtual dimeEntity * | copy (dimeModel *const model) const |
virtual int | countRecords () const |
virtual GeometryType | extractGeometry (dimeArray< dimeVec3f > &verts, dimeArray< int > &indices, dimeVec3f &extrusionDir, dxfdouble &thickness) |
dimeVertex * | getCoordVertex (const int index) |
const dimeVec3f & | getElevation () const |
virtual const char * | getEntityName () const |
int16 | getFlags () const |
dimeVertex * | getIndexVertex (const int index) |
int | getNumCoordVertices () const |
int | getNumIndexVertices () const |
int | getNumSplineFrameControlPoints () const |
int16 | getPolymeshCountM () const |
int16 | getPolymeshCountN () const |
virtual bool | getRecord (const int groupcode, dimeParam ¶m, const int index=0) const |
int16 | getSmoothSurfaceMdensity () const |
int16 | getSmoothSurfaceNdensity () const |
dimeVertex * | getSplineFrameControlPoint (const int index) |
int16 | getSurfaceType () const |
int | getType () const |
virtual bool | read (dimeInput *const in) |
void | setCoordVertices (dimeVertex **vertices, const int num, dimeMemHandler *const memhandler=NULL) |
void | setElevation (const dimeVec3f &e) |
void | setFlags (const int16 flags) |
void | setIndexVertices (dimeVertex **vertices, const int num, dimeMemHandler *const memhandler=NULL) |
virtual void | setLayer (const dimeLayer *const layer) |
void | setSeqend (const dimeEntity *ent) |
void | setSplineFrameControlPoints (dimeVertex **vertices, const int num, dimeMemHandler *const memhandler=NULL) |
void | setSurfaceType (const int16 type) |
virtual int | typeId () const |
virtual bool | write (dimeOutput *const out) |
Public Member Functions inherited from dimeExtrusionEntity | |
dimeExtrusionEntity () | |
const dimeVec3f & | getExtrusionDir () const |
dxfdouble | getThickness () const |
virtual bool | isOfType (const int thtypeid) const |
void | setExtrusionDir (const dimeVec3f &v) |
void | setThickness (const dxfdouble val) |
Public Member Functions inherited from dimeEntity | |
dimeEntity () | |
virtual | ~dimeEntity () |
int16 | getColorNumber () const |
int16 | getEntityFlags () const |
const dimeLayer * | getLayer () const |
const char * | getLayerName () const |
bool | isDeleted () const |
bool | isTagged () const |
virtual void | print () const |
void | setColorNumber (const int16 c) |
void | setDeleted (const bool onOff=true) |
void | setEntityFlags (const int16 flags) |
void | setTagged (const bool onOff=true) |
Public Member Functions inherited from dimeRecordHolder | |
dimeRecordHolder (const int separator) | |
virtual | ~dimeRecordHolder () |
dimeRecord * | findRecord (const int groupcode, const int index=0) |
int | getNumRecordsInRecordHolder (void) const |
dimeRecord * | getRecordInRecordHolder (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 ¶m, dimeMemHandler *const memhandler) |
virtual bool | traverse (const dimeState *const state, dimeCallback callback, void *userdata) |
Protected Member Functions inherited from dimeExtrusionEntity | |
void | copyExtrusionData (const dimeExtrusionEntity *const entity) |
bool | writeExtrusionData (dimeOutput *const out) |
Protected Member Functions inherited from dimeEntity | |
bool | copyRecords (dimeEntity *const entity, dimeModel *const model) const |
virtual void | fixReferences (dimeModel *const model) |
bool | preWrite (dimeOutput *const file) |
virtual bool | shouldWriteRecord (const int groupcode) const |
Protected Member Functions inherited from dimeRecordHolder | |
bool | copyRecords (dimeRecordHolder *const rh, dimeMemHandler *const memhandler) const |
Additional Inherited Members | |
Static Public Member Functions inherited from dimeEntity | |
static void | arbitraryAxis (const dimeVec3f &givenaxis, dimeVec3f &newaxis) |
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 dimeEntity * | createEntity (const char *const name, dimeMemHandler *const memhandler=NULL) |
static void | generateUCS (const dimeVec3f &givenaxis, dimeMatrix &m) |
static bool | readEntities (dimeInput *const file, dimeArray< dimeEntity * > &array, const char *const stopat) |
Protected Attributes inherited from dimeExtrusionEntity | |
dimeVec3f | extrusionDir |
dxfdouble | thickness |
Protected Attributes inherited from dimeRecordHolder | |
int | numRecords |
dimeRecord ** | records |
The dimePolyline class handles a POLYLINE entity.
dimePolyline::dimePolyline | ( | ) |
Constructor.
|
virtual |
Destructor.
|
virtual |
Must be implemented by subclasses to return a copy of the entity. model is the model the new entity should belong to.
Implements dimeEntity.
|
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 dimeExtrusionEntity.
|
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.
|
virtual |
Must be implemented by subclasses to return the entity name, e.g. POLYLINE, 3DFACE, etc.
Implements dimeEntity.
|
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 group code queried is not stored internally, the subclass should call its parent's method.
Reimplemented from dimeExtrusionEntity.
int dimePolyline::getType | ( | ) | const |
Convenience function that returns the type of the polyline.
|
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.
Reimplemented from dimeExtrusionEntity.
|
virtual |
Reads a POLYLINE entity.
Reimplemented from dimeEntity.
void dimePolyline::setCoordVertices | ( | dimeVertex ** | vertices, |
const int | num, | ||
dimeMemHandler *const | memhandler = NULL ) |
Sets the coordinate vertices for this polyline. Old vertices will be deleted.
void dimePolyline::setIndexVertices | ( | dimeVertex ** | vertices, |
const int | num, | ||
dimeMemHandler *const | memhandler = NULL ) |
Sets the index vertices for this polyline. Old vertices will be deleted.
|
virtual |
Sets the layer for this entity. This will change the record with group code 8. If layer equals NULL, the layer will be set to the default layer.
Reimplemented from dimeEntity.
void dimePolyline::setSeqend | ( | const dimeEntity * | ent | ) |
Sets the SEQEND entity for this polyline.
void dimePolyline::setSplineFrameControlPoints | ( | dimeVertex ** | vertices, |
const int | num, | ||
dimeMemHandler *const | memhandler = NULL ) |
Sets the spline frame control point vertices for this polyline. Old control points will be deleted.
|
protectedvirtual |
Overloaded from dimeEntity. Will first do a callback for this entity, then for all vertices. Each vertex will have a pointer to its polyline "parent".
Reimplemented from dimeEntity.
|
virtual |
Must be implemented by all subclasses, and should return an unique id for that class.
Reimplemented from dimeExtrusionEntity.
|
virtual |
Writes POLYLINE data to file.
Reimplemented from dimeEntity.