@woosh/meep-engine 2.37.18 → 2.38.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/core/assert.js +1 -1
- package/core/binary/float2uint8.js +8 -0
- package/core/binary/uint82float.js +8 -0
- package/core/bvh2/bvh3/ExplicitBinaryBoundingVolumeHierarchy.js +6 -4
- package/core/collection/array/array_get_index_in_range.js +16 -0
- package/core/collection/array/typed/isTypedArray.js +20 -0
- package/core/collection/array/typedArrayToDataType.js +1 -0
- package/{engine/navigation/grid → core/collection/heap}/BinaryHeap.js +6 -1
- package/{engine/navigation/grid → core/collection/heap}/FastBinaryHeap.js +3 -2
- package/{engine/navigation/grid → core/collection/heap}/FastBinaryHeap.spec.js +3 -3
- package/core/collection/heap/Uin32Heap.spec.js +59 -0
- package/core/collection/heap/Uint32Heap.js +385 -0
- package/core/collection/list/List.d.ts +1 -1
- package/core/collection/table/RowFirstTable.js +34 -0
- package/core/collection/table/RowFirstTable.spec.js +59 -1
- package/core/color/Color.js +83 -1
- package/core/color/YCbCr_to_rgb_uint24.js +3 -4
- package/core/color/hsv2rgb.js +4 -3
- package/core/color/linear_to_sRGB.js +4 -5
- package/core/color/rgb2hex.js +1 -1
- package/core/color/rgb2uint24.js +6 -4
- package/core/color/rgb_to_YCbCr_uint24.js +11 -13
- package/core/events/signal/Signal.d.ts +11 -9
- package/core/events/signal/Signal.spec.js +16 -0
- package/core/geom/2d/quad-tree/qt_collect_by_circle.js +67 -0
- package/core/geom/3d/topology/computeTopoMeshVertexDuplicates.js +9 -6
- package/core/geom/3d/topology/expandConnectivityByLocality.js +5 -5
- package/core/geom/3d/topology/query/query_edge_is_boundary.js +7 -0
- package/core/geom/3d/topology/query/query_edge_is_manifold.js +13 -0
- package/core/geom/3d/topology/query/query_edge_is_manifold_or_boundary.js +11 -0
- package/core/geom/3d/topology/query/query_edge_is_wire.js +13 -0
- package/core/geom/3d/topology/query/query_edge_other_vertex.js +20 -0
- package/core/geom/3d/topology/query/query_edge_share_vert.js +9 -0
- package/core/geom/3d/topology/query/query_face_get_other_edges.js +39 -0
- package/core/geom/3d/topology/query/query_face_next_vertex.js +19 -0
- package/core/geom/3d/topology/query/query_face_prev_vertex.js +18 -0
- package/core/geom/3d/topology/query/query_vertex_in_edge.js +14 -0
- package/core/geom/3d/topology/query/query_vertex_pair_share_face.js +24 -0
- package/core/geom/3d/topology/query/query_vertices_in_edge.js +19 -0
- package/core/geom/3d/topology/simplify/collapseEdge.spec.js +3 -5
- package/core/geom/3d/topology/simplify/collapse_all_degenerate_edges.js +8 -10
- package/core/geom/3d/topology/simplify/compute_face_normal_change_dot_product.js +12 -2
- package/core/geom/3d/topology/simplify/decimate_edge_collapse_snap.js +277 -0
- package/core/geom/3d/topology/simplify/edge_collapse_quadratic.js +126 -0
- package/core/geom/3d/topology/simplify/prototypeMeshSimplification.js +502 -0
- package/core/geom/3d/topology/simplify/quadratic/Quadratic3.js +37 -5
- package/core/geom/3d/topology/simplify/quadratic/build_vertex_quadratics.js +86 -1
- package/core/geom/3d/topology/simplify/simplifyTopoMesh.js +4 -4
- package/core/geom/3d/topology/simplify/simplifyTopoMesh2.js +119 -0
- package/core/geom/3d/topology/simplify/tm_edge_collapse_is_degenerate_flip.js +81 -0
- package/core/geom/3d/topology/{TopoEdge.js → struct/TopoEdge.js} +47 -20
- package/core/geom/3d/topology/{TopoEdge.spec.js → struct/TopoEdge.spec.js} +0 -0
- package/core/geom/3d/topology/{TopoMesh.js → struct/TopoMesh.js} +20 -41
- package/core/geom/3d/topology/{TopoTriangle.js → struct/TopoTriangle.js} +15 -25
- package/core/geom/3d/topology/{TopoVertex.js → struct/TopoVertex.js} +21 -4
- package/core/geom/3d/topology/{TopoVertex.spec.js → struct/TopoVertex.spec.js} +0 -0
- package/core/geom/3d/topology/tm_edge_kill.js +24 -0
- package/core/geom/3d/topology/tm_edge_splice.js +42 -0
- package/core/geom/3d/topology/tm_face_area.js +18 -0
- package/core/geom/3d/topology/tm_face_kill.js +12 -0
- package/core/geom/3d/topology/tm_face_normal.js +14 -0
- package/core/geom/3d/topology/tm_kill_only_edge.js +35 -0
- package/core/geom/3d/topology/tm_kill_only_face.js +12 -0
- package/core/geom/3d/topology/tm_kill_only_vert.js +14 -0
- package/core/geom/3d/topology/tm_vert_kill.js +19 -0
- package/core/geom/3d/topology/tm_vert_splice.js +64 -0
- package/core/geom/3d/topology/tm_vertex_compute_normal.js +42 -0
- package/core/geom/3d/topology/topoMeshToBufferGeometry.js +18 -4
- package/core/geom/3d/topology/weld_duplicate_vertices.js +63 -0
- package/core/geom/Quaternion.d.ts +21 -1
- package/core/geom/Quaternion.js +279 -200
- package/core/geom/Quaternion.spec.js +71 -2
- package/core/geom/Vector2.js +3 -3
- package/core/geom/Vector3.d.ts +2 -0
- package/core/geom/Vector3.js +31 -7
- package/core/geom/Vector3.schema.json +16 -0
- package/core/geom/Vector4.js +16 -0
- package/core/geom/packing/MaxRectangles.js +1 -1
- package/core/graph/cluster_mesh_metis.js +16 -0
- package/core/graph/coarsen_graph.js +1 -1
- package/core/graph/graph_k_means_cluster.js +1 -1
- package/core/json/JsonUtils.js +2 -20
- package/core/math/bell_membership_function.js +19 -0
- package/core/math/exp2.js +8 -0
- package/core/math/interval/NumericInterval.js +17 -0
- package/core/math/physics/brdf/brdf_burley.js +25 -0
- package/core/math/physics/bsdf/bsdf_schlick.js +22 -0
- package/core/math/physics/irradiance/interpolate_irradiance_linear.js +18 -0
- package/{engine/sound/ecs/emitter/attenuate/attenuateSoundLogarithmic.js → core/math/physics/irradiance/interpolate_irradiance_lograrithmic.js} +2 -2
- package/{engine/sound/ecs/emitter/attenuate/attenuateSoundSmith.js → core/math/physics/irradiance/interpolate_irradiance_smith.js} +1 -1
- package/core/math/random/seededRandom.js +2 -31
- package/core/math/random/seededRandom_Mulberry32.js +31 -0
- package/core/math/random/seededRandom_sine.js +33 -0
- package/core/model/ObservedEnum.js +8 -0
- package/editor/Editor.js +97 -1
- package/editor/actions/concrete/ModifyPatchSampler2DAction.js +118 -0
- package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +30 -0
- package/editor/actions/concrete/PatchTerrainHeightAction.js +13 -105
- package/editor/ecs/component/FieldDescriptor.js +34 -0
- package/editor/ecs/component/FieldValueAdapter.js +20 -0
- package/editor/ecs/component/TypeEditor.js +33 -0
- package/editor/ecs/component/TypeSchema.d.ts +38 -0
- package/editor/ecs/component/createFieldEditor.js +90 -0
- package/editor/ecs/component/createObjectEditor.js +266 -60
- package/editor/ecs/component/editors/ColorEditor.js +39 -0
- package/editor/ecs/component/editors/HTMLElementEditor.js +17 -0
- package/editor/ecs/component/editors/ImagePathEditor.js +50 -0
- package/editor/ecs/component/editors/NumericIntervalEditor.js +86 -0
- package/editor/ecs/component/editors/ObservedBooleanEditor.js +13 -0
- package/editor/ecs/component/editors/ObservedEnumEditor.js +32 -0
- package/editor/ecs/component/editors/ObservedIntegerEditor.js +43 -0
- package/editor/ecs/component/editors/ObservedStringEditor.js +51 -0
- package/editor/ecs/component/editors/Sampler2DEditor.js +107 -0
- package/editor/ecs/component/editors/collection/ListEditor.js +83 -0
- package/editor/ecs/component/editors/common/BitFlagsEditor.js +80 -0
- package/editor/ecs/component/editors/common/EnumEditor.js +41 -0
- package/editor/ecs/component/editors/common/makeV3_editor.js +85 -0
- package/editor/ecs/component/editors/common/noEditor.js +9 -0
- package/editor/ecs/component/editors/ecs/GridObstacleEditor.js +17 -0
- package/editor/ecs/component/editors/ecs/MinimapMarkerEditor.js +16 -0
- package/editor/ecs/component/editors/ecs/ParameterLookupTableEditor.js +44 -0
- package/editor/ecs/component/editors/ecs/ParameterTrackEditor.js +17 -0
- package/editor/ecs/component/editors/ecs/ParticleEmitterEditor.js +58 -0
- package/editor/ecs/component/editors/ecs/ParticleEmitterLayerEditor.js +54 -0
- package/editor/ecs/component/editors/ecs/SimulationStepDefinitionEditor.js +21 -0
- package/editor/ecs/component/editors/ecs/Trail2DEditor.js +33 -0
- package/editor/ecs/component/editors/ecs/TransformEditor.js +23 -0
- package/editor/ecs/component/editors/ecs/terrain/SplatMappingEditor.js +21 -0
- package/editor/ecs/component/editors/ecs/terrain/TerrainEditor.js +89 -0
- package/editor/ecs/component/editors/ecs/terrain/TerrainLayerEditor.js +18 -0
- package/editor/ecs/component/editors/ecs/terrain/TerrainLayersEditor.js +22 -0
- package/editor/ecs/component/editors/ecs/terrain/TerrainOverlayEditor.js +20 -0
- package/editor/ecs/component/editors/geom/QuaternionEditor.js +56 -0
- package/editor/ecs/component/editors/geom/Vector1Editor.js +57 -0
- package/editor/ecs/component/editors/geom/Vector2Editor.js +11 -0
- package/editor/ecs/component/editors/geom/Vector3Editor.js +13 -0
- package/editor/ecs/component/editors/geom/Vector4Editor.js +12 -0
- package/editor/ecs/component/editors/primitive/ArrayEditor.js +46 -0
- package/editor/ecs/component/editors/primitive/BooleanEditor.js +27 -0
- package/editor/ecs/component/editors/primitive/FunctionEditor.js +29 -0
- package/editor/ecs/component/editors/primitive/NumberEditor.js +60 -0
- package/editor/ecs/component/editors/primitive/ObjectEditor.js +12 -0
- package/editor/ecs/component/editors/primitive/StringEditor.js +31 -0
- package/editor/ecs/component/editors/three/BufferGeometryEditor.js +28 -0
- package/editor/ecs/component/editors/three/MaterialEditor.js +27 -0
- package/editor/ecs/component/editors/three/MeshEditor.js +35 -0
- package/editor/ecs/component/editors/three/TextureEditor.js +32 -0
- package/editor/ecs/component/findNearestRegisteredType.js +59 -0
- package/editor/ecs/component/prototypeObjectEditor.js +379 -0
- package/editor/tools/SelectionTool.js +1 -1
- package/editor/tools/paint/TerrainHeightPaintTool.js +88 -68
- package/editor/tools/paint/TerrainPaintTool.js +2 -1
- package/editor/tools/paint/TerrainTexturePaintTool.js +8 -73
- package/editor/view/EditorView.js +1 -1
- package/editor/view/ecs/ComponentControlView.js +2 -30
- package/editor/view/ecs/EntityEditor.js +61 -139
- package/editor/view/ecs/components/GridObstacleController.js +4 -4
- package/editor/view/ecs/components/TerrainController.js +1 -1
- package/editor/view/ecs/components/common/NumberController.js +19 -7
- package/editor/view/node-graph/NodeGraphView.js +2 -2
- package/editor/view/node-graph/NodeView.js +7 -9
- package/engine/animation/keyed2/AnimationTrack.js +1 -1
- package/engine/asset/AssetManager.d.ts +1 -1
- package/engine/asset/AssetManager.js +390 -388
- package/engine/asset/loaders/gltf/extensions/MSFT_texture_dds.js +14 -2
- package/engine/ecs/components/TagEditor.js +15 -0
- package/engine/ecs/fow/FogOfWarEditor.js +13 -0
- package/engine/ecs/parent/ParentEntitySystem.js +57 -0
- package/engine/ecs/terrain/ecs/OffsetScaleTransform2D.d.ts +6 -0
- package/engine/ecs/terrain/ecs/Terrain.js +44 -43
- package/engine/ecs/terrain/ecs/TerrainSystem.js +2 -2
- package/engine/ecs/terrain/ecs/layers/TerrainLayer.js +1 -1
- package/engine/ecs/terrain/ecs/splat/SplatMapping.js +26 -28
- package/engine/ecs/terrain/overlay/TerrainOverlay.js +71 -66
- package/engine/ecs/terrain/tiles/TerrainTileManager.js +23 -0
- package/engine/ecs/terrain/util/loadVisibleTerrainTiles.js +1 -1
- package/engine/ecs/terrain/util/paintTerrainOverlayViaLookupTable.js +13 -7
- package/engine/ecs/terrain/util/tensionOptimizeUV.js +1 -1
- package/engine/ecs/transform/Transform.d.ts +2 -0
- package/engine/ecs/transform/Transform.editor.schema.json +16 -0
- package/engine/ecs/transform/Transform.js +3 -0
- package/engine/graphics/ecs/highlight/HighlightEditor.js +17 -0
- package/engine/graphics/ecs/light/Light.js +0 -47
- package/engine/graphics/ecs/light/LightSerializationAdapter.js +50 -0
- package/engine/graphics/ecs/mesh/MeshEditor.js +28 -0
- package/engine/graphics/ecs/mesh-v2/DrawMode.js +2 -1
- package/engine/graphics/ecs/mesh-v2/aggregate/prototypeSGMesh.js +3 -3
- package/engine/graphics/ecs/mesh-v2/build_three_object.js +3 -1
- package/engine/graphics/ecs/mesh-v2/sg_compute_hierarchy_bounding_box_by_parent_entity.js +31 -0
- package/engine/graphics/ecs/mesh-v2/sg_hierarchy_compute_bounding_box_via_parent_entity.d.ts +4 -0
- package/engine/graphics/ecs/sprite/Sprite.js +11 -0
- package/engine/graphics/ecs/sprite/SpriteSystemPE.js +133 -0
- package/engine/graphics/ecs/sprite/prototypeSpriteSystem.js +1570 -0
- package/engine/graphics/micron/build/PatchRepresentation.js +7 -3
- package/engine/graphics/micron/build/buildMicronGeometryFromBufferGeometry.js +18 -8
- package/engine/graphics/micron/build/clustering/build_clustering_2.js +1 -1
- package/engine/graphics/micron/build/clustering/build_leaf_patches.js +2 -2
- package/engine/graphics/micron/build/clustering/build_leaf_patches_metis.js +1 -1
- package/engine/graphics/micron/build/hierarchy/buildAbstractPatchHierarchy.js +21 -3
- package/engine/graphics/micron/build/hierarchy/merge_patches.js +96 -43
- package/engine/graphics/micron/build/hierarchy/qvdr_build_simplified_clusters.js +11 -5
- package/engine/graphics/micron/format/VirtualGeometry.js +46 -3
- package/engine/graphics/micron/format/micron_build_proxy_geometry.js +4 -2
- package/engine/graphics/micron/prototypeVirtualGeometry.js +47 -10
- package/engine/graphics/micron/render/instanced/shader/shader_rewrite_standard.js +17 -17
- package/engine/graphics/micron/render/refinement/get_geometry_patch_cut.js +15 -3
- package/engine/graphics/micron/simplifyGeometry.js +1 -1
- package/engine/graphics/particles/particular/engine/ParticularEngine.js +5 -0
- package/engine/graphics/particles/particular/engine/emitter/ParticleLayer.js +17 -9
- package/engine/graphics/particles/particular/engine/renderers/ParticleRenderer.js +12 -10
- package/engine/graphics/particles/particular/engine/renderers/billboard/ParticleBillboardMaterial.js +7 -2
- package/engine/graphics/particles/particular/engine/renderers/billboard/SoftBillboardParticlePool.js +27 -0
- package/engine/graphics/particles/particular/engine/renderers/billboard/SoftBillboardParticleRenderer.js +80 -0
- package/engine/graphics/particles/particular/engine/shader/ShaderManager.js +16 -4
- package/engine/graphics/shaders/TerrainShader.js +8 -8
- package/engine/graphics/texture/atlas/TextureAtlasDebugger.js +2 -1
- package/engine/graphics/texture/sampler/Sampler2D.js +206 -201
- package/engine/graphics/texture/sampler/Sampler2D.spec.js +34 -35
- package/engine/graphics/texture/sampler/bicubic.js +59 -0
- package/engine/graphics/texture/sampler/downsampleSample2D.spec.js +2 -2
- package/engine/graphics/texture/sampler/genericResampleSampler2D.js +0 -2
- package/engine/graphics/texture/sampler/prototypeSamplerFiltering.js +146 -0
- package/engine/graphics/texture/sampler/{downsampleSampler2D.js → sampler2D_scale_down_linear.js} +8 -4
- package/engine/graphics/texture/sampler/sampler2_d_scale_down_lanczos.js +140 -0
- package/engine/graphics/texture/sampler/scaleSampler2D.js +3 -3
- package/engine/graphics/texture/sampler/writeSampler2DDataToDataTexture.js +1 -1
- package/engine/graphics/util/ScaleObject3ToBox.js +14 -1
- package/engine/graphics/util/makeMeshPreviewScene.js +2 -1
- package/engine/grid/components/GridObstacle.js +0 -44
- package/engine/grid/components/GridObstacleSerializationAdapter.js +46 -0
- package/engine/input/devices/PointerDevice.d.ts +1 -1
- package/engine/input/devices/PointerDevice.js +17 -2
- package/engine/input/ecs/util/TerrainCameraTargetSampler.js +2 -2
- package/engine/navigation/ecs/components/Path.d.ts +2 -0
- package/engine/navigation/ecs/components/Path.js +6 -1
- package/engine/navigation/ecs/components/computeNonuniformCatmullRomSplineSample.js +117 -0
- package/engine/navigation/grid/AStar.js +1 -1
- package/engine/navigation/grid/GridField.js +3 -2
- package/engine/platform/GetURLHash.js +27 -0
- package/engine/platform/WebEnginePlatform.js +1 -22
- package/engine/sound/ecs/emitter/SoundEmitter.js +10 -6
- package/engine/ui/DraggableAspect.js +2 -2
- package/generation/GridGenerator.js +7 -6
- package/generation/example/SampleGenerator0.js +39 -35
- package/generation/example/filters/SampleGroundMoistureFilter.js +58 -17
- package/generation/example/generators/interactive/mir_generator_place_buff_objects.js +7 -6
- package/generation/example/generators/mir_generator_place_bases.js +7 -3
- package/generation/example/generators/mir_generator_place_road_decorators.js +3 -3
- package/generation/example/generators/mir_generator_place_starting_point.js +3 -2
- package/generation/example/themes/SampleTheme0.js +11 -7
- package/generation/filtering/numeric/CellFilterLiteralFloat.js +5 -0
- package/generation/filtering/numeric/complex/CellFilterDilate.js +36 -0
- package/generation/filtering/numeric/complex/CellFilterGaussianBlur.js +15 -5
- package/generation/filtering/numeric/complex/CellFilterSimplexNoise.js +53 -1
- package/generation/filtering/numeric/math/CellFilterMax2.js +3 -0
- package/generation/filtering/numeric/math/CellFilterMembershipGeneralizedBell.js +55 -0
- package/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.js +42 -0
- package/generation/filtering/numeric/sampling/CellFilterSampleLayerCubic.js +36 -0
- package/generation/filtering/numeric/sampling/CellFilterSampleLayerLinear.js +41 -0
- package/generation/grid/GridData.d.ts +5 -1
- package/generation/grid/GridData.js +35 -36
- package/generation/grid/MarkerMatchCounter.js +5 -3
- package/generation/grid/generation/discrete/GridTaskConnectRooms.js +1 -1
- package/generation/grid/generation/discrete/layer/GridTaskBuildSourceDistanceMap.js +1 -1
- package/generation/grid/generation/discrete/layer/GridTaskDistanceToMarkers.js +1 -1
- package/generation/grid/generation/road/GridTaskGenerateRoads.js +1 -1
- package/generation/markers/GridActionRuleSet.js +15 -32
- package/generation/markers/GridCellActionPlaceMarker.js +12 -8
- package/generation/markers/debug/visualizeMarkers.js +56 -36
- package/generation/markers/emitter/MarkerNodeEmitterFromAction.js +8 -8
- package/generation/markers/prototypeGridCellActionPlaceMarker.js +209 -0
- package/generation/markers/transform/MarkerNodeTransformerOffsetPosition.js +1 -5
- package/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +2 -2
- package/generation/placement/GridCellPlacementRule.js +31 -25
- package/generation/theme/ThemeEngine.js +1 -1
- package/package.json +1 -1
- package/samples/terrain/from_image.js +7 -3
- package/samples/terrain/main.js +1 -1
- package/view/View.js +23 -1
- package/view/common/LabelView.js +1 -1
- package/view/compose3x3transform.js +32 -8
- package/view/controller/dat/DatGuiUtils.js +1 -1
- package/view/elements/DropDownSelectionView.js +11 -3
- package/view/elements/image/ImageView.js +3 -1
- package/core/model/ObservedReal.js +0 -55
- package/editor/ecs/component/ObjectEditor.js +0 -0
- package/engine/graphics/particles/particular/engine/renderers/SoftBillboardParticleRenderer.js +0 -7
- package/engine/sound/ecs/emitter/attenuate/attenuateSoundLinear.js +0 -11
- package/generation/filtering/numeric/CellFilterReadGridLayer.js +0 -73
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { compute_triangle_normal } from "./struct/TopoTriangle.js";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
* @param {number[]} result
|
|
6
|
+
* @param {TopoTriangle} face
|
|
7
|
+
*/
|
|
8
|
+
export function tm_face_normal(result, face) {
|
|
9
|
+
const v0 = face.vertices[0];
|
|
10
|
+
const v1 = face.vertices[1];
|
|
11
|
+
const v2 = face.vertices[2];
|
|
12
|
+
|
|
13
|
+
compute_triangle_normal(result, v0, v1, v2);
|
|
14
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { assert } from "../../../assert.js";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
* @param {TopoMesh} mesh
|
|
6
|
+
* @param {TopoEdge} edge
|
|
7
|
+
*/
|
|
8
|
+
export function tm_kill_only_edge(mesh, edge) {
|
|
9
|
+
assert.equal(edge.isTopoEdge, true, "e.isTopoEdge !== true");
|
|
10
|
+
|
|
11
|
+
// validate that the edge does not have any live back links
|
|
12
|
+
// const vertices = this.vertices;
|
|
13
|
+
// const vertex_count = vertices.length;
|
|
14
|
+
// for (let i = 0; i < vertex_count; i++) {
|
|
15
|
+
// const v = vertices[i];
|
|
16
|
+
//
|
|
17
|
+
// if (v.containsEdge(e)) {
|
|
18
|
+
// // live link to edge
|
|
19
|
+
// debugger;
|
|
20
|
+
// }
|
|
21
|
+
// }
|
|
22
|
+
//
|
|
23
|
+
// const faces = this.faces;
|
|
24
|
+
// const face_count = faces.length;
|
|
25
|
+
// for (let i = 0; i < face_count; i++) {
|
|
26
|
+
// const face = faces[i];
|
|
27
|
+
//
|
|
28
|
+
// if (face.containsEdge(e)) {
|
|
29
|
+
// // live link to face
|
|
30
|
+
// debugger;
|
|
31
|
+
// }
|
|
32
|
+
// }
|
|
33
|
+
|
|
34
|
+
mesh.__edges.delete(edge);
|
|
35
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { assert } from "../../../assert.js";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
*
|
|
5
|
+
* @param {TopoMesh} mesh
|
|
6
|
+
* @param {TopoTriangle} face
|
|
7
|
+
*/
|
|
8
|
+
export function tm_kill_only_face(mesh, face) {
|
|
9
|
+
assert.equal(face.isTopoFace, true, "f.isTopoFace !== true");
|
|
10
|
+
|
|
11
|
+
mesh.__faces.delete(face);
|
|
12
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { assert } from "../../../assert.js";
|
|
2
|
+
import { array_remove_first } from "../../../collection/array/array_remove_first.js";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
*
|
|
6
|
+
* @param {TopoMesh} mesh
|
|
7
|
+
* @param {TopoVertex} vertex
|
|
8
|
+
*/
|
|
9
|
+
export function tm_kill_only_vert(mesh, vertex) {
|
|
10
|
+
assert.equal(vertex.isTopoVertex, true, "v.isTopoVertex !== true");
|
|
11
|
+
assert.arrayHas(mesh.vertices, vertex, 'element not found');
|
|
12
|
+
|
|
13
|
+
array_remove_first(mesh.vertices, vertex);
|
|
14
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { tm_edge_kill } from "./tm_edge_kill.js";
|
|
2
|
+
import { tm_kill_only_vert } from "./tm_kill_only_vert.js";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Remove vertex and all edges that use it
|
|
6
|
+
* @param {TopoMesh} mesh
|
|
7
|
+
* @param {TopoVertex} vertex
|
|
8
|
+
*/
|
|
9
|
+
export function tm_vert_kill(mesh, vertex) {
|
|
10
|
+
const edges = vertex.edges;
|
|
11
|
+
|
|
12
|
+
const edge_count = edges.length;
|
|
13
|
+
|
|
14
|
+
for (let i = edge_count - 1; i >= 0; i--) {
|
|
15
|
+
tm_edge_kill(mesh, edges[i]);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
tm_kill_only_vert(mesh, vertex);
|
|
19
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { assert } from "../../../assert.js";
|
|
2
|
+
import { tm_vert_kill } from "./tm_vert_kill.js";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Splice vertex
|
|
6
|
+
* Merges two vertices into one, source into destination, removing source.
|
|
7
|
+
* NOTE: source vertex is deleted in the process
|
|
8
|
+
*
|
|
9
|
+
* @param {TopoMesh} mesh
|
|
10
|
+
* @param {TopoVertex} destination
|
|
11
|
+
* @param {TopoVertex} source
|
|
12
|
+
* @returns {boolean}
|
|
13
|
+
*/
|
|
14
|
+
export function tm_vert_splice(mesh, destination, source) {
|
|
15
|
+
if (destination === source) {
|
|
16
|
+
// already spliced
|
|
17
|
+
return false;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
assert.defined(source, 'victim');
|
|
21
|
+
assert.notNull(source, 'victim');
|
|
22
|
+
assert.equal(source.isTopoVertex, true, "victim.isTopoVertex !== true");
|
|
23
|
+
assert.notEqual(destination, source, "cannot replace self");
|
|
24
|
+
|
|
25
|
+
const faces = source.faces;
|
|
26
|
+
const face_count = faces.length;
|
|
27
|
+
|
|
28
|
+
let i = 0;
|
|
29
|
+
|
|
30
|
+
for (; i < face_count; i++) {
|
|
31
|
+
// take over the victim's faces
|
|
32
|
+
const face = faces.pop();
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
// face.computeNormal(); // DEBUG
|
|
36
|
+
face.replaceVertex(source, destination);
|
|
37
|
+
|
|
38
|
+
destination.addUniqueFace(face);
|
|
39
|
+
|
|
40
|
+
// face.computeNormal(); // DEBUG
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const edges = source.edges;
|
|
44
|
+
const edge_count = edges.length;
|
|
45
|
+
|
|
46
|
+
// const destination_edges = destination.edges;
|
|
47
|
+
|
|
48
|
+
for (i = 0; i < edge_count; i++) {
|
|
49
|
+
// take over the victim's edges
|
|
50
|
+
const edge = edges.pop();
|
|
51
|
+
|
|
52
|
+
edge.replaceVertex(source, destination);
|
|
53
|
+
//
|
|
54
|
+
// for (let j = 0; j < destination_edges.length; j++) {
|
|
55
|
+
// destination_edges[j]
|
|
56
|
+
// }
|
|
57
|
+
|
|
58
|
+
destination.addUniqueEdge(edge);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
tm_vert_kill(mesh, source);
|
|
62
|
+
|
|
63
|
+
return true;
|
|
64
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { compute_triangle_normal } from "./struct/TopoTriangle.js";
|
|
2
|
+
//
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
const scratch_v3_0 = new Float32Array(3);
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
*
|
|
9
|
+
* @param {number[]} result
|
|
10
|
+
* @param {number} result_offset
|
|
11
|
+
* @param {TopoVertex} vertex
|
|
12
|
+
*/
|
|
13
|
+
export function tm_vertex_compute_normal(result, result_offset, vertex) {
|
|
14
|
+
const faces = vertex.faces;
|
|
15
|
+
const face_length = faces.length;
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
let _x = 0;
|
|
19
|
+
let _y = 0;
|
|
20
|
+
let _z = 0;
|
|
21
|
+
|
|
22
|
+
for (let i = 0; i < face_length; i++) {
|
|
23
|
+
const face = faces[i];
|
|
24
|
+
|
|
25
|
+
compute_triangle_normal(scratch_v3_0, face.vertices[0], face.vertices[1], face.vertices[2]);
|
|
26
|
+
|
|
27
|
+
_x += scratch_v3_0[0];
|
|
28
|
+
_y += scratch_v3_0[1];
|
|
29
|
+
_z += scratch_v3_0[2];
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// re-normalize
|
|
33
|
+
const len_inv = Math.hypot(_x,_y,_z);
|
|
34
|
+
|
|
35
|
+
_x *= len_inv;
|
|
36
|
+
_y *= len_inv;
|
|
37
|
+
_z *= len_inv;
|
|
38
|
+
|
|
39
|
+
result[result_offset] = _x;
|
|
40
|
+
result[result_offset+1] = _y;
|
|
41
|
+
result[result_offset+2] = _z;
|
|
42
|
+
}
|
|
@@ -6,6 +6,8 @@ import { BufferAttribute, BufferGeometry } from "three";
|
|
|
6
6
|
* @returns {THREE.BufferGeometry}
|
|
7
7
|
*/
|
|
8
8
|
export function topoMeshToBufferGeometry(mesh) {
|
|
9
|
+
const vertices_lookup = new Map();
|
|
10
|
+
|
|
9
11
|
// build vertices array
|
|
10
12
|
const vertex_count = mesh.vertices.length;
|
|
11
13
|
const position_array = new Float32Array(vertex_count * 3);
|
|
@@ -17,11 +19,23 @@ export function topoMeshToBufferGeometry(mesh) {
|
|
|
17
19
|
position_array[i_3] = vertex.x;
|
|
18
20
|
position_array[i_3 + 1] = vertex.y;
|
|
19
21
|
position_array[i_3 + 2] = vertex.z;
|
|
22
|
+
|
|
23
|
+
vertices_lookup.set(vertex, i);
|
|
20
24
|
}
|
|
21
25
|
// build face array
|
|
22
26
|
const mesh_faces = mesh.getFaces();
|
|
23
27
|
const face_count = mesh_faces.size;
|
|
24
|
-
|
|
28
|
+
|
|
29
|
+
let IndexArrayType;
|
|
30
|
+
if (vertex_count <= 255) {
|
|
31
|
+
IndexArrayType = Uint8Array;
|
|
32
|
+
} else if (vertex_count <= 65535) {
|
|
33
|
+
IndexArrayType = Uint16Array;
|
|
34
|
+
} else {
|
|
35
|
+
IndexArrayType = Uint32Array;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const face_array = new IndexArrayType(face_count * 3);
|
|
25
39
|
|
|
26
40
|
let i_3 = 0;
|
|
27
41
|
for (let face of mesh_faces) {
|
|
@@ -30,9 +44,9 @@ export function topoMeshToBufferGeometry(mesh) {
|
|
|
30
44
|
const vB = face.vertices[1];
|
|
31
45
|
const vC = face.vertices[2];
|
|
32
46
|
|
|
33
|
-
const vAi =
|
|
34
|
-
const vBi =
|
|
35
|
-
const vCi =
|
|
47
|
+
const vAi = vertices_lookup.get(vA);
|
|
48
|
+
const vBi = vertices_lookup.get(vB);
|
|
49
|
+
const vCi = vertices_lookup.get(vC);
|
|
36
50
|
|
|
37
51
|
face_array[i_3] = vAi;
|
|
38
52
|
face_array[i_3 + 1] = vBi;
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { computeTopoMeshVertexDuplicates } from "./computeTopoMeshVertexDuplicates.js";
|
|
2
|
+
import { EPSILON } from "../../../math/MathUtils.js";
|
|
3
|
+
import { tm_vert_splice } from "./tm_vert_splice.js";
|
|
4
|
+
import { debugValidateMesh } from "./debugValidateMesh.js";
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
*
|
|
8
|
+
* @param {TopoMesh} mesh
|
|
9
|
+
* @param {AABB3} bounds
|
|
10
|
+
* @param {number} tolerance
|
|
11
|
+
* @returns {number} removed vertices
|
|
12
|
+
*/
|
|
13
|
+
export function weld_duplicate_vertices(mesh, bounds, tolerance = EPSILON) {
|
|
14
|
+
|
|
15
|
+
debugValidateMesh(mesh);
|
|
16
|
+
|
|
17
|
+
const duplicates = computeTopoMeshVertexDuplicates(mesh, bounds, tolerance);
|
|
18
|
+
|
|
19
|
+
const removed_vertices = new Set();
|
|
20
|
+
|
|
21
|
+
let removal_count = 0;
|
|
22
|
+
|
|
23
|
+
for (let entry of duplicates) {
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
*
|
|
27
|
+
* @type {TopoVertex}
|
|
28
|
+
*/
|
|
29
|
+
const source = entry[0];
|
|
30
|
+
|
|
31
|
+
if (removed_vertices.has(source.index)) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
*
|
|
37
|
+
* @type {TopoVertex[]}
|
|
38
|
+
*/
|
|
39
|
+
const vertex_duplicates = entry[1];
|
|
40
|
+
|
|
41
|
+
const duplicate_count = vertex_duplicates.length;
|
|
42
|
+
for (let i = 0; i < duplicate_count; i++) {
|
|
43
|
+
const v = vertex_duplicates[i];
|
|
44
|
+
|
|
45
|
+
const duplicate_vertex_index = v.index;
|
|
46
|
+
|
|
47
|
+
if (removed_vertices.has(duplicate_vertex_index)) {
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
removed_vertices.add(duplicate_vertex_index);
|
|
52
|
+
|
|
53
|
+
tm_vert_splice(mesh, source, v);
|
|
54
|
+
|
|
55
|
+
removal_count++;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
debugValidateMesh(mesh);
|
|
60
|
+
|
|
61
|
+
return removal_count;
|
|
62
|
+
|
|
63
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import Signal from "../events/signal/Signal";
|
|
2
2
|
import {Matrix4, Quaternion as ThreeQuaternion} from "three";
|
|
3
|
+
import Vector3 from "./Vector3";
|
|
3
4
|
|
|
4
5
|
export default class Quaternion {
|
|
5
6
|
public x: number
|
|
@@ -7,7 +8,7 @@ export default class Quaternion {
|
|
|
7
8
|
public z: number
|
|
8
9
|
public w: number
|
|
9
10
|
|
|
10
|
-
|
|
11
|
+
readonly onChanged: Signal<number, number, number, number, number, number, number, number>;
|
|
11
12
|
|
|
12
13
|
set(x: number, y: number, z: number, w: number): void
|
|
13
14
|
|
|
@@ -15,6 +16,10 @@ export default class Quaternion {
|
|
|
15
16
|
copy(other: ThreeQuaternion): void
|
|
16
17
|
copy(other: { x: number, y: number, z: number, w: number }): void
|
|
17
18
|
|
|
19
|
+
equals(other: { x: number, y: number, z: number, w: number }): boolean
|
|
20
|
+
|
|
21
|
+
normalize(): void
|
|
22
|
+
|
|
18
23
|
__setThreeEuler(threeEuler: any): void
|
|
19
24
|
|
|
20
25
|
__setFromEuler(x: number, y: number, z: number, order?: string): void
|
|
@@ -24,4 +29,19 @@ export default class Quaternion {
|
|
|
24
29
|
setFromRotationMatrix(m: Matrix4): void
|
|
25
30
|
|
|
26
31
|
decodeFromUint32(uint: number): void
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
toEulerAnglesXYZ(v3: { set(x: number, y: number, z: number): any }): void
|
|
35
|
+
|
|
36
|
+
fromEulerAnglesXYZ(x: number, y: number, z: number): void
|
|
37
|
+
|
|
38
|
+
fromAxisAngle(axis: Vector3 | { x: number, y: number, z: number }, angle: number): void
|
|
39
|
+
|
|
40
|
+
computeTwistAngle(axis: Vector3): number
|
|
41
|
+
|
|
42
|
+
multiplyQuaternions(a: Quaternion, b: Quaternion): void
|
|
43
|
+
|
|
44
|
+
toJSON(): any
|
|
45
|
+
|
|
46
|
+
fromJSON(j: any): void
|
|
27
47
|
}
|