HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
GEO_PrimPoly Class Reference

#include <GEO_PrimPoly.h>

+ Inheritance diagram for GEO_PrimPoly:

Public Member Functions

SYS_FORCE_INLINE GEO_PrimPoly (GA_Detail *d, GA_Offset offset=GA_INVALID_OFFSET)
 
SYS_FORCE_INLINE GEO_PrimPoly (GA_Detail *gdp, GA_Offset offset, const GA_OffsetListRef &vertex_list)
 
const GA_PrimitiveDefinitiongetTypeDef () const override
 
int64 getMemoryUsage () const override
 Report approximate memory usage. More...
 
void countMemory (UT_MemoryCounter &counter) const override
 
int unroll (int append_pts=1) override
 
int loft (int newcount, int start=-1, int stop=-1) override
 
int warp (float u, const UT_Vector3 &delta, GA_AttributeRefMap &map, float sharpness=0.0f, float bias=-1.0f) override
 
int evaluateBreakpoint (int uidx, UT_Vector4 &pos, int du=0) const override
 
void computeInteriorPointWeights (UT_Array< GA_Offset > &vtxlist, UT_Array< float > &weightlist, fpreal u, fpreal v, fpreal w) const overridefinal
 
int attach (const GEO_Face &face, int blend=1, float bias=.5f, float tolerance=1.f, int=0, GA_PointGroup *ptgroup=0) override
 
GD_Faceplanar (GD_Detail &dgdp, int copyxy=0) const override
 
unsigned getOrder () const override
 
bool isDegenerate () const override
 Is the primitive degenerate. More...
 
int breakCount () const override
 
float unitLengthToUnitDomain (float ulength, float tolerance=1e-05F) const override
 
float unitToUnitLengthDomain (float uparm) const override
 
const GA_PrimitiveJSONgetJSON () const override
 
void getAdjacentBoundaryVertices (GA_Offset vtx, GA_Offset &prev_vtx, GA_Offset &next_vtx) const override
 
int deleteVertex (GA_Size num) override
 
GA_Size insertVertex (GA_Offset ptoff, GA_Size where=0) override
 
GA_Size appendVertex (GA_Offset ptoff) override
 
bool supportsHedge () const override
 
GA_Size stealVertex (GA_Offset vtx, GA_Offset insert_before_vtx=GA_INVALID_OFFSET) override
 
void flipEdge (GEO_PrimPoly *that, GA_Size i, GA_Size j, GA_ElementWranglerCache &wranglers)
 
bool isPlanar (float tolerance=0.0001F) const
 Determine if the polygon is planar. More...
 
bool isConvex (float tolerance=0.0001F) const
 Determine if the polygon is convex. More...
 
- Public Member Functions inherited from GEO_Face
UT_Vector3 computeNormal () const override
 Return a normal vector for the primitive. More...
 
UT_Vector3D computeNormalD () const override
 
void normal (NormalComp &output) const override
 
void normal (NormalCompD &output) const override
 
bool saveH9 (std::ostream &os, bool binary, const UT_Array< GA_AttribSaveDataH9 > &prim_attribs, const UT_Array< GA_AttribSaveDataH9 > &vtx_attribs) const override
 
bool loadH9 (UT_IStream &is, const UT_Array< GA_AttribLoadDataH9 > &prim_attribs, const UT_Array< GA_AttribLoadDataH9 > &vtx_attribs) override
 
void copyPrimitive (const GEO_Primitive *src) override
 
GEO_Primitivecopy (int preserve_shared_pts=0) const override
 
void copySubclassData (const GA_Primitive *source) override
 
void realToUnitPair (float ureal, float vreal, float &uunit, float &vunit) const override
 
void unitToRealPair (float uunit, float vunit, float &ureal, float &vreal) const override
 
void unitLengthToUnitPair (float ulength, float vlength, float &uparm, float &vparm) const override
 
void unitLengthToUnitPair (float ulength, float vlength, float &uparm, float &vparm, float tolerance) const override
 
void unitToUnitLengthPair (float uparm, float vparm, float &ulength, float &vlength) const override
 
bool evaluate (fpreal u, GEO_Vertex result, GEO_AttributeHandleList &gah, int du=0, int uoffset=-1) const
 
bool evaluate (fpreal u, GA_Offset result_vtx, GA_AttributeRefMap &gah, int du=0, int uoffset=-1) const
 
int evaluate (float u, UT_Vector4 &pos, unsigned du=0, int uoffset=-1) const
 
int evaluateNormalVector (UT_Vector3 &nml, float u, float v=0, float w=0) const override
 
virtual int evaluateFrenetFrame (UT_Vector3 &x, UT_Vector3 &t, UT_Vector3 &m, UT_Vector3 &b, float u, int accurate=1, int uoffset=-1) const
 
void fillBreakParameters (UT_Array< float > &uvals, int ustartidx, int ustopidx, int ulod) const
 
virtual bool evaluateMesh (const UT_Span< const float > &uvals, GA_Offset *results, GA_AttributeRefMap &hlist, unsigned du=0) const
 
virtual bool evaluateMesh (const UT_Span< const float > &uvals, UT_Vector4 *pos, unsigned du=0) const
 
virtual float breakSegmIndexToDomain (int ustartidx, int ustopidx, int lod, int index) const
 
virtual GA_Size removeRepeatedVertices (bool check_order=false, bool count_only=false, bool delete_orphaned_points=false)
 
virtual GA_Size removeRepeatedPoints (float tol=0.001F, bool check_order=false, bool count_only=false, bool delete_orphaned_points=false)
 
int subdivide (float u, GA_AttributeRefMap &map)
 
int subdivide (float u)
 
int warpAlongNormal (float u, float distance, GA_AttributeRefMap &map, float sharpness, float bias)
 
virtual float unitToRealDomain (float u_unit) const
 
