@mlightcad/geometry-engine 3.0.2 → 3.0.4
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/package.json +3 -3
- package/dist/geometry-engine.js +0 -10702
- package/dist/geometry-engine.umd.cjs +0 -4
- package/lib/geometry/AcGeArea2d.d.ts +0 -61
- package/lib/geometry/AcGeArea2d.d.ts.map +0 -1
- package/lib/geometry/AcGeArea2d.js +0 -174
- package/lib/geometry/AcGeArea2d.js.map +0 -1
- package/lib/geometry/AcGeCatmullRomCurve3d.d.ts +0 -146
- package/lib/geometry/AcGeCatmullRomCurve3d.d.ts.map +0 -1
- package/lib/geometry/AcGeCatmullRomCurve3d.js +0 -358
- package/lib/geometry/AcGeCatmullRomCurve3d.js.map +0 -1
- package/lib/geometry/AcGeCircArc2d.d.ts +0 -132
- package/lib/geometry/AcGeCircArc2d.d.ts.map +0 -1
- package/lib/geometry/AcGeCircArc2d.js +0 -473
- package/lib/geometry/AcGeCircArc2d.js.map +0 -1
- package/lib/geometry/AcGeCircArc3d.d.ts +0 -138
- package/lib/geometry/AcGeCircArc3d.d.ts.map +0 -1
- package/lib/geometry/AcGeCircArc3d.js +0 -447
- package/lib/geometry/AcGeCircArc3d.js.map +0 -1
- package/lib/geometry/AcGeCurve2d.d.ts +0 -85
- package/lib/geometry/AcGeCurve2d.d.ts.map +0 -1
- package/lib/geometry/AcGeCurve2d.js +0 -213
- package/lib/geometry/AcGeCurve2d.js.map +0 -1
- package/lib/geometry/AcGeCurve3d.d.ts +0 -27
- package/lib/geometry/AcGeCurve3d.d.ts.map +0 -1
- package/lib/geometry/AcGeCurve3d.js +0 -29
- package/lib/geometry/AcGeCurve3d.js.map +0 -1
- package/lib/geometry/AcGeEllipseArc2d.d.ts +0 -105
- package/lib/geometry/AcGeEllipseArc2d.d.ts.map +0 -1
- package/lib/geometry/AcGeEllipseArc2d.js +0 -292
- package/lib/geometry/AcGeEllipseArc2d.js.map +0 -1
- package/lib/geometry/AcGeEllipseArc3d.d.ts +0 -142
- package/lib/geometry/AcGeEllipseArc3d.d.ts.map +0 -1
- package/lib/geometry/AcGeEllipseArc3d.js +0 -459
- package/lib/geometry/AcGeEllipseArc3d.js.map +0 -1
- package/lib/geometry/AcGeLine2d.d.ts +0 -56
- package/lib/geometry/AcGeLine2d.d.ts.map +0 -1
- package/lib/geometry/AcGeLine2d.js +0 -125
- package/lib/geometry/AcGeLine2d.js.map +0 -1
- package/lib/geometry/AcGeLine3d.d.ts +0 -134
- package/lib/geometry/AcGeLine3d.d.ts.map +0 -1
- package/lib/geometry/AcGeLine3d.js +0 -291
- package/lib/geometry/AcGeLine3d.js.map +0 -1
- package/lib/geometry/AcGeLoop2d.d.ts +0 -59
- package/lib/geometry/AcGeLoop2d.d.ts.map +0 -1
- package/lib/geometry/AcGeLoop2d.js +0 -141
- package/lib/geometry/AcGeLoop2d.js.map +0 -1
- package/lib/geometry/AcGeNurbsCurve.d.ts +0 -73
- package/lib/geometry/AcGeNurbsCurve.d.ts.map +0 -1
- package/lib/geometry/AcGeNurbsCurve.js +0 -172
- package/lib/geometry/AcGeNurbsCurve.js.map +0 -1
- package/lib/geometry/AcGePolyline2d.d.ts +0 -90
- package/lib/geometry/AcGePolyline2d.d.ts.map +0 -1
- package/lib/geometry/AcGePolyline2d.js +0 -224
- package/lib/geometry/AcGePolyline2d.js.map +0 -1
- package/lib/geometry/AcGeShape.d.ts +0 -12
- package/lib/geometry/AcGeShape.d.ts.map +0 -1
- package/lib/geometry/AcGeShape.js +0 -22
- package/lib/geometry/AcGeShape.js.map +0 -1
- package/lib/geometry/AcGeShape2d.d.ts +0 -31
- package/lib/geometry/AcGeShape2d.d.ts.map +0 -1
- package/lib/geometry/AcGeShape2d.js +0 -51
- package/lib/geometry/AcGeShape2d.js.map +0 -1
- package/lib/geometry/AcGeShape3d.d.ts +0 -33
- package/lib/geometry/AcGeShape3d.d.ts.map +0 -1
- package/lib/geometry/AcGeShape3d.js +0 -52
- package/lib/geometry/AcGeShape3d.js.map +0 -1
- package/lib/geometry/AcGeSpline3d.d.ts +0 -99
- package/lib/geometry/AcGeSpline3d.d.ts.map +0 -1
- package/lib/geometry/AcGeSpline3d.js +0 -350
- package/lib/geometry/AcGeSpline3d.js.map +0 -1
- package/lib/geometry/index.d.ts +0 -15
- package/lib/geometry/index.d.ts.map +0 -1
- package/lib/geometry/index.js +0 -15
- package/lib/geometry/index.js.map +0 -1
- package/lib/index.d.ts +0 -4
- package/lib/index.d.ts.map +0 -1
- package/lib/index.js +0 -4
- package/lib/index.js.map +0 -1
- package/lib/math/AcGeBox2d.d.ts +0 -173
- package/lib/math/AcGeBox2d.d.ts.map +0 -1
- package/lib/math/AcGeBox2d.js +0 -289
- package/lib/math/AcGeBox2d.js.map +0 -1
- package/lib/math/AcGeBox3d.d.ts +0 -195
- package/lib/math/AcGeBox3d.d.ts.map +0 -1
- package/lib/math/AcGeBox3d.js +0 -378
- package/lib/math/AcGeBox3d.js.map +0 -1
- package/lib/math/AcGeEuler.d.ts +0 -133
- package/lib/math/AcGeEuler.d.ts.map +0 -1
- package/lib/math/AcGeEuler.js +0 -358
- package/lib/math/AcGeEuler.js.map +0 -1
- package/lib/math/AcGeMatrix2d.d.ts +0 -203
- package/lib/math/AcGeMatrix2d.d.ts.map +0 -1
- package/lib/math/AcGeMatrix2d.js +0 -393
- package/lib/math/AcGeMatrix2d.js.map +0 -1
- package/lib/math/AcGeMatrix3d.d.ts +0 -279
- package/lib/math/AcGeMatrix3d.d.ts.map +0 -1
- package/lib/math/AcGeMatrix3d.js +0 -1037
- package/lib/math/AcGeMatrix3d.js.map +0 -1
- package/lib/math/AcGePlane.d.ts +0 -131
- package/lib/math/AcGePlane.d.ts.map +0 -1
- package/lib/math/AcGePlane.js +0 -218
- package/lib/math/AcGePlane.js.map +0 -1
- package/lib/math/AcGePoint.d.ts +0 -4
- package/lib/math/AcGePoint.d.ts.map +0 -1
- package/lib/math/AcGePoint.js +0 -2
- package/lib/math/AcGePoint.js.map +0 -1
- package/lib/math/AcGePoint2d.d.ts +0 -17
- package/lib/math/AcGePoint2d.d.ts.map +0 -1
- package/lib/math/AcGePoint2d.js +0 -40
- package/lib/math/AcGePoint2d.js.map +0 -1
- package/lib/math/AcGePoint3d.d.ts +0 -18
- package/lib/math/AcGePoint3d.d.ts.map +0 -1
- package/lib/math/AcGePoint3d.js +0 -43
- package/lib/math/AcGePoint3d.js.map +0 -1
- package/lib/math/AcGeQuaternion.d.ts +0 -230
- package/lib/math/AcGeQuaternion.d.ts.map +0 -1
- package/lib/math/AcGeQuaternion.js +0 -666
- package/lib/math/AcGeQuaternion.js.map +0 -1
- package/lib/math/AcGeVector.d.ts +0 -9
- package/lib/math/AcGeVector.d.ts.map +0 -1
- package/lib/math/AcGeVector.js +0 -2
- package/lib/math/AcGeVector.js.map +0 -1
- package/lib/math/AcGeVector2d.d.ts +0 -361
- package/lib/math/AcGeVector2d.d.ts.map +0 -1
- package/lib/math/AcGeVector2d.js +0 -622
- package/lib/math/AcGeVector2d.js.map +0 -1
- package/lib/math/AcGeVector3d.d.ts +0 -493
- package/lib/math/AcGeVector3d.d.ts.map +0 -1
- package/lib/math/AcGeVector3d.js +0 -868
- package/lib/math/AcGeVector3d.js.map +0 -1
- package/lib/math/index.d.ts +0 -14
- package/lib/math/index.d.ts.map +0 -1
- package/lib/math/index.js +0 -14
- package/lib/math/index.js.map +0 -1
- package/lib/util/AcGeConstants.d.ts +0 -19
- package/lib/util/AcGeConstants.d.ts.map +0 -1
- package/lib/util/AcGeConstants.js +0 -25
- package/lib/util/AcGeConstants.js.map +0 -1
- package/lib/util/AcGeGeometryUtil.d.ts +0 -16
- package/lib/util/AcGeGeometryUtil.d.ts.map +0 -1
- package/lib/util/AcGeGeometryUtil.js +0 -56
- package/lib/util/AcGeGeometryUtil.js.map +0 -1
- package/lib/util/AcGeMathUtil.d.ts +0 -203
- package/lib/util/AcGeMathUtil.d.ts.map +0 -1
- package/lib/util/AcGeMathUtil.js +0 -585
- package/lib/util/AcGeMathUtil.js.map +0 -1
- package/lib/util/AcGeNurbsUtil.d.ts +0 -34
- package/lib/util/AcGeNurbsUtil.d.ts.map +0 -1
- package/lib/util/AcGeNurbsUtil.js +0 -218
- package/lib/util/AcGeNurbsUtil.js.map +0 -1
- package/lib/util/AcGeTol.d.ts +0 -91
- package/lib/util/AcGeTol.d.ts.map +0 -1
- package/lib/util/AcGeTol.js +0 -83
- package/lib/util/AcGeTol.js.map +0 -1
- package/lib/util/index.d.ts +0 -6
- package/lib/util/index.d.ts.map +0 -1
- package/lib/util/index.js +0 -6
- package/lib/util/index.js.map +0 -1
|
@@ -1,358 +0,0 @@
|
|
|
1
|
-
var __extends = (this && this.__extends) || (function () {
|
|
2
|
-
var extendStatics = function (d, b) {
|
|
3
|
-
extendStatics = Object.setPrototypeOf ||
|
|
4
|
-
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
|
5
|
-
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
|
|
6
|
-
return extendStatics(d, b);
|
|
7
|
-
};
|
|
8
|
-
return function (d, b) {
|
|
9
|
-
if (typeof b !== "function" && b !== null)
|
|
10
|
-
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
|
|
11
|
-
extendStatics(d, b);
|
|
12
|
-
function __() { this.constructor = d; }
|
|
13
|
-
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
|
14
|
-
};
|
|
15
|
-
})();
|
|
16
|
-
import { AcGeBox3d, AcGePoint3d, AcGeVector3d } from '../math';
|
|
17
|
-
import { AcGeCurve3d } from './AcGeCurve3d';
|
|
18
|
-
/**
|
|
19
|
-
* Internal class for computing cubic polynomial coefficients
|
|
20
|
-
* Based on an optimized c++ solution in
|
|
21
|
-
* - http://stackoverflow.com/questions/9489736/catmull-rom-curve-with-no-cusps-and-no-self-intersections/
|
|
22
|
-
* - http://ideone.com/NoEbVM
|
|
23
|
-
*/
|
|
24
|
-
var CubicPoly = /** @class */ (function () {
|
|
25
|
-
function CubicPoly() {
|
|
26
|
-
this.c0 = 0;
|
|
27
|
-
this.c1 = 0;
|
|
28
|
-
this.c2 = 0;
|
|
29
|
-
this.c3 = 0;
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Compute coefficients for a cubic polynomial
|
|
33
|
-
* p(s) = c0 + c1*s + c2*s^2 + c3*s^3
|
|
34
|
-
* such that
|
|
35
|
-
* p(0) = x0, p(1) = x1
|
|
36
|
-
* and
|
|
37
|
-
* p'(0) = t0, p'(1) = t1.
|
|
38
|
-
*/
|
|
39
|
-
CubicPoly.prototype.init = function (x0, x1, t0, t1) {
|
|
40
|
-
this.c0 = x0;
|
|
41
|
-
this.c1 = t0;
|
|
42
|
-
this.c2 = -3 * x0 + 3 * x1 - 2 * t0 - t1;
|
|
43
|
-
this.c3 = 2 * x0 - 2 * x1 + t0 + t1;
|
|
44
|
-
};
|
|
45
|
-
/**
|
|
46
|
-
* Initialize for Catmull-Rom interpolation
|
|
47
|
-
*/
|
|
48
|
-
CubicPoly.prototype.initCatmullRom = function (x0, x1, x2, x3, tension) {
|
|
49
|
-
this.init(x1, x2, tension * (x2 - x0), tension * (x3 - x1));
|
|
50
|
-
};
|
|
51
|
-
/**
|
|
52
|
-
* Initialize for non-uniform Catmull-Rom interpolation
|
|
53
|
-
*/
|
|
54
|
-
CubicPoly.prototype.initNonuniformCatmullRom = function (x0, x1, x2, x3, dt0, dt1, dt2) {
|
|
55
|
-
// compute tangents when parameterized in [t1,t2]
|
|
56
|
-
var t1 = (x1 - x0) / dt0 - (x2 - x0) / (dt0 + dt1) + (x2 - x1) / dt1;
|
|
57
|
-
var t2 = (x2 - x1) / dt1 - (x3 - x1) / (dt1 + dt2) + (x3 - x2) / dt2;
|
|
58
|
-
// rescale tangents for parametrization in [0,1]
|
|
59
|
-
t1 *= dt1;
|
|
60
|
-
t2 *= dt1;
|
|
61
|
-
this.init(x1, x2, t1, t2);
|
|
62
|
-
};
|
|
63
|
-
/**
|
|
64
|
-
* Calculate the polynomial value at parameter t
|
|
65
|
-
*/
|
|
66
|
-
CubicPoly.prototype.calc = function (t) {
|
|
67
|
-
var t2 = t * t;
|
|
68
|
-
var t3 = t2 * t;
|
|
69
|
-
return this.c0 + this.c1 * t + this.c2 * t2 + this.c3 * t3;
|
|
70
|
-
};
|
|
71
|
-
return CubicPoly;
|
|
72
|
-
}());
|
|
73
|
-
/**
|
|
74
|
-
* A curve representing a Catmull-Rom spline.
|
|
75
|
-
*
|
|
76
|
-
* ```js
|
|
77
|
-
* //Create a closed wavey loop
|
|
78
|
-
* const curve = new AcGeCatmullRomCurve3d( [
|
|
79
|
-
* new AcGePoint3d( -10, 0, 10 ),
|
|
80
|
-
* new AcGePoint3d( -5, 5, 5 ),
|
|
81
|
-
* new AcGePoint3d( 0, 0, 0 ),
|
|
82
|
-
* new AcGePoint3d( 5, -5, 5 ),
|
|
83
|
-
* new AcGePoint3d( 10, 0, 10 )
|
|
84
|
-
* ], true ); // true for closed curve
|
|
85
|
-
*
|
|
86
|
-
* const points = curve.getPoints( 50 );
|
|
87
|
-
*
|
|
88
|
-
* // Convert to NURBS curve
|
|
89
|
-
* const nurbsCurve = curve.toNurbsCurve();
|
|
90
|
-
* ```
|
|
91
|
-
*/
|
|
92
|
-
var AcGeCatmullRomCurve3d = /** @class */ (function (_super) {
|
|
93
|
-
__extends(AcGeCatmullRomCurve3d, _super);
|
|
94
|
-
/**
|
|
95
|
-
* Constructs a new Catmull-Rom curve.
|
|
96
|
-
*
|
|
97
|
-
* @param points - An array of 3D points defining the curve.
|
|
98
|
-
* @param closed - Whether the curve is closed or not.
|
|
99
|
-
* @param curveType - The curve type.
|
|
100
|
-
* @param tension - Tension of the curve.
|
|
101
|
-
*/
|
|
102
|
-
function AcGeCatmullRomCurve3d(points, closed, curveType, tension) {
|
|
103
|
-
if (points === void 0) { points = []; }
|
|
104
|
-
if (closed === void 0) { closed = false; }
|
|
105
|
-
if (curveType === void 0) { curveType = 'centripetal'; }
|
|
106
|
-
if (tension === void 0) { tension = 0.5; }
|
|
107
|
-
var _this = _super.call(this) || this;
|
|
108
|
-
/**
|
|
109
|
-
* This flag can be used for type testing.
|
|
110
|
-
*/
|
|
111
|
-
_this.isCatmullRomCurve3d = true;
|
|
112
|
-
/**
|
|
113
|
-
* The curve type identifier
|
|
114
|
-
*/
|
|
115
|
-
_this.type = 'CatmullRomCurve3d';
|
|
116
|
-
// Internal computation objects
|
|
117
|
-
_this._tmp = new AcGeVector3d();
|
|
118
|
-
_this._px = new CubicPoly();
|
|
119
|
-
_this._py = new CubicPoly();
|
|
120
|
-
_this._pz = new CubicPoly();
|
|
121
|
-
_this._points = points.map(function (p) { return new AcGePoint3d(p); });
|
|
122
|
-
_this._closed = closed;
|
|
123
|
-
_this._curveType = curveType;
|
|
124
|
-
_this._tension = tension;
|
|
125
|
-
return _this;
|
|
126
|
-
}
|
|
127
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "points", {
|
|
128
|
-
/**
|
|
129
|
-
* An array of 3D points defining the curve.
|
|
130
|
-
*/
|
|
131
|
-
get: function () {
|
|
132
|
-
return this._points;
|
|
133
|
-
},
|
|
134
|
-
enumerable: false,
|
|
135
|
-
configurable: true
|
|
136
|
-
});
|
|
137
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "closed", {
|
|
138
|
-
/**
|
|
139
|
-
* Whether the curve is closed or not.
|
|
140
|
-
*/
|
|
141
|
-
get: function () {
|
|
142
|
-
return this._closed;
|
|
143
|
-
},
|
|
144
|
-
enumerable: false,
|
|
145
|
-
configurable: true
|
|
146
|
-
});
|
|
147
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "curveType", {
|
|
148
|
-
/**
|
|
149
|
-
* The curve type.
|
|
150
|
-
*/
|
|
151
|
-
get: function () {
|
|
152
|
-
return this._curveType;
|
|
153
|
-
},
|
|
154
|
-
enumerable: false,
|
|
155
|
-
configurable: true
|
|
156
|
-
});
|
|
157
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "tension", {
|
|
158
|
-
/**
|
|
159
|
-
* Tension of the curve.
|
|
160
|
-
*/
|
|
161
|
-
get: function () {
|
|
162
|
-
return this._tension;
|
|
163
|
-
},
|
|
164
|
-
enumerable: false,
|
|
165
|
-
configurable: true
|
|
166
|
-
});
|
|
167
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "startPoint", {
|
|
168
|
-
/**
|
|
169
|
-
* Start point of this curve.
|
|
170
|
-
*/
|
|
171
|
-
get: function () {
|
|
172
|
-
return this._points.length > 0 ? this._points[0] : new AcGePoint3d();
|
|
173
|
-
},
|
|
174
|
-
enumerable: false,
|
|
175
|
-
configurable: true
|
|
176
|
-
});
|
|
177
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "endPoint", {
|
|
178
|
-
/**
|
|
179
|
-
* End point of this curve.
|
|
180
|
-
*/
|
|
181
|
-
get: function () {
|
|
182
|
-
return this._points.length > 0
|
|
183
|
-
? this._points[this._points.length - 1]
|
|
184
|
-
: new AcGePoint3d();
|
|
185
|
-
},
|
|
186
|
-
enumerable: false,
|
|
187
|
-
configurable: true
|
|
188
|
-
});
|
|
189
|
-
Object.defineProperty(AcGeCatmullRomCurve3d.prototype, "length", {
|
|
190
|
-
/**
|
|
191
|
-
* Length of this curve (approximated).
|
|
192
|
-
*/
|
|
193
|
-
get: function () {
|
|
194
|
-
if (this._points.length < 2)
|
|
195
|
-
return 0;
|
|
196
|
-
var totalLength = 0;
|
|
197
|
-
for (var i = 1; i < this._points.length; i++) {
|
|
198
|
-
totalLength += this._points[i - 1].distanceTo(this._points[i]);
|
|
199
|
-
}
|
|
200
|
-
if (this._closed && this._points.length > 2) {
|
|
201
|
-
totalLength += this._points[this._points.length - 1].distanceTo(this._points[0]);
|
|
202
|
-
}
|
|
203
|
-
return totalLength;
|
|
204
|
-
},
|
|
205
|
-
enumerable: false,
|
|
206
|
-
configurable: true
|
|
207
|
-
});
|
|
208
|
-
/**
|
|
209
|
-
* Returns a point on the curve.
|
|
210
|
-
*
|
|
211
|
-
* @param t - A interpolation factor representing a position on the curve. Must be in the range `[0,1]`.
|
|
212
|
-
* @param optionalTarget - The optional target vector the result is written to.
|
|
213
|
-
* @return The position on the curve.
|
|
214
|
-
*/
|
|
215
|
-
AcGeCatmullRomCurve3d.prototype.getPoint = function (t, optionalTarget) {
|
|
216
|
-
if (optionalTarget === void 0) { optionalTarget = new AcGePoint3d(); }
|
|
217
|
-
var point = optionalTarget;
|
|
218
|
-
var points = this._points;
|
|
219
|
-
var l = points.length;
|
|
220
|
-
if (l === 0) {
|
|
221
|
-
return point.set(0, 0, 0);
|
|
222
|
-
}
|
|
223
|
-
if (l === 1) {
|
|
224
|
-
return point.copy(points[0]);
|
|
225
|
-
}
|
|
226
|
-
var p = (l - (this._closed ? 0 : 1)) * t;
|
|
227
|
-
var intPoint = Math.floor(p);
|
|
228
|
-
var weight = p - intPoint;
|
|
229
|
-
if (this._closed) {
|
|
230
|
-
intPoint +=
|
|
231
|
-
intPoint > 0 ? 0 : (Math.floor(Math.abs(intPoint) / l) + 1) * l;
|
|
232
|
-
}
|
|
233
|
-
else if (weight === 0 && intPoint === l - 1) {
|
|
234
|
-
intPoint = l - 2;
|
|
235
|
-
weight = 1;
|
|
236
|
-
}
|
|
237
|
-
var p0, p3; // 4 points (p1 & p2 defined below)
|
|
238
|
-
if (this._closed || intPoint > 0) {
|
|
239
|
-
p0 = points[(intPoint - 1) % l];
|
|
240
|
-
}
|
|
241
|
-
else {
|
|
242
|
-
// extrapolate first point
|
|
243
|
-
this._tmp.subVectors(points[0], points[1]).add(points[0]);
|
|
244
|
-
p0 = new AcGePoint3d(this._tmp.x, this._tmp.y, this._tmp.z);
|
|
245
|
-
}
|
|
246
|
-
var p1 = points[intPoint % l];
|
|
247
|
-
var p2 = points[(intPoint + 1) % l];
|
|
248
|
-
if (this._closed || intPoint + 2 < l) {
|
|
249
|
-
p3 = points[(intPoint + 2) % l];
|
|
250
|
-
}
|
|
251
|
-
else {
|
|
252
|
-
// extrapolate last point
|
|
253
|
-
this._tmp.subVectors(points[l - 1], points[l - 2]).add(points[l - 1]);
|
|
254
|
-
p3 = new AcGePoint3d(this._tmp.x, this._tmp.y, this._tmp.z);
|
|
255
|
-
}
|
|
256
|
-
if (this._curveType === 'centripetal' || this._curveType === 'chordal') {
|
|
257
|
-
// init Centripetal / Chordal Catmull-Rom
|
|
258
|
-
var pow = this._curveType === 'chordal' ? 0.5 : 0.25;
|
|
259
|
-
var dt0 = Math.pow(p0.distanceToSquared(p1), pow);
|
|
260
|
-
var dt1 = Math.pow(p1.distanceToSquared(p2), pow);
|
|
261
|
-
var dt2 = Math.pow(p2.distanceToSquared(p3), pow);
|
|
262
|
-
// safety check for repeated points
|
|
263
|
-
if (dt1 < 1e-4)
|
|
264
|
-
dt1 = 1.0;
|
|
265
|
-
if (dt0 < 1e-4)
|
|
266
|
-
dt0 = dt1;
|
|
267
|
-
if (dt2 < 1e-4)
|
|
268
|
-
dt2 = dt1;
|
|
269
|
-
this._px.initNonuniformCatmullRom(p0.x, p1.x, p2.x, p3.x, dt0, dt1, dt2);
|
|
270
|
-
this._py.initNonuniformCatmullRom(p0.y, p1.y, p2.y, p3.y, dt0, dt1, dt2);
|
|
271
|
-
this._pz.initNonuniformCatmullRom(p0.z, p1.z, p2.z, p3.z, dt0, dt1, dt2);
|
|
272
|
-
}
|
|
273
|
-
else if (this._curveType === 'catmullrom') {
|
|
274
|
-
this._px.initCatmullRom(p0.x, p1.x, p2.x, p3.x, this._tension);
|
|
275
|
-
this._py.initCatmullRom(p0.y, p1.y, p2.y, p3.y, this._tension);
|
|
276
|
-
this._pz.initCatmullRom(p0.z, p1.z, p2.z, p3.z, this._tension);
|
|
277
|
-
}
|
|
278
|
-
point.set(this._px.calc(weight), this._py.calc(weight), this._pz.calc(weight));
|
|
279
|
-
return point;
|
|
280
|
-
};
|
|
281
|
-
/**
|
|
282
|
-
* Get an array of points along the curve
|
|
283
|
-
* @param divisions - Number of divisions to create
|
|
284
|
-
* @returns Array of points along the curve
|
|
285
|
-
*/
|
|
286
|
-
AcGeCatmullRomCurve3d.prototype.getPoints = function (divisions) {
|
|
287
|
-
var points = [];
|
|
288
|
-
for (var d = 0; d <= divisions; d++) {
|
|
289
|
-
points.push(this.getPoint(d / divisions));
|
|
290
|
-
}
|
|
291
|
-
return points;
|
|
292
|
-
};
|
|
293
|
-
/**
|
|
294
|
-
* Set the points defining the curve
|
|
295
|
-
* @param points - Array of points
|
|
296
|
-
*/
|
|
297
|
-
AcGeCatmullRomCurve3d.prototype.setPoints = function (points) {
|
|
298
|
-
this._points = points.map(function (p) { return new AcGePoint3d(p); });
|
|
299
|
-
this._boundingBoxNeedsUpdate = true;
|
|
300
|
-
};
|
|
301
|
-
/**
|
|
302
|
-
* Set whether the curve is closed
|
|
303
|
-
* @param closed - Whether the curve should be closed
|
|
304
|
-
*/
|
|
305
|
-
AcGeCatmullRomCurve3d.prototype.setClosed = function (closed) {
|
|
306
|
-
if (this._closed === closed) {
|
|
307
|
-
return;
|
|
308
|
-
}
|
|
309
|
-
this._closed = closed;
|
|
310
|
-
this._boundingBoxNeedsUpdate = true;
|
|
311
|
-
};
|
|
312
|
-
/**
|
|
313
|
-
* Set the curve type
|
|
314
|
-
* @param curveType - The curve type
|
|
315
|
-
*/
|
|
316
|
-
AcGeCatmullRomCurve3d.prototype.setCurveType = function (curveType) {
|
|
317
|
-
this._curveType = curveType;
|
|
318
|
-
};
|
|
319
|
-
/**
|
|
320
|
-
* Set the tension of the curve
|
|
321
|
-
* @param tension - The tension value
|
|
322
|
-
*/
|
|
323
|
-
AcGeCatmullRomCurve3d.prototype.setTension = function (tension) {
|
|
324
|
-
this._tension = tension;
|
|
325
|
-
};
|
|
326
|
-
/**
|
|
327
|
-
* Transforms the curve by applying the input matrix.
|
|
328
|
-
* @param matrix Input transformation matrix
|
|
329
|
-
* @return Return this curve
|
|
330
|
-
*/
|
|
331
|
-
AcGeCatmullRomCurve3d.prototype.transform = function (matrix) {
|
|
332
|
-
this._points = this._points.map(function (point) {
|
|
333
|
-
var transformedPoint = new AcGePoint3d();
|
|
334
|
-
transformedPoint.copy(point);
|
|
335
|
-
transformedPoint.applyMatrix3d(matrix);
|
|
336
|
-
return transformedPoint;
|
|
337
|
-
});
|
|
338
|
-
this._boundingBoxNeedsUpdate = true;
|
|
339
|
-
return this;
|
|
340
|
-
};
|
|
341
|
-
/**
|
|
342
|
-
* Calculate the bounding box of this curve.
|
|
343
|
-
* @return The bounding box
|
|
344
|
-
*/
|
|
345
|
-
AcGeCatmullRomCurve3d.prototype.calculateBoundingBox = function () {
|
|
346
|
-
if (this._points.length === 0) {
|
|
347
|
-
return new AcGeBox3d();
|
|
348
|
-
}
|
|
349
|
-
var box = new AcGeBox3d();
|
|
350
|
-
this._points.forEach(function (point) {
|
|
351
|
-
box.expandByPoint(point);
|
|
352
|
-
});
|
|
353
|
-
return box;
|
|
354
|
-
};
|
|
355
|
-
return AcGeCatmullRomCurve3d;
|
|
356
|
-
}(AcGeCurve3d));
|
|
357
|
-
export { AcGeCatmullRomCurve3d };
|
|
358
|
-
//# sourceMappingURL=AcGeCatmullRomCurve3d.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AcGeCatmullRomCurve3d.js","sourceRoot":"","sources":["../../src/geometry/AcGeCatmullRomCurve3d.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import { AcGeBox2d, AcGeMatrix2d, AcGePoint2d, AcGePoint2dLike } from '../math';
|
|
2
|
-
import { AcGeCurve2d } from './AcGeCurve2d';
|
|
3
|
-
/**
|
|
4
|
-
* Represent a circular arc.
|
|
5
|
-
*
|
|
6
|
-
* The angle system behavior depends on the clockwise property:
|
|
7
|
-
* - If clockwise = false (counterclockwise): Angles are stored in normal mathematical sense
|
|
8
|
-
* (0° = +X axis, 90° = +Y axis, 180° = -X axis, 270° = -Y axis)
|
|
9
|
-
* - If clockwise = true: Angles are stored in a mirrored system where positive angles go clockwise
|
|
10
|
-
* (0° = +X axis, 270° = +Y axis, 180° = -X axis, 90° = -Y axis)
|
|
11
|
-
*
|
|
12
|
-
* This means a "90° above X axis" in counterclockwise mode becomes "270°" in clockwise mode.
|
|
13
|
-
*/
|
|
14
|
-
export declare class AcGeCircArc2d extends AcGeCurve2d {
|
|
15
|
-
private _center;
|
|
16
|
-
private _radius;
|
|
17
|
-
private _startAngle;
|
|
18
|
-
private _endAngle;
|
|
19
|
-
private _clockwise;
|
|
20
|
-
constructor(p1: AcGePoint2dLike, p2: AcGePoint2dLike, p3: AcGePoint2dLike);
|
|
21
|
-
constructor(start: AcGePoint2dLike, end: AcGePoint2dLike, bulge: number);
|
|
22
|
-
constructor(center: AcGePoint2dLike, radius: number, startAngle: number, endAngle: number, clockwise: boolean);
|
|
23
|
-
/**
|
|
24
|
-
* Create arc by three points
|
|
25
|
-
* @param p1 Input the start point
|
|
26
|
-
* @param p2 Input one point between the start point and the end point
|
|
27
|
-
* @param p3 Input the end point
|
|
28
|
-
*/
|
|
29
|
-
private createByThreePoints;
|
|
30
|
-
/**
|
|
31
|
-
* Create circular arc by two points and one bugle factor
|
|
32
|
-
* @param from Input start point
|
|
33
|
-
* @param to Input end point
|
|
34
|
-
* @param bulge Input the bulge factor used to indicate how much of an arc segment is present at this
|
|
35
|
-
* vertex. The bulge factor is the tangent of one fourth the included angle for an arc segment, made
|
|
36
|
-
* negative if the arc goes clockwise from the start point to the endpoint. A bulge of 0 indicates a
|
|
37
|
-
* straight segment, and a bulge of 1 is a semicircle. Get more details from the following links.
|
|
38
|
-
* - https://ezdxf.readthedocs.io/en/stable/dxfentities/lwpolyline.html
|
|
39
|
-
* - https://www.afralisp.net/archive/lisp/Bulges1.htm
|
|
40
|
-
*/
|
|
41
|
-
private createByStartEndPointsAndBulge;
|
|
42
|
-
/**
|
|
43
|
-
* Center of circular arc
|
|
44
|
-
*/
|
|
45
|
-
get center(): AcGePoint2d;
|
|
46
|
-
set center(value: AcGePoint2dLike);
|
|
47
|
-
/**
|
|
48
|
-
* Radius of circular arc
|
|
49
|
-
*/
|
|
50
|
-
get radius(): number;
|
|
51
|
-
set radius(value: number);
|
|
52
|
-
/**
|
|
53
|
-
* Start angle in radians of circular arc in the range 0 to 2 * PI.
|
|
54
|
-
* If clockwise=true, angles are mirrored (0 = +X, 270° = +Y, 180° = -X, 90° = -Y).
|
|
55
|
-
* If clockwise=false, angles are in normal mathematical sense (0 = +X, 90° = +Y, 180° = -X, 270° = -Y).
|
|
56
|
-
*/
|
|
57
|
-
get startAngle(): number;
|
|
58
|
-
set startAngle(value: number);
|
|
59
|
-
/**
|
|
60
|
-
* End angle in radians of circular arc in the range 0 to 2 * PI.
|
|
61
|
-
* If clockwise=true, angles are mirrored (0 = +X, 270° = +Y, 180° = -X, 90° = -Y).
|
|
62
|
-
* If clockwise=false, angles are in normal mathematical sense (0 = +X, 90° = +Y, 180° = -X, 270° = -Y).
|
|
63
|
-
*/
|
|
64
|
-
get endAngle(): number;
|
|
65
|
-
set endAngle(value: number);
|
|
66
|
-
/**
|
|
67
|
-
* Mirror an angle for clockwise mode: 0° stays 0°, 90° becomes 270°, 180° stays 180°, 270° becomes 90°
|
|
68
|
-
* @param angle Input angle in radians
|
|
69
|
-
* @returns Mirrored angle in radians
|
|
70
|
-
*/
|
|
71
|
-
private _mirrorAngle;
|
|
72
|
-
/**
|
|
73
|
-
* Get the internal (unmirrored) angle for calculations
|
|
74
|
-
* @param angle Input angle (may be mirrored)
|
|
75
|
-
* @returns Internal angle for calculations
|
|
76
|
-
*/
|
|
77
|
-
private _getInternalAngle;
|
|
78
|
-
/**
|
|
79
|
-
* Angle between endAngle and startAngle in range 0 to 2*PI
|
|
80
|
-
*/
|
|
81
|
-
get deltaAngle(): number;
|
|
82
|
-
/**
|
|
83
|
-
* Rotation direction of the arc.
|
|
84
|
-
*/
|
|
85
|
-
get clockwise(): boolean;
|
|
86
|
-
set clockwise(value: boolean);
|
|
87
|
-
/**
|
|
88
|
-
* Start point of circular arc
|
|
89
|
-
*/
|
|
90
|
-
get startPoint(): AcGePoint2d;
|
|
91
|
-
/**
|
|
92
|
-
* End point of circular arc
|
|
93
|
-
*/
|
|
94
|
-
get endPoint(): AcGePoint2d;
|
|
95
|
-
/**
|
|
96
|
-
* Middle point of circular arc
|
|
97
|
-
*/
|
|
98
|
-
get midPoint(): AcGePoint2d;
|
|
99
|
-
/**
|
|
100
|
-
* Return true if its start point is identical to its end point. Otherwise, return false.
|
|
101
|
-
*/
|
|
102
|
-
get closed(): boolean;
|
|
103
|
-
/**
|
|
104
|
-
* @inheritdoc
|
|
105
|
-
*/
|
|
106
|
-
calculateBoundingBox(): AcGeBox2d;
|
|
107
|
-
/**
|
|
108
|
-
* Get length of circular arc
|
|
109
|
-
*/
|
|
110
|
-
get length(): number;
|
|
111
|
-
/**
|
|
112
|
-
* @inheritdoc
|
|
113
|
-
*/
|
|
114
|
-
transform(_matrix: AcGeMatrix2d): this;
|
|
115
|
-
/**
|
|
116
|
-
* @inheritdoc
|
|
117
|
-
*/
|
|
118
|
-
clone(): AcGeCircArc2d;
|
|
119
|
-
/**
|
|
120
|
-
* Calculate a point on the ellipse at a given angle.
|
|
121
|
-
* @param angle Input the angle in radians where the point is to be calculated.
|
|
122
|
-
* @returns Return the 2d coordinates of the point on the circular arc.
|
|
123
|
-
*/
|
|
124
|
-
getPointAtAngle(angle: number): AcGePoint2d;
|
|
125
|
-
/**
|
|
126
|
-
* Divide this arc into the specified nubmer of points and return those points as an array of points.
|
|
127
|
-
* @param numPoints Input the nubmer of points returned
|
|
128
|
-
* @returns Return an array of points
|
|
129
|
-
*/
|
|
130
|
-
getPoints(numPoints?: number): AcGePoint2d[];
|
|
131
|
-
}
|
|
132
|
-
//# sourceMappingURL=AcGeCircArc2d.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AcGeCircArc2d.d.ts","sourceRoot":"","sources":["../../src/geometry/AcGeCircArc2d.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,WAAW,EACX,eAAe,EAEhB,MAAM,SAAS,CAAA;AAEhB,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C;;;;;;;;;;GAUG;AACH,qBAAa,aAAc,SAAQ,WAAW;IAC5C,OAAO,CAAC,OAAO,CAAc;IAC7B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,WAAW,CAAS;IAC5B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,UAAU,CAAU;gBAEhB,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE,eAAe,EAAE,EAAE,EAAE,eAAe;gBAC7D,KAAK,EAAE,eAAe,EAAE,GAAG,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM;gBAErE,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,OAAO;IA6CpB;;;;;OAKG;IACH,OAAO,CAAC,mBAAmB;IAmE3B;;;;;;;;;;OAUG;IACH,OAAO,CAAC,8BAA8B;IA2DtC;;OAEG;IACH,IAAI,MAAM,IAAI,WAAW,CAExB;IACD,IAAI,MAAM,CAAC,KAAK,EAAE,eAAe,EAGhC;IAED;;OAEG;IACH,IAAI,MAAM,IAAI,MAAM,CAEnB;IACD,IAAI,MAAM,CAAC,KAAK,EAAE,MAAM,EAGvB;IAED;;;;OAIG;IACH,IAAI,UAAU,IAAI,MAAM,CAIvB;IACD,IAAI,UAAU,CAAC,KAAK,EAAE,MAAM,EAK3B;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,MAAM,CAErB;IACD,IAAI,QAAQ,CAAC,KAAK,EAAE,MAAM,EASzB;IAED;;;;OAIG;IACH,OAAO,CAAC,YAAY;IAQpB;;;;OAIG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;OAEG;IACH,IAAI,UAAU,WAMb;IAED;;OAEG;IACH,IAAI,SAAS,IAGQ,OAAO,CAD3B;IACD,IAAI,SAAS,CAAC,KAAK,EAAE,OAAO,EAG3B;IAED;;OAEG;IACH,IAAI,UAAU,IAAI,WAAW,CAE5B;IAED;;OAEG;IACH,IAAI,QAAQ,IAAI,WAAW,CAE1B;IAED;;OAEG;IACH,IAAI,QAAQ,IAAI,WAAW,CAU1B;IAED;;OAEG;IACH,IAAI,MAAM,YAIT;IAED;;OAEG;IACH,oBAAoB,IAAI,SAAS;IA2BjC;;OAEG;IACH,IAAI,MAAM,WAET;IAED;;OAEG;IACH,SAAS,CAAC,OAAO,EAAE,YAAY;IAM/B;;OAEG;IACH,KAAK;IAUL;;;;OAIG;IACH,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW;IAO3C;;;;OAIG;IACH,SAAS,CAAC,SAAS,GAAE,MAAY,GAAG,WAAW,EAAE;CA6BlD"}
|