/usr/include/dime/entities/FaceEntity.h is in libdime-dev 0.20030921-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | /**************************************************************************\
*
* FILE: FaceEntity.h
*
* This source file is part of DIME.
* Copyright (C) 1998-1999 by Systems In Motion. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License, version 2, as
* published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License (the accompanying file named COPYING) for more
* details.
*
**************************************************************************
*
* If you need DIME for a non-GPL project, contact Systems In Motion
* to acquire a Professional Edition License:
*
* Systems In Motion http://www.sim.no/
* Prof. Brochs gate 6 sales@sim.no
* N-7030 Trondheim Voice: +47 22114160
* NORWAY Fax: +47 67172912
*
\**************************************************************************/
#ifndef DIME_FACEENTITY_H
#define DIME_FACEENTITY_H
#include <dime/Basic.h>
#include <dime/entities/Entity.h>
#include <dime/util/Linear.h>
class DIME_DLL_API dimeFaceEntity : public dimeEntity
{
public:
bool isQuad() const;
virtual bool getRecord(const int groupcode,
dimeParam ¶m,
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 dimeVec3f &getVertex(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;
protected:
virtual bool swapQuadCoords() const;
virtual bool handleRecord(const int groupcode,
const dimeParam ¶m,
dimeMemHandler * const memhandler);
void copyCoords(const dimeFaceEntity * const entity);
bool writeCoords(dimeOutput * const file);
dimeFaceEntity();
dimeVec3f coords[4];
}; // class dimeFaceEntity
inline const dimeVec3f &
dimeFaceEntity::getVertex(const int idx) const
{
assert(idx >= 0 && idx < 4);
return this->coords[idx];
}
inline bool
dimeFaceEntity::isQuad() const
{
return (coords[2] != coords[3]);
}
inline void
dimeFaceEntity::setVertex(const int idx, const dimeVec3f &v)
{
assert(idx >= 0 && idx < 4);
this->coords[idx] = v;
}
#endif // ! DIME_FACEENTITY_H
|