virtual float realToUnitDomain (float u_real) const
 
virtual void unitToRealSequence (float *uunit, float *ureal, int ulen) const
 
virtual void validInterval (int &a, int &b) const
 
virtual void validRange (float &ua, float &ub) const
 
SYS_FORCE_INLINE bool isClosed () const
 
SYS_FORCE_INLINE void setClosed (bool isclosed)
 
virtual void close (int rounded=1, int preserve_shape=0)
 
virtual void open (int preserve_shape=0, int safe=0)
 
bool hasEdge (const GA_Edge &edge) const override
 Method to determine if a primitive has an edge (undirected). More...
 
void iterateEdges (GA_IterateEdgesFunc apply_func) const override
 
void iterateEdgesByVertex (GA_IterateEdgesByVertexFunc apply_func) const override
 
int getEdgeCount () const
 
void reverse () override
 Reverse the order of vertices. More...
 
void sampleEnds (int n)
 
virtual int cycle (int amount, int=1)
 
float radius () const
 
bool findEdgePoints (GA_Offset pta, GA_Offset ptb, GA_Size &pidx0, GA_Size &pidx1) const
 
bool findEdgePoints (const GA_Edge &edge, GA_Size &pidx0, GA_Size &pidx1) const
 
bool hasDEdge (GA_Offset a, GA_Offset b) const
 
bool isBridge (GA_Offset a, GA_Offset b) const
 
int refine (float k, GA_AttributeRefMap &gah, int r=1)
 
int refine (float k, int r=1)
 
virtual int pointInFace (const UT_Vector3 &pos, const UT_Vector3 *normal) const
 
float uvDist (float u1, float v1, float u2, float v2) const override
 
virtual void weights (unsigned short on_off)
 
fpreal calcVolume (const UT_Vector3 &refpt) const override
 
fpreal calcArea () const override
 
fpreal calcPerimeter () const override
 
- Public Member Functions inherited from GEO_TriMesh
bool getBBox (UT_BoundingBox *bbox) const override
 
void addToBSphere (UT_BoundingSphere *bsphere) const override
 
UT_Vector3 baryCenter () const override
 
UT_Vector3D baryCenterD () const override
 
bool saveH9 (std::ostream &os, bool binary, const UT_Array< GA_AttribSaveDataH9 > &prim_attribs, const UT_Array< GA_AttribSaveDataH9 > &vtx_attribs) const override
 
bool loadH9 (UT_IStream &is, const UT_Array< GA_AttribLoadDataH9 > &prim_attribs, const UT_Array< GA_AttribLoadDataH9 > &vtx_attribs) override
 
virtual bool changePointRef (GA_Offset from, GA_Offset to)
 
bool isDegenerate () const override
 Is the primitive degenerate. More...
 
SYS_FORCE_INLINE void setSize (GA_Size nvertices)
 
int detachPoints (GA_PointGroup &grp) override
 
GA_DereferenceStatus dereferencePoint (GA_Offset point, bool dry_run=false) override
 
GA_DereferenceStatus dereferencePoints (const GA_RangeMemberQuery &pt_q, bool dry_run=false) override
 
virtual void deleteVertices (const UT_Array< GA_Size > &nums)
 
GA_Size findVertex (GA_Offset vtx) const
 return the index of a vertex within our vertex list More...
 
SYS_FORCE_INLINE GA_Size getFastVertexCount () const
 
SYS_FORCE_INLINE GA_Offset getFastVertexOffset (GA_Size index) const
 
GA_Size find (GA_Offset pt) const
 
const GEO_Vertex operator() (GA_Size i) const
 
GEO_Vertex operator() (GA_Size i)
 
const GEO_Vertex operator[] (GA_Size i) const
 
GEO_Vertex operator[] (GA_Size i)
 
void setVertexPoint (GA_Size i, GA_Offset pt)
 
virtual bool vertexApply (bool(*apply)(GA_Offset vtx, void *), void *data=0) const final
 
void unitLengthToUnitPair (float ulength, float vlength, float &uparm, float &vparm) const override
 
void unitLengthToUnitPair (float ulength, float vlength, float &uparm, float &vparm, float tolerance) const override
 
void unitToUnitLengthPair (float uparm, float vparm, float &ulength, float &vlength) const override
 
void assignVertexList (const GA_OffsetList &list, bool destroy_existing=true, bool update_topology=true)
 
virtual bool jsonSaveBasis (UT_JSONWriter &w) const
 
virtual bool jsonSaveBasis (UT_JSONValue &v) const
 
virtual bool jsonLoadBasis (UT_JSONParser &p)
 
virtual bool jsonLoadBasis (UT_JSONParser &p, const UT_JSONValue &v)
 
bool saveVertexArray (UT_JSONWriter &w, const GA_SaveMap &map) const
 
bool loadVertexArray (UT_JSONParser &p, const GA_LoadMap &map)
 
- Public Member Functions inherited from GEO_Primitive
GA_PrimCompat::TypeMask getPrimitiveId () const override
 
void copyAttributesAndGroups (const GEO_Primitive &src, bool copy_groups=true)
 
void copyAttributesAndGroups (const GEO_Primitive &src, GA_AttributeRefMap &gah, bool copy_groups=true)
 
void copyAttributesAndGroups (const GEO_Primitive &src, GA_PrimitiveWrangler &wrangler, bool copy_groups=true)
 NOTE: The copying of groups only works if src is in the same detail. More...
 
void copyAttributeData (const GEO_Primitive &src)
 
void copyAttributeData (const GEO_Primitive &src, GA_AttributeRefMap &gah)
 
void copyAttributeData (const GEO_Primitive &src, GA_PrimitiveWrangler &wrangler)
 
void copyAttributeValues (const GEO_Primitive &src, GA_PrimitiveWrangler &wrangler)
 
void copyGroupMembership (const GEO_Primitive &src)
 
