@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.
Files changed (289) hide show
  1. package/core/assert.js +1 -1
  2. package/core/binary/float2uint8.js +8 -0
  3. package/core/binary/uint82float.js +8 -0
  4. package/core/bvh2/bvh3/ExplicitBinaryBoundingVolumeHierarchy.js +6 -4
  5. package/core/collection/array/array_get_index_in_range.js +16 -0
  6. package/core/collection/array/typed/isTypedArray.js +20 -0
  7. package/core/collection/array/typedArrayToDataType.js +1 -0
  8. package/{engine/navigation/grid → core/collection/heap}/BinaryHeap.js +6 -1
  9. package/{engine/navigation/grid → core/collection/heap}/FastBinaryHeap.js +3 -2
  10. package/{engine/navigation/grid → core/collection/heap}/FastBinaryHeap.spec.js +3 -3
  11. package/core/collection/heap/Uin32Heap.spec.js +59 -0
  12. package/core/collection/heap/Uint32Heap.js +385 -0
  13. package/core/collection/list/List.d.ts +1 -1
  14. package/core/collection/table/RowFirstTable.js +34 -0
  15. package/core/collection/table/RowFirstTable.spec.js +59 -1
  16. package/core/color/Color.js +83 -1
  17. package/core/color/YCbCr_to_rgb_uint24.js +3 -4
  18. package/core/color/hsv2rgb.js +4 -3
  19. package/core/color/linear_to_sRGB.js +4 -5
  20. package/core/color/rgb2hex.js +1 -1
  21. package/core/color/rgb2uint24.js +6 -4
  22. package/core/color/rgb_to_YCbCr_uint24.js +11 -13
  23. package/core/events/signal/Signal.d.ts +11 -9
  24. package/core/events/signal/Signal.spec.js +16 -0
  25. package/core/geom/2d/quad-tree/qt_collect_by_circle.js +67 -0
  26. package/core/geom/3d/topology/computeTopoMeshVertexDuplicates.js +9 -6
  27. package/core/geom/3d/topology/expandConnectivityByLocality.js +5 -5
  28. package/core/geom/3d/topology/query/query_edge_is_boundary.js +7 -0
  29. package/core/geom/3d/topology/query/query_edge_is_manifold.js +13 -0
  30. package/core/geom/3d/topology/query/query_edge_is_manifold_or_boundary.js +11 -0
  31. package/core/geom/3d/topology/query/query_edge_is_wire.js +13 -0
  32. package/core/geom/3d/topology/query/query_edge_other_vertex.js +20 -0
  33. package/core/geom/3d/topology/query/query_edge_share_vert.js +9 -0
  34. package/core/geom/3d/topology/query/query_face_get_other_edges.js +39 -0
  35. package/core/geom/3d/topology/query/query_face_next_vertex.js +19 -0
  36. package/core/geom/3d/topology/query/query_face_prev_vertex.js +18 -0
  37. package/core/geom/3d/topology/query/query_vertex_in_edge.js +14 -0
  38. package/core/geom/3d/topology/query/query_vertex_pair_share_face.js +24 -0
  39. package/core/geom/3d/topology/query/query_vertices_in_edge.js +19 -0
  40. package/core/geom/3d/topology/simplify/collapseEdge.spec.js +3 -5
  41. package/core/geom/3d/topology/simplify/collapse_all_degenerate_edges.js +8 -10
  42. package/core/geom/3d/topology/simplify/compute_face_normal_change_dot_product.js +12 -2
  43. package/core/geom/3d/topology/simplify/decimate_edge_collapse_snap.js +277 -0
  44. package/core/geom/3d/topology/simplify/edge_collapse_quadratic.js +126 -0
  45. package/core/geom/3d/topology/simplify/prototypeMeshSimplification.js +502 -0
  46. package/core/geom/3d/topology/simplify/quadratic/Quadratic3.js +37 -5
  47. package/core/geom/3d/topology/simplify/quadratic/build_vertex_quadratics.js +86 -1
  48. package/core/geom/3d/topology/simplify/simplifyTopoMesh.js +4 -4
  49. package/core/geom/3d/topology/simplify/simplifyTopoMesh2.js +119 -0
  50. package/core/geom/3d/topology/simplify/tm_edge_collapse_is_degenerate_flip.js +81 -0
  51. package/core/geom/3d/topology/{TopoEdge.js → struct/TopoEdge.js} +47 -20
  52. package/core/geom/3d/topology/{TopoEdge.spec.js → struct/TopoEdge.spec.js} +0 -0
  53. package/core/geom/3d/topology/{TopoMesh.js → struct/TopoMesh.js} +20 -41
  54. package/core/geom/3d/topology/{TopoTriangle.js → struct/TopoTriangle.js} +15 -25
  55. package/core/geom/3d/topology/{TopoVertex.js → struct/TopoVertex.js} +21 -4
  56. package/core/geom/3d/topology/{TopoVertex.spec.js → struct/TopoVertex.spec.js} +0 -0
  57. package/core/geom/3d/topology/tm_edge_kill.js +24 -0
  58. package/core/geom/3d/topology/tm_edge_splice.js +42 -0
  59. package/core/geom/3d/topology/tm_face_area.js +18 -0
  60. package/core/geom/3d/topology/tm_face_kill.js +12 -0
  61. package/core/geom/3d/topology/tm_face_normal.js +14 -0
  62. package/core/geom/3d/topology/tm_kill_only_edge.js +35 -0
  63. package/core/geom/3d/topology/tm_kill_only_face.js +12 -0
  64. package/core/geom/3d/topology/tm_kill_only_vert.js +14 -0
  65. package/core/geom/3d/topology/tm_vert_kill.js +19 -0
  66. package/core/geom/3d/topology/tm_vert_splice.js +64 -0
  67. package/core/geom/3d/topology/tm_vertex_compute_normal.js +42 -0
  68. package/core/geom/3d/topology/topoMeshToBufferGeometry.js +18 -4
  69. package/core/geom/3d/topology/weld_duplicate_vertices.js +63 -0
  70. package/core/geom/Quaternion.d.ts +21 -1
  71. package/core/geom/Quaternion.js +279 -200
  72. package/core/geom/Quaternion.spec.js +71 -2
  73. package/core/geom/Vector2.js +3 -3
  74. package/core/geom/Vector3.d.ts +2 -0
  75. package/core/geom/Vector3.js +31 -7
  76. package/core/geom/Vector3.schema.json +16 -0
  77. package/core/geom/Vector4.js +16 -0
  78. package/core/geom/packing/MaxRectangles.js +1 -1
  79. package/core/graph/cluster_mesh_metis.js +16 -0
  80. package/core/graph/coarsen_graph.js +1 -1
  81. package/core/graph/graph_k_means_cluster.js +1 -1
  82. package/core/json/JsonUtils.js +2 -20
  83. package/core/math/bell_membership_function.js +19 -0
  84. package/core/math/exp2.js +8 -0
  85. package/core/math/interval/NumericInterval.js +17 -0
  86. package/core/math/physics/brdf/brdf_burley.js +25 -0
  87. package/core/math/physics/bsdf/bsdf_schlick.js +22 -0
  88. package/core/math/physics/irradiance/interpolate_irradiance_linear.js +18 -0
  89. package/{engine/sound/ecs/emitter/attenuate/attenuateSoundLogarithmic.js → core/math/physics/irradiance/interpolate_irradiance_lograrithmic.js} +2 -2
  90. package/{engine/sound/ecs/emitter/attenuate/attenuateSoundSmith.js → core/math/physics/irradiance/interpolate_irradiance_smith.js} +1 -1
  91. package/core/math/random/seededRandom.js +2 -31
  92. package/core/math/random/seededRandom_Mulberry32.js +31 -0
  93. package/core/math/random/seededRandom_sine.js +33 -0
  94. package/core/model/ObservedEnum.js +8 -0
  95. package/editor/Editor.js +97 -1
  96. package/editor/actions/concrete/ModifyPatchSampler2DAction.js +118 -0
  97. package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +30 -0
  98. package/editor/actions/concrete/PatchTerrainHeightAction.js +13 -105
  99. package/editor/ecs/component/FieldDescriptor.js +34 -0
  100. package/editor/ecs/component/FieldValueAdapter.js +20 -0
  101. package/editor/ecs/component/TypeEditor.js +33 -0
  102. package/editor/ecs/component/TypeSchema.d.ts +38 -0
  103. package/editor/ecs/component/createFieldEditor.js +90 -0
  104. package/editor/ecs/component/createObjectEditor.js +266 -60
  105. package/editor/ecs/component/editors/ColorEditor.js +39 -0
  106. package/editor/ecs/component/editors/HTMLElementEditor.js +17 -0
  107. package/editor/ecs/component/editors/ImagePathEditor.js +50 -0
  108. package/editor/ecs/component/editors/NumericIntervalEditor.js +86 -0
  109. package/editor/ecs/component/editors/ObservedBooleanEditor.js +13 -0
  110. package/editor/ecs/component/editors/ObservedEnumEditor.js +32 -0
  111. package/editor/ecs/component/editors/ObservedIntegerEditor.js +43 -0
  112. package/editor/ecs/component/editors/ObservedStringEditor.js +51 -0
  113. package/editor/ecs/component/editors/Sampler2DEditor.js +107 -0
  114. package/editor/ecs/component/editors/collection/ListEditor.js +83 -0
  115. package/editor/ecs/component/editors/common/BitFlagsEditor.js +80 -0
  116. package/editor/ecs/component/editors/common/EnumEditor.js +41 -0
  117. package/editor/ecs/component/editors/common/makeV3_editor.js +85 -0
  118. package/editor/ecs/component/editors/common/noEditor.js +9 -0
  119. package/editor/ecs/component/editors/ecs/GridObstacleEditor.js +17 -0
  120. package/editor/ecs/component/editors/ecs/MinimapMarkerEditor.js +16 -0
  121. package/editor/ecs/component/editors/ecs/ParameterLookupTableEditor.js +44 -0
  122. package/editor/ecs/component/editors/ecs/ParameterTrackEditor.js +17 -0
  123. package/editor/ecs/component/editors/ecs/ParticleEmitterEditor.js +58 -0
  124. package/editor/ecs/component/editors/ecs/ParticleEmitterLayerEditor.js +54 -0
  125. package/editor/ecs/component/editors/ecs/SimulationStepDefinitionEditor.js +21 -0
  126. package/editor/ecs/component/editors/ecs/Trail2DEditor.js +33 -0
  127. package/editor/ecs/component/editors/ecs/TransformEditor.js +23 -0
  128. package/editor/ecs/component/editors/ecs/terrain/SplatMappingEditor.js +21 -0
  129. package/editor/ecs/component/editors/ecs/terrain/TerrainEditor.js +89 -0
  130. package/editor/ecs/component/editors/ecs/terrain/TerrainLayerEditor.js +18 -0
  131. package/editor/ecs/component/editors/ecs/terrain/TerrainLayersEditor.js +22 -0
  132. package/editor/ecs/component/editors/ecs/terrain/TerrainOverlayEditor.js +20 -0
  133. package/editor/ecs/component/editors/geom/QuaternionEditor.js +56 -0
  134. package/editor/ecs/component/editors/geom/Vector1Editor.js +57 -0
  135. package/editor/ecs/component/editors/geom/Vector2Editor.js +11 -0
  136. package/editor/ecs/component/editors/geom/Vector3Editor.js +13 -0
  137. package/editor/ecs/component/editors/geom/Vector4Editor.js +12 -0
  138. package/editor/ecs/component/editors/primitive/ArrayEditor.js +46 -0
  139. package/editor/ecs/component/editors/primitive/BooleanEditor.js +27 -0
  140. package/editor/ecs/component/editors/primitive/FunctionEditor.js +29 -0
  141. package/editor/ecs/component/editors/primitive/NumberEditor.js +60 -0
  142. package/editor/ecs/component/editors/primitive/ObjectEditor.js +12 -0
  143. package/editor/ecs/component/editors/primitive/StringEditor.js +31 -0
  144. package/editor/ecs/component/editors/three/BufferGeometryEditor.js +28 -0
  145. package/editor/ecs/component/editors/three/MaterialEditor.js +27 -0
  146. package/editor/ecs/component/editors/three/MeshEditor.js +35 -0
  147. package/editor/ecs/component/editors/three/TextureEditor.js +32 -0
  148. package/editor/ecs/component/findNearestRegisteredType.js +59 -0
  149. package/editor/ecs/component/prototypeObjectEditor.js +379 -0
  150. package/editor/tools/SelectionTool.js +1 -1
  151. package/editor/tools/paint/TerrainHeightPaintTool.js +88 -68
  152. package/editor/tools/paint/TerrainPaintTool.js +2 -1
  153. package/editor/tools/paint/TerrainTexturePaintTool.js +8 -73
  154. package/editor/view/EditorView.js +1 -1
  155. package/editor/view/ecs/ComponentControlView.js +2 -30
  156. package/editor/view/ecs/EntityEditor.js +61 -139
  157. package/editor/view/ecs/components/GridObstacleController.js +4 -4
  158. package/editor/view/ecs/components/TerrainController.js +1 -1
  159. package/editor/view/ecs/components/common/NumberController.js +19 -7
  160. package/editor/view/node-graph/NodeGraphView.js +2 -2
  161. package/editor/view/node-graph/NodeView.js +7 -9
  162. package/engine/animation/keyed2/AnimationTrack.js +1 -1
  163. package/engine/asset/AssetManager.d.ts +1 -1
  164. package/engine/asset/AssetManager.js +390 -388
  165. package/engine/asset/loaders/gltf/extensions/MSFT_texture_dds.js +14 -2
  166. package/engine/ecs/components/TagEditor.js +15 -0
  167. package/engine/ecs/fow/FogOfWarEditor.js +13 -0
  168. package/engine/ecs/parent/ParentEntitySystem.js +57 -0
  169. package/engine/ecs/terrain/ecs/OffsetScaleTransform2D.d.ts +6 -0
  170. package/engine/ecs/terrain/ecs/Terrain.js +44 -43
  171. package/engine/ecs/terrain/ecs/TerrainSystem.js +2 -2
  172. package/engine/ecs/terrain/ecs/layers/TerrainLayer.js +1 -1
  173. package/engine/ecs/terrain/ecs/splat/SplatMapping.js +26 -28
  174. package/engine/ecs/terrain/overlay/TerrainOverlay.js +71 -66
  175. package/engine/ecs/terrain/tiles/TerrainTileManager.js +23 -0
  176. package/engine/ecs/terrain/util/loadVisibleTerrainTiles.js +1 -1
  177. package/engine/ecs/terrain/util/paintTerrainOverlayViaLookupTable.js +13 -7
  178. package/engine/ecs/terrain/util/tensionOptimizeUV.js +1 -1
  179. package/engine/ecs/transform/Transform.d.ts +2 -0
  180. package/engine/ecs/transform/Transform.editor.schema.json +16 -0
  181. package/engine/ecs/transform/Transform.js +3 -0
  182. package/engine/graphics/ecs/highlight/HighlightEditor.js +17 -0
  183. package/engine/graphics/ecs/light/Light.js +0 -47
  184. package/engine/graphics/ecs/light/LightSerializationAdapter.js +50 -0
  185. package/engine/graphics/ecs/mesh/MeshEditor.js +28 -0
  186. package/engine/graphics/ecs/mesh-v2/DrawMode.js +2 -1
  187. package/engine/graphics/ecs/mesh-v2/aggregate/prototypeSGMesh.js +3 -3
  188. package/engine/graphics/ecs/mesh-v2/build_three_object.js +3 -1
  189. package/engine/graphics/ecs/mesh-v2/sg_compute_hierarchy_bounding_box_by_parent_entity.js +31 -0
  190. package/engine/graphics/ecs/mesh-v2/sg_hierarchy_compute_bounding_box_via_parent_entity.d.ts +4 -0
  191. package/engine/graphics/ecs/sprite/Sprite.js +11 -0
  192. package/engine/graphics/ecs/sprite/SpriteSystemPE.js +133 -0
  193. package/engine/graphics/ecs/sprite/prototypeSpriteSystem.js +1570 -0
  194. package/engine/graphics/micron/build/PatchRepresentation.js +7 -3
  195. package/engine/graphics/micron/build/buildMicronGeometryFromBufferGeometry.js +18 -8
  196. package/engine/graphics/micron/build/clustering/build_clustering_2.js +1 -1
  197. package/engine/graphics/micron/build/clustering/build_leaf_patches.js +2 -2
  198. package/engine/graphics/micron/build/clustering/build_leaf_patches_metis.js +1 -1
  199. package/engine/graphics/micron/build/hierarchy/buildAbstractPatchHierarchy.js +21 -3
  200. package/engine/graphics/micron/build/hierarchy/merge_patches.js +96 -43
  201. package/engine/graphics/micron/build/hierarchy/qvdr_build_simplified_clusters.js +11 -5
  202. package/engine/graphics/micron/format/VirtualGeometry.js +46 -3
  203. package/engine/graphics/micron/format/micron_build_proxy_geometry.js +4 -2
  204. package/engine/graphics/micron/prototypeVirtualGeometry.js +47 -10
  205. package/engine/graphics/micron/render/instanced/shader/shader_rewrite_standard.js +17 -17
  206. package/engine/graphics/micron/render/refinement/get_geometry_patch_cut.js +15 -3
  207. package/engine/graphics/micron/simplifyGeometry.js +1 -1
  208. package/engine/graphics/particles/particular/engine/ParticularEngine.js +5 -0
  209. package/engine/graphics/particles/particular/engine/emitter/ParticleLayer.js +17 -9
  210. package/engine/graphics/particles/particular/engine/renderers/ParticleRenderer.js +12 -10
  211. package/engine/graphics/particles/particular/engine/renderers/billboard/ParticleBillboardMaterial.js +7 -2
  212. package/engine/graphics/particles/particular/engine/renderers/billboard/SoftBillboardParticlePool.js +27 -0
  213. package/engine/graphics/particles/particular/engine/renderers/billboard/SoftBillboardParticleRenderer.js +80 -0
  214. package/engine/graphics/particles/particular/engine/shader/ShaderManager.js +16 -4
  215. package/engine/graphics/shaders/TerrainShader.js +8 -8
  216. package/engine/graphics/texture/atlas/TextureAtlasDebugger.js +2 -1
  217. package/engine/graphics/texture/sampler/Sampler2D.js +206 -201
  218. package/engine/graphics/texture/sampler/Sampler2D.spec.js +34 -35
  219. package/engine/graphics/texture/sampler/bicubic.js +59 -0
  220. package/engine/graphics/texture/sampler/downsampleSample2D.spec.js +2 -2
  221. package/engine/graphics/texture/sampler/genericResampleSampler2D.js +0 -2
  222. package/engine/graphics/texture/sampler/prototypeSamplerFiltering.js +146 -0
  223. package/engine/graphics/texture/sampler/{downsampleSampler2D.js → sampler2D_scale_down_linear.js} +8 -4
  224. package/engine/graphics/texture/sampler/sampler2_d_scale_down_lanczos.js +140 -0
  225. package/engine/graphics/texture/sampler/scaleSampler2D.js +3 -3
  226. package/engine/graphics/texture/sampler/writeSampler2DDataToDataTexture.js +1 -1
  227. package/engine/graphics/util/ScaleObject3ToBox.js +14 -1
  228. package/engine/graphics/util/makeMeshPreviewScene.js +2 -1
  229. package/engine/grid/components/GridObstacle.js +0 -44
  230. package/engine/grid/components/GridObstacleSerializationAdapter.js +46 -0
  231. package/engine/input/devices/PointerDevice.d.ts +1 -1
  232. package/engine/input/devices/PointerDevice.js +17 -2
  233. package/engine/input/ecs/util/TerrainCameraTargetSampler.js +2 -2
  234. package/engine/navigation/ecs/components/Path.d.ts +2 -0
  235. package/engine/navigation/ecs/components/Path.js +6 -1
  236. package/engine/navigation/ecs/components/computeNonuniformCatmullRomSplineSample.js +117 -0
  237. package/engine/navigation/grid/AStar.js +1 -1
  238. package/engine/navigation/grid/GridField.js +3 -2
  239. package/engine/platform/GetURLHash.js +27 -0
  240. package/engine/platform/WebEnginePlatform.js +1 -22
  241. package/engine/sound/ecs/emitter/SoundEmitter.js +10 -6
  242. package/engine/ui/DraggableAspect.js +2 -2
  243. package/generation/GridGenerator.js +7 -6
  244. package/generation/example/SampleGenerator0.js +39 -35
  245. package/generation/example/filters/SampleGroundMoistureFilter.js +58 -17
  246. package/generation/example/generators/interactive/mir_generator_place_buff_objects.js +7 -6
  247. package/generation/example/generators/mir_generator_place_bases.js +7 -3
  248. package/generation/example/generators/mir_generator_place_road_decorators.js +3 -3
  249. package/generation/example/generators/mir_generator_place_starting_point.js +3 -2
  250. package/generation/example/themes/SampleTheme0.js +11 -7
  251. package/generation/filtering/numeric/CellFilterLiteralFloat.js +5 -0
  252. package/generation/filtering/numeric/complex/CellFilterDilate.js +36 -0
  253. package/generation/filtering/numeric/complex/CellFilterGaussianBlur.js +15 -5
  254. package/generation/filtering/numeric/complex/CellFilterSimplexNoise.js +53 -1
  255. package/generation/filtering/numeric/math/CellFilterMax2.js +3 -0
  256. package/generation/filtering/numeric/math/CellFilterMembershipGeneralizedBell.js +55 -0
  257. package/generation/filtering/numeric/sampling/AbstractCellFilterSampleGridLayer.js +42 -0
  258. package/generation/filtering/numeric/sampling/CellFilterSampleLayerCubic.js +36 -0
  259. package/generation/filtering/numeric/sampling/CellFilterSampleLayerLinear.js +41 -0
  260. package/generation/grid/GridData.d.ts +5 -1
  261. package/generation/grid/GridData.js +35 -36
  262. package/generation/grid/MarkerMatchCounter.js +5 -3
  263. package/generation/grid/generation/discrete/GridTaskConnectRooms.js +1 -1
  264. package/generation/grid/generation/discrete/layer/GridTaskBuildSourceDistanceMap.js +1 -1
  265. package/generation/grid/generation/discrete/layer/GridTaskDistanceToMarkers.js +1 -1
  266. package/generation/grid/generation/road/GridTaskGenerateRoads.js +1 -1
  267. package/generation/markers/GridActionRuleSet.js +15 -32
  268. package/generation/markers/GridCellActionPlaceMarker.js +12 -8
  269. package/generation/markers/debug/visualizeMarkers.js +56 -36
  270. package/generation/markers/emitter/MarkerNodeEmitterFromAction.js +8 -8
  271. package/generation/markers/prototypeGridCellActionPlaceMarker.js +209 -0
  272. package/generation/markers/transform/MarkerNodeTransformerOffsetPosition.js +1 -5
  273. package/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +2 -2
  274. package/generation/placement/GridCellPlacementRule.js +31 -25
  275. package/generation/theme/ThemeEngine.js +1 -1
  276. package/package.json +1 -1
  277. package/samples/terrain/from_image.js +7 -3
  278. package/samples/terrain/main.js +1 -1
  279. package/view/View.js +23 -1
  280. package/view/common/LabelView.js +1 -1
  281. package/view/compose3x3transform.js +32 -8
  282. package/view/controller/dat/DatGuiUtils.js +1 -1
  283. package/view/elements/DropDownSelectionView.js +11 -3
  284. package/view/elements/image/ImageView.js +3 -1
  285. package/core/model/ObservedReal.js +0 -55
  286. package/editor/ecs/component/ObjectEditor.js +0 -0
  287. package/engine/graphics/particles/particular/engine/renderers/SoftBillboardParticleRenderer.js +0 -7
  288. package/engine/sound/ecs/emitter/attenuate/attenuateSoundLinear.js +0 -11
  289. 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
- const face_array = new Uint16Array(face_count * 3);
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 = mesh.vertices.indexOf(vA);
34
- const vBi = mesh.vertices.indexOf(vB);
35
- const vCi = mesh.vertices.indexOf(vC);
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
- public get onChanged(): Signal;
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
  }