@vgpu/render 0.0.1
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 +21 -0
- package/README.md +55 -0
- package/dist/domain/camera.d.ts +10 -0
- package/dist/domain/camera.d.ts.map +1 -0
- package/dist/domain/camera.js +2 -0
- package/dist/domain/camera.js.map +1 -0
- package/dist/domain/capsule-data.d.ts +10 -0
- package/dist/domain/capsule-data.d.ts.map +1 -0
- package/dist/domain/capsule-data.js +61 -0
- package/dist/domain/capsule-data.js.map +1 -0
- package/dist/domain/cone-data.d.ts +13 -0
- package/dist/domain/cone-data.d.ts.map +1 -0
- package/dist/domain/cone-data.js +52 -0
- package/dist/domain/cone-data.js.map +1 -0
- package/dist/domain/cylinder-data.d.ts +14 -0
- package/dist/domain/cylinder-data.d.ts.map +1 -0
- package/dist/domain/cylinder-data.js +58 -0
- package/dist/domain/cylinder-data.js.map +1 -0
- package/dist/domain/deg-to-rad.d.ts +2 -0
- package/dist/domain/deg-to-rad.d.ts.map +1 -0
- package/dist/domain/deg-to-rad.js +4 -0
- package/dist/domain/deg-to-rad.js.map +1 -0
- package/dist/domain/disk-data.d.ts +12 -0
- package/dist/domain/disk-data.d.ts.map +1 -0
- package/dist/domain/disk-data.js +21 -0
- package/dist/domain/disk-data.js.map +1 -0
- package/dist/domain/icosphere-data.d.ts +8 -0
- package/dist/domain/icosphere-data.d.ts.map +1 -0
- package/dist/domain/icosphere-data.js +58 -0
- package/dist/domain/icosphere-data.js.map +1 -0
- package/dist/domain/index.d.ts +40 -0
- package/dist/domain/index.d.ts.map +1 -0
- package/dist/domain/index.js +23 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/material-factory.d.ts +34 -0
- package/dist/domain/material-factory.d.ts.map +1 -0
- package/dist/domain/material-factory.js +106 -0
- package/dist/domain/material-factory.js.map +1 -0
- package/dist/domain/material-sampler.d.ts +7 -0
- package/dist/domain/material-sampler.d.ts.map +1 -0
- package/dist/domain/material-sampler.js +11 -0
- package/dist/domain/material-sampler.js.map +1 -0
- package/dist/domain/material-textures-schema.d.ts +29 -0
- package/dist/domain/material-textures-schema.d.ts.map +1 -0
- package/dist/domain/material-textures-schema.js +57 -0
- package/dist/domain/material-textures-schema.js.map +1 -0
- package/dist/domain/material-textures.d.ts +13 -0
- package/dist/domain/material-textures.d.ts.map +1 -0
- package/dist/domain/material-textures.js +91 -0
- package/dist/domain/material-textures.js.map +1 -0
- package/dist/domain/material.d.ts +27 -0
- package/dist/domain/material.d.ts.map +1 -0
- package/dist/domain/material.js +2 -0
- package/dist/domain/material.js.map +1 -0
- package/dist/domain/mesh-box.d.ts +8 -0
- package/dist/domain/mesh-box.d.ts.map +1 -0
- package/dist/domain/mesh-box.js +57 -0
- package/dist/domain/mesh-box.js.map +1 -0
- package/dist/domain/mesh-cache.d.ts +4 -0
- package/dist/domain/mesh-cache.d.ts.map +1 -0
- package/dist/domain/mesh-cache.js +14 -0
- package/dist/domain/mesh-cache.js.map +1 -0
- package/dist/domain/mesh-capsule.d.ts +14 -0
- package/dist/domain/mesh-capsule.d.ts.map +1 -0
- package/dist/domain/mesh-capsule.js +52 -0
- package/dist/domain/mesh-capsule.js.map +1 -0
- package/dist/domain/mesh-cone.d.ts +16 -0
- package/dist/domain/mesh-cone.d.ts.map +1 -0
- package/dist/domain/mesh-cone.js +54 -0
- package/dist/domain/mesh-cone.js.map +1 -0
- package/dist/domain/mesh-cylinder.d.ts +18 -0
- package/dist/domain/mesh-cylinder.d.ts.map +1 -0
- package/dist/domain/mesh-cylinder.js +67 -0
- package/dist/domain/mesh-cylinder.js.map +1 -0
- package/dist/domain/mesh-disk.d.ts +11 -0
- package/dist/domain/mesh-disk.d.ts.map +1 -0
- package/dist/domain/mesh-disk.js +45 -0
- package/dist/domain/mesh-disk.js.map +1 -0
- package/dist/domain/mesh-dodecahedron.d.ts +4 -0
- package/dist/domain/mesh-dodecahedron.d.ts.map +1 -0
- package/dist/domain/mesh-dodecahedron.js +10 -0
- package/dist/domain/mesh-dodecahedron.js.map +1 -0
- package/dist/domain/mesh-fullscreen-quad.d.ts +7 -0
- package/dist/domain/mesh-fullscreen-quad.d.ts.map +1 -0
- package/dist/domain/mesh-fullscreen-quad.js +39 -0
- package/dist/domain/mesh-fullscreen-quad.js.map +1 -0
- package/dist/domain/mesh-icosahedron.d.ts +4 -0
- package/dist/domain/mesh-icosahedron.d.ts.map +1 -0
- package/dist/domain/mesh-icosahedron.js +10 -0
- package/dist/domain/mesh-icosahedron.js.map +1 -0
- package/dist/domain/mesh-icosphere.d.ts +11 -0
- package/dist/domain/mesh-icosphere.d.ts.map +1 -0
- package/dist/domain/mesh-icosphere.js +47 -0
- package/dist/domain/mesh-icosphere.js.map +1 -0
- package/dist/domain/mesh-octahedron.d.ts +4 -0
- package/dist/domain/mesh-octahedron.d.ts.map +1 -0
- package/dist/domain/mesh-octahedron.js +10 -0
- package/dist/domain/mesh-octahedron.js.map +1 -0
- package/dist/domain/mesh-plane.d.ts +13 -0
- package/dist/domain/mesh-plane.d.ts.map +1 -0
- package/dist/domain/mesh-plane.js +51 -0
- package/dist/domain/mesh-plane.js.map +1 -0
- package/dist/domain/mesh-ring.d.ts +12 -0
- package/dist/domain/mesh-ring.d.ts.map +1 -0
- package/dist/domain/mesh-ring.js +47 -0
- package/dist/domain/mesh-ring.js.map +1 -0
- package/dist/domain/mesh-sphere.d.ts +10 -0
- package/dist/domain/mesh-sphere.d.ts.map +1 -0
- package/dist/domain/mesh-sphere.js +51 -0
- package/dist/domain/mesh-sphere.js.map +1 -0
- package/dist/domain/mesh-tetrahedron.d.ts +5 -0
- package/dist/domain/mesh-tetrahedron.d.ts.map +1 -0
- package/dist/domain/mesh-tetrahedron.js +10 -0
- package/dist/domain/mesh-tetrahedron.js.map +1 -0
- package/dist/domain/mesh-torus.d.ts +17 -0
- package/dist/domain/mesh-torus.d.ts.map +1 -0
- package/dist/domain/mesh-torus.js +56 -0
- package/dist/domain/mesh-torus.js.map +1 -0
- package/dist/domain/mesh-types.d.ts +38 -0
- package/dist/domain/mesh-types.d.ts.map +1 -0
- package/dist/domain/mesh-types.js +2 -0
- package/dist/domain/mesh-types.js.map +1 -0
- package/dist/domain/mesh.d.ts +61 -0
- package/dist/domain/mesh.d.ts.map +1 -0
- package/dist/domain/mesh.js +49 -0
- package/dist/domain/mesh.js.map +1 -0
- package/dist/domain/orthographic-camera.d.ts +14 -0
- package/dist/domain/orthographic-camera.d.ts.map +1 -0
- package/dist/domain/orthographic-camera.js +10 -0
- package/dist/domain/orthographic-camera.js.map +1 -0
- package/dist/domain/perspective-camera.d.ts +12 -0
- package/dist/domain/perspective-camera.d.ts.map +1 -0
- package/dist/domain/perspective-camera.js +10 -0
- package/dist/domain/perspective-camera.js.map +1 -0
- package/dist/domain/plane-data.d.ts +12 -0
- package/dist/domain/plane-data.d.ts.map +1 -0
- package/dist/domain/plane-data.js +25 -0
- package/dist/domain/plane-data.js.map +1 -0
- package/dist/domain/polyhedron-data.d.ts +7 -0
- package/dist/domain/polyhedron-data.d.ts.map +1 -0
- package/dist/domain/polyhedron-data.js +42 -0
- package/dist/domain/polyhedron-data.js.map +1 -0
- package/dist/domain/polyhedron-mesh.d.ts +10 -0
- package/dist/domain/polyhedron-mesh.d.ts.map +1 -0
- package/dist/domain/polyhedron-mesh.js +37 -0
- package/dist/domain/polyhedron-mesh.js.map +1 -0
- package/dist/domain/polyhedron-seeds.d.ts +6 -0
- package/dist/domain/polyhedron-seeds.d.ts.map +1 -0
- package/dist/domain/polyhedron-seeds.js +51 -0
- package/dist/domain/polyhedron-seeds.js.map +1 -0
- package/dist/domain/primitive-data-utils.d.ts +9 -0
- package/dist/domain/primitive-data-utils.d.ts.map +1 -0
- package/dist/domain/primitive-data-utils.js +36 -0
- package/dist/domain/primitive-data-utils.js.map +1 -0
- package/dist/domain/ring-data.d.ts +13 -0
- package/dist/domain/ring-data.d.ts.map +1 -0
- package/dist/domain/ring-data.js +24 -0
- package/dist/domain/ring-data.js.map +1 -0
- package/dist/domain/sphere-data.d.ts +11 -0
- package/dist/domain/sphere-data.d.ts.map +1 -0
- package/dist/domain/sphere-data.js +31 -0
- package/dist/domain/sphere-data.js.map +1 -0
- package/dist/domain/srgb.d.ts +5 -0
- package/dist/domain/srgb.d.ts.map +1 -0
- package/dist/domain/srgb.js +11 -0
- package/dist/domain/srgb.js.map +1 -0
- package/dist/domain/torus-data.d.ts +11 -0
- package/dist/domain/torus-data.d.ts.map +1 -0
- package/dist/domain/torus-data.js +38 -0
- package/dist/domain/torus-data.js.map +1 -0
- package/dist/domain/vertex-layout.d.ts +3 -0
- package/dist/domain/vertex-layout.d.ts.map +1 -0
- package/dist/domain/vertex-layout.js +14 -0
- package/dist/domain/vertex-layout.js.map +1 -0
- package/dist/domain/wgsl-alignment.d.ts +17 -0
- package/dist/domain/wgsl-alignment.d.ts.map +1 -0
- package/dist/domain/wgsl-alignment.js +39 -0
- package/dist/domain/wgsl-alignment.js.map +1 -0
- package/dist/edit/edit-source.d.ts +10 -0
- package/dist/edit/edit-source.d.ts.map +1 -0
- package/dist/edit/edit-source.js +9 -0
- package/dist/edit/edit-source.js.map +1 -0
- package/dist/edit/editable-mesh.d.ts +11 -0
- package/dist/edit/editable-mesh.d.ts.map +1 -0
- package/dist/edit/editable-mesh.js +30 -0
- package/dist/edit/editable-mesh.js.map +1 -0
- package/dist/edit/element-set.d.ts +4 -0
- package/dist/edit/element-set.d.ts.map +1 -0
- package/dist/edit/element-set.js +78 -0
- package/dist/edit/element-set.js.map +1 -0
- package/dist/edit/errors.d.ts +11 -0
- package/dist/edit/errors.d.ts.map +1 -0
- package/dist/edit/errors.js +11 -0
- package/dist/edit/errors.js.map +1 -0
- package/dist/edit/half-edge-bake.d.ts +5 -0
- package/dist/edit/half-edge-bake.d.ts.map +1 -0
- package/dist/edit/half-edge-bake.js +30 -0
- package/dist/edit/half-edge-bake.js.map +1 -0
- package/dist/edit/half-edge-build.d.ts +4 -0
- package/dist/edit/half-edge-build.d.ts.map +1 -0
- package/dist/edit/half-edge-build.js +61 -0
- package/dist/edit/half-edge-build.js.map +1 -0
- package/dist/edit/half-edge-kernel.d.ts +21 -0
- package/dist/edit/half-edge-kernel.d.ts.map +1 -0
- package/dist/edit/half-edge-kernel.js +14 -0
- package/dist/edit/half-edge-kernel.js.map +1 -0
- package/dist/edit/half-edge-views.d.ts +8 -0
- package/dist/edit/half-edge-views.d.ts.map +1 -0
- package/dist/edit/half-edge-views.js +40 -0
- package/dist/edit/half-edge-views.js.map +1 -0
- package/dist/edit/index.d.ts +38 -0
- package/dist/edit/index.d.ts.map +1 -0
- package/dist/edit/index.js +20 -0
- package/dist/edit/index.js.map +1 -0
- package/dist/edit/kernel-handle.d.ts +5 -0
- package/dist/edit/kernel-handle.d.ts.map +1 -0
- package/dist/edit/kernel-handle.js +7 -0
- package/dist/edit/kernel-handle.js.map +1 -0
- package/dist/edit/operator-utils.d.ts +33 -0
- package/dist/edit/operator-utils.d.ts.map +1 -0
- package/dist/edit/operator-utils.js +101 -0
- package/dist/edit/operator-utils.js.map +1 -0
- package/dist/edit/operators/bevel.d.ts +18 -0
- package/dist/edit/operators/bevel.d.ts.map +1 -0
- package/dist/edit/operators/bevel.js +65 -0
- package/dist/edit/operators/bevel.js.map +1 -0
- package/dist/edit/operators/bridge.d.ts +14 -0
- package/dist/edit/operators/bridge.d.ts.map +1 -0
- package/dist/edit/operators/bridge.js +55 -0
- package/dist/edit/operators/bridge.js.map +1 -0
- package/dist/edit/operators/dissolve-edges.d.ts +12 -0
- package/dist/edit/operators/dissolve-edges.d.ts.map +1 -0
- package/dist/edit/operators/dissolve-edges.js +55 -0
- package/dist/edit/operators/dissolve-edges.js.map +1 -0
- package/dist/edit/operators/dissolve-faces.d.ts +9 -0
- package/dist/edit/operators/dissolve-faces.d.ts.map +1 -0
- package/dist/edit/operators/dissolve-faces.js +98 -0
- package/dist/edit/operators/dissolve-faces.js.map +1 -0
- package/dist/edit/operators/dissolve-vertices.d.ts +13 -0
- package/dist/edit/operators/dissolve-vertices.d.ts.map +1 -0
- package/dist/edit/operators/dissolve-vertices.js +36 -0
- package/dist/edit/operators/dissolve-vertices.js.map +1 -0
- package/dist/edit/operators/extrude.d.ts +18 -0
- package/dist/edit/operators/extrude.d.ts.map +1 -0
- package/dist/edit/operators/extrude.js +33 -0
- package/dist/edit/operators/extrude.js.map +1 -0
- package/dist/edit/operators/fill-hole.d.ts +12 -0
- package/dist/edit/operators/fill-hole.d.ts.map +1 -0
- package/dist/edit/operators/fill-hole.js +29 -0
- package/dist/edit/operators/fill-hole.js.map +1 -0
- package/dist/edit/operators/grid-fill.d.ts +12 -0
- package/dist/edit/operators/grid-fill.d.ts.map +1 -0
- package/dist/edit/operators/grid-fill.js +20 -0
- package/dist/edit/operators/grid-fill.js.map +1 -0
- package/dist/edit/operators/heal-manifold.d.ts +15 -0
- package/dist/edit/operators/heal-manifold.d.ts.map +1 -0
- package/dist/edit/operators/heal-manifold.js +62 -0
- package/dist/edit/operators/heal-manifold.js.map +1 -0
- package/dist/edit/operators/inset.d.ts +16 -0
- package/dist/edit/operators/inset.d.ts.map +1 -0
- package/dist/edit/operators/inset.js +40 -0
- package/dist/edit/operators/inset.js.map +1 -0
- package/dist/edit/operators/loop-cut.d.ts +14 -0
- package/dist/edit/operators/loop-cut.d.ts.map +1 -0
- package/dist/edit/operators/loop-cut.js +120 -0
- package/dist/edit/operators/loop-cut.js.map +1 -0
- package/dist/edit/operators/merge-by-distance.d.ts +15 -0
- package/dist/edit/operators/merge-by-distance.d.ts.map +1 -0
- package/dist/edit/operators/merge-by-distance.js +78 -0
- package/dist/edit/operators/merge-by-distance.js.map +1 -0
- package/dist/edit/operators/recompute-normals.d.ts +7 -0
- package/dist/edit/operators/recompute-normals.d.ts.map +1 -0
- package/dist/edit/operators/recompute-normals.js +67 -0
- package/dist/edit/operators/recompute-normals.js.map +1 -0
- package/dist/edit/operators/subdivide-edges.d.ts +11 -0
- package/dist/edit/operators/subdivide-edges.d.ts.map +1 -0
- package/dist/edit/operators/subdivide-edges.js +106 -0
- package/dist/edit/operators/subdivide-edges.js.map +1 -0
- package/dist/edit/operators/subdivide-faces.d.ts +11 -0
- package/dist/edit/operators/subdivide-faces.d.ts.map +1 -0
- package/dist/edit/operators/subdivide-faces.js +45 -0
- package/dist/edit/operators/subdivide-faces.js.map +1 -0
- package/dist/edit/selection.d.ts +19 -0
- package/dist/edit/selection.d.ts.map +1 -0
- package/dist/edit/selection.js +21 -0
- package/dist/edit/selection.js.map +1 -0
- package/dist/edit/to-editable.d.ts +9 -0
- package/dist/edit/to-editable.d.ts.map +1 -0
- package/dist/edit/to-editable.js +19 -0
- package/dist/edit/to-editable.js.map +1 -0
- package/dist/edit/types.d.ts +111 -0
- package/dist/edit/types.d.ts.map +1 -0
- package/dist/edit/types.js +2 -0
- package/dist/edit/types.js.map +1 -0
- package/dist/edit/warnings.d.ts +14 -0
- package/dist/edit/warnings.d.ts.map +1 -0
- package/dist/edit/warnings.js +11 -0
- package/dist/edit/warnings.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/inspect/index.d.ts +9 -0
- package/dist/inspect/index.d.ts.map +1 -0
- package/dist/inspect/index.js +5 -0
- package/dist/inspect/index.js.map +1 -0
- package/dist/inspect/inspect-material.d.ts +12 -0
- package/dist/inspect/inspect-material.d.ts.map +1 -0
- package/dist/inspect/inspect-material.js +2 -0
- package/dist/inspect/inspect-material.js.map +1 -0
- package/dist/inspect/mesh-to-readable.d.ts +4 -0
- package/dist/inspect/mesh-to-readable.d.ts.map +1 -0
- package/dist/inspect/mesh-to-readable.js +47 -0
- package/dist/inspect/mesh-to-readable.js.map +1 -0
- package/dist/inspect/mesh-to-wireframe.d.ts +5 -0
- package/dist/inspect/mesh-to-wireframe.d.ts.map +1 -0
- package/dist/inspect/mesh-to-wireframe.js +101 -0
- package/dist/inspect/mesh-to-wireframe.js.map +1 -0
- package/dist/inspect/normal-debug-material.d.ts +8 -0
- package/dist/inspect/normal-debug-material.d.ts.map +1 -0
- package/dist/inspect/normal-debug-material.js +42 -0
- package/dist/inspect/normal-debug-material.js.map +1 -0
- package/dist/inspect/normal-debug-shader.d.ts +2 -0
- package/dist/inspect/normal-debug-shader.d.ts.map +1 -0
- package/dist/inspect/normal-debug-shader.js +32 -0
- package/dist/inspect/normal-debug-shader.js.map +1 -0
- package/dist/inspect/wireframe-material.d.ts +9 -0
- package/dist/inspect/wireframe-material.d.ts.map +1 -0
- package/dist/inspect/wireframe-material.js +45 -0
- package/dist/inspect/wireframe-material.js.map +1 -0
- package/dist/inspect/wireframe-mesh.d.ts +9 -0
- package/dist/inspect/wireframe-mesh.d.ts.map +1 -0
- package/dist/inspect/wireframe-mesh.js +2 -0
- package/dist/inspect/wireframe-mesh.js.map +1 -0
- package/dist/inspect/wireframe-shader.d.ts +2 -0
- package/dist/inspect/wireframe-shader.d.ts.map +1 -0
- package/dist/inspect/wireframe-shader.js +24 -0
- package/dist/inspect/wireframe-shader.js.map +1 -0
- package/dist/passes/index.d.ts +6 -0
- package/dist/passes/index.d.ts.map +1 -0
- package/dist/passes/index.js +5 -0
- package/dist/passes/index.js.map +1 -0
- package/dist/passes/pass-sequence.d.ts +9 -0
- package/dist/passes/pass-sequence.d.ts.map +1 -0
- package/dist/passes/pass-sequence.js +21 -0
- package/dist/passes/pass-sequence.js.map +1 -0
- package/dist/passes/pass.d.ts +4 -0
- package/dist/passes/pass.d.ts.map +1 -0
- package/dist/passes/pass.js +99 -0
- package/dist/passes/pass.js.map +1 -0
- package/dist/pipeline.d.ts +16 -0
- package/dist/pipeline.d.ts.map +1 -0
- package/dist/pipeline.js +10 -0
- package/dist/pipeline.js.map +1 -0
- package/dist/rapid-renderer.d.ts +18 -0
- package/dist/rapid-renderer.d.ts.map +1 -0
- package/dist/rapid-renderer.js +58 -0
- package/dist/rapid-renderer.js.map +1 -0
- package/dist/render-pass.d.ts +33 -0
- package/dist/render-pass.d.ts.map +1 -0
- package/dist/render-pass.js +67 -0
- package/dist/render-pass.js.map +1 -0
- package/dist/render-target/render-target-canvas.d.ts +15 -0
- package/dist/render-target/render-target-canvas.d.ts.map +1 -0
- package/dist/render-target/render-target-canvas.js +59 -0
- package/dist/render-target/render-target-canvas.js.map +1 -0
- package/dist/render-target/render-target-multi.d.ts +4 -0
- package/dist/render-target/render-target-multi.d.ts.map +1 -0
- package/dist/render-target/render-target-multi.js +90 -0
- package/dist/render-target/render-target-multi.js.map +1 -0
- package/dist/render-target/render-target.d.ts +10 -0
- package/dist/render-target/render-target.d.ts.map +1 -0
- package/dist/render-target/render-target.js +98 -0
- package/dist/render-target/render-target.js.map +1 -0
- package/dist/render-target/types.d.ts +59 -0
- package/dist/render-target/types.d.ts.map +1 -0
- package/dist/render-target/types.js +2 -0
- package/dist/render-target/types.js.map +1 -0
- package/dist/uniform-pool-internals.d.ts +12 -0
- package/dist/uniform-pool-internals.d.ts.map +1 -0
- package/dist/uniform-pool-internals.js +24 -0
- package/dist/uniform-pool-internals.js.map +1 -0
- package/dist/uniform-pool-types.d.ts +22 -0
- package/dist/uniform-pool-types.d.ts.map +1 -0
- package/dist/uniform-pool-types.js +2 -0
- package/dist/uniform-pool-types.js.map +1 -0
- package/dist/uniform-pool.d.ts +30 -0
- package/dist/uniform-pool.d.ts.map +1 -0
- package/dist/uniform-pool.js +127 -0
- package/dist/uniform-pool.js.map +1 -0
- package/dist/utils/canvas-mouse-tracker.d.ts +11 -0
- package/dist/utils/canvas-mouse-tracker.d.ts.map +1 -0
- package/dist/utils/canvas-mouse-tracker.js +19 -0
- package/dist/utils/canvas-mouse-tracker.js.map +1 -0
- package/dist/utils/canvas-resolution.d.ts +9 -0
- package/dist/utils/canvas-resolution.d.ts.map +1 -0
- package/dist/utils/canvas-resolution.js +16 -0
- package/dist/utils/canvas-resolution.js.map +1 -0
- package/dist/utils/frame-clock.d.ts +10 -0
- package/dist/utils/frame-clock.d.ts.map +1 -0
- package/dist/utils/frame-clock.js +47 -0
- package/dist/utils/frame-clock.js.map +1 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +4 -0
- package/dist/utils/index.js.map +1 -0
- package/package.json +76 -0
- package/src/RenderPass.docs.md +41 -0
- package/src/createRenderPipeline.docs.md +34 -0
- package/src/domain/camera.docs.md +21 -0
- package/src/domain/deg-to-rad.docs.md +9 -0
- package/src/domain/material-factory.docs.md +59 -0
- package/src/domain/material.docs.md +12 -0
- package/src/domain/mesh.docs.md +28 -0
- package/src/domain/orthographic-camera.docs.md +22 -0
- package/src/domain/perspective-camera.docs.md +20 -0
- package/src/domain/srgb.docs.md +11 -0
- package/src/inspect/inspect-material.docs.md +23 -0
- package/src/inspect/mesh-to-wireframe.docs.md +29 -0
- package/src/inspect/normal-debug-material.docs.md +26 -0
- package/src/inspect/wireframe-material.docs.md +22 -0
- package/src/rapid-renderer.docs.md +18 -0
- package/src/uniform-pool.docs.md +60 -0
- package/src/utils/canvas-mouse-tracker.docs.md +13 -0
- package/src/utils/canvas-resolution.docs.md +13 -0
- package/src/utils/frame-clock.docs.md +14 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grid-fill.js","sourceRoot":"","sources":["../../../src/edit/operators/grid-fill.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAC;AAMlH,MAAM,UAAU,QAAQ,CAAC,EAAgB,EAAE,QAA0B,EAAE,OAAwB,EAAE;IAC/F,WAAW,CAAC,QAAQ,CAAC,CAAC;IACtB,MAAM,KAAK,GAAG,YAAY,CAAC,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC,EAAE,CAAC,EAAE,QAAQ,GAAsB,EAAE,CAAC;IAC1J,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,KAAK,CAAC;QAAE,QAAQ,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,0BAA0B,EAAE,+DAA+D,CAAC,CAAC,CAAC;IAC5J,IAAI,OAAO,IAAI,CAAC,QAAQ,KAAK,QAAQ,IAAI,IAAI,CAAC,QAAQ,GAAG,CAAC;QAAE,MAAM,IAAI,aAAa,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,CAAC,CAAC;IACnH,QAAQ,CAAC,IAAI,CAAC,IAAI,eAAe,CAAC,wBAAwB,EAAE,2CAA2C,IAAI,CAAC,QAAQ,IAAI,MAAM,6CAA6C,CAAC,CAAC,CAAC;IAC9K,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE;QAAE,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACxF,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,GAAG,SAAS,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAC7H,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;AAC7C,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.ts";
|
|
2
|
+
import type { EditableMesh as EditableMeshValue } from "../types.ts";
|
|
3
|
+
export interface HealManifoldReport {
|
|
4
|
+
readonly nonManifoldEdgesFixed: number;
|
|
5
|
+
readonly nonManifoldVerticesFixed: number;
|
|
6
|
+
readonly holesFixed: number;
|
|
7
|
+
readonly duplicateFacesRemoved: number;
|
|
8
|
+
}
|
|
9
|
+
export interface HealManifoldResult {
|
|
10
|
+
readonly mesh: EditableMeshValue;
|
|
11
|
+
readonly report: HealManifoldReport;
|
|
12
|
+
readonly warnings?: readonly MeshEditWarning[];
|
|
13
|
+
}
|
|
14
|
+
export declare function healManifold(em: EditableMeshValue): HealManifoldResult;
|
|
15
|
+
//# sourceMappingURL=heal-manifold.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"heal-manifold.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/heal-manifold.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,KAAK,EAAE,YAAY,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAGrE,MAAM,WAAW,kBAAkB;IAAG,QAAQ,CAAC,qBAAqB,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,wBAAwB,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,qBAAqB,EAAE,MAAM,CAAA;CAAE;AAC9L,MAAM,WAAW,kBAAkB;IAAG,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAC;IAAC,QAAQ,CAAC,MAAM,EAAE,kBAAkB,CAAC;IAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,SAAS,eAAe,EAAE,CAAA;CAAE;AAE7J,wBAAgB,YAAY,CAAC,EAAE,EAAE,iBAAiB,GAAG,kBAAkB,CAoBtE"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.js";
|
|
2
|
+
import { EditableMesh } from "../editable-mesh.js";
|
|
3
|
+
import { p, sub, cross } from "../operator-utils.js";
|
|
4
|
+
import { unwrapKernel } from "../kernel-handle.js";
|
|
5
|
+
export function healManifold(em) {
|
|
6
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel), positions = Array.from(k.positions), indices = [], smooth = [], edgeUse = new Map(), seenFaces = new Set();
|
|
7
|
+
let nonManifoldEdgesFixed = 0, duplicateFacesRemoved = 0, degenerate = 0;
|
|
8
|
+
for (let f = 0; f < em.faceCount; f++) {
|
|
9
|
+
const tri = Array.from(k.faceVertices.slice(f * 3, f * 3 + 3));
|
|
10
|
+
const faceKey = [...tri].sort((a, b) => a - b).join(":"), edges = triEdges(tri);
|
|
11
|
+
if (new Set(tri).size < 3 || triArea(em, tri) <= 1e-12) {
|
|
12
|
+
degenerate++;
|
|
13
|
+
continue;
|
|
14
|
+
}
|
|
15
|
+
if (seenFaces.has(faceKey)) {
|
|
16
|
+
duplicateFacesRemoved++;
|
|
17
|
+
continue;
|
|
18
|
+
}
|
|
19
|
+
if (edges.some((e) => (edgeUse.get(e) ?? 0) >= 2)) {
|
|
20
|
+
nonManifoldEdgesFixed++;
|
|
21
|
+
continue;
|
|
22
|
+
}
|
|
23
|
+
seenFaces.add(faceKey);
|
|
24
|
+
for (const e of edges)
|
|
25
|
+
edgeUse.set(e, (edgeUse.get(e) ?? 0) + 1);
|
|
26
|
+
indices.push(...tri);
|
|
27
|
+
smooth.push(k.useSmooth[f]);
|
|
28
|
+
}
|
|
29
|
+
const mesh = EditableMesh.fromArrays({ positions: new Float32Array(positions), indices: new Uint32Array(indices), useSmooth: Uint8Array.from(smooth) });
|
|
30
|
+
preserveSharp(em, mesh);
|
|
31
|
+
const warnings = [];
|
|
32
|
+
if (degenerate)
|
|
33
|
+
warnings.push(new MeshEditWarning("DEGENERATE_FACE_DROPPED", `${degenerate} zero-area face(s) were removed while healing manifold topology.`));
|
|
34
|
+
if (!mesh.isManifold || hasOverusedEdges(mesh))
|
|
35
|
+
warnings.push(new MeshEditWarning("HEAL_NON_MANIFOLD_RESIDUE", "Some non-manifold residue remains after deterministic healManifold cleanup."));
|
|
36
|
+
const report = { nonManifoldEdgesFixed, nonManifoldVerticesFixed: 0, holesFixed: 0, duplicateFacesRemoved };
|
|
37
|
+
const out = { mesh, report };
|
|
38
|
+
return warnings.length ? { ...out, warnings } : out;
|
|
39
|
+
}
|
|
40
|
+
function preserveSharp(oldMesh, mesh) {
|
|
41
|
+
const oldSharp = new Set(), ok = unwrapKernel(oldMesh.gpu.halfEdgeKernel), nk = unwrapKernel(mesh.gpu.halfEdgeKernel);
|
|
42
|
+
for (let e = 0; e < oldMesh.edgeCount; e++)
|
|
43
|
+
if (ok.isSharp[e])
|
|
44
|
+
oldSharp.add(posKey(p(oldMesh, ok.edgeVertexA[e]), p(oldMesh, ok.edgeVertexB[e])));
|
|
45
|
+
nk.isSharp.fill(0);
|
|
46
|
+
for (let e = 0; e < mesh.edgeCount; e++)
|
|
47
|
+
if (oldSharp.has(posKey(p(mesh, nk.edgeVertexA[e]), p(mesh, nk.edgeVertexB[e]))))
|
|
48
|
+
nk.isSharp[e] = 1;
|
|
49
|
+
}
|
|
50
|
+
function hasOverusedEdges(em) {
|
|
51
|
+
const counts = new Map(), k = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
52
|
+
for (let f = 0; f < em.faceCount; f++)
|
|
53
|
+
for (const e of triEdges(Array.from(k.faceVertices.slice(f * 3, f * 3 + 3))))
|
|
54
|
+
counts.set(e, (counts.get(e) ?? 0) + 1);
|
|
55
|
+
return [...counts.values()].some((v) => v !== 2);
|
|
56
|
+
}
|
|
57
|
+
function triEdges(t) { return [edgeKey(t[0], t[1]), edgeKey(t[1], t[2]), edgeKey(t[2], t[0])]; }
|
|
58
|
+
function edgeKey(a, b) { return a < b ? `${a}:${b}` : `${b}:${a}`; }
|
|
59
|
+
function posKey(a, b) { const ka = q(a), kb = q(b); return ka < kb ? `${ka}|${kb}` : `${kb}|${ka}`; }
|
|
60
|
+
function q(v) { return `${Math.fround(v[0])},${Math.fround(v[1])},${Math.fround(v[2])}`; }
|
|
61
|
+
function triArea(em, tri) { const n = cross(sub(p(em, tri[1]), p(em, tri[0])), sub(p(em, tri[2]), p(em, tri[0]))); return Math.hypot(n[0], n[1], n[2]) * 0.5; }
|
|
62
|
+
//# sourceMappingURL=heal-manifold.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"heal-manifold.js","sourceRoot":"","sources":["../../../src/edit/operators/heal-manifold.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.ts";
|
|
2
|
+
import type { EditableMesh, ElementSelection } from "../types.ts";
|
|
3
|
+
export interface InsetOptions {
|
|
4
|
+
readonly thickness: number;
|
|
5
|
+
readonly depth?: number;
|
|
6
|
+
readonly individual?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface InsetResult {
|
|
9
|
+
readonly mesh: EditableMesh;
|
|
10
|
+
readonly insetFaces: ElementSelection;
|
|
11
|
+
readonly boundaryFaces: ElementSelection;
|
|
12
|
+
readonly rimEdges: ElementSelection;
|
|
13
|
+
readonly warnings?: readonly MeshEditWarning[];
|
|
14
|
+
}
|
|
15
|
+
export declare function inset(em: EditableMesh, faces: ElementSelection, opts: InsetOptions): InsetResult;
|
|
16
|
+
//# sourceMappingURL=inset.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inset.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/inset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAGlE,MAAM,WAAW,YAAY;IAAG,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,OAAO,CAAA;CAAE;AACpH,MAAM,WAAW,WAAW;IAAG,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC;IAAC,QAAQ,CAAC,UAAU,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,aAAa,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,SAAS,eAAe,EAAE,CAAA;CAAE;AAElO,wBAAgB,KAAK,CAAC,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,IAAI,EAAE,YAAY,GAAG,WAAW,CAsBhG"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.js";
|
|
2
|
+
import { selection } from "../selection.js";
|
|
3
|
+
import { add, addQuad, addTri, build, center, faceVerts, key, mul, normal, p, requireSelection } from "../operator-utils.js";
|
|
4
|
+
import { unwrapKernel } from "../kernel-handle.js";
|
|
5
|
+
export function inset(em, faces, opts) {
|
|
6
|
+
requireSelection(faces, "face");
|
|
7
|
+
const selected = new Set(faces.indices), parts = { positions: [], faces: [], useSmooth: [], sharp: new Set() };
|
|
8
|
+
const inner = [], boundary = [], warnings = [], source = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
9
|
+
for (let f = 0; f < em.faceCount; f++)
|
|
10
|
+
if (!selected.has(f)) {
|
|
11
|
+
const v = faceVerts(em, f).map((i) => p(em, i));
|
|
12
|
+
addTri(parts, v[0], v[1], v[2], source.useSmooth[f]);
|
|
13
|
+
for (const e of source.faceEdges.slice(f * 3, f * 3 + 3))
|
|
14
|
+
if (source.isSharp[e])
|
|
15
|
+
parts.sharp.add(key(p(em, source.edgeVertexA[e]), p(em, source.edgeVertexB[e])));
|
|
16
|
+
}
|
|
17
|
+
for (const f of faces.indices) {
|
|
18
|
+
const verts = faceVerts(em, f).map((i) => p(em, i)), c = center(verts), n = normal(verts), t = clamp(opts.thickness);
|
|
19
|
+
if (t !== opts.thickness)
|
|
20
|
+
warnings.push(new MeshEditWarning("INSET_OVERLAP_CLAMPED", "Inset thickness was clamped before faces crossed.", { domain: "face", index: f }));
|
|
21
|
+
const ins = verts.map((v) => add(toward(v, c, t), n, opts.depth ?? 0));
|
|
22
|
+
inner.push(addTri(parts, ins[0], ins[1], ins[2], source.useSmooth[f]));
|
|
23
|
+
for (let i = 0; i < 3; i++) {
|
|
24
|
+
const q = addQuad(parts, verts[i], verts[(i + 1) % 3], ins[(i + 1) % 3], ins[i], source.useSmooth[f]);
|
|
25
|
+
boundary.push(...q);
|
|
26
|
+
const e = source.faceEdges[f * 3 + i];
|
|
27
|
+
if (source.isSharp[e])
|
|
28
|
+
parts.sharp.add(key(verts[i], verts[(i + 1) % 3]));
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
const mesh = build(parts), rimEdges = edgeSelectionOf(mesh, boundary);
|
|
32
|
+
const out = { mesh, insetFaces: selection("face", inner), boundaryFaces: selection("face", boundary), rimEdges };
|
|
33
|
+
return warnings.length ? { ...out, warnings } : out;
|
|
34
|
+
}
|
|
35
|
+
function toward(v, c, t) { return add(v, mul([c[0] - v[0], c[1] - v[1], c[2] - v[2]], t)); }
|
|
36
|
+
function clamp(t) { return Math.max(0, Math.min(0.49, t)); }
|
|
37
|
+
function edgeSelectionOf(mesh, faces) { const s = new Set(faces), out = [], k = unwrapKernel(mesh.gpu.halfEdgeKernel); for (let e = 0; e < k.edgeCount; e++)
|
|
38
|
+
if (s.has(k.edgeFaceA[e]) || s.has(k.edgeFaceB[e]))
|
|
39
|
+
out.push(e); return selection("edge", out); }
|
|
40
|
+
//# sourceMappingURL=inset.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inset.js","sourceRoot":"","sources":["../../../src/edit/operators/inset.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.ts";
|
|
2
|
+
import type { EditableMesh, ElementSelection } from "../types.ts";
|
|
3
|
+
export interface LoopCutOptions {
|
|
4
|
+
readonly cuts?: number;
|
|
5
|
+
readonly slide?: number;
|
|
6
|
+
readonly markSharp?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface LoopCutResult {
|
|
9
|
+
readonly mesh: EditableMesh;
|
|
10
|
+
readonly insertedLoop: ElementSelection;
|
|
11
|
+
readonly warnings?: readonly MeshEditWarning[];
|
|
12
|
+
}
|
|
13
|
+
export declare function loopCut(em: EditableMesh, seedEdge: number, opts?: LoopCutOptions): LoopCutResult;
|
|
14
|
+
//# sourceMappingURL=loop-cut.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-cut.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/loop-cut.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAIlE,MAAM,WAAW,cAAc;IAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,CAAA;CAAE;AACjH,MAAM,WAAW,aAAa;IAAG,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC;IAAC,QAAQ,CAAC,YAAY,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,SAAS,eAAe,EAAE,CAAA;CAAE;AAGvJ,wBAAgB,OAAO,CAAC,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,GAAE,cAAmB,GAAG,aAAa,CAMpG"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { MeshEditError } from "../errors.js";
|
|
2
|
+
import { MeshEditWarning } from "../warnings.js";
|
|
3
|
+
import { selection } from "../selection.js";
|
|
4
|
+
import { addQuad, addTri, build, edgeVerts, key, normal, p } from "../operator-utils.js";
|
|
5
|
+
import { subdivideEdges } from "./subdivide-edges.js";
|
|
6
|
+
import { unwrapKernel } from "../kernel-handle.js";
|
|
7
|
+
export function loopCut(em, seedEdge, opts = {}) {
|
|
8
|
+
if (seedEdge < 0 || seedEdge >= em.edgeCount)
|
|
9
|
+
throw new MeshEditError({ code: "EMPTY_SELECTION" });
|
|
10
|
+
const ring = collectRing(em, seedEdge);
|
|
11
|
+
if (!ring)
|
|
12
|
+
return fallback(em, seedEdge, opts);
|
|
13
|
+
const cut = cutRing(em, ring, clamp01(0.5 + (opts.slide ?? 0) * 0.5), opts.markSharp ?? false);
|
|
14
|
+
return { mesh: cut.mesh, insertedLoop: selection("edge", cut.edges, true) };
|
|
15
|
+
}
|
|
16
|
+
function fallback(em, seedEdge, opts) {
|
|
17
|
+
const result = subdivideEdges(em, selection("edge", [seedEdge], true), { cuts: opts.cuts ?? 1 });
|
|
18
|
+
for (const e of result.newEdges.indices)
|
|
19
|
+
unwrapKernel(result.mesh.gpu.halfEdgeKernel).isSharp[e] = 0;
|
|
20
|
+
return { mesh: result.mesh, insertedLoop: selection("edge", result.newEdges.indices, true), warnings: [new MeshEditWarning("LOOP_CUT_AMBIGUOUS_CONTINUATION", "Loop cut could not find an unambiguous continuation; only the seed edge was cut.", { domain: "edge", index: seedEdge })] };
|
|
21
|
+
}
|
|
22
|
+
function collectRing(em, seed) {
|
|
23
|
+
// v1 kernel has face slots but no twin half-edges, so we infer loop steps through coplanar triangle pairs.
|
|
24
|
+
const graph = new Map();
|
|
25
|
+
for (let e = 0; e < em.edgeCount; e++)
|
|
26
|
+
for (const f of edgeFaces(em, e)) {
|
|
27
|
+
const link = continuation(em, e, f);
|
|
28
|
+
if (link) {
|
|
29
|
+
addLink(graph, link.a, link.b, link);
|
|
30
|
+
addLink(graph, link.b, link.a, link);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
const first = graph.get(seed);
|
|
34
|
+
if (!first || first.size !== 2)
|
|
35
|
+
return null;
|
|
36
|
+
const edges = [seed], links = [];
|
|
37
|
+
let prev = -1, cur = seed;
|
|
38
|
+
for (let guard = 0; guard <= em.edgeCount; guard++) {
|
|
39
|
+
const nexts = graph.get(cur);
|
|
40
|
+
if (!nexts || nexts.size !== 2)
|
|
41
|
+
return null;
|
|
42
|
+
const next = [...nexts.keys()].find((e) => e !== prev);
|
|
43
|
+
if (next === undefined)
|
|
44
|
+
return null;
|
|
45
|
+
links.push(nexts.get(next));
|
|
46
|
+
if (next === seed)
|
|
47
|
+
return edges.length > 2 ? { edges, links } : null;
|
|
48
|
+
if (edges.includes(next))
|
|
49
|
+
return null;
|
|
50
|
+
edges.push(next);
|
|
51
|
+
prev = cur;
|
|
52
|
+
cur = next;
|
|
53
|
+
}
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
function cutRing(em, ring, t, markSharp) {
|
|
57
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel), drop = new Set(ring.links.flatMap((l) => l.faces)), rails = new Set(ring.edges);
|
|
58
|
+
const parts = { positions: [], faces: [], useSmooth: [], sharp: new Set() }, cutPoints = new Map(), ringKeys = new Set();
|
|
59
|
+
for (let f = 0; f < em.faceCount; f++)
|
|
60
|
+
if (!drop.has(f))
|
|
61
|
+
addTri(parts, p(em, k.faceVertices[f * 3]), p(em, k.faceVertices[f * 3 + 1]), p(em, k.faceVertices[f * 3 + 2]), k.useSmooth[f]);
|
|
62
|
+
for (const e of ring.edges)
|
|
63
|
+
cutPoints.set(e, splitPoint(em, e, t));
|
|
64
|
+
for (const link of ring.links) {
|
|
65
|
+
const dir = edgeDir(em, link.a), [a0, a1] = orderedEdgeDir(em, link.a, dir), [b0, b1] = orderedEdgeDir(em, link.b, dir), ma = cutPoints.get(link.a), mb = cutPoints.get(link.b);
|
|
66
|
+
const smooth = Math.max(k.useSmooth[link.faces[0]], k.useSmooth[link.faces[1]]), target = faceNormal(em, link.faces[0]);
|
|
67
|
+
addQuadOriented(parts, a0, b0, mb, ma, smooth, target);
|
|
68
|
+
addQuadOriented(parts, ma, mb, b1, a1, smooth, target);
|
|
69
|
+
ringKeys.add(key(ma, mb));
|
|
70
|
+
if (markSharp)
|
|
71
|
+
parts.sharp.add(key(ma, mb));
|
|
72
|
+
}
|
|
73
|
+
for (let e = 0; e < em.edgeCount; e++)
|
|
74
|
+
if (k.isSharp[e] && !isDroppedDiagonal(em, e, drop) && !rails.has(e))
|
|
75
|
+
parts.sharp.add(key(p(em, k.edgeVertexA[e]), p(em, k.edgeVertexB[e])));
|
|
76
|
+
for (const e of ring.edges)
|
|
77
|
+
if (k.isSharp[e]) {
|
|
78
|
+
const [a, b] = orderedEdge(em, e), m = cutPoints.get(e);
|
|
79
|
+
parts.sharp.add(key(a, m));
|
|
80
|
+
parts.sharp.add(key(m, b));
|
|
81
|
+
}
|
|
82
|
+
const mesh = build(parts), out = [], nk = unwrapKernel(mesh.gpu.halfEdgeKernel);
|
|
83
|
+
for (let e = 0; e < mesh.edgeCount; e++)
|
|
84
|
+
if (ringKeys.has(key(pos(nk.positions, nk.edgeVertexA[e]), pos(nk.positions, nk.edgeVertexB[e]))))
|
|
85
|
+
out.push(e);
|
|
86
|
+
tintFaces(mesh, out);
|
|
87
|
+
return { mesh, edges: out };
|
|
88
|
+
}
|
|
89
|
+
function continuation(em, e, face) {
|
|
90
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel), fe = Array.from(k.faceEdges.slice(face * 3, face * 3 + 3)), out = [];
|
|
91
|
+
for (const bridge of fe)
|
|
92
|
+
if (bridge !== e) {
|
|
93
|
+
const other = k.opposite(bridge, face);
|
|
94
|
+
if (other === null || dot(faceNormal(em, face), faceNormal(em, other)) < 0.999)
|
|
95
|
+
continue;
|
|
96
|
+
for (const r of Array.from(k.faceEdges.slice(other * 3, other * 3 + 3)))
|
|
97
|
+
if (r !== bridge && r !== e && disjoint(em, e, r) && parallel(em, e, r))
|
|
98
|
+
out.push({ a: e, b: r, faces: [face, other] });
|
|
99
|
+
}
|
|
100
|
+
return out.length === 1 ? out[0] : null;
|
|
101
|
+
}
|
|
102
|
+
function addLink(graph, a, b, link) { const m = graph.get(a) ?? new Map(); m.set(b, link); graph.set(a, m); }
|
|
103
|
+
function edgeFaces(em, e) { const k = unwrapKernel(em.gpu.halfEdgeKernel), out = [k.edgeFaceA[e], k.edgeFaceB[e]].filter((f) => f >= 0); return out.length === 2 ? out : []; }
|
|
104
|
+
function disjoint(em, a, b) { const av = new Set(edgeVerts(em, a)); return edgeVerts(em, b).every((v) => !av.has(v)); }
|
|
105
|
+
function parallel(em, a, b) { const da = edgeDir(em, a), db = edgeDir(em, b); return Math.abs(dot(da, db)) > 0.999; }
|
|
106
|
+
function edgeDir(em, e) { const [a, b] = edgeVerts(em, e), av = p(em, a), bv = p(em, b), d = [bv[0] - av[0], bv[1] - av[1], bv[2] - av[2]], l = Math.hypot(...d) || 1; return [d[0] / l, d[1] / l, d[2] / l]; }
|
|
107
|
+
function orderedEdge(em, e) { return orderedEdgeDir(em, e, edgeDir(em, e)); }
|
|
108
|
+
function orderedEdgeDir(em, e, d) { const [a, b] = edgeVerts(em, e), av = p(em, a), bv = p(em, b); return dot(av, d) <= dot(bv, d) ? [av, bv] : [bv, av]; }
|
|
109
|
+
function splitPoint(em, e, t) { const [a, b] = orderedEdge(em, e); return [a[0] + (b[0] - a[0]) * t, a[1] + (b[1] - a[1]) * t, a[2] + (b[2] - a[2]) * t]; }
|
|
110
|
+
function faceNormal(em, f) { const n = unwrapKernel(em.gpu.halfEdgeKernel).faceNormals, i = f * 3; return [n[i], n[i + 1], n[i + 2]]; }
|
|
111
|
+
function addQuadOriented(m, a, b, c, d, smooth, target) { dot(normal([a, b, c]), target) >= 0 ? addQuad(m, a, b, c, d, smooth) : addQuad(m, a, d, c, b, smooth); }
|
|
112
|
+
function isDroppedDiagonal(em, e, drop) { const k = unwrapKernel(em.gpu.halfEdgeKernel); return drop.has(k.edgeFaceA[e]) && drop.has(k.edgeFaceB[e]); }
|
|
113
|
+
function tintFaces(em, edges) { const k = unwrapKernel(em.gpu.halfEdgeKernel); for (const e of edges)
|
|
114
|
+
for (const f of [k.edgeFaceA[e], k.edgeFaceB[e]])
|
|
115
|
+
if (f >= 0)
|
|
116
|
+
k.faceNormals.set([0.577, 0.577, 0.577], f * 3); }
|
|
117
|
+
function dot(a, b) { return a[0] * b[0] + a[1] * b[1] + a[2] * b[2]; }
|
|
118
|
+
function clamp01(v) { return Math.max(0.001, Math.min(0.999, v)); }
|
|
119
|
+
function pos(a, v) { const i = v * 3; return [a[i], a[i + 1], a[i + 2]]; }
|
|
120
|
+
//# sourceMappingURL=loop-cut.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loop-cut.js","sourceRoot":"","sources":["../../../src/edit/operators/loop-cut.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.ts";
|
|
2
|
+
import type { EditableMesh as EditableMeshValue, ElementSelection } from "../types.ts";
|
|
3
|
+
export interface MergeByDistanceOptions {
|
|
4
|
+
readonly threshold?: number;
|
|
5
|
+
readonly selection?: ElementSelection;
|
|
6
|
+
readonly key?: "position" | "full-vertex";
|
|
7
|
+
}
|
|
8
|
+
export interface MergeByDistanceResult {
|
|
9
|
+
readonly mesh: EditableMeshValue;
|
|
10
|
+
readonly mergeMap: ReadonlyMap<number, number>;
|
|
11
|
+
readonly weldedCount: number;
|
|
12
|
+
readonly warnings?: readonly MeshEditWarning[];
|
|
13
|
+
}
|
|
14
|
+
export declare function mergeByDistance(em: EditableMeshValue, opts?: MergeByDistanceOptions): MergeByDistanceResult;
|
|
15
|
+
//# sourceMappingURL=merge-by-distance.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-by-distance.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/merge-by-distance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAIjD,OAAO,KAAK,EAAE,YAAY,IAAI,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEvF,MAAM,WAAW,sBAAsB;IAAG,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,UAAU,GAAG,aAAa,CAAA;CAAE;AACzJ,MAAM,WAAW,qBAAqB;IAAG,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAC;IAAC,QAAQ,CAAC,QAAQ,EAAE,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,SAAS,eAAe,EAAE,CAAA;CAAE;AAEzM,wBAAgB,eAAe,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,GAAE,sBAA2B,GAAG,qBAAqB,CAsB/G"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { MeshEditWarning } from "../warnings.js";
|
|
2
|
+
import { EditableMesh } from "../editable-mesh.js";
|
|
3
|
+
import { unwrapKernel } from "../kernel-handle.js";
|
|
4
|
+
import { requireSelection, p, normal } from "../operator-utils.js";
|
|
5
|
+
export function mergeByDistance(em, opts = {}) {
|
|
6
|
+
const vertices = opts.selection ?? em.vertices.all();
|
|
7
|
+
requireSelection(vertices, "vertex");
|
|
8
|
+
const threshold = opts.threshold ?? 1e-4, clusters = clusterVertices(em, vertices.indices, threshold), oldToSurvivor = new Map();
|
|
9
|
+
for (let v = 0; v < em.vertexCount; v++)
|
|
10
|
+
oldToSurvivor.set(v, v);
|
|
11
|
+
for (const c of clusters)
|
|
12
|
+
for (const v of c)
|
|
13
|
+
oldToSurvivor.set(v, c[0]);
|
|
14
|
+
const used = usedSurvivors(em, oldToSurvivor), survivorToNew = new Map(), positions = [];
|
|
15
|
+
for (const s of used) {
|
|
16
|
+
survivorToNew.set(s, positions.length / 3);
|
|
17
|
+
positions.push(...p(em, s));
|
|
18
|
+
}
|
|
19
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel), indices = [], smooth = [], warnings = [];
|
|
20
|
+
let degenerate = 0;
|
|
21
|
+
for (let f = 0; f < em.faceCount; f++) {
|
|
22
|
+
const tri = Array.from(k.faceVertices.slice(f * 3, f * 3 + 3), (v) => survivorToNew.get(oldToSurvivor.get(v)));
|
|
23
|
+
if (new Set(tri).size < 3 || area(positions, tri) <= 1e-12) {
|
|
24
|
+
degenerate++;
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
indices.push(...tri);
|
|
28
|
+
smooth.push(k.useSmooth[f]);
|
|
29
|
+
}
|
|
30
|
+
if (degenerate)
|
|
31
|
+
warnings.push(new MeshEditWarning("MERGE_DEGENERATE_FACES_REMOVED", `${degenerate} face(s) collapsed during mergeByDistance and were removed.`));
|
|
32
|
+
if (opts.key === "position" && (em.hasUVs || em.hasNormals || em.hasVertexColors))
|
|
33
|
+
warnings.push(new MeshEditWarning("SEAM_DESTROYED", "Position-only merge may destroy attribute seams."));
|
|
34
|
+
const mesh = EditableMesh.fromArrays({ positions: new Float32Array(positions), indices: new Uint32Array(indices), useSmooth: Uint8Array.from(smooth) });
|
|
35
|
+
applySharpOr(em, mesh, oldToSurvivor, survivorToNew);
|
|
36
|
+
const mergeMap = new Map();
|
|
37
|
+
for (let v = 0; v < em.vertexCount; v++)
|
|
38
|
+
mergeMap.set(v, survivorToNew.get(oldToSurvivor.get(v)) ?? -1);
|
|
39
|
+
const out = { mesh, mergeMap, weldedCount: em.vertexCount - used.length };
|
|
40
|
+
return warnings.length ? { ...out, warnings } : out;
|
|
41
|
+
}
|
|
42
|
+
function clusterVertices(em, selected, threshold) {
|
|
43
|
+
const pending = [...selected].sort((a, b) => a - b), out = [];
|
|
44
|
+
while (pending.length) {
|
|
45
|
+
const seed = pending.shift(), cluster = [seed];
|
|
46
|
+
for (let i = pending.length - 1; i >= 0; i--)
|
|
47
|
+
if (dist(p(em, seed), p(em, pending[i])) <= threshold)
|
|
48
|
+
cluster.push(pending.splice(i, 1)[0]);
|
|
49
|
+
cluster.sort((a, b) => a - b);
|
|
50
|
+
if (cluster.length > 1)
|
|
51
|
+
out.push(cluster);
|
|
52
|
+
}
|
|
53
|
+
return out;
|
|
54
|
+
}
|
|
55
|
+
function usedSurvivors(em, map) {
|
|
56
|
+
const used = new Set(), k = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
57
|
+
for (let i = 0; i < k.faceVertices.length; i++)
|
|
58
|
+
used.add(map.get(k.faceVertices[i]));
|
|
59
|
+
return [...used].sort((a, b) => a - b);
|
|
60
|
+
}
|
|
61
|
+
function applySharpOr(em, mesh, oldToSurvivor, survivorToNew) {
|
|
62
|
+
const sharp = new Set(), k = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
63
|
+
for (let e = 0; e < em.edgeCount; e++)
|
|
64
|
+
if (k.isSharp[e]) {
|
|
65
|
+
const a = survivorToNew.get(oldToSurvivor.get(k.edgeVertexA[e])), b = survivorToNew.get(oldToSurvivor.get(k.edgeVertexB[e]));
|
|
66
|
+
if (a !== b)
|
|
67
|
+
sharp.add(edgeKey(a, b));
|
|
68
|
+
}
|
|
69
|
+
const nk = unwrapKernel(mesh.gpu.halfEdgeKernel);
|
|
70
|
+
nk.isSharp.fill(0);
|
|
71
|
+
for (let e = 0; e < mesh.edgeCount; e++)
|
|
72
|
+
if (sharp.has(edgeKey(nk.edgeVertexA[e], nk.edgeVertexB[e])))
|
|
73
|
+
nk.isSharp[e] = 1;
|
|
74
|
+
}
|
|
75
|
+
function dist(a, b) { return Math.hypot(a[0] - b[0], a[1] - b[1], a[2] - b[2]); }
|
|
76
|
+
function edgeKey(a, b) { return a < b ? `${a}:${b}` : `${b}:${a}`; }
|
|
77
|
+
function area(pos, tri) { return Math.hypot(...normal(tri.map((v) => [pos[v * 3], pos[v * 3 + 1], pos[v * 3 + 2]]))); }
|
|
78
|
+
//# sourceMappingURL=merge-by-distance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merge-by-distance.js","sourceRoot":"","sources":["../../../src/edit/operators/merge-by-distance.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { EditableMesh as EditableMeshValue } from "../types.ts";
|
|
2
|
+
export interface RecomputeNormalsOptions {
|
|
3
|
+
readonly weighting?: "angle" | "area" | "uniform";
|
|
4
|
+
readonly creaseAngle?: number;
|
|
5
|
+
}
|
|
6
|
+
export declare function recomputeNormals(em: EditableMeshValue, opts?: RecomputeNormalsOptions): EditableMeshValue;
|
|
7
|
+
//# sourceMappingURL=recompute-normals.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recompute-normals.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/recompute-normals.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAGrE,MAAM,WAAW,uBAAuB;IAAG,QAAQ,CAAC,SAAS,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;IAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAA;CAAE;AAE7H,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,GAAE,uBAA4B,GAAG,iBAAiB,CAiB7G"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { EditableMesh } from "../editable-mesh.js";
|
|
2
|
+
import { normal, p, norm, add, sub, cross } from "../operator-utils.js";
|
|
3
|
+
import { unwrapKernel } from "../kernel-handle.js";
|
|
4
|
+
export function recomputeNormals(em, opts = {}) {
|
|
5
|
+
if (em.faceCount === 0)
|
|
6
|
+
return em;
|
|
7
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
8
|
+
const sharpOpts = opts.creaseAngle === undefined ? { sharpEdges: new Uint8Array(k.isSharp) } : { creaseAngle: opts.creaseAngle };
|
|
9
|
+
const mesh = EditableMesh.fromArrays({ positions: new Float32Array(k.positions), indices: new Uint32Array(k.faceVertices), useSmooth: new Uint8Array(k.useSmooth), ...sharpOpts });
|
|
10
|
+
const nk = unwrapKernel(mesh.gpu.halfEdgeKernel), flats = flatNormals(mesh), out = new Float32Array(nk.faceNormals.length), visited = new Uint8Array(mesh.faceCount);
|
|
11
|
+
for (let f = 0; f < mesh.faceCount; f++) {
|
|
12
|
+
if (visited[f])
|
|
13
|
+
continue;
|
|
14
|
+
const comp = nk.useSmooth[f] ? smoothComponent(mesh, f, visited) : (visited[f] = 1, [f]);
|
|
15
|
+
if (comp.length === 1)
|
|
16
|
+
out.set(flats.slice(f * 3, f * 3 + 3), f * 3);
|
|
17
|
+
else {
|
|
18
|
+
const n = componentNormal(mesh, comp, flats, opts.weighting ?? "angle");
|
|
19
|
+
for (const face of comp)
|
|
20
|
+
out.set(n, face * 3);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
nk.faceNormals.set(out);
|
|
24
|
+
return mesh;
|
|
25
|
+
}
|
|
26
|
+
function smoothComponent(em, seed, visited) {
|
|
27
|
+
const k = unwrapKernel(em.gpu.halfEdgeKernel), out = [], stack = [seed];
|
|
28
|
+
visited[seed] = 1;
|
|
29
|
+
while (stack.length) {
|
|
30
|
+
const f = stack.pop();
|
|
31
|
+
out.push(f);
|
|
32
|
+
for (const e of k.faceEdges.slice(f * 3, f * 3 + 3)) {
|
|
33
|
+
if (k.isSharp[e])
|
|
34
|
+
continue;
|
|
35
|
+
const n = k.edgeFaceA[e] === f ? k.edgeFaceB[e] : k.edgeFaceA[e];
|
|
36
|
+
if (n >= 0 && k.useSmooth[n] && !visited[n]) {
|
|
37
|
+
visited[n] = 1;
|
|
38
|
+
stack.push(n);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return out;
|
|
43
|
+
}
|
|
44
|
+
function flatNormals(em) {
|
|
45
|
+
const out = new Float32Array(em.faceCount * 3), k = unwrapKernel(em.gpu.halfEdgeKernel);
|
|
46
|
+
for (let f = 0; f < em.faceCount; f++)
|
|
47
|
+
out.set(normal(Array.from(k.faceVertices.slice(f * 3, f * 3 + 3), (v) => p(em, v))), f * 3);
|
|
48
|
+
return out;
|
|
49
|
+
}
|
|
50
|
+
function componentNormal(em, faces, flats, weighting) {
|
|
51
|
+
let sum = [0, 0, 0];
|
|
52
|
+
for (const f of faces) {
|
|
53
|
+
const n = [flats[f * 3], flats[f * 3 + 1], flats[f * 3 + 2]], w = weighting === "uniform" ? 1 : weighting === "area" ? faceArea(em, f) : faceAngleSum(em, f);
|
|
54
|
+
sum = add(sum, n, Math.max(w, 1e-12));
|
|
55
|
+
}
|
|
56
|
+
return norm(sum);
|
|
57
|
+
}
|
|
58
|
+
function faceArea(em, f) {
|
|
59
|
+
const vs = Array.from(unwrapKernel(em.gpu.halfEdgeKernel).faceVertices.slice(f * 3, f * 3 + 3), (v) => p(em, v)), n = cross(sub(vs[1], vs[0]), sub(vs[2], vs[0]));
|
|
60
|
+
return Math.hypot(n[0], n[1], n[2]) * 0.5;
|
|
61
|
+
}
|
|
62
|
+
function faceAngleSum(em, f) {
|
|
63
|
+
const vs = Array.from(unwrapKernel(em.gpu.halfEdgeKernel).faceVertices.slice(f * 3, f * 3 + 3), (v) => p(em, v));
|
|
64
|
+
return Math.max(cornerAngle(vs[1], vs[0], vs[2]), cornerAngle(vs[0], vs[1], vs[2]), cornerAngle(vs[0], vs[2], vs[1]));
|
|
65
|
+
}
|
|
66
|
+
function cornerAngle(a, o, b) { const u = norm(sub(a, o)), v = norm(sub(b, o)); return Math.acos(Math.max(-1, Math.min(1, u[0] * v[0] + u[1] * v[1] + u[2] * v[2]))); }
|
|
67
|
+
//# sourceMappingURL=recompute-normals.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"recompute-normals.js","sourceRoot":"","sources":["../../../src/edit/operators/recompute-normals.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { EditableMesh, ElementSelection } from "../types.ts";
|
|
2
|
+
export interface SubdivideEdgesOptions {
|
|
3
|
+
readonly cuts?: number;
|
|
4
|
+
}
|
|
5
|
+
export interface SubdivideEdgesResult {
|
|
6
|
+
readonly mesh: EditableMesh;
|
|
7
|
+
readonly newVertices: ElementSelection;
|
|
8
|
+
readonly newEdges: ElementSelection;
|
|
9
|
+
}
|
|
10
|
+
export declare function subdivideEdges(em: EditableMesh, edges: ElementSelection, opts?: SubdivideEdgesOptions): SubdivideEdgesResult;
|
|
11
|
+
//# sourceMappingURL=subdivide-edges.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subdivide-edges.d.ts","sourceRoot":"","sources":["../../../src/edit/operators/subdivide-edges.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAGlE,MAAM,WAAW,qBAAqB;IAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE;AACjE,MAAM,WAAW,oBAAoB;IAAG,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC;IAAC,QAAQ,CAAC,WAAW,EAAE,gBAAgB,CAAC;IAAC,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAA;CAAE;AAElJ,wBAAgB,cAAc,CAAC,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,IAAI,GAAE,qBAA0B,GAAG,oBAAoB,CAgBhI"}
|