brepjs 8.8.2 → 8.8.3
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/dist/2d/curves.d.ts.map +1 -1
- package/dist/2d/lib/Curve2D.d.ts.map +1 -1
- package/dist/2d/lib/approximations.d.ts.map +1 -1
- package/dist/2d/lib/makeCurves.d.ts.map +1 -1
- package/dist/2d/lib/ocWrapper.d.ts.map +1 -1
- package/dist/2d.cjs +2 -2
- package/dist/2d.js +3 -3
- package/dist/Blueprint-BmFJ4caY.cjs +1439 -0
- package/dist/Blueprint-DsoGiJNJ.js +1440 -0
- package/dist/{boolean2D-q5FOdOQW.cjs → boolean2D-BQk8LNmZ.cjs} +212 -127
- package/dist/{boolean2D-Dgnuy63w.js → boolean2D-D5O0F3J8.js} +212 -127
- package/dist/{booleanFns-CFit7JYt.cjs → booleanFns-CVM3dOTP.cjs} +210 -130
- package/dist/{booleanFns--Orezl-b.js → booleanFns-DOyKxL7q.js} +210 -130
- package/dist/brepjs.cjs +457 -304
- package/dist/brepjs.js +551 -398
- package/dist/core/disposal.d.ts +44 -3
- package/dist/core/disposal.d.ts.map +1 -1
- package/dist/core/geometryHelpers.d.ts.map +1 -1
- package/dist/core/kernelCall.d.ts +20 -0
- package/dist/core/kernelCall.d.ts.map +1 -1
- package/dist/core/memory.d.ts +1 -1
- package/dist/core/memory.d.ts.map +1 -1
- package/dist/core.cjs +4 -1
- package/dist/core.d.ts +1 -1
- package/dist/core.d.ts.map +1 -1
- package/dist/core.js +11 -8
- package/dist/{cornerFinder-KNTFoGrm.js → cornerFinder-DH6EwYfL.js} +1 -1
- package/dist/{cornerFinder-v4un1Fr9.cjs → cornerFinder-XAV2ywVS.cjs} +1 -1
- package/dist/curveFns-BHRYwxBM.js +281 -0
- package/dist/{curveFns-6ovDM_sR.cjs → curveFns-BsAHC3Qv.cjs} +137 -36
- package/dist/{drawFns-WgXeXHH1.cjs → drawFns-CsmUF97U.cjs} +181 -101
- package/dist/{drawFns-XwroLxdb.js → drawFns-hD05g0ZQ.js} +181 -101
- package/dist/faceFns-DNQss51F.cjs +358 -0
- package/dist/faceFns-q5CR9pOW.js +359 -0
- package/dist/{helpers-CRfqaW0Y.cjs → helpers-aylLv0_I.cjs} +13 -10
- package/dist/{helpers-CtBCzEqs.js → helpers-tNdaX01G.js} +13 -10
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/io/importFns.d.ts.map +1 -1
- package/dist/io.cjs +131 -63
- package/dist/io.js +131 -63
- package/dist/loft-CjEEqz2P.cjs +530 -0
- package/dist/loft-DTRcYrq2.js +531 -0
- package/dist/measurement-B6_cxjpw.cjs +200 -0
- package/dist/measurement-BXqFvcGh.js +201 -0
- package/dist/measurement.cjs +1 -1
- package/dist/measurement.js +1 -1
- package/dist/{meshFns-CPNNlpbw.cjs → meshFns-CTc1CRkF.cjs} +1 -1
- package/dist/{meshFns-DAmWVyEp.js → meshFns-DDFl7gLN.js} +1 -1
- package/dist/operations/exporterFns.d.ts.map +1 -1
- package/dist/operations/exporterUtils.d.ts +3 -3
- package/dist/operations/exporterUtils.d.ts.map +1 -1
- package/dist/operations/exporters.d.ts.map +1 -1
- package/dist/operations/extrude.d.ts.map +1 -1
- package/dist/operations/extrudeFns.d.ts.map +1 -1
- package/dist/operations/loft.d.ts.map +1 -1
- package/dist/operations/multiSweepFns.d.ts.map +1 -1
- package/dist/{operations-vN0tcoaU.js → operations-jRE2QbPo.js} +261 -166
- package/dist/{operations-BQ25CPI8.cjs → operations-pxjbW4Er.cjs} +261 -166
- package/dist/operations.cjs +2 -2
- package/dist/operations.js +2 -2
- package/dist/query/shapeDistanceFilter.d.ts.map +1 -1
- package/dist/query.cjs +66 -14
- package/dist/query.js +67 -15
- package/dist/{shapeFns-C785aeVn.cjs → shapeFns-D4CRxxmF.cjs} +61 -7
- package/dist/{shapeFns-ClpALED4.js → shapeFns-DNnBK8fG.js} +61 -7
- package/dist/{shapeTypes-DnwCo942.js → shapeTypes-Bi_9RZa2.js} +50 -19
- package/dist/{shapeTypes-CIijJxCz.cjs → shapeTypes-CWuX602K.cjs} +32 -1
- package/dist/sketching/CompoundSketch.d.ts.map +1 -1
- package/dist/sketching/Sketch.d.ts.map +1 -1
- package/dist/sketching/Sketcher.d.ts.map +1 -1
- package/dist/sketching/Sketcher2d.d.ts.map +1 -1
- package/dist/sketching/cannedSketches.d.ts.map +1 -1
- package/dist/sketching/draw.d.ts.map +1 -1
- package/dist/sketching.cjs +2 -2
- package/dist/sketching.js +2 -2
- package/dist/surfaceBuilders-CLal3WlK.cjs +429 -0
- package/dist/surfaceBuilders-W9Y25CIb.js +430 -0
- package/dist/topology/curveBuilders.d.ts.map +1 -1
- package/dist/topology/shapeFns.d.ts.map +1 -1
- package/dist/topology/solidBuilders.d.ts.map +1 -1
- package/dist/topology/surfaceBuilders.d.ts.map +1 -1
- package/dist/{topology-CqyxpmEh.js → topology-CMM6vAzx.js} +6 -6
- package/dist/{topology-zG8maSDK.cjs → topology-CNw-wsmG.cjs} +6 -6
- package/dist/topology.cjs +6 -6
- package/dist/topology.js +6 -6
- package/package.json +4 -1
- package/dist/Blueprint-BmbNUnGI.cjs +0 -1185
- package/dist/Blueprint-C-JJkkwL.js +0 -1186
- package/dist/curveFns-BhQECv8e.js +0 -180
- package/dist/faceFns-3PDjBeW7.js +0 -272
- package/dist/faceFns-CxaLWOjc.cjs +0 -271
- package/dist/loft-CVb-IjEI.cjs +0 -372
- package/dist/loft-DMFjK6lk.js +0 -373
- package/dist/measurement-CecYIt3s.cjs +0 -134
- package/dist/measurement-DHDLAH7-.js +0 -135
- package/dist/surfaceBuilders-CC0ZQGix.cjs +0 -289
- package/dist/surfaceBuilders-CrJtFu2a.js +0 -290
|
@@ -0,0 +1,429 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __knownSymbol = (name, symbol) => (symbol = Symbol[name]) ? symbol : /* @__PURE__ */ Symbol.for("Symbol." + name);
|
|
3
|
+
var __typeError = (msg) => {
|
|
4
|
+
throw TypeError(msg);
|
|
5
|
+
};
|
|
6
|
+
var __using = (stack, value, async) => {
|
|
7
|
+
if (value != null) {
|
|
8
|
+
if (typeof value !== "object" && typeof value !== "function") __typeError("Object expected");
|
|
9
|
+
var dispose, inner;
|
|
10
|
+
if (async) dispose = value[__knownSymbol("asyncDispose")];
|
|
11
|
+
if (dispose === void 0) {
|
|
12
|
+
dispose = value[__knownSymbol("dispose")];
|
|
13
|
+
if (async) inner = dispose;
|
|
14
|
+
}
|
|
15
|
+
if (typeof dispose !== "function") __typeError("Object not disposable");
|
|
16
|
+
if (inner) dispose = function() {
|
|
17
|
+
try {
|
|
18
|
+
inner.call(this);
|
|
19
|
+
} catch (e) {
|
|
20
|
+
return Promise.reject(e);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
stack.push([async, dispose, value]);
|
|
24
|
+
} else if (async) {
|
|
25
|
+
stack.push([async]);
|
|
26
|
+
}
|
|
27
|
+
return value;
|
|
28
|
+
};
|
|
29
|
+
var __callDispose = (stack, error, hasError) => {
|
|
30
|
+
var E = typeof SuppressedError === "function" ? SuppressedError : function(e, s, m, _) {
|
|
31
|
+
return _ = Error(m), _.name = "SuppressedError", _.error = e, _.suppressed = s, _;
|
|
32
|
+
};
|
|
33
|
+
var fail = (e) => error = hasError ? new E(e, error, "An error was suppressed during disposal") : (hasError = true, e);
|
|
34
|
+
var next = (it) => {
|
|
35
|
+
while (it = stack.pop()) {
|
|
36
|
+
try {
|
|
37
|
+
var result = it[1] && it[1].call(it[2]);
|
|
38
|
+
if (it[0]) return Promise.resolve(result).then(next, (e) => (fail(e), next()));
|
|
39
|
+
} catch (e) {
|
|
40
|
+
fail(e);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if (hasError) throw error;
|
|
44
|
+
};
|
|
45
|
+
return next();
|
|
46
|
+
};
|
|
47
|
+
const occtBoundary = require("./occtBoundary-Cqfsau2c.cjs");
|
|
48
|
+
const errors = require("./errors-NNmTtM5u.cjs");
|
|
49
|
+
const shapeTypes = require("./shapeTypes-CWuX602K.cjs");
|
|
50
|
+
const shapeFns = require("./shapeFns-D4CRxxmF.cjs");
|
|
51
|
+
const faceFns = require("./faceFns-DNQss51F.cjs");
|
|
52
|
+
function range(len) {
|
|
53
|
+
return Array.from(Array(len).keys());
|
|
54
|
+
}
|
|
55
|
+
function zip(arrays) {
|
|
56
|
+
const minLength = Math.min(...arrays.map((arr) => arr.length));
|
|
57
|
+
return range(minLength).map((i) => arrays.map((arr) => arr[i]));
|
|
58
|
+
}
|
|
59
|
+
function makeLine(v1, v2) {
|
|
60
|
+
var _stack = [];
|
|
61
|
+
try {
|
|
62
|
+
const oc = occtBoundary.getKernel().oc;
|
|
63
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
64
|
+
const p1 = scope.register(occtBoundary.toOcPnt(v1));
|
|
65
|
+
const p2 = scope.register(occtBoundary.toOcPnt(v2));
|
|
66
|
+
const maker = scope.register(new oc.BRepBuilderAPI_MakeEdge_3(p1, p2));
|
|
67
|
+
return shapeTypes.createEdge(maker.Edge());
|
|
68
|
+
} catch (_) {
|
|
69
|
+
var _error = _, _hasError = true;
|
|
70
|
+
} finally {
|
|
71
|
+
__callDispose(_stack, _error, _hasError);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
function makeCircle(radius, center = [0, 0, 0], normal = [0, 0, 1]) {
|
|
75
|
+
var _stack = [];
|
|
76
|
+
try {
|
|
77
|
+
const oc = occtBoundary.getKernel().oc;
|
|
78
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
79
|
+
const ax = scope.register(occtBoundary.makeOcAx2(center, normal));
|
|
80
|
+
const circleGp = scope.register(new oc.gp_Circ_2(ax, radius));
|
|
81
|
+
const edgeMaker = scope.register(new oc.BRepBuilderAPI_MakeEdge_8(circleGp));
|
|
82
|
+
return shapeTypes.createEdge(edgeMaker.Edge());
|
|
83
|
+
} catch (_) {
|
|
84
|
+
var _error = _, _hasError = true;
|
|
85
|
+
} finally {
|
|
86
|
+
__callDispose(_stack, _error, _hasError);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
function makeEllipse(majorRadius, minorRadius, center = [0, 0, 0], normal = [0, 0, 1], xDir) {
|
|
90
|
+
var _stack = [];
|
|
91
|
+
try {
|
|
92
|
+
if (minorRadius > majorRadius) {
|
|
93
|
+
return errors.err(
|
|
94
|
+
errors.validationError("ELLIPSE_RADII", "The minor radius must be smaller than the major one")
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
const oc = occtBoundary.getKernel().oc;
|
|
98
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
99
|
+
const ax = scope.register(occtBoundary.makeOcAx2(center, normal, xDir));
|
|
100
|
+
const ellipseGp = scope.register(new oc.gp_Elips_2(ax, majorRadius, minorRadius));
|
|
101
|
+
const edgeMaker = scope.register(new oc.BRepBuilderAPI_MakeEdge_12(ellipseGp));
|
|
102
|
+
return errors.ok(shapeTypes.createEdge(edgeMaker.Edge()));
|
|
103
|
+
} catch (_) {
|
|
104
|
+
var _error = _, _hasError = true;
|
|
105
|
+
} finally {
|
|
106
|
+
__callDispose(_stack, _error, _hasError);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
function makeHelix(pitch, height, radius, center = [0, 0, 0], dir = [0, 0, 1], lefthand = false) {
|
|
110
|
+
var _stack = [];
|
|
111
|
+
try {
|
|
112
|
+
const oc = occtBoundary.getKernel().oc;
|
|
113
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
114
|
+
const angularStep = lefthand ? -2 * Math.PI : 2 * Math.PI;
|
|
115
|
+
const geomLine = scope.register(
|
|
116
|
+
new oc.Geom2d_Line_3(
|
|
117
|
+
scope.register(new oc.gp_Pnt2d_3(0, 0)),
|
|
118
|
+
scope.register(new oc.gp_Dir2d_4(angularStep, pitch))
|
|
119
|
+
)
|
|
120
|
+
);
|
|
121
|
+
const nTurns = height / pitch;
|
|
122
|
+
const uStart = scope.register(geomLine.Value(0));
|
|
123
|
+
const uStop = scope.register(geomLine.Value(nTurns * Math.sqrt((2 * Math.PI) ** 2 + pitch ** 2)));
|
|
124
|
+
const geomSeg = scope.register(new oc.GCE2d_MakeSegment_1(uStart, uStop));
|
|
125
|
+
const geomSurf = new oc.Geom_CylindricalSurface_1(scope.register(occtBoundary.makeOcAx3(center, dir)), radius);
|
|
126
|
+
const e = scope.register(
|
|
127
|
+
new oc.BRepBuilderAPI_MakeEdge_30(
|
|
128
|
+
scope.register(new oc.Handle_Geom2d_Curve_2(geomSeg.Value().get())),
|
|
129
|
+
scope.register(new oc.Handle_Geom_Surface_2(geomSurf))
|
|
130
|
+
)
|
|
131
|
+
).Edge();
|
|
132
|
+
const w = scope.register(new oc.BRepBuilderAPI_MakeWire_2(e)).Wire();
|
|
133
|
+
oc.BRepLib.BuildCurves3d_2(w);
|
|
134
|
+
return shapeTypes.createWire(w);
|
|
135
|
+
} catch (_) {
|
|
136
|
+
var _error = _, _hasError = true;
|
|
137
|
+
} finally {
|
|
138
|
+
__callDispose(_stack, _error, _hasError);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
function makeThreePointArc(v1, v2, v3) {
|
|
142
|
+
var _stack = [];
|
|
143
|
+
try {
|
|
144
|
+
const oc = occtBoundary.getKernel().oc;
|
|
145
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
146
|
+
const p1 = scope.register(occtBoundary.toOcPnt(v1));
|
|
147
|
+
const p2 = scope.register(occtBoundary.toOcPnt(v2));
|
|
148
|
+
const p3 = scope.register(occtBoundary.toOcPnt(v3));
|
|
149
|
+
const arcMaker = scope.register(new oc.GC_MakeArcOfCircle_4(p1, p2, p3));
|
|
150
|
+
const circleGeom = scope.register(arcMaker.Value());
|
|
151
|
+
const curve = scope.register(new oc.Handle_Geom_Curve_2(circleGeom.get()));
|
|
152
|
+
const edgeMaker = scope.register(new oc.BRepBuilderAPI_MakeEdge_24(curve));
|
|
153
|
+
return shapeTypes.createEdge(edgeMaker.Edge());
|
|
154
|
+
} catch (_) {
|
|
155
|
+
var _error = _, _hasError = true;
|
|
156
|
+
} finally {
|
|
157
|
+
__callDispose(_stack, _error, _hasError);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
function makeEllipseArc(majorRadius, minorRadius, startAngle, endAngle, center = [0, 0, 0], normal = [0, 0, 1], xDir) {
|
|
161
|
+
var _stack = [];
|
|
162
|
+
try {
|
|
163
|
+
if (minorRadius > majorRadius) {
|
|
164
|
+
return errors.err(
|
|
165
|
+
errors.validationError("ELLIPSE_RADII", "The minor radius must be smaller than the major one")
|
|
166
|
+
);
|
|
167
|
+
}
|
|
168
|
+
const oc = occtBoundary.getKernel().oc;
|
|
169
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
170
|
+
const ax = scope.register(occtBoundary.makeOcAx2(center, normal, xDir));
|
|
171
|
+
const ellipseGp = scope.register(new oc.gp_Elips_2(ax, majorRadius, minorRadius));
|
|
172
|
+
const edgeMaker = scope.register(
|
|
173
|
+
new oc.BRepBuilderAPI_MakeEdge_13(ellipseGp, startAngle, endAngle)
|
|
174
|
+
);
|
|
175
|
+
return errors.ok(shapeTypes.createEdge(edgeMaker.Edge()));
|
|
176
|
+
} catch (_) {
|
|
177
|
+
var _error = _, _hasError = true;
|
|
178
|
+
} finally {
|
|
179
|
+
__callDispose(_stack, _error, _hasError);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
function makeBSplineApproximation(points, { tolerance = 1e-3, smoothing = null, degMax = 6, degMin = 1 } = {}) {
|
|
183
|
+
var _stack = [];
|
|
184
|
+
try {
|
|
185
|
+
const oc = occtBoundary.getKernel().oc;
|
|
186
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
187
|
+
const pnts = scope.register(new oc.TColgp_Array1OfPnt_2(1, points.length));
|
|
188
|
+
points.forEach((point, index) => {
|
|
189
|
+
pnts.SetValue(index + 1, scope.register(occtBoundary.toOcPnt(point)));
|
|
190
|
+
});
|
|
191
|
+
let splineBuilder;
|
|
192
|
+
if (smoothing) {
|
|
193
|
+
splineBuilder = scope.register(
|
|
194
|
+
new oc.GeomAPI_PointsToBSpline_5(
|
|
195
|
+
pnts,
|
|
196
|
+
smoothing[0],
|
|
197
|
+
smoothing[1],
|
|
198
|
+
smoothing[2],
|
|
199
|
+
degMax,
|
|
200
|
+
oc.GeomAbs_Shape.GeomAbs_C2,
|
|
201
|
+
tolerance
|
|
202
|
+
)
|
|
203
|
+
);
|
|
204
|
+
} else {
|
|
205
|
+
splineBuilder = scope.register(
|
|
206
|
+
new oc.GeomAPI_PointsToBSpline_2(
|
|
207
|
+
pnts,
|
|
208
|
+
degMin,
|
|
209
|
+
degMax,
|
|
210
|
+
oc.GeomAbs_Shape.GeomAbs_C2,
|
|
211
|
+
tolerance
|
|
212
|
+
)
|
|
213
|
+
);
|
|
214
|
+
}
|
|
215
|
+
if (!splineBuilder.IsDone()) {
|
|
216
|
+
return errors.err(errors.occtError("BSPLINE_FAILED", "B-spline approximation failed"));
|
|
217
|
+
}
|
|
218
|
+
const splineGeom = scope.register(splineBuilder.Curve());
|
|
219
|
+
const curve = scope.register(new oc.Handle_Geom_Curve_2(splineGeom.get()));
|
|
220
|
+
return errors.ok(shapeTypes.createEdge(new oc.BRepBuilderAPI_MakeEdge_24(curve).Edge()));
|
|
221
|
+
} catch (_) {
|
|
222
|
+
var _error = _, _hasError = true;
|
|
223
|
+
} finally {
|
|
224
|
+
__callDispose(_stack, _error, _hasError);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
function makeBezierCurve(points) {
|
|
228
|
+
var _stack = [];
|
|
229
|
+
try {
|
|
230
|
+
if (points.length < 2) {
|
|
231
|
+
return errors.err(
|
|
232
|
+
errors.validationError(
|
|
233
|
+
"BEZIER_MIN_POINTS",
|
|
234
|
+
`Need at least 2 points for a Bezier curve, got ${points.length}`,
|
|
235
|
+
void 0,
|
|
236
|
+
{
|
|
237
|
+
pointCount: points.length
|
|
238
|
+
}
|
|
239
|
+
)
|
|
240
|
+
);
|
|
241
|
+
}
|
|
242
|
+
const oc = occtBoundary.getKernel().oc;
|
|
243
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
244
|
+
const arrayOfPoints = scope.register(new oc.TColgp_Array1OfPnt_2(1, points.length));
|
|
245
|
+
points.forEach((p, i) => {
|
|
246
|
+
arrayOfPoints.SetValue(i + 1, scope.register(occtBoundary.toOcPnt(p)));
|
|
247
|
+
});
|
|
248
|
+
const bezCurve = new oc.Geom_BezierCurve_1(arrayOfPoints);
|
|
249
|
+
const curve = scope.register(new oc.Handle_Geom_Curve_2(bezCurve));
|
|
250
|
+
const edgeMaker = scope.register(new oc.BRepBuilderAPI_MakeEdge_24(curve));
|
|
251
|
+
return errors.ok(shapeTypes.createEdge(edgeMaker.Edge()));
|
|
252
|
+
} catch (_) {
|
|
253
|
+
var _error = _, _hasError = true;
|
|
254
|
+
} finally {
|
|
255
|
+
__callDispose(_stack, _error, _hasError);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
function makeTangentArc(startPoint, startTgt, endPoint) {
|
|
259
|
+
var _stack = [];
|
|
260
|
+
try {
|
|
261
|
+
const oc = occtBoundary.getKernel().oc;
|
|
262
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
263
|
+
const circleGeom = scope.register(
|
|
264
|
+
new oc.GC_MakeArcOfCircle_5(
|
|
265
|
+
scope.register(occtBoundary.toOcPnt(startPoint)),
|
|
266
|
+
scope.register(occtBoundary.toOcVec(startTgt)),
|
|
267
|
+
scope.register(occtBoundary.toOcPnt(endPoint))
|
|
268
|
+
).Value()
|
|
269
|
+
);
|
|
270
|
+
const curve = scope.register(new oc.Handle_Geom_Curve_2(circleGeom.get()));
|
|
271
|
+
const edgeMaker = scope.register(new oc.BRepBuilderAPI_MakeEdge_24(curve));
|
|
272
|
+
return shapeTypes.createEdge(edgeMaker.Edge());
|
|
273
|
+
} catch (_) {
|
|
274
|
+
var _error = _, _hasError = true;
|
|
275
|
+
} finally {
|
|
276
|
+
__callDispose(_stack, _error, _hasError);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
function assembleWire(listOfEdges) {
|
|
280
|
+
var _stack = [];
|
|
281
|
+
try {
|
|
282
|
+
const oc = occtBoundary.getKernel().oc;
|
|
283
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
284
|
+
const wireBuilder = scope.register(new oc.BRepBuilderAPI_MakeWire_1());
|
|
285
|
+
listOfEdges.forEach((e) => {
|
|
286
|
+
if (shapeTypes.isEdge(e)) {
|
|
287
|
+
wireBuilder.Add_1(e.wrapped);
|
|
288
|
+
}
|
|
289
|
+
if (shapeTypes.isWire(e)) {
|
|
290
|
+
wireBuilder.Add_2(e.wrapped);
|
|
291
|
+
}
|
|
292
|
+
});
|
|
293
|
+
const progress = scope.register(new oc.Message_ProgressRange_1());
|
|
294
|
+
wireBuilder.Build(progress);
|
|
295
|
+
const res = wireBuilder.Error();
|
|
296
|
+
if (res !== oc.BRepBuilderAPI_WireError.BRepBuilderAPI_WireDone) {
|
|
297
|
+
const errorNames = /* @__PURE__ */ new Map([
|
|
298
|
+
[oc.BRepBuilderAPI_WireError.BRepBuilderAPI_EmptyWire, "empty wire"],
|
|
299
|
+
[oc.BRepBuilderAPI_WireError.BRepBuilderAPI_NonManifoldWire, "non manifold wire"],
|
|
300
|
+
[oc.BRepBuilderAPI_WireError.BRepBuilderAPI_DisconnectedWire, "disconnected wire"]
|
|
301
|
+
]);
|
|
302
|
+
return errors.err(
|
|
303
|
+
errors.occtError(
|
|
304
|
+
"WIRE_BUILD_FAILED",
|
|
305
|
+
`Failed to build the wire, ${errorNames.get(res) || "unknown error"}`
|
|
306
|
+
)
|
|
307
|
+
);
|
|
308
|
+
}
|
|
309
|
+
return errors.ok(shapeTypes.createWire(wireBuilder.Wire()));
|
|
310
|
+
} catch (_) {
|
|
311
|
+
var _error = _, _hasError = true;
|
|
312
|
+
} finally {
|
|
313
|
+
__callDispose(_stack, _error, _hasError);
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
function makeFace(wire, holes) {
|
|
317
|
+
const oc = occtBoundary.getKernel().oc;
|
|
318
|
+
const faceBuilder = new oc.BRepBuilderAPI_MakeFace_15(wire.wrapped, false);
|
|
319
|
+
holes?.forEach((hole) => {
|
|
320
|
+
faceBuilder.Add(hole.wrapped);
|
|
321
|
+
});
|
|
322
|
+
if (!faceBuilder.IsDone()) {
|
|
323
|
+
faceBuilder.delete();
|
|
324
|
+
return errors.err(
|
|
325
|
+
errors.occtError("FACE_BUILD_FAILED", "Failed to build the face. Your wire might be non planar.")
|
|
326
|
+
);
|
|
327
|
+
}
|
|
328
|
+
const face = faceBuilder.Face();
|
|
329
|
+
faceBuilder.delete();
|
|
330
|
+
return errors.ok(shapeTypes.createFace(face));
|
|
331
|
+
}
|
|
332
|
+
function fill(face) {
|
|
333
|
+
const outer = faceFns.outerWire(face);
|
|
334
|
+
return makeFace(outer);
|
|
335
|
+
}
|
|
336
|
+
function makeNewFaceWithinFace(originFace, wire) {
|
|
337
|
+
var _stack = [];
|
|
338
|
+
try {
|
|
339
|
+
const oc = occtBoundary.getKernel().oc;
|
|
340
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
341
|
+
const surface = scope.register(oc.BRep_Tool.Surface_2(originFace.wrapped));
|
|
342
|
+
const faceBuilder = scope.register(
|
|
343
|
+
new oc.BRepBuilderAPI_MakeFace_21(surface, wire.wrapped, true)
|
|
344
|
+
);
|
|
345
|
+
const face = faceBuilder.Face();
|
|
346
|
+
return shapeTypes.createFace(face);
|
|
347
|
+
} catch (_) {
|
|
348
|
+
var _error = _, _hasError = true;
|
|
349
|
+
} finally {
|
|
350
|
+
__callDispose(_stack, _error, _hasError);
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
function makeNonPlanarFace(wire) {
|
|
354
|
+
var _stack = [];
|
|
355
|
+
try {
|
|
356
|
+
const oc = occtBoundary.getKernel().oc;
|
|
357
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
358
|
+
const faceBuilder = scope.register(
|
|
359
|
+
new oc.BRepOffsetAPI_MakeFilling(3, 15, 2, false, 1e-5, 1e-4, 0.01, 0.1, 8, 9)
|
|
360
|
+
);
|
|
361
|
+
shapeFns.getEdges(wire).forEach((edge) => {
|
|
362
|
+
faceBuilder.Add_1(
|
|
363
|
+
edge.wrapped,
|
|
364
|
+
oc.GeomAbs_Shape.GeomAbs_C0,
|
|
365
|
+
true
|
|
366
|
+
);
|
|
367
|
+
});
|
|
368
|
+
const progress = scope.register(new oc.Message_ProgressRange_1());
|
|
369
|
+
faceBuilder.Build(progress);
|
|
370
|
+
return errors.andThen(faceFns.cast(faceBuilder.Shape()), (newFace) => {
|
|
371
|
+
if (!shapeTypes.isFace(newFace)) {
|
|
372
|
+
return errors.err(errors.occtError("FACE_BUILD_FAILED", "Failed to create a face"));
|
|
373
|
+
}
|
|
374
|
+
return errors.ok(newFace);
|
|
375
|
+
});
|
|
376
|
+
} catch (_) {
|
|
377
|
+
var _error = _, _hasError = true;
|
|
378
|
+
} finally {
|
|
379
|
+
__callDispose(_stack, _error, _hasError);
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
function addHolesInFace(face, holes) {
|
|
383
|
+
var _stack = [];
|
|
384
|
+
try {
|
|
385
|
+
const oc = occtBoundary.getKernel().oc;
|
|
386
|
+
const scope = __using(_stack, new shapeTypes.DisposalScope());
|
|
387
|
+
const faceMaker = scope.register(new oc.BRepBuilderAPI_MakeFace_2(face.wrapped));
|
|
388
|
+
holes.forEach((wire) => {
|
|
389
|
+
faceMaker.Add(wire.wrapped);
|
|
390
|
+
});
|
|
391
|
+
const builtFace = scope.register(faceMaker.Face());
|
|
392
|
+
const fixer = scope.register(new oc.ShapeFix_Face_2(builtFace));
|
|
393
|
+
fixer.FixOrientation_1();
|
|
394
|
+
const newFace = fixer.Face();
|
|
395
|
+
return shapeTypes.createFace(newFace);
|
|
396
|
+
} catch (_) {
|
|
397
|
+
var _error = _, _hasError = true;
|
|
398
|
+
} finally {
|
|
399
|
+
__callDispose(_stack, _error, _hasError);
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
function makePolygon(points) {
|
|
403
|
+
if (points.length < 3)
|
|
404
|
+
return errors.err(
|
|
405
|
+
errors.validationError("POLYGON_MIN_POINTS", "You need at least 3 points to make a polygon")
|
|
406
|
+
);
|
|
407
|
+
const edges = zip([points, [...points.slice(1), points[0]]]).map(
|
|
408
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- zip returns untyped pairs
|
|
409
|
+
([p1, p2]) => makeLine(p1, p2)
|
|
410
|
+
);
|
|
411
|
+
return errors.andThen(assembleWire(edges), (wire) => makeFace(wire));
|
|
412
|
+
}
|
|
413
|
+
exports.addHolesInFace = addHolesInFace;
|
|
414
|
+
exports.assembleWire = assembleWire;
|
|
415
|
+
exports.fill = fill;
|
|
416
|
+
exports.makeBSplineApproximation = makeBSplineApproximation;
|
|
417
|
+
exports.makeBezierCurve = makeBezierCurve;
|
|
418
|
+
exports.makeCircle = makeCircle;
|
|
419
|
+
exports.makeEllipse = makeEllipse;
|
|
420
|
+
exports.makeEllipseArc = makeEllipseArc;
|
|
421
|
+
exports.makeFace = makeFace;
|
|
422
|
+
exports.makeHelix = makeHelix;
|
|
423
|
+
exports.makeLine = makeLine;
|
|
424
|
+
exports.makeNewFaceWithinFace = makeNewFaceWithinFace;
|
|
425
|
+
exports.makeNonPlanarFace = makeNonPlanarFace;
|
|
426
|
+
exports.makePolygon = makePolygon;
|
|
427
|
+
exports.makeTangentArc = makeTangentArc;
|
|
428
|
+
exports.makeThreePointArc = makeThreePointArc;
|
|
429
|
+
exports.zip = zip;
|