virtual void transform (const UT_Matrix4 &)
 
bool evaluateBaryCenter (GA_Offset result_vtx, GA_AttributeRefMap &map) const
 
bool evaluatePoint (GA_Offset result_vtx, GA_AttributeRefMap &map, fpreal u, fpreal v=0, uint du=0, uint dv=0) const
 
int evaluatePoint (UT_Vector4 &pos, float u, float v=0, unsigned du=0, unsigned dv=0) const
 
bool evaluateInteriorPoint (GA_Offset result_vtx, GA_AttributeRefMap &map, fpreal u, fpreal v, fpreal w=0) const
 
int evaluateInteriorPoint (UT_Vector4 &pos, fpreal u, fpreal v, fpreal w=0) const
 
SYS_FORCE_INLINE GEO_DetailgetParent () const
 
virtual bool getVisibleBBox (UT_BoundingBox *bbox) const
 
bool enlargeVisibleBoundingBox (UT_BoundingBox &b, const GA_Attribute *P) const override
 
template<typename T >
UT_Vector3T< TbaryCenterT () const
 
virtual void isolate ()
 Method to isolate a pasted surface. More...
 
bool hasEdge (const GA_Edge &edge) const override
 Method to determine if a primitive has an edge (undirected). More...
 
GEO_Vertex getVertexElement (GA_Size i) const
 
virtual GEO_MetaPrimcastToMetaPrim ()
 
virtual const GEO_MetaPrimcastToMetaPrim () const
 
virtual int parametricBBox (float u, float v, float *u0, float *u1, float *v0, float *v1)
 
int bboxIntersectRay (const UT_Vector3 &rayorig, const UT_Vector3 &raydir, int maxtries=10, float tmax=1E17F, float *distance=0, UT_Vector3 *nml=0) const
 
virtual bool isQuadric () const
 
bool enlargeBoundingBox (UT_BoundingRect &b, const GA_Attribute *p) const override
 
bool enlargeBoundingBox (UT_BoundingBox &b, const GA_Attribute *p) const override
 
virtual bool hasGuideEdge (int edgeid, UT_Vector3 &a, UT_Vector3 &b) const
 
virtual bool hasXsectPoint (int pointid, UT_Vector3 &p) const
 
fpreal calcVolume (const UT_Vector3 &) const override
 
fpreal calcArea () const override
 
fpreal calcPerimeter () const override
 
- Public Member Functions inherited from GA_Primitive
virtual ~GA_Primitive ()
 
const char * getTypeName () const
 
SYS_FORCE_INLINE GA_DetailgetDetail () const
 
SYS_FORCE_INLINE GA_Offset getMapOffset () const
 Gets the offset of this primitive in the detail containing it. More...
 
SYS_FORCE_INLINE GA_Index getMapIndex () const
 Gets the index of this primitive in the detail containing it. More...
 
SYS_FORCE_INLINE const
GA_IndexMap
getIndexMap () const
 Gets the index map for primitives in the detail containing this primitive. More...
 
GA_Index getNum () const
 
void swapOffsetValue (const GA_Defragment &defrag)
 For defragmentation, we need to update the offset. More...
 
bool isPrimary () const
 
SYS_FORCE_INLINE const
GA_PrimitiveTypeId
getTypeId () const
 
GA_PrimitiveFamilyMask getFamilyMask () const
 
bool isFamily (unsigned family_mask) const
 
bool hasLocalTransform () const
 Whether the primitive has a transform associated with it. More...
 
virtual void getLocalTransform (UT_Matrix3D &matrix) const
 
virtual void getLocalTransform4 (UT_Matrix4D &matrix) const
 
virtual void setLocalTransform (const UT_Matrix3D &matrix)
 Set the local transform. The default implementation does nothing. More...
 
SYS_FORCE_INLINE GA_Size getVertexCount () const
 Return the number of vertices used by this primitive. More...
 
SYS_FORCE_INLINE GA_Offset getVertexOffset (GA_Size primvertexnum) const
 
SYS_FORCE_INLINE GA_Index getVertexIndex (GA_Size primvertexnum) const
 
SYS_FORCE_INLINE GA_Offset getPointOffset (GA_Size i) const
 
SYS_FORCE_INLINE void setPointOffset (GA_Size i, GA_Offset ptoff)
 
SYS_FORCE_INLINE GA_Index getPointIndex (GA_Size i) const
 
SYS_FORCE_INLINE UT_Vector3 getPos3 (GA_Size i) const
 
SYS_FORCE_INLINE UT_Vector3D getPos3D (GA_Size i) const
 
template<typename T >
UT_Vector3T< TgetPos3T (GA_Size i) const
 
SYS_FORCE_INLINE void setPos3 (GA_Size i, const UT_Vector3 &pos) const
 
SYS_FORCE_INLINE void setPos3 (GA_Size i, const UT_Vector3D &pos) const
 
SYS_FORCE_INLINE UT_Vector4 getPos4 (GA_Size i) const
 
SYS_FORCE_INLINE UT_Vector4D getPos4D (GA_Size i) const
 
SYS_FORCE_INLINE void setPos4 (GA_Size i, const UT_Vector4 &pos) const
 
SYS_FORCE_INLINE void setPos4 (GA_Size i, const UT_Vector4D &pos) const
 
GA_Range getVertexRange (bool harden=false) const
 Get a range of all the vertices accessed by the primitive. More...
 
GA_Range getPointRange (bool harden=false) const
 
bool isPointUsed (GA_Offset ptoff) const
 
void addPointRefToGroup (GA_PointGroup &grp) const
 
void edgeApply (GA_EdgeApplyFunc apply, void *data=nullptr) const
 
void edgeApplyIndex (GA_EdgeApplyIndexFunc apply, void *data=nullptr) const
 
bool findEdgePoints (GA_Offset ptoff0, GA_Offset ptoff1, GA_Size &vtx0, GA_Size &vtx1) const
 
