Range2d Class

Range box in xy plane

Extends

Implements

Methods

Name Description
constructor(lowX: number = Range2d._EXTREME_POSITIVE, lowY: number = Range2d._EXTREME_POSITIVE, highX: number = Range2d._EXTREME_NEGATIVE, highY: number = Range2d._EXTREME_NEGATIVE): Range2d    
clone(result?: Range2d): Range2d Return a clone of this range (or copy to optional result)  
cloneTranslated(shift: Readonly<WritableXAndY>, result?: Range2d): Range2d Return a copy, translated by adding shift components in all directions.  
containsPoint(point: Readonly<WritableXAndY>): boolean Test if a point is within the range.  
containsRange(other: Readonly<WritableLowAndHighXY>): boolean Test of other range is within this range  
containsXY(x: number, y: number): boolean Test if a point given as x,y is within the range  
corners3d(asLoop: boolean = false, z: number = 0): Point3d[] Return an array with the 4 corners.  
diagonal(result?: Vector2d): Vector2d Return the diagonal vector.  
diagonalFractionToPoint(fraction: number, result?: Point2d): Point2d Return the point at the specified fraction along the diagonal vector.  
distanceToPoint(point: Readonly<WritableXAndY>): number Return 0 if the point is within the range, otherwise the distance to the closest face or corner  
distanceToRange(other: Readonly<WritableLowAndHighXY>): number Return 0 if the point is within the range, otherwise the distance to the closest face or corner  
expandInPlace(delta: number): void Move all limits by a fixed amount.  
extendPoint(point: Readonly<WritableXAndY>): void Expand this range to include a point.  
extendRange(other: Readonly<WritableLowAndHighXY>): void Expand this range to include a range.  
extendTransformedXY(transform: Transform, x: number, y: number): void Expand this range to include a point given by x,y  
extendXY(x: number, y: number): void Expand this range to include a point given by x,y  
fractionToPoint(fractionX: number, fractionY: number, result?: Point2d): Point2d Return a point given by fractional positions on the XY axes.  
freeze(): Readonly<Range2d> Freeze this instance (and its members) so it is read-only  
intersect(other: Readonly<WritableLowAndHighXY>, result?: Range2d): Range2d Return the intersection of ranges.  
intersectsRange(other: Readonly<WritableLowAndHighXY>): boolean Test if there is any intersection with other range  
isAlmostEqual(other: Range2d): boolean Returns true if this and other have equal low and high parts, or both are null ranges.  
maxAbs(): number Largest absolute value among any coordinates in the box corners.  
scaleAboutCenterInPlace(scaleFactor: number): void Move low and high points by scaleFactor around the center point.  
setFrom(other: Readonly<WritableLowAndHighXY>): void Copy all content from any other that has low and high xy data.  
setFromJSON(json: Range2dProps): void Treat any array of numbers as numbers to be inserted !!!  
setNull(): void Reset the low and high to null range state.  
setXY(x: number, y: number): void Set low and hight to a single xy value.  
toFloat64Array(): Float64Array Flatten the low and high coordinates of this instance into an array of 4 doubles  
toJSON(): Range2dProps Return json array with two points as produced by Point2d.toJSON  
union(other: Readonly<WritableLowAndHighXY>, result?: Range2d): Range2d Return the union of ranges.  
worldToLocal(point: Point2d, result?: Point2d): undefined | Point2d Return fractional coordinates of point within the range.  
xLength(): number Length of the box in the x direction  
yLength(): number Length of the box in the y direction  
createArray<T extends Range2d<T>>(points: Point2d[], result?: T): T Static Create a range around an array of points.  
createFrom<T extends Range2d<T>>(other: Readonly<WritableLowAndHighXY>, result?: T): T Static Create a new Range2d from any other that has low and high xy data.  
createNull<T extends Range2d<T>>(result?: T): T Static Create a range with no content.  
createXY<T extends Range2d<T>>(x: number, y: number, result?: T): T Static Create a single point box  
createXYXY<T extends Range2d<T>>(xA: number, yA: number, xB: number, yB: number, result?: T): T Static Create a box with 2 pairs of xy candidates.  
createXYXYOrCorrectToNull<T extends Range2d<T>>(xA: number, yA: number, xB: number, yB: number, result?: T): T Static Create a box with 2 pairs of xy candidates.  
createXYXYXY<T extends Range2d<T>>(xA: number, yA: number, xB: number, yB: number, xC: number, yC: number, result?: T): T Static Create a box with 3 pairs of xy candidates.  
fromArrayBuffer<T extends Range2d<T>>(buffer: ArrayBuffer): T Static Construct a Range2d from an un-typed array.  
fromFloat64Array<T extends Range2d<T>>(f64: Float64Array): T Static Construct a Range2d from an array of double-precision values  
fromJSON<T extends Range2d<T>>(json?: Range2dProps): T Static Use setFromJSON to parse json into a new Range2d instance.  
isNull(range: Readonly<WritableLowAndHighXY>): boolean Static Test if the box has high strictly less than low for any of x,y, condition.  
toFloat64Array(val: Readonly<WritableLowAndHighXY>): Float64Array Static Flatten the low and high coordinates of any json object with low.x ..  

Inherited methods

Name Inherited from Description
coordinateToRangeAbsoluteDistance(x: number, low: number, high: number): number Static RangeBase Given a coordinate and pair of range limits, return the smallest distance to the range.
isExtremePoint2d(xy: Point2d): boolean Static RangeBase Return true if either of x,y is outside the range `[_EXTREME_NEGATIVE, _EXTREME_POSITIVE]'
isExtremePoint3d(xyz: Point3d): boolean Static RangeBase Return true if any x or y or z is outside the range `[_EXTREME_NEGATIVE, _EXTREME_POSITIVE]'
isExtremeValue(x: number): boolean Static RangeBase Return true if x is outside the range `[_EXTREME_NEGATIVE, _EXTREME_POSITIVE]'
multiplyIfPositive(q: number, factor: number, defaultValue: number = 0.0): number Static RangeBase If a > 0, return (extrapolationFactor * a); otherwise return defaultValue
npcScaleFactor(low: number, high: number): number ProtectedStatic RangeBase Return 0 if high<= low, otherwise 1/(high-low) for use in fractionalizing
rangeToRangeAbsoluteDistance(lowA: number, highA: number, lowB: number, highB: number): number Static RangeBase Return the min absolute distance from any point of [lowA,highA]' to any point of [lowB,highB]'.

Properties

Name Type Description
center Accessor ReadOnly Point2d Return the midpoint of the diagonal.  
high Point2d High point coordinates.  
isAlmostZeroX Accessor ReadOnly boolean Test if the x direction size is nearly zero  
isAlmostZeroY Accessor ReadOnly boolean Test if the y direction size is nearly zero  
isNull Accessor ReadOnly boolean Test if the box has high<low for any of x,y, condition.  
isSinglePoint Accessor ReadOnly boolean Test of the range contains a single point.  
low Point2d Low point coordinates.  
xHigh Accessor ReadOnly number Return the high x coordinate  
xLow Accessor ReadOnly number Return the low x coordinate  
yHigh Accessor ReadOnly number Return the high y coordinate  
yLow Accessor ReadOnly number Return the low y coordinate  

Inherited properties

Name Type Inherited from Description
_EXTREME_NEGATIVE ProtectedStaticReadonly number RangeBase Number considered to be impossibly negative for a coordinate in a range.
_EXTREME_POSITIVE ProtectedStaticReadonly number RangeBase Number considered impossibly large possibly for a coordinate in a range.

Defined in

Last Updated: 20 April, 2024