@ifc-lite/drawing-2d 1.4.0
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/LICENSE +373 -0
- package/dist/drawing-generator.d.ts +80 -0
- package/dist/drawing-generator.d.ts.map +1 -0
- package/dist/drawing-generator.js +281 -0
- package/dist/drawing-generator.js.map +1 -0
- package/dist/edge-extractor.d.ts +47 -0
- package/dist/edge-extractor.d.ts.map +1 -0
- package/dist/edge-extractor.js +204 -0
- package/dist/edge-extractor.js.map +1 -0
- package/dist/gpu-section-cutter.d.ts +42 -0
- package/dist/gpu-section-cutter.d.ts.map +1 -0
- package/dist/gpu-section-cutter.js +405 -0
- package/dist/gpu-section-cutter.js.map +1 -0
- package/dist/graphic-overrides/index.d.ts +10 -0
- package/dist/graphic-overrides/index.d.ts.map +1 -0
- package/dist/graphic-overrides/index.js +8 -0
- package/dist/graphic-overrides/index.js.map +1 -0
- package/dist/graphic-overrides/presets.d.ts +22 -0
- package/dist/graphic-overrides/presets.d.ts.map +1 -0
- package/dist/graphic-overrides/presets.js +283 -0
- package/dist/graphic-overrides/presets.js.map +1 -0
- package/dist/graphic-overrides/rule-engine.d.ts +64 -0
- package/dist/graphic-overrides/rule-engine.d.ts.map +1 -0
- package/dist/graphic-overrides/rule-engine.js +438 -0
- package/dist/graphic-overrides/rule-engine.js.map +1 -0
- package/dist/graphic-overrides/types.d.ts +200 -0
- package/dist/graphic-overrides/types.d.ts.map +1 -0
- package/dist/graphic-overrides/types.js +5 -0
- package/dist/graphic-overrides/types.js.map +1 -0
- package/dist/hatch-generator.d.ts +76 -0
- package/dist/hatch-generator.d.ts.map +1 -0
- package/dist/hatch-generator.js +282 -0
- package/dist/hatch-generator.js.map +1 -0
- package/dist/hidden-line.d.ts +64 -0
- package/dist/hidden-line.d.ts.map +1 -0
- package/dist/hidden-line.js +318 -0
- package/dist/hidden-line.js.map +1 -0
- package/dist/index.d.ts +44 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +109 -0
- package/dist/index.js.map +1 -0
- package/dist/line-merger.d.ts +35 -0
- package/dist/line-merger.d.ts.map +1 -0
- package/dist/line-merger.js +265 -0
- package/dist/line-merger.js.map +1 -0
- package/dist/math.d.ts +90 -0
- package/dist/math.d.ts.map +1 -0
- package/dist/math.js +284 -0
- package/dist/math.js.map +1 -0
- package/dist/openings/index.d.ts +7 -0
- package/dist/openings/index.d.ts.map +1 -0
- package/dist/openings/index.js +10 -0
- package/dist/openings/index.js.map +1 -0
- package/dist/openings/opening-filter.d.ts +61 -0
- package/dist/openings/opening-filter.d.ts.map +1 -0
- package/dist/openings/opening-filter.js +244 -0
- package/dist/openings/opening-filter.js.map +1 -0
- package/dist/openings/opening-relationship-builder.d.ts +35 -0
- package/dist/openings/opening-relationship-builder.d.ts.map +1 -0
- package/dist/openings/opening-relationship-builder.js +121 -0
- package/dist/openings/opening-relationship-builder.js.map +1 -0
- package/dist/openings/opening-utils.d.ts +55 -0
- package/dist/openings/opening-utils.d.ts.map +1 -0
- package/dist/openings/opening-utils.js +128 -0
- package/dist/openings/opening-utils.js.map +1 -0
- package/dist/polygon-builder.d.ts +62 -0
- package/dist/polygon-builder.d.ts.map +1 -0
- package/dist/polygon-builder.js +261 -0
- package/dist/polygon-builder.js.map +1 -0
- package/dist/section-cutter.d.ts +49 -0
- package/dist/section-cutter.d.ts.map +1 -0
- package/dist/section-cutter.js +220 -0
- package/dist/section-cutter.js.map +1 -0
- package/dist/sheet/frame-renderer.d.ts +28 -0
- package/dist/sheet/frame-renderer.d.ts.map +1 -0
- package/dist/sheet/frame-renderer.js +199 -0
- package/dist/sheet/frame-renderer.js.map +1 -0
- package/dist/sheet/frame-types.d.ts +57 -0
- package/dist/sheet/frame-types.d.ts.map +1 -0
- package/dist/sheet/frame-types.js +88 -0
- package/dist/sheet/frame-types.js.map +1 -0
- package/dist/sheet/index.d.ts +26 -0
- package/dist/sheet/index.d.ts.map +1 -0
- package/dist/sheet/index.js +12 -0
- package/dist/sheet/index.js.map +1 -0
- package/dist/sheet/paper-sizes.d.ts +36 -0
- package/dist/sheet/paper-sizes.d.ts.map +1 -0
- package/dist/sheet/paper-sizes.js +252 -0
- package/dist/sheet/paper-sizes.js.map +1 -0
- package/dist/sheet/scale-bar-renderer.d.ts +29 -0
- package/dist/sheet/scale-bar-renderer.d.ts.map +1 -0
- package/dist/sheet/scale-bar-renderer.js +287 -0
- package/dist/sheet/scale-bar-renderer.js.map +1 -0
- package/dist/sheet/scale-bar-types.d.ts +82 -0
- package/dist/sheet/scale-bar-types.d.ts.map +1 -0
- package/dist/sheet/scale-bar-types.js +66 -0
- package/dist/sheet/scale-bar-types.js.map +1 -0
- package/dist/sheet/sheet-types.d.ts +84 -0
- package/dist/sheet/sheet-types.d.ts.map +1 -0
- package/dist/sheet/sheet-types.js +77 -0
- package/dist/sheet/sheet-types.js.map +1 -0
- package/dist/sheet/title-block-renderer.d.ts +44 -0
- package/dist/sheet/title-block-renderer.d.ts.map +1 -0
- package/dist/sheet/title-block-renderer.js +335 -0
- package/dist/sheet/title-block-renderer.js.map +1 -0
- package/dist/sheet/title-block-types.d.ts +100 -0
- package/dist/sheet/title-block-types.d.ts.map +1 -0
- package/dist/sheet/title-block-types.js +174 -0
- package/dist/sheet/title-block-types.js.map +1 -0
- package/dist/styles.d.ts +77 -0
- package/dist/styles.d.ts.map +1 -0
- package/dist/styles.js +347 -0
- package/dist/styles.js.map +1 -0
- package/dist/styling/index.d.ts +7 -0
- package/dist/styling/index.d.ts.map +1 -0
- package/dist/styling/index.js +10 -0
- package/dist/styling/index.js.map +1 -0
- package/dist/styling/layer-mapping.d.ts +57 -0
- package/dist/styling/layer-mapping.d.ts.map +1 -0
- package/dist/styling/layer-mapping.js +303 -0
- package/dist/styling/layer-mapping.js.map +1 -0
- package/dist/styling/line-styles.d.ts +49 -0
- package/dist/styling/line-styles.d.ts.map +1 -0
- package/dist/styling/line-styles.js +123 -0
- package/dist/styling/line-styles.js.map +1 -0
- package/dist/styling/line-weights.d.ts +61 -0
- package/dist/styling/line-weights.d.ts.map +1 -0
- package/dist/styling/line-weights.js +183 -0
- package/dist/styling/line-weights.js.map +1 -0
- package/dist/svg-exporter.d.ts +63 -0
- package/dist/svg-exporter.d.ts.map +1 -0
- package/dist/svg-exporter.js +278 -0
- package/dist/svg-exporter.js.map +1 -0
- package/dist/symbols/door-symbol.d.ts +82 -0
- package/dist/symbols/door-symbol.d.ts.map +1 -0
- package/dist/symbols/door-symbol.js +390 -0
- package/dist/symbols/door-symbol.js.map +1 -0
- package/dist/symbols/index.d.ts +8 -0
- package/dist/symbols/index.d.ts.map +1 -0
- package/dist/symbols/index.js +11 -0
- package/dist/symbols/index.js.map +1 -0
- package/dist/symbols/symbol-renderer.d.ts +29 -0
- package/dist/symbols/symbol-renderer.d.ts.map +1 -0
- package/dist/symbols/symbol-renderer.js +173 -0
- package/dist/symbols/symbol-renderer.js.map +1 -0
- package/dist/symbols/symbol-utils.d.ts +48 -0
- package/dist/symbols/symbol-utils.d.ts.map +1 -0
- package/dist/symbols/symbol-utils.js +129 -0
- package/dist/symbols/symbol-utils.js.map +1 -0
- package/dist/symbols/window-symbol.d.ts +57 -0
- package/dist/symbols/window-symbol.d.ts.map +1 -0
- package/dist/symbols/window-symbol.js +209 -0
- package/dist/symbols/window-symbol.js.map +1 -0
- package/dist/types.d.ts +443 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +31 -0
- package/dist/types.js.map +1 -0
- package/package.json +53 -0
|
@@ -0,0 +1,318 @@
|
|
|
1
|
+
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
2
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
3
|
+
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
4
|
+
import { vec3, point2DLerp, point2DDistance, boundsEmpty, boundsExtendPoint, EPSILON, } from './math';
|
|
5
|
+
const DEFAULT_OPTIONS = {
|
|
6
|
+
resolution: 1024,
|
|
7
|
+
samplesPerLine: 10,
|
|
8
|
+
depthBias: 0.001,
|
|
9
|
+
};
|
|
10
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
11
|
+
// HIDDEN LINE CLASSIFIER
|
|
12
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
13
|
+
export class HiddenLineClassifier {
|
|
14
|
+
options;
|
|
15
|
+
depthBuffer = null;
|
|
16
|
+
width = 0;
|
|
17
|
+
height = 0;
|
|
18
|
+
bounds = null;
|
|
19
|
+
constructor(options = {}) {
|
|
20
|
+
this.options = { ...DEFAULT_OPTIONS, ...options };
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Build depth buffer from projected triangles
|
|
24
|
+
*
|
|
25
|
+
* @param meshes Source meshes
|
|
26
|
+
* @param axis Section axis
|
|
27
|
+
* @param sectionPosition Position along axis
|
|
28
|
+
* @param maxDepth Maximum depth to render
|
|
29
|
+
* @param flipped Whether view is flipped
|
|
30
|
+
* @param bounds Optional pre-computed 2D bounds
|
|
31
|
+
*/
|
|
32
|
+
buildDepthBuffer(meshes, axis, sectionPosition, maxDepth, flipped, bounds) {
|
|
33
|
+
// Compute bounds if not provided
|
|
34
|
+
if (!bounds) {
|
|
35
|
+
bounds = this.computeBounds(meshes, axis, sectionPosition, maxDepth, flipped);
|
|
36
|
+
}
|
|
37
|
+
this.bounds = bounds;
|
|
38
|
+
// Calculate buffer dimensions
|
|
39
|
+
const boundsWidth = bounds.max.x - bounds.min.x;
|
|
40
|
+
const boundsHeight = bounds.max.y - bounds.min.y;
|
|
41
|
+
if (boundsWidth < EPSILON || boundsHeight < EPSILON) {
|
|
42
|
+
this.width = 1;
|
|
43
|
+
this.height = 1;
|
|
44
|
+
this.depthBuffer = new Float32Array([Infinity]);
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
const aspect = boundsWidth / boundsHeight;
|
|
48
|
+
if (aspect > 1) {
|
|
49
|
+
this.width = this.options.resolution;
|
|
50
|
+
this.height = Math.max(1, Math.floor(this.options.resolution / aspect));
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.height = this.options.resolution;
|
|
54
|
+
this.width = Math.max(1, Math.floor(this.options.resolution * aspect));
|
|
55
|
+
}
|
|
56
|
+
// Initialize depth buffer with infinity (far)
|
|
57
|
+
this.depthBuffer = new Float32Array(this.width * this.height);
|
|
58
|
+
this.depthBuffer.fill(Infinity);
|
|
59
|
+
// Rasterize all triangles
|
|
60
|
+
for (const mesh of meshes) {
|
|
61
|
+
this.rasterizeMesh(mesh, axis, sectionPosition, maxDepth, flipped);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Classify lines as visible or hidden based on depth buffer
|
|
66
|
+
*/
|
|
67
|
+
classifyLines(lines) {
|
|
68
|
+
if (!this.depthBuffer || !this.bounds) {
|
|
69
|
+
throw new Error('Depth buffer not built. Call buildDepthBuffer first.');
|
|
70
|
+
}
|
|
71
|
+
const results = [];
|
|
72
|
+
for (const line of lines) {
|
|
73
|
+
const result = this.classifySingleLine(line);
|
|
74
|
+
results.push(result);
|
|
75
|
+
}
|
|
76
|
+
return results;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Update lines with visibility classification
|
|
80
|
+
* Returns new array with visibility set
|
|
81
|
+
*/
|
|
82
|
+
applyVisibility(lines) {
|
|
83
|
+
const results = this.classifyLines(lines);
|
|
84
|
+
const output = [];
|
|
85
|
+
for (const result of results) {
|
|
86
|
+
if (result.overallVisibility === 'visible') {
|
|
87
|
+
output.push({ ...result.line, visibility: 'visible' });
|
|
88
|
+
}
|
|
89
|
+
else if (result.overallVisibility === 'hidden') {
|
|
90
|
+
output.push({ ...result.line, visibility: 'hidden' });
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
// Partial visibility - split into segments
|
|
94
|
+
for (const seg of result.segments) {
|
|
95
|
+
output.push({
|
|
96
|
+
...result.line,
|
|
97
|
+
line: { start: seg.start, end: seg.end },
|
|
98
|
+
visibility: seg.visible ? 'visible' : 'hidden',
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return output;
|
|
104
|
+
}
|
|
105
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
106
|
+
// PRIVATE METHODS
|
|
107
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
108
|
+
computeBounds(meshes, axis, sectionPosition, maxDepth, flipped) {
|
|
109
|
+
let bounds = boundsEmpty();
|
|
110
|
+
const axes = this.getProjectionAxes(axis);
|
|
111
|
+
for (const mesh of meshes) {
|
|
112
|
+
const { positions } = mesh;
|
|
113
|
+
const vertexCount = positions.length / 3;
|
|
114
|
+
for (let i = 0; i < vertexCount; i++) {
|
|
115
|
+
const x = positions[i * 3];
|
|
116
|
+
const y = positions[i * 3 + 1];
|
|
117
|
+
const z = positions[i * 3 + 2];
|
|
118
|
+
const v = { x, y, z };
|
|
119
|
+
// Check if vertex is in depth range
|
|
120
|
+
const depth = v[axis] - sectionPosition;
|
|
121
|
+
const inRange = flipped
|
|
122
|
+
? depth <= 0 && depth >= -maxDepth
|
|
123
|
+
: depth >= 0 && depth <= maxDepth;
|
|
124
|
+
if (inRange) {
|
|
125
|
+
const u = v[axes.u];
|
|
126
|
+
const vCoord = v[axes.v];
|
|
127
|
+
const point2d = { x: flipped ? -u : u, y: vCoord };
|
|
128
|
+
bounds = boundsExtendPoint(bounds, point2d);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
// Add small margin
|
|
133
|
+
const margin = Math.max(bounds.max.x - bounds.min.x, bounds.max.y - bounds.min.y) * 0.01;
|
|
134
|
+
bounds.min.x -= margin;
|
|
135
|
+
bounds.min.y -= margin;
|
|
136
|
+
bounds.max.x += margin;
|
|
137
|
+
bounds.max.y += margin;
|
|
138
|
+
return bounds;
|
|
139
|
+
}
|
|
140
|
+
getProjectionAxes(axis) {
|
|
141
|
+
switch (axis) {
|
|
142
|
+
case 'x':
|
|
143
|
+
return { u: 'z', v: 'y' };
|
|
144
|
+
case 'y':
|
|
145
|
+
return { u: 'x', v: 'z' };
|
|
146
|
+
case 'z':
|
|
147
|
+
return { u: 'x', v: 'y' };
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
rasterizeMesh(mesh, axis, sectionPosition, maxDepth, flipped) {
|
|
151
|
+
const { positions, indices } = mesh;
|
|
152
|
+
const axes = this.getProjectionAxes(axis);
|
|
153
|
+
const triangleCount = indices.length / 3;
|
|
154
|
+
for (let t = 0; t < triangleCount; t++) {
|
|
155
|
+
const i0 = indices[t * 3];
|
|
156
|
+
const i1 = indices[t * 3 + 1];
|
|
157
|
+
const i2 = indices[t * 3 + 2];
|
|
158
|
+
// Get 3D vertices
|
|
159
|
+
const v0 = this.getVertex(positions, i0);
|
|
160
|
+
const v1 = this.getVertex(positions, i1);
|
|
161
|
+
const v2 = this.getVertex(positions, i2);
|
|
162
|
+
// Check if triangle is in depth range
|
|
163
|
+
const d0 = v0[axis] - sectionPosition;
|
|
164
|
+
const d1 = v1[axis] - sectionPosition;
|
|
165
|
+
const d2 = v2[axis] - sectionPosition;
|
|
166
|
+
const inRange = (d) => flipped ? d <= 0 && d >= -maxDepth : d >= 0 && d <= maxDepth;
|
|
167
|
+
// Skip triangles entirely outside depth range
|
|
168
|
+
if (!inRange(d0) && !inRange(d1) && !inRange(d2)) {
|
|
169
|
+
continue;
|
|
170
|
+
}
|
|
171
|
+
// Project to 2D + depth
|
|
172
|
+
const p0 = this.projectVertex(v0, axes, flipped);
|
|
173
|
+
const p1 = this.projectVertex(v1, axes, flipped);
|
|
174
|
+
const p2 = this.projectVertex(v2, axes, flipped);
|
|
175
|
+
// Rasterize triangle
|
|
176
|
+
this.rasterizeTriangle(p0, p1, p2);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
getVertex(positions, index) {
|
|
180
|
+
const base = index * 3;
|
|
181
|
+
return vec3(positions[base], positions[base + 1], positions[base + 2]);
|
|
182
|
+
}
|
|
183
|
+
projectVertex(v, axes, flipped) {
|
|
184
|
+
const u = v[axes.u];
|
|
185
|
+
const vCoord = v[axes.v];
|
|
186
|
+
// Find depth axis: the one not used for u or v projection
|
|
187
|
+
const allAxes = ['x', 'y', 'z'];
|
|
188
|
+
const depthAxis = allAxes.find(a => a !== axes.u && a !== axes.v) ?? 'z';
|
|
189
|
+
return {
|
|
190
|
+
x: flipped ? -u : u,
|
|
191
|
+
y: vCoord,
|
|
192
|
+
depth: v[depthAxis],
|
|
193
|
+
};
|
|
194
|
+
}
|
|
195
|
+
rasterizeTriangle(p0, p1, p2) {
|
|
196
|
+
if (!this.bounds || !this.depthBuffer)
|
|
197
|
+
return;
|
|
198
|
+
// Convert to pixel coordinates
|
|
199
|
+
const toPixelX = (x) => ((x - this.bounds.min.x) / (this.bounds.max.x - this.bounds.min.x)) * (this.width - 1);
|
|
200
|
+
const toPixelY = (y) => ((y - this.bounds.min.y) / (this.bounds.max.y - this.bounds.min.y)) * (this.height - 1);
|
|
201
|
+
const px0 = { x: toPixelX(p0.x), y: toPixelY(p0.y), depth: p0.depth };
|
|
202
|
+
const px1 = { x: toPixelX(p1.x), y: toPixelY(p1.y), depth: p1.depth };
|
|
203
|
+
const px2 = { x: toPixelX(p2.x), y: toPixelY(p2.y), depth: p2.depth };
|
|
204
|
+
// Compute bounding box
|
|
205
|
+
const minX = Math.max(0, Math.floor(Math.min(px0.x, px1.x, px2.x)));
|
|
206
|
+
const maxX = Math.min(this.width - 1, Math.ceil(Math.max(px0.x, px1.x, px2.x)));
|
|
207
|
+
const minY = Math.max(0, Math.floor(Math.min(px0.y, px1.y, px2.y)));
|
|
208
|
+
const maxY = Math.min(this.height - 1, Math.ceil(Math.max(px0.y, px1.y, px2.y)));
|
|
209
|
+
// Rasterize using barycentric coordinates
|
|
210
|
+
for (let py = minY; py <= maxY; py++) {
|
|
211
|
+
for (let px = minX; px <= maxX; px++) {
|
|
212
|
+
const bary = this.barycentricCoords(px + 0.5, py + 0.5, px0, px1, px2);
|
|
213
|
+
if (bary.u >= 0 && bary.v >= 0 && bary.w >= 0) {
|
|
214
|
+
// Interpolate depth
|
|
215
|
+
const depth = bary.u * px0.depth + bary.v * px1.depth + bary.w * px2.depth;
|
|
216
|
+
const idx = py * this.width + px;
|
|
217
|
+
if (depth < this.depthBuffer[idx]) {
|
|
218
|
+
this.depthBuffer[idx] = depth;
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
barycentricCoords(px, py, p0, p1, p2) {
|
|
225
|
+
const v0x = p1.x - p0.x;
|
|
226
|
+
const v0y = p1.y - p0.y;
|
|
227
|
+
const v1x = p2.x - p0.x;
|
|
228
|
+
const v1y = p2.y - p0.y;
|
|
229
|
+
const v2x = px - p0.x;
|
|
230
|
+
const v2y = py - p0.y;
|
|
231
|
+
const dot00 = v0x * v0x + v0y * v0y;
|
|
232
|
+
const dot01 = v0x * v1x + v0y * v1y;
|
|
233
|
+
const dot02 = v0x * v2x + v0y * v2y;
|
|
234
|
+
const dot11 = v1x * v1x + v1y * v1y;
|
|
235
|
+
const dot12 = v1x * v2x + v1y * v2y;
|
|
236
|
+
const denom = dot00 * dot11 - dot01 * dot01;
|
|
237
|
+
// Handle degenerate triangles (zero area) by returning invalid coordinates
|
|
238
|
+
if (Math.abs(denom) < 1e-10) {
|
|
239
|
+
return { u: -1, v: -1, w: -1 };
|
|
240
|
+
}
|
|
241
|
+
const invDenom = 1 / denom;
|
|
242
|
+
const v = (dot11 * dot02 - dot01 * dot12) * invDenom;
|
|
243
|
+
const w = (dot00 * dot12 - dot01 * dot02) * invDenom;
|
|
244
|
+
const u = 1 - v - w;
|
|
245
|
+
return { u, v, w };
|
|
246
|
+
}
|
|
247
|
+
classifySingleLine(line) {
|
|
248
|
+
if (!this.bounds || !this.depthBuffer) {
|
|
249
|
+
return {
|
|
250
|
+
line,
|
|
251
|
+
segments: [{ start: line.line.start, end: line.line.end, visible: true }],
|
|
252
|
+
overallVisibility: 'visible',
|
|
253
|
+
};
|
|
254
|
+
}
|
|
255
|
+
const { samplesPerLine, depthBias } = this.options;
|
|
256
|
+
const lineLength = point2DDistance(line.line.start, line.line.end);
|
|
257
|
+
// For very short lines, just test the midpoint
|
|
258
|
+
const numSamples = lineLength < EPSILON ? 1 : Math.max(2, samplesPerLine);
|
|
259
|
+
const segments = [];
|
|
260
|
+
let currentStart = line.line.start;
|
|
261
|
+
let currentVisible = this.sampleVisibility(line.line.start, line.depth, depthBias);
|
|
262
|
+
let visibleCount = currentVisible ? 1 : 0;
|
|
263
|
+
for (let i = 1; i <= numSamples; i++) {
|
|
264
|
+
const t = i / numSamples;
|
|
265
|
+
const point = point2DLerp(line.line.start, line.line.end, t);
|
|
266
|
+
const isVisible = this.sampleVisibility(point, line.depth, depthBias);
|
|
267
|
+
if (isVisible)
|
|
268
|
+
visibleCount++;
|
|
269
|
+
// Check for visibility change
|
|
270
|
+
if (isVisible !== currentVisible && i < numSamples) {
|
|
271
|
+
// Find transition point (approximate)
|
|
272
|
+
const transitionT = (i - 0.5) / numSamples;
|
|
273
|
+
const transitionPoint = point2DLerp(line.line.start, line.line.end, transitionT);
|
|
274
|
+
segments.push({
|
|
275
|
+
start: currentStart,
|
|
276
|
+
end: transitionPoint,
|
|
277
|
+
visible: currentVisible,
|
|
278
|
+
});
|
|
279
|
+
currentStart = transitionPoint;
|
|
280
|
+
currentVisible = isVisible;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
// Final segment
|
|
284
|
+
segments.push({
|
|
285
|
+
start: currentStart,
|
|
286
|
+
end: line.line.end,
|
|
287
|
+
visible: currentVisible,
|
|
288
|
+
});
|
|
289
|
+
// Determine overall visibility
|
|
290
|
+
let overallVisibility;
|
|
291
|
+
if (visibleCount === numSamples + 1) {
|
|
292
|
+
overallVisibility = 'visible';
|
|
293
|
+
}
|
|
294
|
+
else if (visibleCount === 0) {
|
|
295
|
+
overallVisibility = 'hidden';
|
|
296
|
+
}
|
|
297
|
+
else {
|
|
298
|
+
overallVisibility = 'partial';
|
|
299
|
+
}
|
|
300
|
+
return { line, segments, overallVisibility };
|
|
301
|
+
}
|
|
302
|
+
sampleVisibility(point, lineDepth, depthBias) {
|
|
303
|
+
if (!this.bounds || !this.depthBuffer)
|
|
304
|
+
return true;
|
|
305
|
+
// Convert to pixel coordinates
|
|
306
|
+
const px = ((point.x - this.bounds.min.x) / (this.bounds.max.x - this.bounds.min.x)) *
|
|
307
|
+
(this.width - 1);
|
|
308
|
+
const py = ((point.y - this.bounds.min.y) / (this.bounds.max.y - this.bounds.min.y)) *
|
|
309
|
+
(this.height - 1);
|
|
310
|
+
// Clamp to buffer bounds
|
|
311
|
+
const ix = Math.max(0, Math.min(this.width - 1, Math.floor(px)));
|
|
312
|
+
const iy = Math.max(0, Math.min(this.height - 1, Math.floor(py)));
|
|
313
|
+
const bufferDepth = this.depthBuffer[iy * this.width + ix];
|
|
314
|
+
// Line is visible if it's at or in front of the depth buffer
|
|
315
|
+
return lineDepth <= bufferDepth + depthBias;
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
//# sourceMappingURL=hidden-line.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hidden-line.js","sourceRoot":"","sources":["../src/hidden-line.ts"],"names":[],"mappings":"AAAA;;+DAE+D;AAW/D,OAAO,EACL,IAAI,EACJ,WAAW,EACX,eAAe,EACf,WAAW,EACX,iBAAiB,EACjB,OAAO,GACR,MAAM,QAAQ,CAAC;AA2BhB,MAAM,eAAe,GAAsB;IACzC,UAAU,EAAE,IAAI;IAChB,cAAc,EAAE,EAAE;IAClB,SAAS,EAAE,KAAK;CACjB,CAAC;AAEF,8EAA8E;AAC9E,yBAAyB;AACzB,8EAA8E;AAE9E,MAAM,OAAO,oBAAoB;IACvB,OAAO,CAAoB;IAE3B,WAAW,GAAwB,IAAI,CAAC;IACxC,KAAK,GAAW,CAAC,CAAC;IAClB,MAAM,GAAW,CAAC,CAAC;IACnB,MAAM,GAAoB,IAAI,CAAC;IAEvC,YAAY,UAAsC,EAAE;QAClD,IAAI,CAAC,OAAO,GAAG,EAAE,GAAG,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IACpD,CAAC;IAED;;;;;;;;;OASG;IACH,gBAAgB,CACd,MAAkB,EAClB,IAAqB,EACrB,eAAuB,EACvB,QAAgB,EAChB,OAAgB,EAChB,MAAiB;QAEjB,iCAAiC;QACjC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;QAChF,CAAC;QACD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QAErB,8BAA8B;QAC9B,MAAM,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAChD,MAAM,YAAY,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAEjD,IAAI,WAAW,GAAG,OAAO,IAAI,YAAY,GAAG,OAAO,EAAE,CAAC;YACpD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;YAChD,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,WAAW,GAAG,YAAY,CAAC;QAC1C,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;YACrC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC;QAC1E,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;YACtC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC;QACzE,CAAC;QAED,8CAA8C;QAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9D,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEhC,0BAA0B;QAC1B,KAAK,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,eAAe,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,KAAoB;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QAED,MAAM,OAAO,GAAuB,EAAE,CAAC;QAEvC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAC7C,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvB,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,KAAoB;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE1C,MAAM,MAAM,GAAkB,EAAE,CAAC;QAEjC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;gBAC3C,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;YACzD,CAAC;iBAAM,IAAI,MAAM,CAAC,iBAAiB,KAAK,QAAQ,EAAE,CAAC;gBACjD,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC;YACxD,CAAC;iBAAM,CAAC;gBACN,2CAA2C;gBAC3C,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;oBAClC,MAAM,CAAC,IAAI,CAAC;wBACV,GAAG,MAAM,CAAC,IAAI;wBACd,IAAI,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE;wBACxC,UAAU,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;qBAC/C,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,8EAA8E;IAC9E,kBAAkB;IAClB,8EAA8E;IAEtE,aAAa,CACnB,MAAkB,EAClB,IAAqB,EACrB,eAAuB,EACvB,QAAgB,EAChB,OAAgB;QAEhB,IAAI,MAAM,GAAG,WAAW,EAAE,CAAC;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAE1C,KAAK,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAC1B,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;YAC3B,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC;YAEzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC;gBACrC,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC3B,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/B,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/B,MAAM,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;gBAEtB,oCAAoC;gBACpC,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC;gBACxC,MAAM,OAAO,GAAG,OAAO;oBACrB,CAAC,CAAC,KAAK,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,QAAQ;oBAClC,CAAC,CAAC,KAAK,IAAI,CAAC,IAAI,KAAK,IAAI,QAAQ,CAAC;gBAEpC,IAAI,OAAO,EAAE,CAAC;oBACZ,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACpB,MAAM,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACzB,MAAM,OAAO,GAAG,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC;oBACnD,MAAM,GAAG,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;QACH,CAAC;QAED,mBAAmB;QACnB,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QACzF,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC;QACvB,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC;QACvB,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC;QACvB,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC;QAEvB,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,iBAAiB,CAAC,IAAqB;QAC7C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,GAAG;gBACN,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;YAC5B,KAAK,GAAG;gBACN,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;YAC5B,KAAK,GAAG;gBACN,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC;QAC9B,CAAC;IACH,CAAC;IAEO,aAAa,CACnB,IAAc,EACd,IAAqB,EACrB,eAAuB,EACvB,QAAgB,EAChB,OAAgB;QAEhB,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAC1C,MAAM,aAAa,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;QAEzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE,CAAC;YACvC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAC1B,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9B,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;YAE9B,kBAAkB;YAClB,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YACzC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YACzC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAEzC,sCAAsC;YACtC,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC;YACtC,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC;YACtC,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC;YAEtC,MAAM,OAAO,GAAG,CAAC,CAAS,EAAE,EAAE,CAC5B,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC;YAE/D,8CAA8C;YAC9C,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;gBACjD,SAAS;YACX,CAAC;YAED,wBAAwB;YACxB,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACjD,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACjD,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YAEjD,qBAAqB;YACrB,IAAI,CAAC,iBAAiB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAEO,SAAS,CAAC,SAAuB,EAAE,KAAa;QACtD,MAAM,IAAI,GAAG,KAAK,GAAG,CAAC,CAAC;QACvB,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,IAAI,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC;IACzE,CAAC;IAEO,aAAa,CACnB,CAAO,EACP,IAAgD,EAChD,OAAgB;QAEhB,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,MAAM,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,0DAA0D;QAC1D,MAAM,OAAO,GAAwB,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACrD,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;QACzE,OAAO;YACL,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnB,CAAC,EAAE,MAAM;YACT,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC;SACpB,CAAC;IACJ,CAAC;IAEO,iBAAiB,CACvB,EAA2C,EAC3C,EAA2C,EAC3C,EAA2C;QAE3C,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO;QAE9C,+BAA+B;QAC/B,MAAM,QAAQ,GAAG,CAAC,CAAS,EAAE,EAAE,CAC7B,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAC5F,MAAM,QAAQ,GAAG,CAAC,CAAS,EAAE,EAAE,CAC7B,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAE7F,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC;QACtE,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC;QACtE,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,EAAE,CAAC;QAEtE,uBAAuB;QACvB,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAChF,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAEjF,0CAA0C;QAC1C,KAAK,IAAI,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC;YACrC,KAAK,IAAI,EAAE,GAAG,IAAI,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC;gBACrC,MAAM,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,EAAE,GAAG,GAAG,EAAE,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;gBAEvE,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC9C,oBAAoB;oBACpB,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC;oBAE3E,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;oBACjC,IAAI,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC;wBAClC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;oBAChC,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEO,iBAAiB,CACvB,EAAU,EACV,EAAU,EACV,EAA4B,EAC5B,EAA4B,EAC5B,EAA4B;QAE5B,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;QACxB,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QACtB,MAAM,GAAG,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;QAEtB,MAAM,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QACpC,MAAM,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QACpC,MAAM,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QACpC,MAAM,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QACpC,MAAM,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;QAEpC,MAAM,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;QAC5C,2EAA2E;QAC3E,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,EAAE,CAAC;YAC5B,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QACjC,CAAC;QACD,MAAM,QAAQ,GAAG,CAAC,GAAG,KAAK,CAAC;QAC3B,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC,GAAG,QAAQ,CAAC;QACrD,MAAM,CAAC,GAAG,CAAC,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC,GAAG,QAAQ,CAAC;QACrD,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAEpB,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;IACrB,CAAC;IAEO,kBAAkB,CAAC,IAAiB;QAC1C,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtC,OAAO;gBACL,IAAI;gBACJ,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBACzE,iBAAiB,EAAE,SAAS;aAC7B,CAAC;QACJ,CAAC;QAED,MAAM,EAAE,cAAc,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QACnD,MAAM,UAAU,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEnE,+CAA+C;QAC/C,MAAM,UAAU,GAAG,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;QAE1E,MAAM,QAAQ,GAAwB,EAAE,CAAC;QACzC,IAAI,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QACnC,IAAI,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACnF,IAAI,YAAY,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;YACrC,MAAM,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC;YACzB,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;YAC7D,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YAEtE,IAAI,SAAS;gBAAE,YAAY,EAAE,CAAC;YAE9B,8BAA8B;YAC9B,IAAI,SAAS,KAAK,cAAc,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC;gBACnD,sCAAsC;gBACtC,MAAM,WAAW,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,UAAU,CAAC;gBAC3C,MAAM,eAAe,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;gBAEjF,QAAQ,CAAC,IAAI,CAAC;oBACZ,KAAK,EAAE,YAAY;oBACnB,GAAG,EAAE,eAAe;oBACpB,OAAO,EAAE,cAAc;iBACxB,CAAC,CAAC;gBAEH,YAAY,GAAG,eAAe,CAAC;gBAC/B,cAAc,GAAG,SAAS,CAAC;YAC7B,CAAC;QACH,CAAC;QAED,gBAAgB;QAChB,QAAQ,CAAC,IAAI,CAAC;YACZ,KAAK,EAAE,YAAY;YACnB,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG;YAClB,OAAO,EAAE,cAAc;SACxB,CAAC,CAAC;QAEH,+BAA+B;QAC/B,IAAI,iBAAkC,CAAC;QACvC,IAAI,YAAY,KAAK,UAAU,GAAG,CAAC,EAAE,CAAC;YACpC,iBAAiB,GAAG,SAAS,CAAC;QAChC,CAAC;aAAM,IAAI,YAAY,KAAK,CAAC,EAAE,CAAC;YAC9B,iBAAiB,GAAG,QAAQ,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,iBAAiB,GAAG,SAAS,CAAC;QAChC,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC;IAC/C,CAAC;IAEO,gBAAgB,CAAC,KAAc,EAAE,SAAiB,EAAE,SAAiB;QAC3E,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO,IAAI,CAAC;QAEnD,+BAA+B;QAC/B,MAAM,EAAE,GACN,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACzE,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACnB,MAAM,EAAE,GACN,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACzE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEpB,yBAAyB;QACzB,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAElE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,CAAC;QAE3D,6DAA6D;QAC7D,OAAO,SAAS,IAAI,WAAW,GAAG,SAAS,CAAC;IAC9C,CAAC;CACF"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @ifc-lite/drawing-2d
|
|
3
|
+
*
|
|
4
|
+
* 2D architectural drawing generation from IFC models.
|
|
5
|
+
* Generates section cuts, floor plans, and elevations with:
|
|
6
|
+
* - Cut lines (geometry intersected by section plane)
|
|
7
|
+
* - Projection lines (visible geometry beyond cut)
|
|
8
|
+
* - Hidden lines (occluded geometry, dashed)
|
|
9
|
+
* - Silhouettes and feature edges
|
|
10
|
+
* - Hatching (material-based fill patterns by IFC type)
|
|
11
|
+
* - Vector output (SVG)
|
|
12
|
+
*/
|
|
13
|
+
export type { Vec2, Vec3, Point2D, Line2D, Polyline2D, Polygon2D, Bounds2D, SectionAxis, SectionPlaneConfig, SectionConfig, LineCategory, VisibilityState, DrawingLine, DrawingPolygon, CutSegment, MeshCutResult, SectionCutResult, Drawing2D, EdgeData, EntityKey, } from './types';
|
|
14
|
+
export { DEFAULT_SECTION_CONFIG, makeEntityKey, parseEntityKey } from './types';
|
|
15
|
+
export { SectionCutter, cutMeshesStreaming } from './section-cutter';
|
|
16
|
+
export type { StreamingSectionCutterOptions } from './section-cutter';
|
|
17
|
+
export { PolygonBuilder, simplifyPolygon, polygonBounds } from './polygon-builder';
|
|
18
|
+
export { mergeDrawingLines, mergeCollinearLines, deduplicateLines, splitLineAtParams, } from './line-merger';
|
|
19
|
+
export type { LineMergerOptions } from './line-merger';
|
|
20
|
+
export { EdgeExtractor, getViewDirection } from './edge-extractor';
|
|
21
|
+
export { HiddenLineClassifier } from './hidden-line';
|
|
22
|
+
export type { VisibilitySegment, VisibilityResult, HiddenLineOptions } from './hidden-line';
|
|
23
|
+
export { HATCH_PATTERNS, getHatchPattern, LINE_STYLES, TYPE_LINE_WEIGHTS, getLineStyle, COMMON_SCALES, getRecommendedScale, PAPER_SIZES, } from './styles';
|
|
24
|
+
export type { HatchPatternType, HatchPattern, LineStyle, DrawingScale, PaperSize, } from './styles';
|
|
25
|
+
export { HatchGenerator } from './hatch-generator';
|
|
26
|
+
export type { HatchLine, HatchResult, CustomHatchSettings } from './hatch-generator';
|
|
27
|
+
export { SVGExporter, exportToSVG } from './svg-exporter';
|
|
28
|
+
export type { SVGExportOptions } from './svg-exporter';
|
|
29
|
+
export { GPUSectionCutter, isGPUComputeAvailable } from './gpu-section-cutter';
|
|
30
|
+
export { Drawing2DGenerator, createSectionConfig, generateFloorPlan, generateSection, } from './drawing-generator';
|
|
31
|
+
export type { GeneratorOptions, GeneratorProgress } from './drawing-generator';
|
|
32
|
+
export { EPSILON, vec3, vec3Add, vec3Sub, vec3Scale, vec3Dot, vec3Cross, vec3Length, vec3Normalize, vec3Lerp, vec3Equals, vec3Distance, point2D, point2DAdd, point2DSub, point2DScale, point2DDot, point2DLength, point2DDistance, point2DLerp, point2DEquals, point2DNormalize, point2DCross, lineLength, lineMidpoint, lineDirection, linesCollinear, projectPointOnLine, boundsEmpty, boundsExtendPoint, boundsExtendLine, boundsCenter, boundsSize, boundsValid, signedDistanceToPlane, getAxisNormal, getProjectionAxes, projectTo2D, polygonSignedArea, isCounterClockwise, reversePolygon, ensureCCW, ensureCW, } from './math';
|
|
33
|
+
export { OpeningRelationshipBuilder, OpeningFilter, buildOpeningRelationships, getOpeningsForHost, getFillingElement, isOpeningElement, isDoorOrWindow, } from './openings';
|
|
34
|
+
export type { OpeningInfo, OpeningRelationships, VoidRelationship, FillRelationship, DoorOperationType, WindowPartitioningType, EntityMetadata, DrawingContext, } from './types';
|
|
35
|
+
export { DoorSymbolGenerator, WindowSymbolGenerator, SymbolRenderer, generateDoorSymbol, generateWindowSymbol, generateStairArrow, } from './symbols';
|
|
36
|
+
export type { ArchitecturalSymbol, SymbolType, SymbolParameters, DoorSwingParameters, SlidingDoorParameters, WindowFrameParameters, StairArrowParameters, } from './types';
|
|
37
|
+
export { LineWeightAssigner, LINE_WEIGHT_CONFIG, IFC_TYPE_WEIGHTS, LineStyler, DASH_PATTERNS, LayerMapper, DEFAULT_LAYERS, getLayerForIfcType, } from './styling';
|
|
38
|
+
export type { ArchitecturalLine, LineWeight, LineWeightConfig, SemanticLineType, LayerDefinition, AIALayerCode, ArchitecturalDrawing2D, } from './types';
|
|
39
|
+
export type { LineStyle as ArchitecturalLineStyle } from './types';
|
|
40
|
+
export { GraphicOverrideEngine, createOverrideEngine, ifcTypeCriterion, propertyCriterion, andCriteria, orCriteria, BUILT_IN_PRESETS, VIEW_3D_PRESET, ARCHITECTURAL_PRESET, FIRE_SAFETY_PRESET, STRUCTURAL_PRESET, MEP_PRESET, MONOCHROME_PRESET, getBuiltInPreset, getPresetsByCategory, } from './graphic-overrides';
|
|
41
|
+
export type { LineWeightPreset, LineStylePreset, DashPattern, CriteriaOperator, CriteriaType, OverrideCriterion, OverrideCriteria, GraphicStyle, GraphicOverrideRule, GraphicOverridePreset, ElementData, ResolvedGraphicStyle, OverrideResult, } from './graphic-overrides';
|
|
42
|
+
export { PAPER_SIZE_REGISTRY, getPaperSizesByCategory, getDefaultPaperSize, FRAME_PRESETS, createFrame, getDefaultFrame, DEFAULT_TITLE_BLOCK_FIELDS, TITLE_BLOCK_PRESETS, createTitleBlock, getDefaultTitleBlock, updateTitleBlockField, DEFAULT_SCALE_BAR, DEFAULT_NORTH_ARROW, calculateOptimalScaleBarLength, calculateOptimalDivisions, calculateViewportBounds, calculateDrawingTransform, renderFrame, renderTitleBlock, renderScaleBar, renderNorthArrow, } from './sheet';
|
|
43
|
+
export type { PaperOrientation, PaperSizeCategory, PaperSizeDefinition, FrameStyle, FrameBorderConfig, FrameMargins, DrawingFrame, TitleBlockPosition, TitleBlockLayout, TitleBlockField, TitleBlockLogo, RevisionEntry, TitleBlockConfig, ScaleBarStyle, ScaleBarPosition, ScaleBarUnits, ScaleBarConfig, NorthArrowStyle, NorthArrowConfig, ViewportBounds, DrawingSheet, SheetCreationOptions, FrameRenderResult, FrameInnerBounds, TitleBlockRenderResult, TitleBlockExtras, PositionMm, } from './sheet';
|
|
44
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAIA;;;;;;;;;;;GAWG;AAMH,YAAY,EAEV,IAAI,EACJ,IAAI,EACJ,OAAO,EACP,MAAM,EACN,UAAU,EACV,SAAS,EACT,QAAQ,EAGR,WAAW,EACX,kBAAkB,EAClB,aAAa,EAGb,YAAY,EACZ,eAAe,EAGf,WAAW,EACX,cAAc,EAGd,UAAU,EACV,aAAa,EACb,gBAAgB,EAGhB,SAAS,EAGT,QAAQ,EAGR,SAAS,GACV,MAAM,SAAS,CAAC;AAEjB,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAMhF,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AACrE,YAAY,EAAE,6BAA6B,EAAE,MAAM,kBAAkB,CAAC;AAMtE,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAMnF,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,YAAY,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAMvD,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAMnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,YAAY,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAM5F,OAAO,EAEL,cAAc,EACd,eAAe,EAGf,WAAW,EACX,iBAAiB,EACjB,YAAY,EAGZ,aAAa,EACb,mBAAmB,EAGnB,WAAW,GACZ,MAAM,UAAU,CAAC;AAElB,YAAY,EACV,gBAAgB,EAChB,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,SAAS,GACV,MAAM,UAAU,CAAC;AAMlB,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAMrF,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC1D,YAAY,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAMvD,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAM/E,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,eAAe,GAChB,MAAM,qBAAqB,CAAC;AAC7B,YAAY,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAM/E,OAAO,EAEL,OAAO,EAGP,IAAI,EACJ,OAAO,EACP,OAAO,EACP,SAAS,EACT,OAAO,EACP,SAAS,EACT,UAAU,EACV,aAAa,EACb,QAAQ,EACR,UAAU,EACV,YAAY,EAGZ,OAAO,EACP,UAAU,EACV,UAAU,EACV,YAAY,EACZ,UAAU,EACV,aAAa,EACb,eAAe,EACf,WAAW,EACX,aAAa,EACb,gBAAgB,EAChB,YAAY,EAGZ,UAAU,EACV,YAAY,EACZ,aAAa,EACb,cAAc,EACd,kBAAkB,EAGlB,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EAChB,YAAY,EACZ,UAAU,EACV,WAAW,EAGX,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,WAAW,EAGX,iBAAiB,EACjB,kBAAkB,EAClB,cAAc,EACd,SAAS,EACT,QAAQ,GACT,MAAM,QAAQ,CAAC;AAMhB,OAAO,EACL,0BAA0B,EAC1B,aAAa,EACb,yBAAyB,EACzB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,GACf,MAAM,YAAY,CAAC;AAEpB,YAAY,EAEV,WAAW,EACX,oBAAoB,EACpB,gBAAgB,EAChB,gBAAgB,EAChB,iBAAiB,EACjB,sBAAsB,EACtB,cAAc,EACd,cAAc,GACf,MAAM,SAAS,CAAC;AAMjB,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,cAAc,EACd,kBAAkB,EAClB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAEnB,YAAY,EAEV,mBAAmB,EACnB,UAAU,EACV,gBAAgB,EAChB,mBAAmB,EACnB,qBAAqB,EACrB,qBAAqB,EACrB,oBAAoB,GACrB,MAAM,SAAS,CAAC;AAMjB,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,gBAAgB,EAChB,UAAU,EACV,aAAa,EACb,WAAW,EACX,cAAc,EACd,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAEnB,YAAY,EAEV,iBAAiB,EACjB,UAAU,EACV,gBAAgB,EAChB,gBAAgB,EAChB,eAAe,EACf,YAAY,EACZ,sBAAsB,GACvB,MAAM,SAAS,CAAC;AAGjB,YAAY,EAAE,SAAS,IAAI,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAMnE,OAAO,EAEL,qBAAqB,EACrB,oBAAoB,EAGpB,gBAAgB,EAChB,iBAAiB,EACjB,WAAW,EACX,UAAU,EAGV,gBAAgB,EAChB,cAAc,EACd,oBAAoB,EACpB,kBAAkB,EAClB,iBAAiB,EACjB,UAAU,EACV,iBAAiB,EACjB,gBAAgB,EAChB,oBAAoB,GACrB,MAAM,qBAAqB,CAAC;AAE7B,YAAY,EAEV,gBAAgB,EAChB,eAAe,EACf,WAAW,EACX,gBAAgB,EAChB,YAAY,EACZ,iBAAiB,EACjB,gBAAgB,EAChB,YAAY,EACZ,mBAAmB,EACnB,qBAAqB,EACrB,WAAW,EACX,oBAAoB,EACpB,cAAc,GACf,MAAM,qBAAqB,CAAC;AAM7B,OAAO,EAEL,mBAAmB,EACnB,uBAAuB,EACvB,mBAAmB,EAGnB,aAAa,EACb,WAAW,EACX,eAAe,EAGf,0BAA0B,EAC1B,mBAAmB,EACnB,gBAAgB,EAChB,oBAAoB,EACpB,qBAAqB,EAGrB,iBAAiB,EACjB,mBAAmB,EACnB,8BAA8B,EAC9B,yBAAyB,EAGzB,uBAAuB,EACvB,yBAAyB,EAGzB,WAAW,EACX,gBAAgB,EAChB,cAAc,EACd,gBAAgB,GACjB,MAAM,SAAS,CAAC;AAEjB,YAAY,EAEV,gBAAgB,EAChB,iBAAiB,EACjB,mBAAmB,EAGnB,UAAU,EACV,iBAAiB,EACjB,YAAY,EACZ,YAAY,EAGZ,kBAAkB,EAClB,gBAAgB,EAChB,eAAe,EACf,cAAc,EACd,aAAa,EACb,gBAAgB,EAGhB,aAAa,EACb,gBAAgB,EAChB,aAAa,EACb,cAAc,EACd,eAAe,EACf,gBAAgB,EAGhB,cAAc,EACd,YAAY,EACZ,oBAAoB,EAGpB,iBAAiB,EACjB,gBAAgB,EAChB,sBAAsB,EACtB,gBAAgB,EAChB,UAAU,GACX,MAAM,SAAS,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
2
|
+
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
3
|
+
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
4
|
+
export { DEFAULT_SECTION_CONFIG, makeEntityKey, parseEntityKey } from './types';
|
|
5
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
6
|
+
// SECTION CUTTING
|
|
7
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
8
|
+
export { SectionCutter, cutMeshesStreaming } from './section-cutter';
|
|
9
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
10
|
+
// POLYGON BUILDING
|
|
11
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
12
|
+
export { PolygonBuilder, simplifyPolygon, polygonBounds } from './polygon-builder';
|
|
13
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
14
|
+
// LINE MERGING
|
|
15
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
16
|
+
export { mergeDrawingLines, mergeCollinearLines, deduplicateLines, splitLineAtParams, } from './line-merger';
|
|
17
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
18
|
+
// EDGE EXTRACTION
|
|
19
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
20
|
+
export { EdgeExtractor, getViewDirection } from './edge-extractor';
|
|
21
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
22
|
+
// HIDDEN LINE REMOVAL
|
|
23
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
24
|
+
export { HiddenLineClassifier } from './hidden-line';
|
|
25
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
26
|
+
// STYLES (HATCHING & LINE WEIGHTS)
|
|
27
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
28
|
+
export {
|
|
29
|
+
// Hatch patterns
|
|
30
|
+
HATCH_PATTERNS, getHatchPattern,
|
|
31
|
+
// Line styles
|
|
32
|
+
LINE_STYLES, TYPE_LINE_WEIGHTS, getLineStyle,
|
|
33
|
+
// Scales
|
|
34
|
+
COMMON_SCALES, getRecommendedScale,
|
|
35
|
+
// Paper sizes
|
|
36
|
+
PAPER_SIZES, } from './styles';
|
|
37
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
38
|
+
// HATCH GENERATION
|
|
39
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
40
|
+
export { HatchGenerator } from './hatch-generator';
|
|
41
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
42
|
+
// SVG EXPORT
|
|
43
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
44
|
+
export { SVGExporter, exportToSVG } from './svg-exporter';
|
|
45
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
46
|
+
// GPU ACCELERATION
|
|
47
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
48
|
+
export { GPUSectionCutter, isGPUComputeAvailable } from './gpu-section-cutter';
|
|
49
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
50
|
+
// HIGH-LEVEL GENERATOR
|
|
51
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
52
|
+
export { Drawing2DGenerator, createSectionConfig, generateFloorPlan, generateSection, } from './drawing-generator';
|
|
53
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
54
|
+
// MATH UTILITIES
|
|
55
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
56
|
+
export {
|
|
57
|
+
// Constants
|
|
58
|
+
EPSILON,
|
|
59
|
+
// Vec3 operations
|
|
60
|
+
vec3, vec3Add, vec3Sub, vec3Scale, vec3Dot, vec3Cross, vec3Length, vec3Normalize, vec3Lerp, vec3Equals, vec3Distance,
|
|
61
|
+
// Point2D operations
|
|
62
|
+
point2D, point2DAdd, point2DSub, point2DScale, point2DDot, point2DLength, point2DDistance, point2DLerp, point2DEquals, point2DNormalize, point2DCross,
|
|
63
|
+
// Line operations
|
|
64
|
+
lineLength, lineMidpoint, lineDirection, linesCollinear, projectPointOnLine,
|
|
65
|
+
// Bounds operations
|
|
66
|
+
boundsEmpty, boundsExtendPoint, boundsExtendLine, boundsCenter, boundsSize, boundsValid,
|
|
67
|
+
// Plane operations
|
|
68
|
+
signedDistanceToPlane, getAxisNormal, getProjectionAxes, projectTo2D,
|
|
69
|
+
// Polygon operations
|
|
70
|
+
polygonSignedArea, isCounterClockwise, reversePolygon, ensureCCW, ensureCW, } from './math';
|
|
71
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
72
|
+
// OPENING HANDLING
|
|
73
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
74
|
+
export { OpeningRelationshipBuilder, OpeningFilter, buildOpeningRelationships, getOpeningsForHost, getFillingElement, isOpeningElement, isDoorOrWindow, } from './openings';
|
|
75
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
76
|
+
// ARCHITECTURAL SYMBOLS
|
|
77
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
78
|
+
export { DoorSymbolGenerator, WindowSymbolGenerator, SymbolRenderer, generateDoorSymbol, generateWindowSymbol, generateStairArrow, } from './symbols';
|
|
79
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
80
|
+
// LINE STYLING & LAYERS
|
|
81
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
82
|
+
export { LineWeightAssigner, LINE_WEIGHT_CONFIG, IFC_TYPE_WEIGHTS, LineStyler, DASH_PATTERNS, LayerMapper, DEFAULT_LAYERS, getLayerForIfcType, } from './styling';
|
|
83
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
84
|
+
// GRAPHIC OVERRIDES
|
|
85
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
86
|
+
export {
|
|
87
|
+
// Engine
|
|
88
|
+
GraphicOverrideEngine, createOverrideEngine,
|
|
89
|
+
// Criteria helpers
|
|
90
|
+
ifcTypeCriterion, propertyCriterion, andCriteria, orCriteria,
|
|
91
|
+
// Built-in presets
|
|
92
|
+
BUILT_IN_PRESETS, VIEW_3D_PRESET, ARCHITECTURAL_PRESET, FIRE_SAFETY_PRESET, STRUCTURAL_PRESET, MEP_PRESET, MONOCHROME_PRESET, getBuiltInPreset, getPresetsByCategory, } from './graphic-overrides';
|
|
93
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
94
|
+
// DRAWING SHEETS (Paper, Frames, Title Blocks, Scale Bars)
|
|
95
|
+
// ═══════════════════════════════════════════════════════════════════════════
|
|
96
|
+
export {
|
|
97
|
+
// Paper sizes
|
|
98
|
+
PAPER_SIZE_REGISTRY, getPaperSizesByCategory, getDefaultPaperSize,
|
|
99
|
+
// Frames
|
|
100
|
+
FRAME_PRESETS, createFrame, getDefaultFrame,
|
|
101
|
+
// Title blocks
|
|
102
|
+
DEFAULT_TITLE_BLOCK_FIELDS, TITLE_BLOCK_PRESETS, createTitleBlock, getDefaultTitleBlock, updateTitleBlockField,
|
|
103
|
+
// Scale bar
|
|
104
|
+
DEFAULT_SCALE_BAR, DEFAULT_NORTH_ARROW, calculateOptimalScaleBarLength, calculateOptimalDivisions,
|
|
105
|
+
// Sheet utilities
|
|
106
|
+
calculateViewportBounds, calculateDrawingTransform,
|
|
107
|
+
// Sheet renderers
|
|
108
|
+
renderFrame, renderTitleBlock, renderScaleBar, renderNorthArrow, } from './sheet';
|
|
109
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;+DAE+D;AAyD/D,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEhF,8EAA8E;AAC9E,kBAAkB;AAClB,8EAA8E;AAE9E,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAGrE,8EAA8E;AAC9E,mBAAmB;AACnB,8EAA8E;AAE9E,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAEnF,8EAA8E;AAC9E,eAAe;AACf,8EAA8E;AAE9E,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAGvB,8EAA8E;AAC9E,kBAAkB;AAClB,8EAA8E;AAE9E,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEnE,8EAA8E;AAC9E,sBAAsB;AACtB,8EAA8E;AAE9E,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAGrD,8EAA8E;AAC9E,mCAAmC;AACnC,8EAA8E;AAE9E,OAAO;AACL,iBAAiB;AACjB,cAAc,EACd,eAAe;AAEf,cAAc;AACd,WAAW,EACX,iBAAiB,EACjB,YAAY;AAEZ,SAAS;AACT,aAAa,EACb,mBAAmB;AAEnB,cAAc;AACd,WAAW,GACZ,MAAM,UAAU,CAAC;AAUlB,8EAA8E;AAC9E,mBAAmB;AACnB,8EAA8E;AAE9E,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,8EAA8E;AAC9E,aAAa;AACb,8EAA8E;AAE9E,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG1D,8EAA8E;AAC9E,mBAAmB;AACnB,8EAA8E;AAE9E,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAE/E,8EAA8E;AAC9E,uBAAuB;AACvB,8EAA8E;AAE9E,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,eAAe,GAChB,MAAM,qBAAqB,CAAC;AAG7B,8EAA8E;AAC9E,iBAAiB;AACjB,8EAA8E;AAE9E,OAAO;AACL,YAAY;AACZ,OAAO;AAEP,kBAAkB;AAClB,IAAI,EACJ,OAAO,EACP,OAAO,EACP,SAAS,EACT,OAAO,EACP,SAAS,EACT,UAAU,EACV,aAAa,EACb,QAAQ,EACR,UAAU,EACV,YAAY;AAEZ,qBAAqB;AACrB,OAAO,EACP,UAAU,EACV,UAAU,EACV,YAAY,EACZ,UAAU,EACV,aAAa,EACb,eAAe,EACf,WAAW,EACX,aAAa,EACb,gBAAgB,EAChB,YAAY;AAEZ,kBAAkB;AAClB,UAAU,EACV,YAAY,EACZ,aAAa,EACb,cAAc,EACd,kBAAkB;AAElB,oBAAoB;AACpB,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EAChB,YAAY,EACZ,UAAU,EACV,WAAW;AAEX,mBAAmB;AACnB,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,WAAW;AAEX,qBAAqB;AACrB,iBAAiB,EACjB,kBAAkB,EAClB,cAAc,EACd,SAAS,EACT,QAAQ,GACT,MAAM,QAAQ,CAAC;AAEhB,8EAA8E;AAC9E,mBAAmB;AACnB,8EAA8E;AAE9E,OAAO,EACL,0BAA0B,EAC1B,aAAa,EACb,yBAAyB,EACzB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,GACf,MAAM,YAAY,CAAC;AAcpB,8EAA8E;AAC9E,wBAAwB;AACxB,8EAA8E;AAE9E,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,cAAc,EACd,kBAAkB,EAClB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAanB,8EAA8E;AAC9E,wBAAwB;AACxB,8EAA8E;AAE9E,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,gBAAgB,EAChB,UAAU,EACV,aAAa,EACb,WAAW,EACX,cAAc,EACd,kBAAkB,GACnB,MAAM,WAAW,CAAC;AAgBnB,8EAA8E;AAC9E,oBAAoB;AACpB,8EAA8E;AAE9E,OAAO;AACL,SAAS;AACT,qBAAqB,EACrB,oBAAoB;AAEpB,mBAAmB;AACnB,gBAAgB,EAChB,iBAAiB,EACjB,WAAW,EACX,UAAU;AAEV,mBAAmB;AACnB,gBAAgB,EAChB,cAAc,EACd,oBAAoB,EACpB,kBAAkB,EAClB,iBAAiB,EACjB,UAAU,EACV,iBAAiB,EACjB,gBAAgB,EAChB,oBAAoB,GACrB,MAAM,qBAAqB,CAAC;AAmB7B,8EAA8E;AAC9E,2DAA2D;AAC3D,8EAA8E;AAE9E,OAAO;AACL,cAAc;AACd,mBAAmB,EACnB,uBAAuB,EACvB,mBAAmB;AAEnB,SAAS;AACT,aAAa,EACb,WAAW,EACX,eAAe;AAEf,eAAe;AACf,0BAA0B,EAC1B,mBAAmB,EACnB,gBAAgB,EAChB,oBAAoB,EACpB,qBAAqB;AAErB,YAAY;AACZ,iBAAiB,EACjB,mBAAmB,EACnB,8BAA8B,EAC9B,yBAAyB;AAEzB,kBAAkB;AAClB,uBAAuB,EACvB,yBAAyB;AAEzB,kBAAkB;AAClB,WAAW,EACX,gBAAgB,EAChB,cAAc,EACd,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Line Merger - Merges collinear line segments into longer lines
|
|
3
|
+
*
|
|
4
|
+
* Reduces the number of line segments in the output by combining
|
|
5
|
+
* segments that lie on the same line and are connected or overlapping.
|
|
6
|
+
*/
|
|
7
|
+
import type { Line2D, DrawingLine } from './types';
|
|
8
|
+
export interface LineMergerOptions {
|
|
9
|
+
/** Angle tolerance for considering lines collinear (radians) */
|
|
10
|
+
angleTolerance: number;
|
|
11
|
+
/** Distance tolerance for considering lines on same line */
|
|
12
|
+
distanceTolerance: number;
|
|
13
|
+
/** Gap tolerance for merging non-touching collinear segments */
|
|
14
|
+
gapTolerance: number;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Merge collinear line segments within the same entity
|
|
18
|
+
*/
|
|
19
|
+
export declare function mergeDrawingLines(lines: DrawingLine[], options?: Partial<LineMergerOptions>): DrawingLine[];
|
|
20
|
+
/**
|
|
21
|
+
* Core algorithm: merge collinear Line2D segments
|
|
22
|
+
*/
|
|
23
|
+
export declare function mergeCollinearLines(lines: Line2D[], options?: Partial<LineMergerOptions>): Line2D[];
|
|
24
|
+
/**
|
|
25
|
+
* Remove duplicate line segments
|
|
26
|
+
*/
|
|
27
|
+
export declare function deduplicateLines(lines: Line2D[], tolerance?: number): Line2D[];
|
|
28
|
+
/**
|
|
29
|
+
* Split a line at given parameters
|
|
30
|
+
* @param line The line to split
|
|
31
|
+
* @param params Array of t values (0-1) where to split
|
|
32
|
+
* @returns Array of line segments
|
|
33
|
+
*/
|
|
34
|
+
export declare function splitLineAtParams(line: Line2D, params: number[]): Line2D[];
|
|
35
|
+
//# sourceMappingURL=line-merger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"line-merger.d.ts","sourceRoot":"","sources":["../src/line-merger.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AAEH,OAAO,KAAK,EAAW,MAAM,EAAE,WAAW,EAAa,MAAM,SAAS,CAAC;AAiBvE,MAAM,WAAW,iBAAiB;IAChC,gEAAgE;IAChE,cAAc,EAAE,MAAM,CAAC;IACvB,4DAA4D;IAC5D,iBAAiB,EAAE,MAAM,CAAC;IAC1B,gEAAgE;IAChE,YAAY,EAAE,MAAM,CAAC;CACtB;AAQD;;GAEG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,WAAW,EAAE,EACpB,OAAO,GAAE,OAAO,CAAC,iBAAiB,CAAM,GACvC,WAAW,EAAE,CAuBf;AAsBD;;GAEG;AACH,wBAAgB,mBAAmB,CACjC,KAAK,EAAE,MAAM,EAAE,EACf,OAAO,GAAE,OAAO,CAAC,iBAAiB,CAAM,GACvC,MAAM,EAAE,CAuBV;AAyJD;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,MAAM,EAAE,EACf,SAAS,GAAE,MAAc,GACxB,MAAM,EAAE,CAmBV;AA6BD;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAiC1E"}
|