virtual bool enlargeBoundingSphere (UT_BoundingSphere &b, const GA_Attribute *P) const
 
virtual void enlargePointBounds (UT_BoundingBox &box) const
 
void copyUnwiredForMerge (const GA_Primitive *src, const GA_MergeMap &map)
 
virtual bool saveSharedLoadData (UT_JSONWriter &w, GA_SaveMap &save, GA_GeometryIndex *geo_index) const
 
virtual bool registerSharedLoadData (int load_data_type, GA_SharedDataHandlePtr item)
 
const GA_IntrinsicManagergetIntrinsicManager () const
 
virtual void clearForDeletion ()
 
virtual int isVisible () const
 
virtual unsigned getNumSecondaryDetails () const
 A primitive may support any number of secondary details. More...
 
virtual const GA_DetailgetSecondaryDetail (GA_Index i) const
 
virtual GA_DetailgetSecondaryDetail (GA_Index i)
 
GA_Index getNumSecondary (GA_Index detail) const
 
const GA_PrimitivegetSecondaryByIndex (GA_Index detail, GA_Index i) const
 
GA_PrimitivegetSecondaryByIndex (GA_Index detail, GA_Index i)
 
const GA_PrimitivegetSecondaryByOffset (GA_Index detail, GA_Offset o) const
 
GA_PrimitivegetSecondaryByOffset (GA_Index detail, GA_Offset o)
 
SYS_FORCE_INLINE bool isVertexListTrivial () const
 
bool isPointListTrivial () const
 
template<typename FUNCTOR >
SYS_FORCE_INLINE void forEachVertex (FUNCTOR &&functor) const
 
template<typename FUNCTOR >
SYS_FORCE_INLINE void forEachPoint (FUNCTOR &&functor) const
 
bool vertexApply (bool(*apply)(GA_Offset vtx, void *), void *data=nullptr) const
 
virtual void stashed (bool beingstashed, GA_Offset offset=GA_INVALID_OFFSET)
 
virtual void flushCEWriteCaches ()
 Copy any modified caches from the GPU back to CPU cache. More...
 
virtual void flushCECaches ()
 
virtual void stealCEBuffers (const GA_Primitive *src)
 Steal the underlying CE buffer from the source. More...
 
virtual void swapVertexOffsets (const GA_Defragment &defrag)
 
GA_LocalIntrinsic findIntrinsic (const UT_StringRef &nm) const
 
GA_LocalIntrinsic findIntrinsic (GA_GlobalIntrinsic h) const
 
GA_GlobalIntrinsic findGlobalIntrinsic (GA_LocalIntrinsic h) const
 
const char * getIntrinsicName (GA_LocalIntrinsic h) const
 
GA_Size getIntrinsicTupleSize (GA_LocalIntrinsic h) const
 
bool getIntrinsicCollapseSingletons (GA_LocalIntrinsic h) const
 
GA_StorageClass getIntrinsicStorage (GA_LocalIntrinsic h) const
 
bool getIntrinsicReadOnly (GA_LocalIntrinsic h) const
 
const UT_OptionsgetIntrinsicOptions (GA_LocalIntrinsic h) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, UT_String &val) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, UT_StringArray &val) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, UT_OptionsHolder &val) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, UT_Array< UT_OptionsHolder > &val) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, int64 *v, GA_Size size) const
 
GA_Size getIntrinsic (GA_LocalIntrinsic h, fpreal64 *v, GA_Size sz) const
 
bool getIntrinsic (GA_LocalIntrinsic h, float &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, int &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector2 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector3 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector4 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix2 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix3 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix4 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, double &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, int64 &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector2D &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector3D &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Vector4D &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix2D &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix3D &v) const
 
bool getIntrinsic (GA_LocalIntrinsic h, UT_Matrix4D &v) const
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const char *value)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const UT_StringArray &value)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const char **val, GA_Size s)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const UT_OptionsHolder &value)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const UT_Array< UT_OptionsHolder > &value)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const UT_OptionsHolder *value, GA_Size s)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const int64 val)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const fpreal64 val)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const int64 *val, GA_Size sz)
 
GA_Size setIntrinsic (GA_LocalIntrinsic h, const fpreal64 *v, GA_Size sz)
 

Static Public Member Functions

static GEO_PrimPolybuild (GA_Detail *gdp, GA_Size nvertices, bool open=false, bool appendpts=true)
 
static GA_Offset buildBlock (GA_Detail *detail, const UT_Vector3 *points, const GA_Size npoints, const GEO_PolyCounts &polygonsizelist, const int *polygonpointnumbers, const bool closed=true)
 
static GA_Offset buildBlock (GA_Detail *detail, const UT_Vector3 *points, const GA_Size npoints, const GA_PolyCounts &polygonsizelist, const int *polygonpointnumbers, const bool closed=true)
 
static GA_Offset buildBlock (GA_Detail *detail, const GA_Offset startpt, const GA_Size npoints, const GEO_PolyCounts &polygonsizelist, const int *polygonpointnumbers, const bool closed=true)
 
static GA_Offset buildBlock (GA_Detail *detail, const GA_Offset startpt, const GA_Size npoints, const GA_PolyCounts &polygonsizelist, const int *polygonpointnumbers, const bool closed=true)
 
- Static Public Member Functions inherited from GEO_Face
static void unitToRealAdjust (float *uunit, float *ureal, int ulen, int num)
 
static fpreal getIndices (fpreal c, int &c1, int &c2, int max_index, int wrap)
 
static void fillBreakVals (const GA_Basis &ub, UT_Array< float > &uvals, int ustartidx, int ustopidx, int ulod, bool wrap)
 
static bool getUniformStep (const UT_Span< const float > &vals, int idx, int nextidx, fpreal &step)
 
