@itwin/core-geometry 4.0.0-dev.46 → 4.0.0-dev.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/clipping/ClipPrimitive.d.ts +0 -1
- package/lib/cjs/clipping/ClipPrimitive.d.ts.map +1 -1
- package/lib/cjs/clipping/ClipPrimitive.js +0 -1
- package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
- package/lib/cjs/clipping/ClipUtils.d.ts +19 -5
- package/lib/cjs/clipping/ClipUtils.d.ts.map +1 -1
- package/lib/cjs/clipping/ClipUtils.js +32 -5
- package/lib/cjs/clipping/ClipUtils.js.map +1 -1
- package/lib/cjs/curve/CurveCurve.d.ts +2 -5
- package/lib/cjs/curve/CurveCurve.d.ts.map +1 -1
- package/lib/cjs/curve/CurveCurve.js +2 -5
- package/lib/cjs/curve/CurveCurve.js.map +1 -1
- package/lib/cjs/curve/CurveCurveIntersectXY.js +1 -1
- package/lib/cjs/curve/CurveCurveIntersectXY.js.map +1 -1
- package/lib/cjs/curve/CurveCurveIntersectXYZ.js +1 -1
- package/lib/cjs/curve/CurveCurveIntersectXYZ.js.map +1 -1
- package/lib/cjs/geometry3d/Matrix3d.d.ts +17 -4
- package/lib/cjs/geometry3d/Matrix3d.d.ts.map +1 -1
- package/lib/cjs/geometry3d/Matrix3d.js +18 -6
- package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.d.ts +0 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.d.ts.map +1 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js +0 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.d.ts +1 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js +1 -1
- package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
- package/lib/cjs/geometry3d/Transform.d.ts +159 -107
- package/lib/cjs/geometry3d/Transform.d.ts.map +1 -1
- package/lib/cjs/geometry3d/Transform.js +238 -137
- package/lib/cjs/geometry3d/Transform.js.map +1 -1
- package/lib/cjs/geometry3d/XYZProps.d.ts +22 -21
- package/lib/cjs/geometry3d/XYZProps.d.ts.map +1 -1
- package/lib/cjs/geometry3d/XYZProps.js +2 -1
- package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
- package/lib/cjs/polyface/PolyfaceBuilder.d.ts +7 -5
- package/lib/cjs/polyface/PolyfaceBuilder.d.ts.map +1 -1
- package/lib/cjs/polyface/PolyfaceBuilder.js +17 -7
- package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
- package/lib/esm/clipping/ClipPrimitive.d.ts +0 -1
- package/lib/esm/clipping/ClipPrimitive.d.ts.map +1 -1
- package/lib/esm/clipping/ClipPrimitive.js +0 -1
- package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
- package/lib/esm/clipping/ClipUtils.d.ts +19 -5
- package/lib/esm/clipping/ClipUtils.d.ts.map +1 -1
- package/lib/esm/clipping/ClipUtils.js +32 -5
- package/lib/esm/clipping/ClipUtils.js.map +1 -1
- package/lib/esm/curve/CurveCurve.d.ts +2 -5
- package/lib/esm/curve/CurveCurve.d.ts.map +1 -1
- package/lib/esm/curve/CurveCurve.js +2 -5
- package/lib/esm/curve/CurveCurve.js.map +1 -1
- package/lib/esm/curve/CurveCurveIntersectXY.js +1 -1
- package/lib/esm/curve/CurveCurveIntersectXY.js.map +1 -1
- package/lib/esm/curve/CurveCurveIntersectXYZ.js +1 -1
- package/lib/esm/curve/CurveCurveIntersectXYZ.js.map +1 -1
- package/lib/esm/geometry3d/Matrix3d.d.ts +17 -4
- package/lib/esm/geometry3d/Matrix3d.d.ts.map +1 -1
- package/lib/esm/geometry3d/Matrix3d.js +18 -6
- package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.d.ts +0 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.d.ts.map +1 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js +0 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndVectors.d.ts +1 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js +1 -1
- package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
- package/lib/esm/geometry3d/Transform.d.ts +159 -107
- package/lib/esm/geometry3d/Transform.d.ts.map +1 -1
- package/lib/esm/geometry3d/Transform.js +238 -137
- package/lib/esm/geometry3d/Transform.js.map +1 -1
- package/lib/esm/geometry3d/XYZProps.d.ts +22 -21
- package/lib/esm/geometry3d/XYZProps.d.ts.map +1 -1
- package/lib/esm/geometry3d/XYZProps.js +2 -1
- package/lib/esm/geometry3d/XYZProps.js.map +1 -1
- package/lib/esm/polyface/PolyfaceBuilder.d.ts +7 -5
- package/lib/esm/polyface/PolyfaceBuilder.d.ts.map +1 -1
- package/lib/esm/polyface/PolyfaceBuilder.js +17 -7
- package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
- package/package.json +3 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Transform.js","sourceRoot":"","sources":["../../../src/geometry3d/Transform.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module CartesianGeometry\r\n */\r\n\r\nimport { AxisOrder, BeJSONFunctions, Geometry } from \"../Geometry\";\r\nimport { Point4d } from \"../geometry4d/Point4d\";\r\nimport { Matrix3d } from \"./Matrix3d\";\r\nimport { Point2d } from \"./Point2dVector2d\";\r\nimport { Point3d, Vector3d, XYZ } from \"./Point3dVector3d\";\r\nimport { Range3d } from \"./Range\";\r\nimport { TransformProps, XAndY, XYAndZ } from \"./XYZProps\";\r\n\r\n/** A transform is an origin and a Matrix3d.\r\n *\r\n * * This describes a coordinate frame with\r\n * this origin, with the columns of the Matrix3d being the\r\n * local x,y,z axis directions.\r\n * * Beware that for common transformations (e.g. scale about point,\r\n * rotate around line, mirror across a plane) the \"fixed point\" that is used\r\n * when describing the transform is NOT the \"origin\" stored in the transform.\r\n * Setup methods (e.g createFixedPointAndMatrix, createScaleAboutPoint)\r\n * take care of determining the appropriate origin coordinates.\r\n * @public\r\n */\r\nexport class Transform implements BeJSONFunctions {\r\n // static (one per class) vars for temporaries in computation.\r\n // ASSUME any user of these vars needs them only within its own scope\r\n // ASSUME no calls to other methods that use the same scratch.\r\n // When Transform was in the same file with Point3d, this was initialized right here.\r\n // But when split, there is a load order issue, so it has to be initialized at point-of-use\r\n private static _scratchPoint: Point3d;\r\n private _origin: XYZ;\r\n private _matrix: Matrix3d;\r\n // Constructor accepts and uses POINTER to content .. no copy here.\r\n private constructor(origin: XYZ, matrix: Matrix3d) { this._origin = origin; this._matrix = matrix; }\r\n\r\n private static _identity?: Transform;\r\n /** The identity Transform. Value is frozen and cannot be modified. */\r\n public static get identity(): Transform {\r\n if (undefined === this._identity) {\r\n this._identity = Transform.createIdentity();\r\n this._identity.freeze();\r\n }\r\n\r\n return this._identity;\r\n }\r\n /** Freeze this instance (and its members) so it is read-only */\r\n public freeze(): Readonly<this> { this._origin.freeze(); this._matrix.freeze(); return Object.freeze(this); }\r\n /**\r\n * Copy contents from other Transform into this Transform\r\n * @param other source transform\r\n */\r\n public setFrom(other: Transform) { this._origin.setFrom(other._origin), this._matrix.setFrom(other._matrix); }\r\n /** Set this Transform to be an identity. */\r\n public setIdentity() { this._origin.setZero(); this._matrix.setIdentity(); }\r\n /** Set this Transform instance from flexible inputs:\r\n * * Any object (such as another Transform) that has `origin` and `matrix` members accepted by Point3d.setFromJSON and Matrix3d.setFromJSON\r\n * * An array of 3 number arrays, each with 4 entries which are rows in a 3x4 matrix.\r\n * * An array of 12 numbers, each block of 4 entries as a row 3x4 matrix.\r\n */\r\n public setFromJSON(json?: TransformProps | Transform): void {\r\n if (json) {\r\n if (json instanceof Object && (json as any).origin && (json as any).matrix) {\r\n this._origin.setFromJSON((json as any).origin);\r\n this._matrix.setFromJSON((json as any).matrix);\r\n return;\r\n }\r\n if (Geometry.isArrayOfNumberArray(json, 3, 4)) {\r\n const data = json as number[][];\r\n this._matrix.setRowValues(\r\n data[0][0], data[0][1], data[0][2],\r\n data[1][0], data[1][1], data[1][2],\r\n data[2][0], data[2][1], data[2][2]);\r\n this._origin.set(data[0][3], data[1][3], data[2][3]);\r\n return;\r\n }\r\n if (Geometry.isNumberArray(json, 12)) {\r\n const data = json as number[];\r\n this._matrix.setRowValues(\r\n data[0], data[1], data[2],\r\n data[4], data[5], data[6],\r\n data[8], data[9], data[10]);\r\n this._origin.set(data[3], data[7], data[11]);\r\n return;\r\n }\r\n }\r\n this.setIdentity();\r\n }\r\n /**\r\n * Test for near equality with other Transform. Comparison uses the isAlmostEqual methods on\r\n * the origin and matrix parts.\r\n * @param other Transform to compare to.\r\n */\r\n public isAlmostEqual(other: Readonly<Transform>): boolean { return this.origin.isAlmostEqual(other.origin) && this.matrix.isAlmostEqual(other.matrix); }\r\n\r\n /**\r\n * Test for near equality with other Transform. Comparison uses the isAlmostEqualAllowZRotation method of Matrix3d\r\n * the origin and matrix parts.\r\n * @param other Transform to compare to.\r\n */\r\n public isAlmostEqualAllowZRotation(other: Transform): boolean { return this._origin.isAlmostEqual(other._origin) && this._matrix.isAlmostEqualAllowZRotation(other._matrix); }\r\n\r\n /** Return a 3 by 4 matrix containing the rows of this Transform\r\n * * This transform's origin is the [3] entry of the json arrays\r\n */\r\n public toJSON(): TransformProps {\r\n return this.toRows();\r\n }\r\n\r\n /** Return a 3 by 4 matrix containing the rows of this Transform\r\n * * This transform's origin is the [3] entry of the json arrays\r\n */\r\n public toRows(): number[][] {\r\n return [\r\n [this._matrix.coffs[0], this._matrix.coffs[1], this._matrix.coffs[2], this._origin.x],\r\n [this._matrix.coffs[3], this._matrix.coffs[4], this._matrix.coffs[5], this._origin.y],\r\n [this._matrix.coffs[6], this._matrix.coffs[7], this._matrix.coffs[8], this._origin.z],\r\n ];\r\n }\r\n\r\n /** Return a new Transform initialized by `setFromJSON (json)` */\r\n public static fromJSON(json?: TransformProps): Transform {\r\n const result = Transform.createIdentity();\r\n result.setFromJSON(json);\r\n return result;\r\n }\r\n /** Copy the contents of this transform into a new Transform (or to the result, if specified). */\r\n public clone(result?: Transform): Transform {\r\n if (result) {\r\n result._matrix.setFrom(this._matrix);\r\n result._origin.setFrom(this._origin);\r\n return result;\r\n }\r\n return new Transform(\r\n Point3d.createFrom(this._origin),\r\n this._matrix.clone());\r\n }\r\n /** Return a copy of this Transform, modified so that its axes are rigid\r\n * * The first axis direction named in axisOrder is preserved\r\n * * The plane of the first and second directions is preserved, and its vector in the rigid matrix has positive dot product with the corresponding vector if the instance\r\n * * The third named column is the cross product of the first and second.\r\n */\r\n public cloneRigid(axisOrder: AxisOrder = AxisOrder.XYZ): Transform | undefined {\r\n const axes0 = Matrix3d.createRigidFromMatrix3d(this.matrix, axisOrder);\r\n if (!axes0)\r\n return undefined;\r\n return new Transform(this.origin.cloneAsPoint3d(), axes0);\r\n }\r\n /** Create a copy with the given origin and matrix captured as the Transform origin and Matrix3d. */\r\n public static createRefs(origin: XYZ | undefined, matrix: Matrix3d, result?: Transform): Transform {\r\n if (!origin)\r\n origin = Point3d.createZero();\r\n if (result) {\r\n result._origin = origin;\r\n result._matrix = matrix;\r\n return result;\r\n }\r\n return new Transform(origin, matrix);\r\n }\r\n /** Create a transform with complete contents given */\r\n public static createRowValues(\r\n qxx: number, qxy: number, qxz: number, ax: number,\r\n qyx: number, qyy: number, qyz: number, ay: number,\r\n qzx: number, qzy: number, qzz: number, az: number,\r\n result?: Transform): Transform {\r\n if (result) {\r\n result._origin.set(ax, ay, az);\r\n result._matrix.setRowValues(qxx, qxy, qxz, qyx, qyy, qyz, qzx, qzy, qzz);\r\n return result;\r\n }\r\n return new Transform(Point3d.create(ax, ay, az), Matrix3d.createRowValues(qxx, qxy, qxz, qyx, qyy, qyz, qzx, qzy, qzz));\r\n }\r\n /** Create a transform with all zeros.\r\n */\r\n public static createZero(result?: Transform): Transform {\r\n return Transform.createRowValues(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, result);\r\n }\r\n\r\n /**\r\n * create a Transform with translation provided by x,y,z parts.\r\n * @param x x part of translation\r\n * @param y y part of translation\r\n * @param z z part of translation\r\n * @param result optional result\r\n * @returns new or updated transform.\r\n */\r\n public static createTranslationXYZ(x: number = 0, y: number = 0, z: number = 0, result?: Transform): Transform {\r\n return Transform.createRefs(Vector3d.create(x, y, z), Matrix3d.createIdentity(), result);\r\n }\r\n /** Create a matrix with specified translation part.\r\n * @param XYZ x,y,z parts of the translation.\r\n * @returns new or updated transform.\r\n */\r\n public static createTranslation(translation: XYZ, result?: Transform): Transform {\r\n return Transform.createRefs(translation, Matrix3d.createIdentity(), result);\r\n }\r\n\r\n /** Return a reference to the matrix within the transform. (NOT a copy) */\r\n public get matrix(): Matrix3d { return this._matrix; }\r\n /** Return a reference to the origin within the transform. (NOT a copy) */\r\n public get origin(): XYZ { return this._origin; }\r\n\r\n /** return a (clone of) the origin part of the transform, as a Point3d */\r\n public getOrigin(): Point3d { return Point3d.createFrom(this._origin); }\r\n\r\n /** return a (clone of) the origin part of the transform, as a Vector3d */\r\n public getTranslation(): Vector3d { return Vector3d.createFrom(this._origin); }\r\n\r\n /** test if the transform has 000 origin and identity Matrix3d */\r\n public get isIdentity(): boolean {\r\n return this._matrix.isIdentity && this._origin.isAlmostZero;\r\n }\r\n /** Return an identity transform, optionally filling existing transform. */\r\n public static createIdentity(result?: Transform): Transform {\r\n if (result) {\r\n result._origin.setZero();\r\n result._matrix.setIdentity();\r\n return result;\r\n }\r\n return Transform.createRefs(Point3d.createZero(), Matrix3d.createIdentity());\r\n }\r\n /** Create by directly installing origin and matrix\r\n * this is a the appropriate construction when the columns of the matrix are coordinate axes of a local-to-global mapping\r\n * Note there is a closely related createFixedPointAndMatrix whose point input is the fixed point of the global-to-global transformation.\r\n */\r\n public static createOriginAndMatrix(origin: XYZ | undefined, matrix: Matrix3d | undefined, result?: Transform): Transform {\r\n if (result) {\r\n result._origin.setFromPoint3d(origin);\r\n result._matrix.setFrom(matrix);\r\n return result;\r\n }\r\n return Transform.createRefs(\r\n origin ? origin.cloneAsPoint3d() : Point3d.createZero(),\r\n matrix === undefined ? Matrix3d.createIdentity() : matrix.clone(), result);\r\n }\r\n /** Create by directly installing origin and columns of the matrix\r\n */\r\n public static createOriginAndMatrixColumns(origin: XYZ, vectorX: Vector3d, vectorY: Vector3d, vectorZ: Vector3d, result?: Transform): Transform {\r\n if (result)\r\n result.setOriginAndMatrixColumns(origin, vectorX, vectorY, vectorZ);\r\n else\r\n result = Transform.createRefs(Vector3d.createFrom(origin), Matrix3d.createColumns(vectorX, vectorY, vectorZ));\r\n return result;\r\n }\r\n /** Create by with matrix from Matrix3d.createRigidFromColumns.\r\n * * Has careful logic for building up optional result without allocations.\r\n */\r\n public static createRigidFromOriginAndColumns(origin: XYZ | undefined, vectorX: Vector3d, vectorY: Vector3d, axisOrder: AxisOrder, result?: Transform): Transform | undefined {\r\n const matrix = Matrix3d.createRigidFromColumns(vectorX, vectorY, axisOrder, result ? result._matrix : undefined);\r\n if (!matrix)\r\n return undefined;\r\n if (result) {\r\n // The matrix was already defined !!!\r\n result._origin.setFrom(origin);\r\n return result;\r\n }\r\n // cleanly capture the matrix and then the point ..\r\n result = Transform.createRefs(undefined, matrix);\r\n result._origin.setFromPoint3d(origin);\r\n return result;\r\n }\r\n\r\n /** Reinitialize by directly installing origin and columns of the matrix\r\n */\r\n public setOriginAndMatrixColumns(origin: XYZ | undefined, vectorX: Vector3d | undefined, vectorY: Vector3d | undefined, vectorZ: Vector3d | undefined) {\r\n if (origin !== undefined)\r\n this._origin.setFrom(origin);\r\n this._matrix.setColumns(vectorX, vectorY, vectorZ);\r\n }\r\n\r\n /** Create a transform with the specified matrix. Compute an origin (different from the given fixedPoint)\r\n * so that the fixedPoint maps back to itself.\r\n */\r\n public static createFixedPointAndMatrix(fixedPoint: XYAndZ | undefined, matrix: Matrix3d, result?: Transform): Transform {\r\n if (fixedPoint) {\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(fixedPoint, matrix, fixedPoint);\r\n return Transform.createRefs(origin, matrix.clone(), result);\r\n }\r\n return Transform.createRefs(undefined, matrix.clone());\r\n }\r\n /** Create a transform with the specified matrix, acting on any `pointX `via\r\n * `pointY = matrix * (pointX - pointA) + pointB`\r\n * so that the fixedPoint maps back to itself.\r\n */\r\n public static createMatrixPickupPutdown(matrix: Matrix3d, pointA: Point3d, pointB: Point3d, result?: Transform): Transform {\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(pointB, matrix, pointA);\r\n return Transform.createRefs(origin, matrix.clone(), result);\r\n }\r\n\r\n /** Create a Transform which leaves the fixedPoint unchanged and\r\n * scales everything else around it by a single scale factor.\r\n */\r\n public static createScaleAboutPoint(fixedPoint: Point3d, scale: number, result?: Transform): Transform {\r\n const matrix = Matrix3d.createScale(scale, scale, scale);\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(fixedPoint, matrix, fixedPoint);\r\n return Transform.createRefs(origin, matrix, result);\r\n }\r\n\r\n /** Transform the input 2d point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyPoint2d(source: XAndY, result?: Point2d): Point2d {\r\n return Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, source, result);\r\n }\r\n\r\n /** Transform the input 3d point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyPoint3d(point: XYAndZ, result?: Point3d): Point3d {\r\n return Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, point, result);\r\n }\r\n\r\n /** Transform the input object with x,y,z members */\r\n public multiplyXYAndZInPlace(point: XYAndZ) {\r\n return Matrix3d.xyzPlusMatrixTimesXYZInPlace(this._origin, this._matrix, point);\r\n }\r\n\r\n /** Transform the input point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyXYZ(x: number, y: number, z: number = 0, result?: Point3d): Point3d {\r\n return Matrix3d.xyzPlusMatrixTimesCoordinates(this._origin, this._matrix, x, y, z, result);\r\n }\r\n /** Multiply a specific row of the transform times xyz. Return the (number). */\r\n public multiplyComponentXYZ(componentIndex: number, x: number, y: number, z: number = 0): number {\r\n const coffs = this._matrix.coffs;\r\n const i0 = 3 * componentIndex;\r\n return this.origin.at(componentIndex) + coffs[i0] * x + coffs[i0 + 1] * y + coffs[i0 + 2] * z;\r\n }\r\n /** Multiply a specific row of the transform times (weighted!) xyzw. Return the (number). */\r\n public multiplyComponentXYZW(componentIndex: number, x: number, y: number, z: number, w: number): number {\r\n const coffs = this._matrix.coffs;\r\n const i0 = 3 * componentIndex;\r\n return this.origin.at(componentIndex) * w +\r\n coffs[i0] * x + coffs[i0 + 1] * y + coffs[i0 + 2] * z;\r\n }\r\n\r\n /** Transform the input homogeneous point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyXYZW(x: number, y: number, z: number, w: number, result?: Point4d): Point4d {\r\n return Matrix3d.xyzPlusMatrixTimesWeightedCoordinates(this._origin, this._matrix, x, y, z, w, result);\r\n }\r\n /** Transform the input homogeneous point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyXYZWToFloat64Array(x: number, y: number, z: number, w: number, result?: Float64Array): Float64Array {\r\n return Matrix3d.xyzPlusMatrixTimesWeightedCoordinatesToFloat64Array(this._origin, this._matrix, x, y, z, w, result);\r\n }\r\n\r\n /** Transform the input homogeneous point. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyXYZToFloat64Array(x: number, y: number, z: number, result?: Float64Array): Float64Array {\r\n return Matrix3d.xyzPlusMatrixTimesCoordinatesToFloat64Array(this._origin, this._matrix, x, y, z, result);\r\n }\r\n /** Multiply the transposed transform (as 4x4 with 0001 row) by Point4d given as xyzw.. Return as a new point or in the pre-allocated result (if result is given) */\r\n public multiplyTransposeXYZW(x: number, y: number, z: number, w: number, result?: Point4d): Point4d {\r\n const coffs = this._matrix.coffs;\r\n const origin = this._origin;\r\n return Point4d.create(\r\n x * coffs[0] + y * coffs[3] + z * coffs[6],\r\n x * coffs[1] + y * coffs[4] + z * coffs[7],\r\n x * coffs[2] + y * coffs[5] + z * coffs[8],\r\n x * origin.x + y * origin.y + z * origin.z + w,\r\n result);\r\n }\r\n\r\n /** for each point: replace point by Transform*point */\r\n public multiplyPoint3dArrayInPlace(points: Point3d[]) {\r\n let point;\r\n for (point of points)\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, point, point);\r\n }\r\n\r\n /** for each point: replace point by Transform*point */\r\n public multiplyPoint3dArrayArrayInPlace(chains: Point3d[][]) {\r\n for (const chain of chains)\r\n this.multiplyPoint3dArrayInPlace(chain);\r\n }\r\n /** Return product of the transform's inverse times a point. */\r\n public multiplyInversePoint3d(point: XYAndZ, result?: Point3d): Point3d | undefined {\r\n return this._matrix.multiplyInverseXYZAsPoint3d(\r\n point.x - this._origin.x,\r\n point.y - this._origin.y,\r\n point.z - this._origin.z,\r\n result);\r\n }\r\n /** Inverse transform the input homogeneous point.\r\n * * Return as a new point or in the optional result.\r\n * * returns undefined if the matrix part if this Transform is singular.\r\n */\r\n public multiplyInversePoint4d(weightedPoint: Point4d, result?: Point4d): Point4d | undefined {\r\n const w = weightedPoint.w;\r\n return this._matrix.multiplyInverseXYZW(\r\n weightedPoint.x - w * this.origin.x,\r\n weightedPoint.y - w * this.origin.y,\r\n weightedPoint.z - w * this.origin.z,\r\n w, result);\r\n }\r\n\r\n /** Return product of the transform's inverse times a point (point given as x,y,z) */\r\n public multiplyInverseXYZ(x: number, y: number, z: number, result?: Point3d): Point3d | undefined {\r\n return this._matrix.multiplyInverseXYZAsPoint3d(\r\n x - this._origin.x,\r\n y - this._origin.y,\r\n z - this._origin.z,\r\n result);\r\n }\r\n\r\n /**\r\n * * for each point: multiply transform * point\r\n * * if result is given, resize to match source and replace each corresponding pi\r\n * * if result is not given, return a new array.\r\n */\r\n public multiplyInversePoint3dArray(source: Point3d[], result?: Point3d[]): Point3d[] | undefined {\r\n if (!this._matrix.computeCachedInverse(true))\r\n return undefined;\r\n const originX = this.origin.x;\r\n const originY = this.origin.y;\r\n const originZ = this.origin.z;\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point3d.createZero);\r\n for (let i = 0; i < n; i++)\r\n this._matrix.multiplyInverseXYZAsPoint3d(\r\n source[i].x - originX,\r\n source[i].y - originY,\r\n source[i].z - originZ,\r\n result[i]);\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(this._matrix.multiplyInverseXYZAsPoint3d(\r\n p.x - originX,\r\n p.y - originY,\r\n p.z - originZ)!);\r\n\r\n return result;\r\n }\r\n /**\r\n * * for each point in source: multiply transformInverse * point in place in the point.\r\n * * return false if not invertible.\r\n */\r\n public multiplyInversePoint3dArrayInPlace(source: Point3d[]): boolean {\r\n if (!this._matrix.computeCachedInverse(true))\r\n return false;\r\n const originX = this.origin.x;\r\n const originY = this.origin.y;\r\n const originZ = this.origin.z;\r\n const n = source.length;\r\n for (let i = 0; i < n; i++)\r\n this._matrix.multiplyInverseXYZAsPoint3d(\r\n source[i].x - originX,\r\n source[i].y - originY,\r\n source[i].z - originZ,\r\n source[i]);\r\n return true;\r\n }\r\n /**\r\n * * Compute (if needed) the inverse of the matrix part, thereby ensuring inverse operations can complete.\r\n * * Return true if matrix inverse completes.\r\n * @param useCached If true, accept prior cached inverse if available.\r\n */\r\n public computeCachedInverse(useCached: boolean = true): boolean {\r\n return this._matrix.computeCachedInverse(useCached);\r\n }\r\n /**\r\n * * If destination has more values than source, remove the extras.\r\n * * If destination has fewer values, use the constructionFunction to create new ones.\r\n * @param source array\r\n * @param dest destination array, to be modified to match source length\r\n * @param constructionFunction function to call to create new entries.\r\n */\r\n // modify destination so it has non-null points for the same length as the source.\r\n // (ASSUME existing elements of dest are non-null, and that parameters are given as either Point2d or Point3d arrays)\r\n public static matchArrayLengths(source: any[], dest: any[], constructionFunction: () => any): number {\r\n const numSource = source.length;\r\n const numDest = dest.length;\r\n if (numSource > numDest) {\r\n for (let i = numDest; i < numSource; i++) {\r\n dest.push(constructionFunction());\r\n }\r\n } else if (numDest > numSource) {\r\n dest.length = numSource;\r\n }\r\n return numSource;\r\n }\r\n\r\n /**\r\n * * for each point: multiply transform * point\r\n * * if result is given, resize to match source and replace each corresponding pi\r\n * * if result is not given, return a new array.\r\n */\r\n public multiplyPoint2dArray(source: Point2d[], result?: Point2d[]): Point2d[] {\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point2d.createZero);\r\n for (let i = 0; i < n; i++)\r\n Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, source[i], result[i]);\r\n return result;\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, p));\r\n\r\n return result;\r\n }\r\n /**\r\n * * for each point: multiply transform * point\r\n * * if result is given, resize to match source and replace each corresponding pi\r\n * * if result is not given, return a new array.\r\n */\r\n public multiplyPoint3dArray(source: Point3d[], result?: Point3d[]): Point3d[] {\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point3d.createZero);\r\n for (let i = 0; i < n; i++)\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, source[i], result[i]);\r\n return result;\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, p));\r\n\r\n return result;\r\n }\r\n\r\n /** Multiply the vector by the Matrix3d part of the transform.\r\n *\r\n * * The transform's origin is not used.\r\n * * Return as new or result by usual optional result convention\r\n */\r\n public multiplyVector(vector: Vector3d, result?: Vector3d): Vector3d {\r\n return this._matrix.multiplyVector(vector, result);\r\n }\r\n\r\n/** Multiply the vector in place by the Matrix3d part of the transform.\r\n *\r\n * * The transform's origin is not used.\r\n */\r\n public multiplyVectorInPlace(vector: Vector3d): void {\r\n this._matrix.multiplyVectorInPlace(vector);\r\n}\r\n\r\n /** Multiply the vector (x,y,z) by the Matrix3d part of the transform.\r\n *\r\n * * The transform's origin is not used.\r\n * * Return as new or result by usual optional result convention\r\n */\r\n public multiplyVectorXYZ(x: number, y: number, z: number, result?: Vector3d): Vector3d {\r\n return this._matrix.multiplyXYZ(x, y, z, result);\r\n }\r\n /** multiply this Transform times other Transform.\r\n * ```\r\n * equation\r\n * \\begin{matrix}\r\n * \\text{`this` transform with matrix part }\\bold{A}\\text{ and translation }\\bold{a} & \\blockTransform{A}{a}\\\\\r\n * \\text{`other` transform with matrix part }\\bold{B}\\text{ and translation part }\\bold{b}\\text{ promoted to block transform} & \\blockTransform{B}{b} \\\\\r\n * \\text{product}& \\blockTransform{A}{a}\\blockTransform{B}{b}=\\blockTransform{AB}{Ab + a}\r\n * \\end{matrix}\r\n * ```\r\n * @param other right hand transform for multiplication.\r\n * @param result optional preallocated result to reuse.\r\n */\r\n public multiplyTransformTransform(other: Transform, result?: Transform) {\r\n if (!result)\r\n return Transform.createRefs(\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, other._origin),\r\n this._matrix.multiplyMatrixMatrix(other._matrix));\r\n result.setMultiplyTransformTransform(this, other);\r\n return result;\r\n }\r\n /**\r\n * multiply transformA * transformB, store to calling instance.\r\n * @param transformA left operand\r\n * @param transformB right operand\r\n */\r\n public setMultiplyTransformTransform(transformA: Transform, transformB: Transform): void {\r\n if (Transform._scratchPoint === undefined)\r\n Transform._scratchPoint = Point3d.create();\r\n Matrix3d.xyzPlusMatrixTimesXYZ(transformA._origin, transformA._matrix, transformB._origin, Transform._scratchPoint);\r\n this._origin.setFrom(Transform._scratchPoint);\r\n transformA._matrix.multiplyMatrixMatrix(transformB._matrix, this._matrix);\r\n }\r\n // [Q A][R 0] = [QR A]\r\n // [0 1][0 1] [0 1]\r\n /** multiply this Transform times other Matrix3d, with other considered to be a Transform with 0 translation.\r\n * ```\r\n * equation\r\n * \\begin{matrix}\r\n * \\text{`this` transform with matrix part }\\bold{A}\\text{ and translation }\\bold{b} & \\blockTransform{B}{b}\\\\\r\n * \\text{`other` matrix }\\bold{B}\\text{ promoted to block transform} & \\blockTransform{B}{0} \\\\\r\n * \\text{product}& \\blockTransform{A}{a}\\blockTransform{B}{0}=\\blockTransform{AB}{a}\r\n * \\end{matrix}\r\n * ```\r\n * @param other right hand Matrix3d for multiplication.\r\n * @param result optional preallocated result to reuse.\r\n */\r\n public multiplyTransformMatrix3d(other: Matrix3d, result?: Transform): Transform {\r\n if (!result)\r\n return Transform.createRefs(\r\n this._origin.cloneAsPoint3d(),\r\n this._matrix.multiplyMatrixMatrix(other));\r\n this._matrix.multiplyMatrixMatrix(other, result._matrix);\r\n result._origin.setFrom(this._origin);\r\n return result;\r\n }\r\n\r\n /**\r\n * Return the range of the transformed corners.\r\n * * The 8 corners are transformed individually.\r\n * * Note that if there is anything other than translation and principal axis scaling in the transform, the volume of the range rotation will increase.\r\n * * Hence to get a \"tight\" range on rotated geometry, a range computation must be made on the rotated geometry itself.\r\n */\r\n public multiplyRange(range: Range3d, result?: Range3d): Range3d {\r\n if (range.isNull)\r\n return range.clone(result);\r\n\r\n // snag current values to allow aliasing.\r\n const lowX = range.low.x;\r\n const lowY = range.low.y;\r\n const lowZ = range.low.z;\r\n const highX = range.high.x;\r\n const highY = range.high.y;\r\n const highZ = range.high.z;\r\n result = Range3d.createNull(result);\r\n result.extendTransformedXYZ(this, lowX, lowY, lowZ);\r\n result.extendTransformedXYZ(this, highX, lowY, lowZ);\r\n result.extendTransformedXYZ(this, lowX, highY, lowZ);\r\n result.extendTransformedXYZ(this, highX, highY, lowZ);\r\n\r\n result.extendTransformedXYZ(this, lowX, lowY, highZ);\r\n result.extendTransformedXYZ(this, highX, lowY, highZ);\r\n result.extendTransformedXYZ(this, lowX, highY, highZ);\r\n result.extendTransformedXYZ(this, highX, highY, highZ);\r\n return result;\r\n }\r\n /**\r\n * * Return a Transform which is the inverse of this transform.\r\n * * Return undefined if this Transform's matrix is singular.\r\n */\r\n public inverse(): Transform | undefined {\r\n const matrixInverse = this._matrix.inverse();\r\n if (!matrixInverse)\r\n return undefined;\r\n return Transform.createRefs(\r\n matrixInverse.multiplyXYZ(-this._origin.x, -this._origin.y, -this._origin.z),\r\n matrixInverse);\r\n }\r\n /** Initialize transforms that map each direction of a box (axis aligned) to `[0,1]`.\r\n * * The corner coordinates do _not_ need to be in order in any of the x,y,z directions.\r\n * * The npcToGlobalTransform (if supplied) maps 000 to the point named point000.\r\n * * The npcToGlobalTransform (if supplied) maps 11 to the point named point000.\r\n * * The globalToNpc transform is the inverse.\r\n * @param min the \"000\" corner of the box\r\n * @param max the \"111\" corner of the box\r\n * @param npcToGlobal (object created by caller, re-initialized here) transform that carries 01 coordinates into the min,max box.\r\n * @param globalToNpc (object created by caller, re-initialized here) transform that carries world coordinates into 01\r\n */\r\n public static initFromRange(min: Point3d, max: Point3d, npcToGlobal?: Transform, globalToNpc?: Transform) {\r\n const diag = max.minus(min);\r\n if (diag.x === 0.0) diag.x = 1.0;\r\n if (diag.y === 0.0) diag.y = 1.0;\r\n if (diag.z === 0.0) diag.z = 1.0;\r\n\r\n const rMatrix = new Matrix3d();\r\n if (npcToGlobal) {\r\n Matrix3d.createScale(diag.x, diag.y, diag.z, rMatrix);\r\n Transform.createOriginAndMatrix(min, rMatrix, npcToGlobal);\r\n }\r\n\r\n if (globalToNpc) {\r\n const origin = new Point3d(- min.x / diag.x, - min.y / diag.y, - min.z / diag.z);\r\n Matrix3d.createScale(1.0 / diag.x, 1.0 / diag.y, 1.0 / diag.z, rMatrix);\r\n Transform.createOriginAndMatrix(origin, rMatrix, globalToNpc);\r\n }\r\n }\r\n}\r\n"]}
|
|
1
|
+
{"version":3,"file":"Transform.js","sourceRoot":"","sources":["../../../src/geometry3d/Transform.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module CartesianGeometry\r\n */\r\n\r\nimport { AxisOrder, BeJSONFunctions, Geometry } from \"../Geometry\";\r\nimport { Point4d } from \"../geometry4d/Point4d\";\r\nimport { Matrix3d } from \"./Matrix3d\";\r\nimport { Point2d } from \"./Point2dVector2d\";\r\nimport { Point3d, Vector3d, XYZ } from \"./Point3dVector3d\";\r\nimport { Range3d } from \"./Range\";\r\nimport { TransformProps, XAndY, XYAndZ } from \"./XYZProps\";\r\n\r\n/**\r\n * A Transform consists of an origin and a Matrix3d. This describes a coordinate frame with this origin, with\r\n * the columns of the Matrix3d being the local x,y,z axis directions.\r\n * * The math for a Transform `T` consisting of a Matrix3d `M` and a Point3d `o` on a Vector3d `p` is: `Tp = M*p + o`.\r\n * In other words, `T` is a combination of two operations on `p`: the action of matrix multiplication, followed by a\r\n * translation. `Origin` is a traditional term for `o`, because `T` can be interpreted as a change of basis from the\r\n * global axes centered at the global origin, to a new set of axes centered at `o`.\r\n * * Beware that for common transformations (e.g. scale about point, rotate around an axis, mirror across a\r\n * plane) the \"fixed point\" that is used when describing the transform is NOT the \"origin\" stored in the\r\n * transform. Setup methods (e.g createFixedPointAndMatrix, createScaleAboutPoint) take care of determining\r\n * the appropriate origin coordinates.\r\n * @public\r\n */\r\nexport class Transform implements BeJSONFunctions {\r\n // static (one per class) vars for temporaries in computation.\r\n // ASSUME any user of these vars needs them only within its own scope\r\n // ASSUME no calls to other methods that use the same scratch.\r\n // When Transform was in the same file with Point3d, this was initialized right here.\r\n // But when split, there is a load order issue, so it has to be initialized at point-of-use\r\n private static _scratchPoint: Point3d;\r\n private _origin: XYZ;\r\n private _matrix: Matrix3d;\r\n // Constructor accepts and uses pointer to content (no copy is done here).\r\n private constructor(origin: XYZ, matrix: Matrix3d) {\r\n this._origin = origin;\r\n this._matrix = matrix;\r\n }\r\n private static _identity?: Transform;\r\n /** The identity Transform. Value is frozen and cannot be modified. */\r\n public static get identity(): Transform {\r\n if (undefined === this._identity) {\r\n this._identity = Transform.createIdentity();\r\n this._identity.freeze();\r\n }\r\n return this._identity;\r\n }\r\n /** Freeze this instance (and its members) so it is read-only */\r\n public freeze(): Readonly<this> {\r\n this._origin.freeze();\r\n this._matrix.freeze();\r\n return Object.freeze(this);\r\n }\r\n /**\r\n * Copy contents from other Transform into this Transform\r\n * @param other source transform\r\n */\r\n public setFrom(other: Transform) {\r\n this._origin.setFrom(other._origin);\r\n this._matrix.setFrom(other._matrix);\r\n }\r\n /** Set this Transform to be an identity. */\r\n public setIdentity() {\r\n this._origin.setZero();\r\n this._matrix.setIdentity();\r\n }\r\n /**\r\n * Set this Transform instance from flexible inputs:\r\n * * Any object (such as another Transform or TransformProps) that has `origin` and `matrix` members\r\n * accepted by `Point3d.setFromJSON` and `Matrix3d.setFromJSON`\r\n * * An array of 3 number arrays, each with 4 entries which are rows in a 3x4 matrix.\r\n * * An array of 12 numbers, each block of 4 entries as a row 3x4 matrix.\r\n * * If no input is provided, the identity Transform is returned.\r\n */\r\n public setFromJSON(json?: TransformProps | Transform): void {\r\n if (json) {\r\n if (json instanceof Object && (json as any).origin && (json as any).matrix) {\r\n this._origin.setFromJSON((json as any).origin);\r\n this._matrix.setFromJSON((json as any).matrix);\r\n return;\r\n }\r\n if (Geometry.isArrayOfNumberArray(json, 3, 4)) {\r\n const data = json as number[][];\r\n this._matrix.setRowValues(\r\n data[0][0], data[0][1], data[0][2],\r\n data[1][0], data[1][1], data[1][2],\r\n data[2][0], data[2][1], data[2][2]\r\n );\r\n this._origin.set(data[0][3], data[1][3], data[2][3]);\r\n return;\r\n }\r\n if (Geometry.isNumberArray(json, 12)) {\r\n const data = json as number[];\r\n this._matrix.setRowValues(\r\n data[0], data[1], data[2],\r\n data[4], data[5], data[6],\r\n data[8], data[9], data[10]\r\n );\r\n this._origin.set(data[3], data[7], data[11]);\r\n return;\r\n }\r\n }\r\n this.setIdentity();\r\n }\r\n /**\r\n * Test for near equality with `other` Transform. Comparison uses the `isAlmostEqual` methods on the `origin` and\r\n * `matrix` parts.\r\n * @param other Transform to compare to.\r\n */\r\n public isAlmostEqual(other: Readonly<Transform>): boolean {\r\n return this.origin.isAlmostEqual(other.origin) && this.matrix.isAlmostEqual(other.matrix);\r\n }\r\n /**\r\n * Test for near equality with `other` Transform. Comparison uses the `isAlmostEqual` methods on the `origin` part\r\n * and the `isAlmostEqualAllowZRotation` method on the `matrix` part.\r\n * @param other Transform to compare to.\r\n */\r\n public isAlmostEqualAllowZRotation(other: Transform): boolean {\r\n return this._origin.isAlmostEqual(other._origin) && this._matrix.isAlmostEqualAllowZRotation(other._matrix);\r\n }\r\n /**\r\n * Return a 3 by 4 matrix containing the rows of this Transform.\r\n * * The transform's origin coordinates are the last entries of the 3 json arrays\r\n */\r\n public toRows(): number[][] {\r\n return [\r\n [this._matrix.coffs[0], this._matrix.coffs[1], this._matrix.coffs[2], this._origin.x],\r\n [this._matrix.coffs[3], this._matrix.coffs[4], this._matrix.coffs[5], this._origin.y],\r\n [this._matrix.coffs[6], this._matrix.coffs[7], this._matrix.coffs[8], this._origin.z],\r\n ];\r\n }\r\n /**\r\n * Return a 3 by 4 matrix containing the rows of this Transform.\r\n * * The transform's origin coordinates are the last entries of the 3 json arrays\r\n */\r\n public toJSON(): TransformProps {\r\n return this.toRows();\r\n }\r\n /** Return a new Transform initialized by `Transform.setFromJSON` */\r\n public static fromJSON(json?: TransformProps): Transform {\r\n const result = Transform.createIdentity();\r\n result.setFromJSON(json);\r\n return result;\r\n }\r\n /** Copy the contents of `this` transform into a new Transform (or to the result, if specified). */\r\n public clone(result?: Transform): Transform {\r\n if (result) {\r\n result._matrix.setFrom(this._matrix);\r\n result._origin.setFrom(this._origin);\r\n return result;\r\n }\r\n return new Transform(\r\n Point3d.createFrom(this._origin),\r\n this._matrix.clone()\r\n );\r\n }\r\n /**\r\n * Return a modified copy of `this` Transform so that its `matrix` part is rigid (`origin` part is untouched).\r\n * * For details of how the matrix is modified to rigid, see documentation of `Matrix3d.axisOrderCrossProductsInPlace`\r\n */\r\n public cloneRigid(axisOrder: AxisOrder = AxisOrder.XYZ): Transform | undefined {\r\n const modifiedMatrix = Matrix3d.createRigidFromMatrix3d(this.matrix, axisOrder);\r\n if (!modifiedMatrix)\r\n return undefined;\r\n return new Transform(this.origin.cloneAsPoint3d(), modifiedMatrix);\r\n }\r\n /** Create a Transform with the given `origin` and `matrix`. */\r\n public static createRefs(origin: XYZ | undefined, matrix: Matrix3d, result?: Transform): Transform {\r\n if (!origin)\r\n origin = Point3d.createZero();\r\n if (result) {\r\n result._origin = origin;\r\n result._matrix = matrix;\r\n return result;\r\n }\r\n return new Transform(origin, matrix);\r\n }\r\n /** Create a Transform with complete contents given */\r\n public static createRowValues(\r\n qxx: number, qxy: number, qxz: number, ax: number,\r\n qyx: number, qyy: number, qyz: number, ay: number,\r\n qzx: number, qzy: number, qzz: number, az: number,\r\n result?: Transform\r\n ): Transform {\r\n if (result) {\r\n result._origin.set(ax, ay, az);\r\n result._matrix.setRowValues(qxx, qxy, qxz, qyx, qyy, qyz, qzx, qzy, qzz);\r\n return result;\r\n }\r\n return new Transform(\r\n Point3d.create(ax, ay, az),\r\n Matrix3d.createRowValues(qxx, qxy, qxz, qyx, qyy, qyz, qzx, qzy, qzz)\r\n );\r\n }\r\n /** Create a Transform with all zeros */\r\n public static createZero(result?: Transform): Transform {\r\n return Transform.createRowValues(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, result);\r\n }\r\n /**\r\n * Create a Transform with translation provided by x,y,z parts.\r\n * @param x x part of translation\r\n * @param y y part of translation\r\n * @param z z part of translation\r\n * @param result optional pre-allocated Transform\r\n * @returns new or updated transform\r\n */\r\n public static createTranslationXYZ(x: number = 0, y: number = 0, z: number = 0, result?: Transform): Transform {\r\n return Transform.createRefs(Vector3d.create(x, y, z), Matrix3d.createIdentity(), result);\r\n }\r\n /**\r\n * Create a Transform with specified `translation` part.\r\n * @param translation x,y,z parts of the translation\r\n * @param result optional pre-allocated Transform\r\n * @returns new or updated transform\r\n */\r\n public static createTranslation(translation: XYZ, result?: Transform): Transform {\r\n return Transform.createRefs(translation, Matrix3d.createIdentity(), result);\r\n }\r\n /** Return a reference (and NOT a copy) to the `matrix` part of the Transform. */\r\n public get matrix(): Matrix3d {\r\n return this._matrix;\r\n }\r\n /** Return a reference (and NOT a copy) to the `origin` part of the Transform. */\r\n public get origin(): XYZ {\r\n return this._origin;\r\n }\r\n /** return a (clone of) the `origin` part of the Transform, as a `Point3d` */\r\n public getOrigin(): Point3d {\r\n return Point3d.createFrom(this._origin);\r\n }\r\n /** return a (clone of) the `origin` part of the Transform, as a `Vector3d` */\r\n public getTranslation(): Vector3d {\r\n return Vector3d.createFrom(this._origin);\r\n }\r\n /** return a (clone of) the `matrix` part of the Transform, as a `Matrix3d` */\r\n public getMatrix(): Matrix3d {\r\n return this._matrix.clone();\r\n }\r\n /** test if the transform has `origin` = (0,0,0) and identity `matrix` */\r\n public get isIdentity(): boolean {\r\n return this._matrix.isIdentity && this._origin.isAlmostZero;\r\n }\r\n /** Create an identity transform */\r\n public static createIdentity(result?: Transform): Transform {\r\n if (result) {\r\n result._origin.setZero();\r\n result._matrix.setIdentity();\r\n return result;\r\n }\r\n return Transform.createRefs(Point3d.createZero(), Matrix3d.createIdentity());\r\n }\r\n /**\r\n * Create a Transform using the given `origin` and `matrix`.\r\n * * This is a the appropriate construction when the columns of the matrix are coordinate axes of a\r\n * local-to-world mapping.\r\n * * This function is a closely related to `createFixedPointAndMatrix` whose point input is the fixed point\r\n * of the world-to-world transformation.\r\n */\r\n public static createOriginAndMatrix(\r\n origin: XYZ | undefined, matrix: Matrix3d | undefined, result?: Transform\r\n ): Transform {\r\n if (result) {\r\n result._origin.setFromPoint3d(origin);\r\n result._matrix.setFrom(matrix);\r\n return result;\r\n }\r\n return Transform.createRefs(\r\n origin ? origin.cloneAsPoint3d() : Point3d.createZero(),\r\n matrix === undefined ? Matrix3d.createIdentity() : matrix.clone(),\r\n result\r\n );\r\n }\r\n /** Create a Transform using the given `origin` and columns of the `matrix`. If `undefined` zero is used. */\r\n public setOriginAndMatrixColumns(\r\n origin: XYZ | undefined, vectorX: Vector3d | undefined, vectorY: Vector3d | undefined, vectorZ: Vector3d | undefined\r\n ): void {\r\n if (origin !== undefined)\r\n this._origin.setFrom(origin);\r\n this._matrix.setColumns(vectorX, vectorY, vectorZ);\r\n }\r\n /** Create a Transform using the given `origin` and columns of the `matrix` */\r\n public static createOriginAndMatrixColumns(\r\n origin: XYZ, vectorX: Vector3d, vectorY: Vector3d, vectorZ: Vector3d, result?: Transform\r\n ): Transform {\r\n if (result)\r\n result.setOriginAndMatrixColumns(origin, vectorX, vectorY, vectorZ);\r\n else\r\n result = Transform.createRefs(Vector3d.createFrom(origin), Matrix3d.createColumns(vectorX, vectorY, vectorZ));\r\n return result;\r\n }\r\n /**\r\n * Create a Transform such that its `matrix` part is rigid.\r\n * * For details of how the matrix is created to be rigid, see documentation of `Matrix3d.createRigidFromColumns`\r\n */\r\n public static createRigidFromOriginAndColumns(\r\n origin: XYZ | undefined, vectorX: Vector3d, vectorY: Vector3d, axisOrder: AxisOrder, result?: Transform\r\n ): Transform | undefined {\r\n const matrix = Matrix3d.createRigidFromColumns(vectorX, vectorY, axisOrder, result ? result._matrix : undefined);\r\n if (!matrix)\r\n return undefined;\r\n if (result) {\r\n // result._matrix was already modified to become rigid via createRigidFromColumns\r\n result._origin.setFrom(origin);\r\n return result;\r\n }\r\n /**\r\n * We don't want to pass \"origin\" to createRefs because createRefs does not clone \"origin\" and use its reference.\r\n * That means if \"origin\" is changed via Transform at any point, the initial \"origin\" passed by the user is also\r\n * changed. To avoid that, we pass undefined to createRefs. This would cause createRefs to create a new \"origin\"\r\n * equals (0,0,0) which then we set it to the \"origin\" passed by user in the next line.\r\n */\r\n result = Transform.createRefs(undefined, matrix);\r\n result._origin.setFromPoint3d(origin);\r\n return result;\r\n }\r\n /**\r\n * Create a Transform with the specified `matrix`. Compute an `origin` (different from the given `fixedPoint`)\r\n * so that the `fixedPoint` maps back to itself. The returned Transform, transforms a point `p` to `M*p + (f - M*f)`\r\n * where `f` is the fixedPoint (i.e., `Tp = M*(p-f) + f`).\r\n */\r\n public static createFixedPointAndMatrix(\r\n fixedPoint: XYAndZ | undefined, matrix: Matrix3d, result?: Transform\r\n ): Transform {\r\n if (fixedPoint) {\r\n /**\r\n * if f is a fixed point, then Tf = M*f + o = f where M is the matrix and o is the origin.\r\n * we define the origin o = f - M*f. Therefore, Tf = Mf + o = M*f + (f - M*f) = f.\r\n */\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(fixedPoint, matrix, fixedPoint);\r\n return Transform.createRefs(origin, matrix.clone(), result);\r\n }\r\n return Transform.createRefs(undefined, matrix.clone());\r\n }\r\n /**\r\n * Create a transform with the specified `matrix` and points `a` and `b`. The returned Transform, transforms\r\n * point `p` to `M*(p-a) + b` (i.e., `Tp = M*(p-a) + b`) so transforms point `a` to 'b'.\r\n */\r\n public static createMatrixPickupPutdown(\r\n matrix: Matrix3d, a: Point3d, b: Point3d, result?: Transform\r\n ): Transform {\r\n // we define the origin o = b - M*a so Tp = M*p + o = M*p + (b - M*a) = M*(x-a) + b\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(b, matrix, a);\r\n return Transform.createRefs(origin, matrix.clone(), result);\r\n }\r\n /**\r\n * Create a Transform which leaves the fixedPoint unchanged and scales everything else around it by\r\n * a single scale factor. The returned Transform, transforms a point `p` to `M*p + (f - M*f)`\r\n * where `f` is the fixedPoint and M is the scale matrix (i.e., `Tp = M*(p-f) + f`).\r\n */\r\n public static createScaleAboutPoint(fixedPoint: Point3d, scale: number, result?: Transform): Transform {\r\n const matrix = Matrix3d.createScale(scale, scale, scale);\r\n /**\r\n * if f is a fixed point, then Tf = M*f + o = f where M is the matrix and o is the origin.\r\n * we define the origin o = f - M*f. Therefore, Tf = M*f + o = M*f + (f - M*f) = f.\r\n */\r\n const origin = Matrix3d.xyzMinusMatrixTimesXYZ(fixedPoint, matrix, fixedPoint);\r\n return Transform.createRefs(origin, matrix, result);\r\n }\r\n /** Transform the input 2d point. Return as a new point or in the pre-allocated result (if result is given). */\r\n public multiplyPoint2d(point: XAndY, result?: Point2d): Point2d {\r\n // Tx = Mx + o so we return Mx + o\r\n return Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, point, result);\r\n }\r\n /** Transform the input 3d point. Return as a new point or in the pre-allocated result (if result is given). */\r\n public multiplyPoint3d(point: XYAndZ, result?: Point3d): Point3d {\r\n // Tx = Mx + o so we return Mx + o\r\n return Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, point, result);\r\n }\r\n /** Transform the input 3d point in place (override the input point by the transformed point). */\r\n public multiplyXYAndZInPlace(point: XYAndZ): void {\r\n // Tx = Mx + o so we override x by Mx + o\r\n return Matrix3d.xyzPlusMatrixTimesXYZInPlace(this._origin, this._matrix, point);\r\n }\r\n /** Transform the input point. Return as a new point or in the pre-allocated result (if result is given). */\r\n public multiplyXYZ(x: number, y: number, z: number = 0, result?: Point3d): Point3d {\r\n // Tx = Mx + o so we return Mx + o\r\n return Matrix3d.xyzPlusMatrixTimesCoordinates(this._origin, this._matrix, x, y, z, result);\r\n }\r\n /**\r\n * Multiply a specific row (component) of the transform matrix times xyz and add it to the origin element\r\n * at the same row. Return the result.\r\n */\r\n public multiplyComponentXYZ(componentIndex: number, x: number, y: number, z: number = 0): number {\r\n const coffs = this._matrix.coffs;\r\n const idx = 3 * componentIndex;\r\n return this.origin.at(componentIndex) + (coffs[idx] * x) + (coffs[idx + 1] * y) + (coffs[idx + 2] * z);\r\n }\r\n /**\r\n * Multiply a specific row (component) of the transform matrix times xyz and add it to the origin element\r\n * at the same row times w. Return the result.\r\n */\r\n public multiplyComponentXYZW(componentIndex: number, x: number, y: number, z: number, w: number): number {\r\n const coffs = this._matrix.coffs;\r\n const idx = 3 * componentIndex;\r\n return (this.origin.at(componentIndex) * w) + (coffs[idx] * x) + (coffs[idx + 1] * y) + (coffs[idx + 2] * z);\r\n }\r\n /**\r\n * If `p = (x,y,z)` then transform is `Tp = M*p + o*w`. This function returns the transformed point as a new\r\n * point4d (`Tp` as first 3 elements and `w` as last element) or in the pre-allocated result (if result is given).\r\n */\r\n public multiplyXYZW(x: number, y: number, z: number, w: number, result?: Point4d): Point4d {\r\n return Matrix3d.xyzPlusMatrixTimesWeightedCoordinates(this._origin, this._matrix, x, y, z, w, result);\r\n }\r\n /**\r\n * If `p = (x,y,z)` then transform is `Tp = M*p + o*w`. This function returns the transformed point as a new\r\n * Float64Array with size 4 (`Tp` as first 3 elements and `w` as last element) or in the pre-allocated result\r\n * (if result is given).\r\n */\r\n public multiplyXYZWToFloat64Array(x: number, y: number, z: number, w: number, result?: Float64Array): Float64Array {\r\n return Matrix3d.xyzPlusMatrixTimesWeightedCoordinatesToFloat64Array(this._origin, this._matrix, x, y, z, w, result);\r\n }\r\n /**\r\n * If `p = (x,y,z)` then transform is `Tp = M*p + o`. This function returns the transformed point as a new\r\n * Float64Array with size 3 (`Tp` as 3 elements) or in the pre-allocated result (if result is given).\r\n */\r\n public multiplyXYZToFloat64Array(x: number, y: number, z: number, result?: Float64Array): Float64Array {\r\n return Matrix3d.xyzPlusMatrixTimesCoordinatesToFloat64Array(this._origin, this._matrix, x, y, z, result);\r\n }\r\n /**\r\n * Treat the 3x3 matrix and origin as upper 3x4 part of a 4x4 matrix, with 0001 as the final row. Now multiply\r\n * the transposed of this 4x4 matrix by Point4d given as xyzw. Return as a new point4d (`M*p` as first 3 elements\r\n * and `o*p + w` as last element where `p = (x,y,z)`) or in the pre-allocated result (if result is given).\r\n */\r\n public multiplyTransposeXYZW(x: number, y: number, z: number, w: number, result?: Point4d): Point4d {\r\n const coffs = this._matrix.coffs;\r\n const origin = this._origin;\r\n return Point4d.create(\r\n (x * coffs[0]) + (y * coffs[3]) + (z * coffs[6]),\r\n (x * coffs[1]) + (y * coffs[4]) + (z * coffs[7]),\r\n (x * coffs[2]) + (y * coffs[5]) + (z * coffs[8]),\r\n (x * origin.x) + (y * origin.y) + (z * origin.z) + w,\r\n result\r\n );\r\n }\r\n /** For each point in the array, replace point by the transformed point (by `Tp = M*p + o`) */\r\n public multiplyPoint3dArrayInPlace(points: Point3d[]) {\r\n let point;\r\n for (point of points)\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, point, point);\r\n }\r\n /** For each point in the 2d array, replace point by the transformed point (by `Tp = M*p + o`) */\r\n public multiplyPoint3dArrayArrayInPlace(chains: Point3d[][]) {\r\n for (const chain of chains)\r\n this.multiplyPoint3dArrayInPlace(chain);\r\n }\r\n /**\r\n * If for a point `p` we have `Tp = M*p + o = point` (where `point` is the transformed point), then\r\n * `p = MInverse * (point - o)`. This function returns the original point `p` if `point` is the\r\n * transformed point (`Tp = point`).\r\n * * Return as a new point or in the optional `result`.\r\n * * Returns `undefined` if the `matrix` part if this Transform is singular.\r\n */\r\n public multiplyInversePoint3d(point: XYAndZ, result?: Point3d): Point3d | undefined {\r\n return this._matrix.multiplyInverseXYZAsPoint3d(\r\n point.x - this._origin.x,\r\n point.y - this._origin.y,\r\n point.z - this._origin.z,\r\n result\r\n );\r\n }\r\n /**\r\n * If for a point `p` we have `Tp = M*p + w*o = weightedPoint` (where `weightedPoint` is the transformed point), then\r\n * `p = MInverse * (weightedPoint - w*o)`. This function returns a Point4d where first 3 elements are the original\r\n * point `p` if `weightedPoint` is the transformed point (`Tp = weightedPoint`) and the last element is `w`.\r\n * * Return as a new point or in the optional `result`.\r\n * * Returns `undefined` if the `matrix` part if this Transform is singular.\r\n */\r\n public multiplyInversePoint4d(weightedPoint: Point4d, result?: Point4d): Point4d | undefined {\r\n const w = weightedPoint.w;\r\n return this._matrix.multiplyInverseXYZW(\r\n weightedPoint.x - w * this.origin.x,\r\n weightedPoint.y - w * this.origin.y,\r\n weightedPoint.z - w * this.origin.z,\r\n w,\r\n result\r\n );\r\n }\r\n /**\r\n * If for a point `p = (x,y,z)` we have `Tp = M*p + o = point` (where `point` is the transformed point), then\r\n * `p = MInverse * (point - o)`. This function returns the original point `p` if `point` is the transformed\r\n * point (`Tp = point`).\r\n * * Return as a new point or in the optional `result`.\r\n * * Returns `undefined` if the `matrix` part if this Transform is singular.\r\n */\r\n public multiplyInverseXYZ(x: number, y: number, z: number, result?: Point3d): Point3d | undefined {\r\n return this._matrix.multiplyInverseXYZAsPoint3d(\r\n x - this._origin.x,\r\n y - this._origin.y,\r\n z - this._origin.z,\r\n result\r\n );\r\n }\r\n /**\r\n * * for each point: multiply transform * point\r\n * * if result is given, resize to match source and replace each corresponding pi\r\n * * if result is not given, return a new array.\r\n */\r\n public multiplyInversePoint3dArray(source: Point3d[], result?: Point3d[]): Point3d[] | undefined {\r\n if (!this._matrix.computeCachedInverse(true))\r\n return undefined;\r\n const originX = this.origin.x;\r\n const originY = this.origin.y;\r\n const originZ = this.origin.z;\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point3d.createZero);\r\n for (let i = 0; i < n; i++)\r\n this._matrix.multiplyInverseXYZAsPoint3d(\r\n source[i].x - originX,\r\n source[i].y - originY,\r\n source[i].z - originZ,\r\n result[i]\r\n );\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(\r\n this._matrix.multiplyInverseXYZAsPoint3d(\r\n p.x - originX,\r\n p.y - originY,\r\n p.z - originZ\r\n )!\r\n );\r\n\r\n return result;\r\n }\r\n /**\r\n * * For each point in source: multiply transformInverse * point in place in the point.\r\n * * Return false if not invertible.\r\n */\r\n public multiplyInversePoint3dArrayInPlace(source: Point3d[]): boolean {\r\n if (!this._matrix.computeCachedInverse(true))\r\n return false;\r\n const originX = this.origin.x;\r\n const originY = this.origin.y;\r\n const originZ = this.origin.z;\r\n const n = source.length;\r\n for (let i = 0; i < n; i++)\r\n this._matrix.multiplyInverseXYZAsPoint3d(\r\n source[i].x - originX,\r\n source[i].y - originY,\r\n source[i].z - originZ,\r\n source[i]\r\n );\r\n return true;\r\n }\r\n /**\r\n * * Compute (if needed) the inverse of the matrix part, thereby ensuring inverse operations can complete.\r\n * * Return true if matrix inverse completes.\r\n * @param useCached If true, accept prior cached inverse if available.\r\n */\r\n public computeCachedInverse(useCached: boolean = true): boolean {\r\n return this._matrix.computeCachedInverse(useCached);\r\n }\r\n /**\r\n * * If destination has more values than source, remove the extras.\r\n * * If destination has fewer values, use the constructionFunction to create new ones.\r\n * @param source array\r\n * @param dest destination array, to be modified to match source length\r\n * @param constructionFunction function to call to create new entries.\r\n */\r\n // modify destination so it has non-null points for the same length as the source.\r\n // (ASSUME existing elements of dest are non-null, and that parameters are given as either Point2d or Point3d arrays)\r\n public static matchArrayLengths(source: any[], dest: any[], constructionFunction: () => any): number {\r\n const numSource = source.length;\r\n const numDest = dest.length;\r\n if (numSource > numDest) {\r\n for (let i = numDest; i < numSource; i++) {\r\n dest.push(constructionFunction());\r\n }\r\n } else if (numDest > numSource) {\r\n dest.length = numSource;\r\n }\r\n return numSource;\r\n }\r\n /**\r\n * * For each point: multiply transform * point\r\n * * If result is given, resize to match source and replace each corresponding pi\r\n * * If result is not given, return a new array.\r\n */\r\n public multiplyPoint2dArray(source: Point2d[], result?: Point2d[]): Point2d[] {\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point2d.createZero);\r\n for (let i = 0; i < n; i++)\r\n Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, source[i], result[i]);\r\n return result;\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(Matrix3d.xyPlusMatrixTimesXY(this._origin, this._matrix, p));\r\n return result;\r\n }\r\n /**\r\n * * For each point: multiply transform * point\r\n * * If result is given, resize to match source and replace each corresponding pi\r\n * * If result is not given, return a new array.\r\n */\r\n public multiplyPoint3dArray(source: Point3d[], result?: Point3d[]): Point3d[] {\r\n if (result) {\r\n const n = Transform.matchArrayLengths(source, result, Point3d.createZero);\r\n for (let i = 0; i < n; i++)\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, source[i], result[i]);\r\n return result;\r\n }\r\n result = [];\r\n for (const p of source)\r\n result.push(Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, p));\r\n return result;\r\n }\r\n /**\r\n * Multiply the vector by the Matrix3d part of the transform.\r\n * * The transform's origin is not used.\r\n * * Return as new or result by usual optional result convention\r\n */\r\n public multiplyVector(vector: Vector3d, result?: Vector3d): Vector3d {\r\n return this._matrix.multiplyVector(vector, result);\r\n }\r\n /**\r\n * Multiply the vector in place by the Matrix3d part of the transform.\r\n * * The transform's origin is not used.\r\n */\r\n public multiplyVectorInPlace(vector: Vector3d): void {\r\n this._matrix.multiplyVectorInPlace(vector);\r\n }\r\n /**\r\n * Multiply the vector (x,y,z) by the Matrix3d part of the transform.\r\n * * The transform's origin is not used.\r\n * * Return as new or result by usual optional result convention\r\n */\r\n public multiplyVectorXYZ(x: number, y: number, z: number, result?: Vector3d): Vector3d {\r\n return this._matrix.multiplyXYZ(x, y, z, result);\r\n }\r\n /** Multiply this Transform times other Transform.\r\n * ```\r\n * equation\r\n * \\begin{matrix}\r\n * \\text{`this` transform with matrix part }\\bold{A}\\text{ and translation }\\bold{a} & \\blockTransform{A}{a}\\\\\r\n * \\text{`other` transform with matrix part }\\bold{B}\\text{ and translation part }\\bold{b}\\text{ promoted to block transform} & \\blockTransform{B}{b} \\\\\r\n * \\text{product}& \\blockTransform{A}{a}\\blockTransform{B}{b}=\\blockTransform{AB}{Ab + a}\r\n * \\end{matrix}\r\n * ```\r\n * @param other right hand transform for multiplication.\r\n * @param result optional preallocated result to reuse.\r\n */\r\n public multiplyTransformTransform(other: Transform, result?: Transform) {\r\n if (!result)\r\n return Transform.createRefs(\r\n Matrix3d.xyzPlusMatrixTimesXYZ(this._origin, this._matrix, other._origin),\r\n this._matrix.multiplyMatrixMatrix(other._matrix)\r\n );\r\n result.setMultiplyTransformTransform(this, other);\r\n return result;\r\n }\r\n /**\r\n * Multiply transformA * transformB, store to calling instance.\r\n * @param transformA left operand\r\n * @param transformB right operand\r\n */\r\n public setMultiplyTransformTransform(transformA: Transform, transformB: Transform): void {\r\n if (Transform._scratchPoint === undefined)\r\n Transform._scratchPoint = Point3d.create();\r\n Matrix3d.xyzPlusMatrixTimesXYZ(transformA._origin, transformA._matrix, transformB._origin, Transform._scratchPoint);\r\n this._origin.setFrom(Transform._scratchPoint);\r\n transformA._matrix.multiplyMatrixMatrix(transformB._matrix, this._matrix);\r\n }\r\n // [Q A][R 0] = [QR A]\r\n // [0 1][0 1] [0 1]\r\n /**\r\n * Multiply this Transform times other Matrix3d, with other considered to be a Transform with 0 translation.\r\n * ```\r\n * equation\r\n * \\begin{matrix}\r\n * \\text{`this` transform with matrix part }\\bold{A}\\text{ and translation }\\bold{b} & \\blockTransform{B}{b}\\\\\r\n * \\text{`other` matrix }\\bold{B}\\text{ promoted to block transform} & \\blockTransform{B}{0} \\\\\r\n * \\text{product}& \\blockTransform{A}{a}\\blockTransform{B}{0}=\\blockTransform{AB}{a}\r\n * \\end{matrix}\r\n * ```\r\n * @param other right hand Matrix3d for multiplication.\r\n * @param result optional preallocated result to reuse.\r\n */\r\n public multiplyTransformMatrix3d(other: Matrix3d, result?: Transform): Transform {\r\n if (!result)\r\n return Transform.createRefs(\r\n this._origin.cloneAsPoint3d(),\r\n this._matrix.multiplyMatrixMatrix(other)\r\n );\r\n this._matrix.multiplyMatrixMatrix(other, result._matrix);\r\n result._origin.setFrom(this._origin);\r\n return result;\r\n }\r\n /**\r\n * Return the range of the transformed corners.\r\n * * The 8 corners are transformed individually.\r\n * * Note that if there is anything other than translation and principal axis scaling in the transform, the volume of the range rotation will increase.\r\n * * Hence to get a \"tight\" range on rotated geometry, a range computation must be made on the rotated geometry itself.\r\n */\r\n public multiplyRange(range: Range3d, result?: Range3d): Range3d {\r\n if (range.isNull)\r\n return range.clone(result);\r\n // snag current values to allow aliasing.\r\n const lowX = range.low.x;\r\n const lowY = range.low.y;\r\n const lowZ = range.low.z;\r\n const highX = range.high.x;\r\n const highY = range.high.y;\r\n const highZ = range.high.z;\r\n result = Range3d.createNull(result);\r\n result.extendTransformedXYZ(this, lowX, lowY, lowZ);\r\n result.extendTransformedXYZ(this, highX, lowY, lowZ);\r\n result.extendTransformedXYZ(this, lowX, highY, lowZ);\r\n result.extendTransformedXYZ(this, highX, highY, lowZ);\r\n result.extendTransformedXYZ(this, lowX, lowY, highZ);\r\n result.extendTransformedXYZ(this, highX, lowY, highZ);\r\n result.extendTransformedXYZ(this, lowX, highY, highZ);\r\n result.extendTransformedXYZ(this, highX, highY, highZ);\r\n return result;\r\n }\r\n /**\r\n * * Return a Transform which is the inverse of this transform.\r\n * @param result optional pre-allocated result\r\n * @return the inverse Transform, or undefined if the matrix is singular\r\n */\r\n public inverse(result?: Transform): Transform | undefined {\r\n const matrixInverse = this._matrix.inverse(result ? result._matrix : undefined);\r\n if (!matrixInverse)\r\n return undefined;\r\n if (result) {\r\n // result._matrix is already defined\r\n matrixInverse.multiplyXYZ(-this._origin.x, -this._origin.y, -this._origin.z, result._origin as Vector3d);\r\n return result;\r\n }\r\n return Transform.createRefs(\r\n matrixInverse.multiplyXYZ(-this._origin.x, -this._origin.y, -this._origin.z),\r\n matrixInverse\r\n );\r\n }\r\n /**\r\n * Initialize transforms that map each direction of a box (axis aligned) to `[0,1]`.\r\n * * The corner coordinates do _not_ need to be in order in any of the x,y,z directions.\r\n * * The npcToGlobalTransform (if supplied) maps 000 to the point named point000.\r\n * * The npcToGlobalTransform (if supplied) maps 11 to the point named point000.\r\n * * The globalToNpc transform is the inverse.\r\n * @param min the \"000\" corner of the box\r\n * @param max the \"111\" corner of the box\r\n * @param npcToGlobal (object created by caller, re-initialized here) transform that carries 01 coordinates into the min,max box.\r\n * @param globalToNpc (object created by caller, re-initialized here) transform that carries world coordinates into 01\r\n */\r\n public static initFromRange(min: Point3d, max: Point3d, npcToGlobal?: Transform, globalToNpc?: Transform) {\r\n const diag = max.minus(min);\r\n if (diag.x === 0.0) diag.x = 1.0;\r\n if (diag.y === 0.0) diag.y = 1.0;\r\n if (diag.z === 0.0) diag.z = 1.0;\r\n const rMatrix = new Matrix3d();\r\n if (npcToGlobal) {\r\n Matrix3d.createScale(diag.x, diag.y, diag.z, rMatrix);\r\n Transform.createOriginAndMatrix(min, rMatrix, npcToGlobal);\r\n }\r\n if (globalToNpc) {\r\n const origin = new Point3d(- min.x / diag.x, - min.y / diag.y, - min.z / diag.z);\r\n Matrix3d.createScale(1.0 / diag.x, 1.0 / diag.y, 1.0 / diag.z, rMatrix);\r\n Transform.createOriginAndMatrix(origin, rMatrix, globalToNpc);\r\n }\r\n }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
*
|
|
2
|
+
* Interface for class with `x` and `y` as number properties.
|
|
3
3
|
* @public
|
|
4
4
|
*/
|
|
5
5
|
export interface WritableXAndY {
|
|
@@ -9,7 +9,7 @@ export interface WritableXAndY {
|
|
|
9
9
|
y: number;
|
|
10
10
|
}
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
12
|
+
* Interface for class with `z` as number property.
|
|
13
13
|
* @public
|
|
14
14
|
*/
|
|
15
15
|
export interface WriteableHasZ {
|
|
@@ -17,49 +17,50 @@ export interface WriteableHasZ {
|
|
|
17
17
|
z: number;
|
|
18
18
|
}
|
|
19
19
|
/**
|
|
20
|
-
*
|
|
20
|
+
* Interface for class with `x`, `y`, `z` as number property.
|
|
21
21
|
* @public
|
|
22
22
|
*/
|
|
23
23
|
export interface WritableXYAndZ extends WritableXAndY, WriteableHasZ {
|
|
24
24
|
}
|
|
25
25
|
/**
|
|
26
|
-
*
|
|
26
|
+
* Interface for class with named properties `low` and `high`, both being `WriteableXAndY`
|
|
27
27
|
* @public
|
|
28
28
|
*/
|
|
29
29
|
export interface WritableLowAndHighXY {
|
|
30
|
-
/**
|
|
30
|
+
/** Low x,y coordinates */
|
|
31
31
|
low: WritableXAndY;
|
|
32
|
-
/**
|
|
32
|
+
/** High x,y,z coordinates */
|
|
33
33
|
high: WritableXAndY;
|
|
34
34
|
}
|
|
35
35
|
/**
|
|
36
|
-
*
|
|
36
|
+
* Interface for class with named properties `low` and `high`, both being `WriteableXYAndZ`
|
|
37
37
|
* @public
|
|
38
38
|
*/
|
|
39
39
|
export interface WritableLowAndHighXYZ {
|
|
40
|
-
/**
|
|
40
|
+
/** Low x,y,z coordinates */
|
|
41
41
|
low: WritableXYAndZ;
|
|
42
42
|
/** High x,y,z coordinates */
|
|
43
43
|
high: WritableXYAndZ;
|
|
44
44
|
}
|
|
45
45
|
/**
|
|
46
|
-
*
|
|
46
|
+
* Interface for readable `z` number members.
|
|
47
47
|
* @public
|
|
48
48
|
*/
|
|
49
49
|
export declare type HasZ = Readonly<WriteableHasZ>;
|
|
50
50
|
/**
|
|
51
|
-
*
|
|
51
|
+
* Interface for readable `x` and `y` number members.
|
|
52
52
|
* @public
|
|
53
53
|
*/
|
|
54
54
|
export declare type XAndY = Readonly<WritableXAndY>;
|
|
55
55
|
/**
|
|
56
|
-
*
|
|
56
|
+
* Interface for type with readable `x`, `y`, `z` number members.
|
|
57
57
|
* @public
|
|
58
58
|
*/
|
|
59
59
|
export declare type XYAndZ = Readonly<WritableXYAndZ>;
|
|
60
60
|
/** @public */
|
|
61
61
|
export declare namespace XYAndZ {
|
|
62
|
-
/**
|
|
62
|
+
/**
|
|
63
|
+
* Return true if two XYAndZs have equal x,y,z parts within a specified tolerance.
|
|
63
64
|
* @param a The first XYAndZ to compare
|
|
64
65
|
* @param b The second XYAndZ to compare
|
|
65
66
|
* @param The tolerance for comparison. If undefined, [[Geometry.smallMetricDistance]] is used.
|
|
@@ -68,17 +69,17 @@ export declare namespace XYAndZ {
|
|
|
68
69
|
function almostEqual(a: XYAndZ, b: XYAndZ, tol?: number): boolean;
|
|
69
70
|
}
|
|
70
71
|
/**
|
|
71
|
-
*
|
|
72
|
+
* Interface for type with readable `low` and `high` members which have `x` and `y` number members.
|
|
72
73
|
* @public
|
|
73
74
|
*/
|
|
74
75
|
export declare type LowAndHighXY = Readonly<WritableLowAndHighXY>;
|
|
75
76
|
/**
|
|
76
|
-
*
|
|
77
|
+
* Interface for type with readable `low` and `high` members which have `x`, `y`, and `z` number members.
|
|
77
78
|
* @public
|
|
78
79
|
*/
|
|
79
80
|
export declare type LowAndHighXYZ = Readonly<WritableLowAndHighXYZ>;
|
|
80
81
|
/**
|
|
81
|
-
*
|
|
82
|
+
* Interface for variant json (one of)
|
|
82
83
|
* * (individually optional) `x`, `y`, `z`
|
|
83
84
|
* * number array
|
|
84
85
|
* @public
|
|
@@ -89,7 +90,7 @@ export declare type XYZProps = {
|
|
|
89
90
|
z?: number;
|
|
90
91
|
} | number[];
|
|
91
92
|
/**
|
|
92
|
-
*
|
|
93
|
+
* Interface for variant json (one of)
|
|
93
94
|
* * (individually optional) `x`, `y`
|
|
94
95
|
* * number array
|
|
95
96
|
* @public
|
|
@@ -99,7 +100,7 @@ export declare type XYProps = {
|
|
|
99
100
|
y?: number;
|
|
100
101
|
} | number[];
|
|
101
102
|
/**
|
|
102
|
-
*
|
|
103
|
+
* Interface for variant json (one of)
|
|
103
104
|
* * array of number arrays, with one matrix row in each array
|
|
104
105
|
* * flat array of numbers, in row-mor order
|
|
105
106
|
* * `Matrix3d` object
|
|
@@ -107,7 +108,7 @@ export declare type XYProps = {
|
|
|
107
108
|
*/
|
|
108
109
|
export declare type Matrix3dProps = number[][] | number[];
|
|
109
110
|
/**
|
|
110
|
-
*
|
|
111
|
+
* Interface for variant json (one of)
|
|
111
112
|
* * array of number arrays, with each low level array containing 4 numbers of a transform row (qx, qy, qz, ax)
|
|
112
113
|
* * flat array of 12 numbers, in row-major order for the 3 rows of 4 values
|
|
113
114
|
* * `Transform` object
|
|
@@ -118,7 +119,7 @@ export declare type TransformProps = number[][] | number[] | {
|
|
|
118
119
|
matrix: Matrix3dProps;
|
|
119
120
|
};
|
|
120
121
|
/**
|
|
121
|
-
*
|
|
122
|
+
* Interface for variant json representing a Range3d
|
|
122
123
|
* * pair of `XYZProps` named `low` and `high`
|
|
123
124
|
* * array of `XYZProps`
|
|
124
125
|
* @public
|
|
@@ -128,7 +129,7 @@ export declare type Range3dProps = {
|
|
|
128
129
|
high: XYZProps;
|
|
129
130
|
} | XYZProps[];
|
|
130
131
|
/**
|
|
131
|
-
*
|
|
132
|
+
* Interface for variant json representing a Range2d
|
|
132
133
|
* * pair of `XYProps` named `low` and `high`
|
|
133
134
|
* * array of `XYProps`
|
|
134
135
|
* @public
|
|
@@ -138,7 +139,7 @@ export declare type Range2dProps = {
|
|
|
138
139
|
high: XYProps;
|
|
139
140
|
} | XYProps[];
|
|
140
141
|
/**
|
|
141
|
-
*
|
|
142
|
+
* Interface for variant json representing a Range1d
|
|
142
143
|
* * pair of `number` named `low` and `high`
|
|
143
144
|
* * array of `number`
|
|
144
145
|
* @public
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"XYZProps.d.ts","sourceRoot":"","sources":["../../../src/geometry3d/XYZProps.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"XYZProps.d.ts","sourceRoot":"","sources":["../../../src/geometry3d/XYZProps.ts"],"names":[],"mappings":"AAWA;;;GAGG;AACH,MAAM,WAAW,aAAa;IAC5B,mBAAmB;IACnB,CAAC,EAAE,MAAM,CAAC;IACV,mBAAmB;IACnB,CAAC,EAAE,MAAM,CAAC;CACX;AACD;;;GAGG;AACH,MAAM,WAAW,aAAa;IAC5B,mBAAmB;IACnB,CAAC,EAAE,MAAM,CAAC;CACX;AACD;;;GAGG;AACH,MAAM,WAAW,cAAe,SAAQ,aAAa,EAAE,aAAa;CACnE;AACD;;;GAGG;AACH,MAAM,WAAW,oBAAoB;IACnC,0BAA0B;IAC1B,GAAG,EAAE,aAAa,CAAC;IACnB,6BAA6B;IAC7B,IAAI,EAAE,aAAa,CAAC;CACrB;AACD;;;GAGG;AACH,MAAM,WAAW,qBAAqB;IACpC,4BAA4B;IAC5B,GAAG,EAAE,cAAc,CAAC;IACpB,6BAA6B;IAC7B,IAAI,EAAE,cAAc,CAAC;CACtB;AACD;;;GAGG;AACH,oBAAY,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;AAC3C;;;GAGG;AACH,oBAAY,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;AAC5C;;;GAGG;AACH,oBAAY,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC;AAE9C,cAAc;AACd,yBAAiB,MAAM,CAAC;IACtB;;;;;;OAMG;IACH,SAAgB,WAAW,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAIvE;CACF;AAED;;;GAGG;AACH,oBAAY,YAAY,GAAG,QAAQ,CAAC,oBAAoB,CAAC,CAAC;AAC1D;;;GAGG;AACH,oBAAY,aAAa,GAAG,QAAQ,CAAC,qBAAqB,CAAC,CAAC;AAC5D;;;;;GAKG;AACH,oBAAY,QAAQ,GAAG;IACrB,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;CACZ,GAAG,MAAM,EAAE,CAAC;AACb;;;;;GAKG;AACH,oBAAY,OAAO,GAAG;IACpB,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;CACZ,GAAG,MAAM,EAAE,CAAC;AACb;;;;;;GAMG;AACH,oBAAY,aAAa,GAAG,MAAM,EAAE,EAAE,GAAG,MAAM,EAAE,CAAC;AAClD;;;;;;GAMG;AACH,oBAAY,cAAc,GAAG,MAAM,EAAE,EAAE,GAAG,MAAM,EAAE,GAAG;IACnD,MAAM,EAAE,QAAQ,CAAC;IACjB,MAAM,EAAE,aAAa,CAAC;CACvB,CAAC;AACF;;;;;GAKG;AACH,oBAAY,YAAY,GAAG;IACzB,GAAG,EAAE,QAAQ,CAAC;IACd,IAAI,EAAE,QAAQ,CAAC;CAChB,GAAG,QAAQ,EAAE,CAAC;AACf;;;;;GAKG;AACH,oBAAY,YAAY,GAAG;IACzB,GAAG,EAAE,OAAO,CAAC;IACb,IAAI,EAAE,OAAO,CAAC;CACf,GAAG,OAAO,EAAE,CAAC;AACd;;;;;GAKG;AACH,oBAAY,YAAY,GAAG;IACzB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;CACd,GAAG,MAAM,EAAE,CAAC"}
|
|
@@ -12,7 +12,8 @@ const Geometry_1 = require("../Geometry");
|
|
|
12
12
|
/** @public */
|
|
13
13
|
var XYAndZ;
|
|
14
14
|
(function (XYAndZ) {
|
|
15
|
-
/**
|
|
15
|
+
/**
|
|
16
|
+
* Return true if two XYAndZs have equal x,y,z parts within a specified tolerance.
|
|
16
17
|
* @param a The first XYAndZ to compare
|
|
17
18
|
* @param b The second XYAndZ to compare
|
|
18
19
|
* @param The tolerance for comparison. If undefined, [[Geometry.smallMetricDistance]] is used.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"XYZProps.js","sourceRoot":"","sources":["../../../src/geometry3d/XYZProps.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,0CAAuC;
|
|
1
|
+
{"version":3,"file":"XYZProps.js","sourceRoot":"","sources":["../../../src/geometry3d/XYZProps.ts"],"names":[],"mappings":";AAAA;;;+FAG+F;;;AAE/F;;GAEG;AAEH,0CAAuC;AA8DvC,cAAc;AACd,IAAiB,MAAM,CAatB;AAbD,WAAiB,MAAM;IACrB;;;;;;OAMG;IACH,SAAgB,WAAW,CAAC,CAAS,EAAE,CAAS,EAAE,GAAY;QAC5D,OAAO,mBAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC;eAC1C,mBAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC;eACxC,mBAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAChD,CAAC;IAJe,kBAAW,cAI1B,CAAA;AACH,CAAC,EAbgB,MAAM,GAAN,cAAM,KAAN,cAAM,QAatB","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module CartesianGeometry\r\n */\r\n\r\nimport { Geometry } from \"../Geometry\";\r\n\r\n/**\r\n * Interface for class with `x` and `y` as number properties.\r\n * @public\r\n */\r\nexport interface WritableXAndY {\r\n /** x coordinate */\r\n x: number;\r\n /** y coordinate */\r\n y: number;\r\n}\r\n/**\r\n * Interface for class with `z` as number property.\r\n * @public\r\n */\r\nexport interface WriteableHasZ {\r\n /** z coordinate */\r\n z: number;\r\n}\r\n/**\r\n * Interface for class with `x`, `y`, `z` as number property.\r\n * @public\r\n */\r\nexport interface WritableXYAndZ extends WritableXAndY, WriteableHasZ {\r\n}\r\n/**\r\n * Interface for class with named properties `low` and `high`, both being `WriteableXAndY`\r\n * @public\r\n */\r\nexport interface WritableLowAndHighXY {\r\n /** Low x,y coordinates */\r\n low: WritableXAndY;\r\n /** High x,y,z coordinates */\r\n high: WritableXAndY;\r\n}\r\n/**\r\n * Interface for class with named properties `low` and `high`, both being `WriteableXYAndZ`\r\n * @public\r\n */\r\nexport interface WritableLowAndHighXYZ {\r\n /** Low x,y,z coordinates */\r\n low: WritableXYAndZ;\r\n /** High x,y,z coordinates */\r\n high: WritableXYAndZ;\r\n}\r\n/**\r\n * Interface for readable `z` number members.\r\n * @public\r\n */\r\nexport type HasZ = Readonly<WriteableHasZ>;\r\n/**\r\n * Interface for readable `x` and `y` number members.\r\n * @public\r\n */\r\nexport type XAndY = Readonly<WritableXAndY>;\r\n/**\r\n * Interface for type with readable `x`, `y`, `z` number members.\r\n * @public\r\n */\r\nexport type XYAndZ = Readonly<WritableXYAndZ>;\r\n\r\n/** @public */\r\nexport namespace XYAndZ { // eslint-disable-line @typescript-eslint/no-redeclare\r\n /**\r\n * Return true if two XYAndZs have equal x,y,z parts within a specified tolerance.\r\n * @param a The first XYAndZ to compare\r\n * @param b The second XYAndZ to compare\r\n * @param The tolerance for comparison. If undefined, [[Geometry.smallMetricDistance]] is used.\r\n * @returns true if the difference in each coordinate of `a` and `b` is smaller than `tol`.\r\n */\r\n export function almostEqual(a: XYAndZ, b: XYAndZ, tol?: number): boolean {\r\n return Geometry.isSameCoordinate(a.x, b.x, tol)\r\n && Geometry.isSameCoordinate(a.y, b.y, tol)\r\n && Geometry.isSameCoordinate(a.z, b.z, tol);\r\n }\r\n}\r\n\r\n/**\r\n * Interface for type with readable `low` and `high` members which have `x` and `y` number members.\r\n * @public\r\n */\r\nexport type LowAndHighXY = Readonly<WritableLowAndHighXY>;\r\n/**\r\n * Interface for type with readable `low` and `high` members which have `x`, `y`, and `z` number members.\r\n * @public\r\n */\r\nexport type LowAndHighXYZ = Readonly<WritableLowAndHighXYZ>;\r\n/**\r\n * Interface for variant json (one of)\r\n * * (individually optional) `x`, `y`, `z`\r\n * * number array\r\n * @public\r\n */\r\nexport type XYZProps = {\r\n x?: number;\r\n y?: number;\r\n z?: number;\r\n} | number[];\r\n/**\r\n * Interface for variant json (one of)\r\n * * (individually optional) `x`, `y`\r\n * * number array\r\n * @public\r\n */\r\nexport type XYProps = {\r\n x?: number;\r\n y?: number;\r\n} | number[];\r\n/**\r\n * Interface for variant json (one of)\r\n * * array of number arrays, with one matrix row in each array\r\n * * flat array of numbers, in row-mor order\r\n * * `Matrix3d` object\r\n * @public\r\n */\r\nexport type Matrix3dProps = number[][] | number[];\r\n/**\r\n * Interface for variant json (one of)\r\n * * array of number arrays, with each low level array containing 4 numbers of a transform row (qx, qy, qz, ax)\r\n * * flat array of 12 numbers, in row-major order for the 3 rows of 4 values\r\n * * `Transform` object\r\n * @public\r\n */\r\nexport type TransformProps = number[][] | number[] | {\r\n origin: XYZProps;\r\n matrix: Matrix3dProps;\r\n};\r\n/**\r\n * Interface for variant json representing a Range3d\r\n * * pair of `XYZProps` named `low` and `high`\r\n * * array of `XYZProps`\r\n * @public\r\n */\r\nexport type Range3dProps = {\r\n low: XYZProps;\r\n high: XYZProps;\r\n} | XYZProps[];\r\n/**\r\n * Interface for variant json representing a Range2d\r\n * * pair of `XYProps` named `low` and `high`\r\n * * array of `XYProps`\r\n * @public\r\n */\r\nexport type Range2dProps = {\r\n low: XYProps;\r\n high: XYProps;\r\n} | XYProps[];\r\n/**\r\n * Interface for variant json representing a Range1d\r\n * * pair of `number` named `low` and `high`\r\n * * array of `number`\r\n * @public\r\n */\r\nexport type Range1dProps = {\r\n low: number;\r\n high: number;\r\n} | number[];\r\n"]}
|
|
@@ -94,8 +94,10 @@ export declare class PolyfaceBuilder extends NullGeometryHandler {
|
|
|
94
94
|
static create(options?: StrokeOptions): PolyfaceBuilder;
|
|
95
95
|
/** add facets for a transformed unit box. */
|
|
96
96
|
addTransformedUnitBox(transform: Transform): void;
|
|
97
|
-
/**
|
|
98
|
-
*
|
|
97
|
+
/** Add facets for a transformed range box.
|
|
98
|
+
* @param transform applied to the range points before adding to the polyface
|
|
99
|
+
* @param range sides become 6 quad polyface facets
|
|
100
|
+
* @param faceSelector for each face in the order of BoxTopology.cornerIndexCCW, faceSelector[i]===false skips that facet.
|
|
99
101
|
*/
|
|
100
102
|
addTransformedRangeMesh(transform: Transform, range: Range3d, faceSelector?: boolean[]): void;
|
|
101
103
|
/** Add triangles from points[0] to each far edge.
|
|
@@ -196,10 +198,10 @@ export declare class PolyfaceBuilder extends NullGeometryHandler {
|
|
|
196
198
|
*/
|
|
197
199
|
addQuadFacet(points: Point3d[] | GrowableXYZArray, params?: Point2d[], normals?: Vector3d[], colors?: number[]): void;
|
|
198
200
|
/** Announce a single quad facet's point indexes.
|
|
199
|
-
*
|
|
200
201
|
* * The actual quad may be reversed or triangulated based on builder setup.
|
|
201
|
-
* *
|
|
202
|
-
* *
|
|
202
|
+
* * indexA0 and indexA1 are in the forward order at the "A" end of the quad
|
|
203
|
+
* * indexB0 and indexB1 are in the forward order at the "B" end of the quad.
|
|
204
|
+
* * This means ccw/cw ordered vertices v[i] should be passed into this function as i=[0,1,3,2]
|
|
203
205
|
*/
|
|
204
206
|
private addIndexedQuadPointIndexes;
|
|
205
207
|
/** For a single quad facet, add the indexes of the corresponding param points. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PolyfaceBuilder.d.ts","sourceRoot":"","sources":["../../../src/polyface/PolyfaceBuilder.ts"],"names":[],"mappings":"AAKA;;GAEG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAG1D,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAGrD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAMnD,OAAO,EAAE,mBAAmB,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAC;AAE/E,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAG1E,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAExD,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAO,MAAM,+BAA+B,CAAC;AAEvE,OAAO,EAAW,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEpD,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AACnC,OAAO,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAMvF,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAgG9D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,qBAAa,eAAgB,SAAQ,mBAAmB;IACtD,OAAO,CAAC,SAAS,CAAkB;IACnC,OAAO,CAAC,QAAQ,CAAgB;IAChC,qEAAqE;IACrE,IAAW,OAAO,IAAI,aAAa,CAA0B;IAE7D,OAAO,CAAC,SAAS,CAAU;IAC3B,2EAA2E;IAC3E,IAAW,YAAY,IAAI,OAAO,CAA2B;IAC7D,4BAA4B;IACrB,aAAa,CAAC,QAAQ,GAAE,OAAc,GAAG,eAAe;IAK/D,sFAAsF;IAC/E,uBAAuB;IAE9B,OAAO;IAOP;;;OAGG;WACW,MAAM,CAAC,OAAO,CAAC,EAAE,aAAa,GAAG,eAAe;IAG9D,6CAA6C;IACtC,qBAAqB,CAAC,SAAS,EAAE,SAAS;IAIjD
|
|
1
|
+
{"version":3,"file":"PolyfaceBuilder.d.ts","sourceRoot":"","sources":["../../../src/polyface/PolyfaceBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -205,8 +205,10 @@ class PolyfaceBuilder extends GeometryHandler_1.NullGeometryHandler {
|
|
|
205
205
|
addTransformedUnitBox(transform) {
|
|
206
206
|
this.addTransformedRangeMesh(transform, Range_1.Range3d.createXYZXYZ(0, 0, 0, 1, 1, 1));
|
|
207
207
|
}
|
|
208
|
-
/**
|
|
209
|
-
*
|
|
208
|
+
/** Add facets for a transformed range box.
|
|
209
|
+
* @param transform applied to the range points before adding to the polyface
|
|
210
|
+
* @param range sides become 6 quad polyface facets
|
|
211
|
+
* @param faceSelector for each face in the order of BoxTopology.cornerIndexCCW, faceSelector[i]===false skips that facet.
|
|
210
212
|
*/
|
|
211
213
|
addTransformedRangeMesh(transform, range, faceSelector) {
|
|
212
214
|
const pointIndex0 = this._polyface.data.pointCount;
|
|
@@ -217,8 +219,16 @@ class PolyfaceBuilder extends GeometryHandler_1.NullGeometryHandler {
|
|
|
217
219
|
let faceCounter = 0;
|
|
218
220
|
for (const facet of BoxTopology_1.BoxTopology.cornerIndexCCW) {
|
|
219
221
|
if (!faceSelector || (faceCounter < faceSelector.length && faceSelector[faceCounter])) {
|
|
220
|
-
|
|
221
|
-
|
|
222
|
+
const myFacet = facet.map((pointIndex) => pointIndex + pointIndex0);
|
|
223
|
+
if (this._reversed)
|
|
224
|
+
myFacet.reverse();
|
|
225
|
+
if (this._options.shouldTriangulate) {
|
|
226
|
+
this.addIndexedTrianglePointIndexes(myFacet[0], myFacet[1], myFacet[2], false);
|
|
227
|
+
this.addIndexedTrianglePointIndexes(myFacet[0], myFacet[2], myFacet[3], false);
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this.addIndexedQuadPointIndexes(myFacet[0], myFacet[1], myFacet[3], myFacet[2], false);
|
|
231
|
+
}
|
|
222
232
|
this._polyface.terminateFacet();
|
|
223
233
|
}
|
|
224
234
|
faceCounter++;
|
|
@@ -548,10 +558,10 @@ class PolyfaceBuilder extends GeometryHandler_1.NullGeometryHandler {
|
|
|
548
558
|
this.addIndexedQuadPointIndexes(idx0, idx1, idx3, idx2);
|
|
549
559
|
}
|
|
550
560
|
/** Announce a single quad facet's point indexes.
|
|
551
|
-
*
|
|
552
561
|
* * The actual quad may be reversed or triangulated based on builder setup.
|
|
553
|
-
* *
|
|
554
|
-
* *
|
|
562
|
+
* * indexA0 and indexA1 are in the forward order at the "A" end of the quad
|
|
563
|
+
* * indexB0 and indexB1 are in the forward order at the "B" end of the quad.
|
|
564
|
+
* * This means ccw/cw ordered vertices v[i] should be passed into this function as i=[0,1,3,2]
|
|
555
565
|
*/
|
|
556
566
|
addIndexedQuadPointIndexes(indexA0, indexA1, indexB0, indexB1, terminate = true) {
|
|
557
567
|
if (this._reversed) {
|