PolyfaceVisitor Interface

A PolyfaceVisitor manages data while walking through facets.

  • The polyface visitor holds data for one facet at a time.
  • The caller can request the position in the addressed polyfaceData as a "readIndex".
  • The readIndex values (as numbers) are not assumed to be sequential (i.e., they might be contiguous facet indices or the indexing scheme might have gaps at the whim of the particular PolyfaceVisitor implementation).

Extends

Implemented by

Methods

Name Description
clearArrays(): void Clear the contents of the data arrays.  
clientAuxIndex(i: number): number Return the aux data index of vertex i within the currently loaded facet.  
clientColorIndex(i: number): number Return the color index of vertex i within the currently loaded facet.  
clientNormalIndex(i: number): number Return the normal index of vertex i within the currently loaded facet.  
clientParamIndex(i: number): number Return the param index of vertex i within the currently loaded facet.  
clientPointIndex(i: number): number Return the point index of vertex i within the currently loaded facet.  
clientPolyface(): undefined | Polyface Return the client polyface.  
currentReadIndex(): number Return the readIndex of the currently loaded facet.  
getVisitableFacetCount(): number Optional Return the number of facets this visitor is able to visit.  
moveToNextFacet(): boolean Load data for the next facet.  
moveToReadIndex(index: number): boolean Load data for the facet with given index.  
pushDataFrom(other: PolyfaceVisitor, index: number): void Transfer data from a specified index of the other visitor as new data in this visitor.  
pushInterpolatedDataFrom(other: PolyfaceVisitor, index0: number, fraction: number, index1: number): void Transfer interpolated data from the other visitor.  
reset(): void Reset to initial state for reading all facets sequentially with moveToNextFacet.  
setNumWrap(numWrap: number): void Set the number of vertices replicated in visitor arrays (both data and index arrays).  

Inherited methods

Name Inherited from Description
clone(): PolyfaceData Inherited PolyfaceData Return a deep clone.
compress(tolerance: numberGeometry.smallMetricDistance): void Inherited PolyfaceData Compress the instance by equating duplicate data.
copyNormalTo(i: number, dest: Vector3d): void Inherited PolyfaceData Copy the contents (not pointer) of normal[i] into dest.
copyParamTo(i: number, dest: Point2d): void Inherited PolyfaceData Copy the contents (not pointer) of param[i] into dest.
copyPointTo(i: number, dest: Point3d): void Inherited PolyfaceData Copy the contents (not pointer) of point[i] into dest.
edgeIndexToEdgeMateIndex(k: number): undefined | number Inherited PolyfaceData Dereference the edgeMateIndex array.
gatherIndexedData(other: PolyfaceData, index0: number, index1: number, numWrap: number): void Inherited PolyfaceData Copy data from other to this.
getColor(i: number): number Inherited PolyfaceData Return indexed color at index i.
getEdgeVisible(i: number): boolean Inherited PolyfaceData Return indexed visibility.
getNormal(i: number, result?: Vector3d): undefined | Vector3d Inherited PolyfaceData Return indexed normal at index i.
getParam(i: number, result?: Point2d): undefined | Point2d Inherited PolyfaceData Return indexed param at index i.
getPoint(i: number, result?: Point3d): undefined | Point3d Inherited PolyfaceData Return indexed point at index i.
isAlmostEqual(other: PolyfaceData): boolean Inherited PolyfaceData Test for equal indices and nearly equal coordinates.
isAlmostEqualParamIndexUV(i: number, u: number, v: number): boolean Inherited PolyfaceData Test if param at a index i matches the given uv
isValidEdgeIndex(value: number): boolean Inherited PolyfaceData Test if value is a valid index into the pointIndex array.
range(result?: Range3d, transform?: Transform): Range3d Inherited PolyfaceData Return the range of the point array (optionally transformed).
resizeAllArrays(length: number): void Inherited PolyfaceData Resize all data and index arrays to the specified length.
resizeAllDataArrays(length: number): void Inherited PolyfaceData Resize all data arrays to the specified length.
reverseIndices(facetStartIndex?: number[]): void Inherited PolyfaceData Reverse the indices for the specified facets in the index arrays (pointIndex, normalIndex, paramIndex, colorIndex,
reverseIndicesSingleFacet(facetIndex: number, facetStartIndex: number[]): void Inherited PolyfaceData Reverse the indices for the specified facet in the index arrays (pointIndex, normalIndex, paramIndex, colorIndex,
reverseNormals(): void Inherited PolyfaceData Scale all the normals by -1.
setTaggedNumericData(data: TaggedNumericData): void Inherited PolyfaceData Set the tagged geometry data.
trimAllIndexArrays(length: number): void Inherited PolyfaceData Trim all index arrays to the stated length.
tryTransformInPlace(transform: Transform): boolean Inherited PolyfaceData Apply a transform to the mesh data.

Inherited properties

Name Type Inherited from Description
auxData Inherited PolyfaceAuxData | undefined PolyfaceData Auxiliary data.
color Inherited number[] | undefined PolyfaceData Color values.
colorIndex Inherited number[] | undefined PolyfaceData Indices of colors at facet vertices.
edgeMateIndex Inherited undefined | number[] | undefined PolyfaceData Optional index array for moving "across an edge" to an adjacent facet.
edgeVisible Inherited boolean[] PolyfaceData Booleans indicating visibility of corresponding edges.
face Inherited FacetFaceData[] PolyfaceData Map from facet index to face data.
normal Inherited GrowableXYZArray | undefined PolyfaceData Coordinates of normal vectors (packed as numbers in a contiguous array).
normalIndex Inherited number[] | undefined PolyfaceData Indices of normals at facet vertices.
param Inherited GrowableXYArray | undefined PolyfaceData Coordinates of uv parameters (packed as numbers in a contiguous array).
paramIndex Inherited number[] | undefined PolyfaceData Indices of params at facet vertices.
point Inherited GrowableXYZArray PolyfaceData Coordinate data for points in the facets (packed as numbers in a contiguous array).
pointIndex Inherited number[] PolyfaceData Indices of points at facet vertices.
taggedNumericData Inherited TaggedNumericData | undefined PolyfaceData Tagged geometry data.
colorCount Accessor Inherited ReadOnly number PolyfaceData Get the color count
expectedClosure Accessor Inherited number PolyfaceData Get flag indicating if the mesh closure is unknown (0), open sheet (1), closed solid (2).
faceCount Accessor Inherited ReadOnly number PolyfaceData Get the number of faces.
* Note that a "face" is not a facet.
* A face is a subset of the Polyface's facets grouped for application purposes.
indexCount Accessor Inherited ReadOnly number PolyfaceData Get the index count. Note that the point array is always indexed, and index arrays all have the same length.
normalCount Accessor Inherited ReadOnly number PolyfaceData Get the normal count
paramCount Accessor Inherited ReadOnly number PolyfaceData Get the param count
pointCount Accessor Inherited ReadOnly number PolyfaceData Get the point count
requireColors Accessor Inherited ReadOnly boolean PolyfaceData Ask if colors are required in this mesh.
requireNormals Accessor Inherited ReadOnly boolean PolyfaceData Ask if normals are required in this mesh.
requireParams Accessor Inherited ReadOnly boolean PolyfaceData Ask if params are required in this mesh.
twoSided Accessor Inherited boolean PolyfaceData Boolean flag indicating if the facets are viewable from the back.
* Default value is true.
* Set to false only if the mesh is known to be a closed volume with outward normals,
indicating it is amenable to backface culling for improved display performance.

Defined in

Last Updated: 03 April, 2025