- Static Public Member Functions inherited from GEO_Primitive
static GA_PrimCompat::TypeMask getPrimitiveMaskH9 (const char *maskstr)
 
- Static Public Member Functions inherited from GA_Primitive
static SYS_FORCE_INLINE
GA_PrimCompat::TypeMask 
primCompatMaskFromTypeId (int type_id)
 

Protected Member Functions

bool savePrivateH9 (std::ostream &, bool binary) const override
 
bool loadPrivateH9 (UT_IStream &) override
 
int findMaxDistance (float &maxdist2, int start, int stop) const
 
bool evaluateInteriorPointRefMap (GA_Offset result_vtx, GA_AttributeRefMap &hlist, fpreal u, fpreal v, fpreal w=0) const override
 
int evaluateInteriorPointV4 (UT_Vector4 &pos, fpreal u, fpreal v, fpreal w=0) const override
 
GA_Offset nextBoundaryVertex (unsigned int i) const
 
GA_Offset prevBoundaryVertex (unsigned int i) const
 
GEO_Primitiveconvert (GEO_ConvertParms &parms, GA_PointGroup *usedpts=0) override
 
GEO_PrimitiveconvertNew (GEO_ConvertParms &parms) override
 
int intersectRay (const UT_Vector3 &o, const UT_Vector3 &d, float tmax=1E17F, float tol=1E-12F, float *distance=0, UT_Vector3 *pos=0, UT_Vector3 *nml=0, int accurate=0, float *u=0, float *v=0, int ignoretrim=1) const override
 
int intersect (const GEO_Primitive &prim, UT_Array< GU_RayInfoHit > &hit_list, float tol=0.01F, int ignoretrim=1) const override
 
void clip (UT_Vector3 normal, float distance=0, GA_PrimitiveGroup *clipgrp=NULL) override
 
- Protected Member Functions inherited from GEO_Face
SYS_FORCE_INLINE GEO_Face (GA_Detail *d, GA_Offset offset=GA_INVALID_OFFSET)
 
 ~GEO_Face () override
 
template<typename T >
UT_Vector3T< TinternalComputeNormal () const
 
template<typename T >
fpreal internalCalcVolume (const UT_Vector3T< T > &refpt) const
 
template<typename T >
fpreal internalCalcArea () const
 
template<typename T >
fpreal internalCalcPerimeter () const
 
 GA_DECLARE_INTRINSICS (override)
 
bool validate () const override
 
GA_Size getMinVertexCount () const override
 
bool evaluatePointRefMap (GA_Offset result_vtx, GA_AttributeRefMap &vtxdata, fpreal u, fpreal v=0, uint du=0, uint dv=0) const override
 
int evaluatePointV4 (UT_Vector4 &pos, float u_unit, float=0, unsigned du=0, unsigned dv=0) const override
 
virtual bool evaluateRefMap (fpreal u, GA_Offset result_vtx, GA_AttributeRefMap &gah, int du=0, int uoffset=-1) const
 
virtual int evaluateV4 (float u, UT_Vector4 &pos, unsigned du=0, int uoffset=-1) const
 
virtual int subdivideRefMap (float u, GA_AttributeRefMap &map)
 
virtual int subdivideFloat (float u)
 
virtual int refineRefMap (float k, GA_AttributeRefMap &gah, int r=1)
 
virtual int refineInt (float k, int r=1)
 
- Protected Member Functions inherited from GEO_TriMesh
SYS_FORCE_INLINE GEO_TriMesh (GA_Detail *d, GA_Offset offset=GA_INVALID_OFFSET)
 
GA_Size multipleInsert (GA_Size where, GA_Size count, bool append_pointsss=true)
 
SYS_FORCE_INLINE GA_Offset vertexPoint (GA_Size i) const
 
void swapVertices (GA_Size i, GA_Size j)
 
bool evaluatePointRefMap (GA_Offset result_vertex, GA_AttributeRefMap &hlist, fpreal u, fpreal v, uint du, uint dv) const override
 
int evaluatePointV4 (UT_Vector4 &pos, float u, float v=0, unsigned du=0, unsigned dv=0) const override
 
bool evaluateBaryCenterRefMap (GA_Offset result_vertex, GA_AttributeRefMap &hlist) const override
 
GA_Offset releaseVertex (GA_Offset vtx) override
 
- Protected Member Functions inherited from GEO_Primitive
SYS_FORCE_INLINE GEO_Primitive (GA_Detail *d, GA_Offset offset=GA_INVALID_OFFSET)
 
 ~GEO_Primitive () override
 
- Protected Member Functions inherited from GA_Primitive
SYS_FORCE_INLINE GA_Primitive (GA_Detail &detail, GA_Offset offset=GA_INVALID_OFFSET)
 
void setNumVertices (GA_Size nvertices)
 
GA_Offset allocateVertex (GA_Offset point=GA_INVALID_OFFSET)
 allocateVertex() will call wireVertex() if the point given is not -1 More...
 
void destroyVertex (GA_Offset vertex)
 
void wireVertex (GA_Offset vertex, GA_Offset point)
 
void registerVertex (GA_Offset vertex)
 
SYS_FORCE_INLINE int64 getBaseMemoryUsage () const
 Report approximate memory usage for myVertexList for subclasses. More...
 
void countBaseMemory (UT_MemoryCounter &counter) const
 
void copyVertexListForMerge (const GA_OffsetListRef &src_vertices, const GA_MergeMap &map)
 

Static Protected Member Functions

static GA_PrimitiveFamilyMask buildFamilyMask ()
 
static
GA_IntrinsicManager::Registrar 
registerIntrinsics (GA_PrimitiveDefinition &defn)
 
- Static Protected Member Functions inherited from GEO_Face
static GA_PrimitiveFamilyMask buildFamilyMask ()
 
