tolerance blob for various stroking methods.
- Across many applications, the critical concepts are: chordTol, angleTol, maxEdgeLength
- Chord error is an distance measured from a curve or facet to its approximating stroke or facet.
- angle is the angle between two contiguous strokes or across a facet edge.
- maxEdgeLength is the length of a stroke or a edge of a facet.
It is rare for all three to be active at once:
- Nearly all stroke and facet use cases will apply an angle tolerance.
- For curves, 15 degrees is typical
- For facets, 22.5 degrees is typical.
- Halving the angle tolerance will (roughly) make curves get twice as many strokes, and surfaces get 4 times as many facets.
- The angle tolerance has the useful property that its effect is independent of scale of that data. If data is suddenly scaled into millimeters rather than meters, the facet counts remain the same.
- When creating output for devices such as 3D printing will want a chord tolerance.
- For graphics display, use an angle tolerance of around 15 degrees and an chord tolerance which is the size of several pixels.
- Analysis meshes (e.g. Finite Elements) commonly need to apply maxEdgeLength.
- Using maxEdgeLength for graphics probably produces too many facets. For example, it causes long cylinders to get many nearly-square facets instead of the small number of long quads usually used for graphics.
- Facet tolerances are, as the Pirates' Code, guidelines, not absolute rules. Facet and stroke code may ignore tolerances in awkward situations.
- If multiple tolerances are in effect, the actual count will usually be based on the one that demands the most strokes or facets, unless it is so high that it violates some upper limit on the number of facets on an arc or a section of a curve.
|applyAngleTol(minCount: number, sweepRadians: number, defaultStepRadians: number): number||return stroke count which is the larger of the existing count or count needed for angle condition for given sweepRadians|
|applyChordTol(minCount: number, radius: number, sweepRadians: number): number||return stroke count which is the larger of existing count or count needed for circular arc chord tolerance condition.|
|applyChordTolToLengthAndRadians(minCount: number, length: number, sweepRadians: number): number||return stroke count which is the larger of existing count or count needed for circular arc chord tol with given arc length and radians|
|applyMaxEdgeLength(minCount: number, totalLength: number): number||return stroke count which is the larger of the minCount or count needed for edge length condition.|
|applyMinStrokesPerPrimitive(minCount: number): number||return stroke count which is the larger of existing count or
|applyTolerancesToArc(radius: number, sweepRadians: number = ...): number||Determine a stroke count for a (partial) circular arc of given radius.|
|clone(): StrokeOptions||Return a deep clone|
|applyAngleTol(options: undefined | StrokeOptions, minCount: number, sweepRadians: number, defaultStepRadians?: number): number Static||return stroke count which is the larger of minCount and the count required to turn sweepRadians, using tolerance from the options.|
|applyMaxEdgeLength(options: undefined | StrokeOptions, minCount: number, edgeLength: number): number Static||Return the number of strokes needed for given edgeLength curve.|
|createForCurves(): StrokeOptions Static||create
|createForFacets(): StrokeOptions Static||create
|angleTol||undefined | Angle||turning angle between strokes.|
|chordTol||undefined | number||distance from stroke to actual geometry|
|defaultCircleStrokes||number||default number of strokes for a circle.|
|hasAngleTol Accessor ReadOnly||boolean||ask if angleTol is specified|
|hasChordTol Accessor ReadOnly||boolean||ask if chordTol is specified|
|hasMaxEdgeLength Accessor ReadOnly||boolean||ask if maxEdgeLength is specified|
|maxEdgeLength||undefined | number||maximum length of a single stroke.|
|minStrokesPerPrimitive||undefined | number||minimum strokes on a primitive|
|needColors||undefined | boolean||optional color request flag|
|needConvexFacets||undefined | boolean||caller expects convex facets.|
|needNormals Accessor||boolean||Whether normals are requested|
|needParams Accessor||boolean||Whether params are requested.|
|needTwoSided Accessor||boolean||Whether twoSided is requested.|
|shouldTriangulate||boolean||whether or not to triangulate each added facet|
- curve/StrokeOptions.ts Line 36
Last Updated: 09 February, 2023