static GA_Offset buildBlock (GA_PrimitiveTypeId type, GA_Detail *detail, const GA_Offset startpt, const GA_Size npoints, const GEO_PolyCounts &facesizelist, const int *facepointnumbers, const bool closed=true)
 
static GA_Offset buildBlock (GA_PrimitiveTypeId type, GA_Detail *detail, const GA_Offset startpt, const GA_Size npoints, const GA_PolyCounts &facesizelist, const int *facepointnumbers, const bool closed=true)
 
- Static Protected Member Functions inherited from GEO_TriMesh
static GA_PrimitiveFamilyMask buildFamilyMask ()
 
static
GA_IntrinsicManager::Registrar 
registerIntrinsics (GA_PrimitiveDefinition &defn)
 
- Static Protected Member Functions inherited from GEO_Primitive
static
GA_IntrinsicManager::Registrar 
registerIntrinsics (GA_PrimitiveDefinition &defn)
 

Friends

class GU_PrimitiveFactory
 
std::ostream & operator<< (std::ostream &os, const GEO_PrimPoly &d)
 

Additional Inherited Members

- Public Types inherited from GEO_Primitive
using NormalComp = NormalCompT< float >
 
using NormalCompArray = NormalCompArrayT< float >
 
using NormalCompAttr = NormalCompAttrT< float >
 
using NormalCompBuffered = NormalCompBufferedT< float >
 
using NormalCompD = NormalCompT< double >
 
using NormalCompArrayD = NormalCompArrayT< double >
 
using NormalCompAttrD = NormalCompAttrT< double >
 
using NormalCompBufferedD = NormalCompBufferedT< double >
 
- Public Types inherited from GA_Primitive
enum  GA_DereferenceStatus { GA_DEREFERENCE_FAIL, GA_DEREFERENCE_OK, GA_DEREFERENCE_DEGENERATE, GA_DEREFERENCE_DESTROY }
 
- Static Public Attributes inherited from GEO_Primitive
static const UT_Array
< GA_AttribSaveDataH9 > & 
theEmptySaveAttribs
 Convience objects to pass as arguments to saveH9()/loadH9(). More...
 
- Protected Attributes inherited from GA_Primitive
GA_OffsetList myVertexList
 

Detailed Description

Examples:
SIM/SNOW_Solver.C, SOP/SOP_DualStar.C, and tetprim/GEO_PrimTetra.C.

Definition at line 25 of file GEO_PrimPoly.h.

Constructor & Destructor Documentation

SYS_FORCE_INLINE GEO_PrimPoly::GEO_PrimPoly ( GA_Detail d,
GA_Offset  offset = GA_INVALID_OFFSET 
)
inline

NOTE: The constructor should only be called from subclass constructors.

Definition at line 32 of file GEO_PrimPoly.h.

SYS_FORCE_INLINE GEO_PrimPoly::GEO_PrimPoly ( GA_Detail gdp,
GA_Offset  offset,
const GA_OffsetListRef vertex_list 
)
inline

This constructor is for making a representation of a polygon on the stack, so that you can call GU_PrimPoly functions on the polygon without needing the detail to allocate one.

Definition at line 40 of file GEO_PrimPoly.h.

Member Function Documentation

GA_Size GEO_PrimPoly::appendVertex ( GA_Offset  ptoff)
overridevirtual
int GEO_PrimPoly::attach ( const GEO_Face face,
int  blend = 1,
float  bias = .5f,
float  tolerance = 1.f,
int  = 0,
GA_PointGroup ptgroup = 0 
)
overridevirtual

Implements GEO_Face.

int GEO_PrimPoly::breakCount ( ) const
overridevirtual

Implements GEO_Face.

static GEO_PrimPoly* GEO_PrimPoly::build ( GA_Detail gdp,
GA_Size  nvertices,
bool  open = false,
bool  appendpts = true 
)
static

Builds a GEO_PrimPoly with nvertices vertices, and optionally adds a point to the detail for each vertex.

Examples:
SIM/SNOW_Solver.C, SOP/SOP_DualStar.C, and tetprim/GEO_PrimTetra.C.
static GA_Offset GEO_PrimPoly::buildBlock ( GA_Detail detail,
const UT_Vector3 points,
const GA_Size  npoints,
const GEO_PolyCounts polygonsizelist,
const int polygonpointnumbers,
const bool  closed = true 
)
static

Builds npoints new points with the specified positions, and then creates polygons that use those points, as dictated by polygonsizelist and polygonpointnumbers, in parallel. polygonpointnumbers lists the numbers of the points used by each polygon, relative to the first point created by this method. The offset of the first polygon is returned, and the rest are at consecutive offsets. All polygonpointnumbers must be between 0 (inclusive) and npoints (exclusive).

NOTE: It's not strictly necessary that the polygons being created use all of the points created.

Examples:
SOP/SOP_BrushHairLen.C.
static GA_Offset GEO_PrimPoly::buildBlock ( GA_Detail detail,
const UT_Vector3 points,
const GA_Size  npoints,
const GA_PolyCounts polygonsizelist,
const int polygonpointnumbers,
const bool  closed = true 
)
static

Builds npoints new points with the specified positions, and then creates polygons that use those points, as dictated by polygonsizelist and polygonpointnumbers, in parallel. polygonpointnumbers lists the numbers of the points used by each polygon, relative to the first point created by this method. The offset of the first polygon is returned, and the rest are at consecutive offsets. All polygonpointnumbers must be between 0 (inclusive) and npoints (exclusive).

NOTE: It's not strictly necessary that the polygons being created use all of the points created.

static GA_Offset GEO_PrimPoly::buildBlock ( GA_Detail detail,
const GA_Offset  startpt,
const GA_Size  npoints,
const GEO_PolyCounts polygonsizelist,
const int polygonpointnumbers,
const bool  closed = true 
)
inlinestatic

Builds polygons using the specified range of point offsets, as dictated by polygonsizelist and polygonpointnumbers, in parallel. polygonpointnumbers lists the offsets of the points used by each polygon MINUS startpt, i.e. they are offsets relative to startpt, not indices relative to startpt. The offset of the first polygon is returned, and the rest are at consecutive offsets. All polygonpointnumbers must be between 0 (inclusive) and npoints (exclusive).

NOTE: Existing primitives are allowed to be using the points in the specified range already, and the polygons being created do not need to use all of the points in the range. However, these cases may impact performance.

Definition at line 179 of file GEO_PrimPoly.h.

static GA_Offset GEO_PrimPoly::buildBlock ( GA_Detail detail,
const GA_Offset  startpt,
const GA_Size  npoints,
const GA_PolyCounts polygonsizelist,
const int polygonpointnumbers,
const bool  closed = true 
)
inlinestatic

Builds polygons using the specified range of point offsets, as dictated by polygonsizelist and polygonpointnumbers, in parallel. polygonpointnumbers lists the offsets of the points used by each polygon MINUS startpt, i.e. they are offsets relative to startpt, not indices relative to startpt. The offset of the first polygon is returned, and the rest are at consecutive offsets. All polygonpointnumbers must be between 0 (inclusive) and npoints (exclusive).

NOTE: Existing primitives are allowed to be using the points in the specified range already, and the polygons being created do not need to use all of the points in the range. However, these cases may impact performance.

Definition at line 196 of file GEO_PrimPoly.h.

static GA_PrimitiveFamilyMask GEO_PrimPoly::buildFamilyMask ( )
inlinestaticprotected

Definition at line 247 of file GEO_PrimPoly.h.

void GEO_PrimPoly::clip ( UT_Vector3  normal,
float  distance = 0,
GA_PrimitiveGroup clipgrp = NULL 
)
inlineoverrideprotectedvirtual

Reimplemented from GEO_Primitive.

Reimplemented in GU_PrimPoly.

Definition at line 323 of file GEO_PrimPoly.h.

void GEO_PrimPoly::computeInteriorPointWeights ( UT_Array< GA_Offset > &  vtxlist,
UT_Array< float > &  weightlist,
fpreal  u,
fpreal  v,
fpreal  w 
) const
finaloverridevirtual

Finds the weightings of the vertices that will compute an interior point given the u,v,w coordinates. The offsets are into the gdp's vertex list, not indices into this primitive's vertex list. Weights are normalized. Note this cannot be used to recover the Position as it often has special case logic (as in spheres, or rational splines), in those cases use evaluateInteriorPoint(UT_Vector4 &pos, ...) It has the advantage over the other evaluateInteriorPoints in that it allows you to avoid creating any temporary vertices. Behaviour for non-sublcassed types is to return the 0th vertex.

Reimplemented from GEO_Face.

GEO_Primitive* GEO_PrimPoly::convert ( GEO_ConvertParms parms,
GA_PointGroup usedpts = 0 
)
inlineoverrideprotectedvirtual

Implements GEO_Primitive.

Reimplemented in GU_PrimPoly.

Definition at line 291 of file GEO_PrimPoly.h.

GEO_Primitive* GEO_PrimPoly::convertNew ( GEO_ConvertParms parms)
inlineoverrideprotectedvirtual

Implements GEO_Primitive.

Reimplemented in GU_PrimPoly.

Definition at line 298 of file GEO_PrimPoly.h.

void GEO_PrimPoly::countMemory ( UT_MemoryCounter counter) const
overridevirtual

Count memory usage using a UT_MemoryCounter in order to count shared memory correctly. NOTE: This should always include sizeof(*this).

Reimplemented from GA_Primitive.

int GEO_PrimPoly::deleteVertex ( GA_Size  num)
overridevirtual

Reimplemented from GEO_TriMesh.

int GEO_PrimPoly::evaluateBreakpoint ( int  uidx,
UT_Vector4 pos,
int  du = 0 
) const
overridevirtual

Implements GEO_Face.

bool GEO_PrimPoly::evaluateInteriorPointRefMap ( GA_Offset  result_vtx,
GA_AttributeRefMap hlist,
fpreal  u,
fpreal  v,
fpreal  w = 0 
) const
overrideprotectedvirtual

Reimplemented from GEO_Primitive.

int GEO_PrimPoly::evaluateInteriorPointV4 ( UT_Vector4 pos,
fpreal  u,
fpreal  v,
fpreal  w = 0 
) const
overrideprotectedvirtual

Reimplemented from GEO_Primitive.

int GEO_PrimPoly::findMaxDistance ( float maxdist2,
int  start,
int  stop 
) const
protected
void GEO_PrimPoly::flipEdge ( GEO_PrimPoly that,
GA_Size  i,
GA_Size  j,
GA_ElementWranglerCache wranglers 
)

Flips a shared edge of two triangles | j+2 j+2 i+1 | / \ /|\ | / \ / | \ | / that\ / t|t \ | j----—j+1 flips to j h|h i | i+1\ this/i \ a|i / | \ / |s/ | \ / |/ | i+2 j+1 i+2 |

i and j are indices into this and that, respectively, and are on opposite ends of the common edge, which is (i, i+1) in this and (j, j+1) in the opposite direction in that. The vertex i+1 in this is moved to where j+2 is in that. The vertex j+1 in that is moved to where i+2 is in this. NOTE: Vertex attributes will be copied from j+2 onto i+1, and from i+2 onto j+1. NOTE: The two triangles must be in the same detail.

void GEO_PrimPoly::getAdjacentBoundaryVertices ( GA_Offset  vtx,
GA_Offset prev_vtx,
GA_Offset next_vtx 
) const
overridevirtual

Return the next and previous vertex on the "boundary" of the primitive (as understood by the primitive) relative to a given vertex. These are needed to maintain half-edge topology attributes. They must be implemented for primitives that realize a notion of a boundary composed of one or more closed cycles of vertices if we want to be able to use hedges to quickly move from such a primitive to another sharing an edge with it. A GA_INVALID_OFFSET for prev_vtx or next_vtx means that either the primitive doesn't care about hedges, the input vertex is not a boundary vertex in the primitive (or not a vertex at all), or vtx is at an end of a boundary (e.g. open polys).

Reimplemented from GA_Primitive.

const GA_PrimitiveJSON* GEO_PrimPoly::getJSON ( ) const
overridevirtual

This method returns the JSON interface for saving/loading the primitive If the method returns a NULL pointer, then the primitive will not be saved to geometry files (and thus cannot be loaded).

Implements GA_Primitive.

int64 GEO_PrimPoly::getMemoryUsage ( ) const
overridevirtual

Report approximate memory usage.

Reimplemented from GA_Primitive.

unsigned GEO_PrimPoly::getOrder ( ) const
overridevirtual

Implements GEO_Face.

const GA_PrimitiveDefinition& GEO_PrimPoly::getTypeDef ( ) const
inlineoverridevirtual

Implements GA_Primitive.

Definition at line 44 of file GEO_PrimPoly.h.

GA_Size GEO_PrimPoly::insertVertex ( GA_Offset  ptoff,
GA_Size  where = 0 
)
overridevirtual

Reimplemented from GEO_TriMesh.

int GEO_PrimPoly::intersect ( const GEO_Primitive prim,
UT_Array< GU_RayInfoHit > &  hit_list,
float  tol = 0.01F,
int  ignoretrim = 1 
) const
inlineoverrideprotectedvirtual

Implements GEO_Face.

Reimplemented in GU_PrimPoly.

Definition at line 315 of file GEO_PrimPoly.h.

int GEO_PrimPoly::intersectRay ( const UT_Vector3 o,
const UT_Vector3 d,
float  tmax = 1E17F,
float  tol = 1E-12F,
float distance = 0,
UT_Vector3 pos = 0,
UT_Vector3 nml = 0,
int  accurate = 0,
float u = 0,
float v = 0,
int  ignoretrim = 1 
) const
inlineoverrideprotectedvirtual

Reimplemented from GEO_Primitive.

Reimplemented in GU_PrimPoly.

Definition at line 304 of file GEO_PrimPoly.h.

bool GEO_PrimPoly::isConvex ( float  tolerance = 0.0001F) const

Determine if the polygon is convex.

bool GEO_PrimPoly::isDegenerate ( ) const
overridevirtual

Is the primitive degenerate.

Reimplemented from GEO_Face.

bool GEO_PrimPoly::isPlanar ( float  tolerance = 0.0001F) const

Determine if the polygon is planar.

bool GEO_PrimPoly::loadPrivateH9 ( UT_IStream )
overrideprotectedvirtual

Implements GEO_Face.

int GEO_PrimPoly::loft ( int  newcount,
int  start = -1,
int  stop = -1 
)
overridevirtual

Implements GEO_Face.

GA_Offset GEO_PrimPoly::nextBoundaryVertex ( unsigned int  i) const
inlineprotected

Definition at line 279 of file GEO_PrimPoly.h.

GD_Face* GEO_PrimPoly::planar ( GD_Detail dgdp,
int  copyxy = 0 
) const
overridevirtual

Implements GEO_Face.

GA_Offset GEO_PrimPoly::prevBoundaryVertex ( unsigned int  i) const
inlineprotected

Definition at line 282 of file GEO_PrimPoly.h.

static GA_IntrinsicManager::Registrar GEO_PrimPoly::registerIntrinsics ( GA_PrimitiveDefinition defn)
inlinestaticprotected

All subclasses should call this method to register the curve intrinsics.

See Also
GA_IntrinsicManager

Definition at line 253 of file GEO_PrimPoly.h.

bool GEO_PrimPoly::savePrivateH9 ( std::ostream &  ,
bool  binary 
) const
overrideprotectedvirtual

Implements GEO_Face.

GA_Size GEO_PrimPoly::stealVertex ( GA_Offset  vtx,
GA_Offset  insert_before_vtx = GA_INVALID_OFFSET 
)
overridevirtual

Steal a vertex from its current primitive and insert it into our vertex list.

Parameters
vtxVertex to be stolen
insert_before_vtx(Optional) the vertex before which to insert the stolen vertex If unspecified (negative) or if the vertex doesn't exist, the stolen vertex is appended at the end of the vertex list.
Returns
The position at which vtx is inserted if successful, or -1 otherwise.

Reimplemented from GEO_TriMesh.

bool GEO_PrimPoly::supportsHedge ( ) const
inlineoverridevirtual

Primitives that implement getAdjacentBoundaryVertices must respond true to supportsHedge().

Reimplemented from GA_Primitive.

Definition at line 125 of file GEO_PrimPoly.h.

float GEO_PrimPoly::unitLengthToUnitDomain ( float  ulength,
float  tolerance = 1e-05F 
) const
overridevirtual

Reimplemented from GEO_Face.

float GEO_PrimPoly::unitToUnitLengthDomain ( float  uparm) const
overridevirtual

Reimplemented from GEO_Face.

int GEO_PrimPoly::unroll ( int  append_pts = 1)
overridevirtual

Reimplemented from GEO_Face.

int GEO_PrimPoly::warp ( float  u,
const UT_Vector3 delta,
GA_AttributeRefMap map,
float  sharpness = 0.0f,
float  bias = -1.0f 
)
overridevirtual

Implements GEO_Face.

Friends And Related Function Documentation

friend class GU_PrimitiveFactory
friend

Definition at line 338 of file GEO_PrimPoly.h.

std::ostream& operator<< ( std::ostream &  os,
const GEO_PrimPoly d 
)
friend

Definition at line 329 of file GEO_PrimPoly.h.


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