chili3d 0.6.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/.github/workflows/main.yml +26 -0
- package/.vscode/c_cpp_properties.json +30 -0
- package/.vscode/launch.json +21 -0
- package/.vscode/settings.json +8 -0
- package/Dockerfile +7 -0
- package/LICENSE +661 -0
- package/README.md +184 -0
- package/biome.json +67 -0
- package/compose.yml +7 -0
- package/cpp/CMakeLists.txt +96 -0
- package/cpp/CMakePresets.json +43 -0
- package/cpp/README.md +21 -0
- package/cpp/src/converter.cpp +413 -0
- package/cpp/src/factory.cpp +612 -0
- package/cpp/src/geometry.cpp +204 -0
- package/cpp/src/mesher.cpp +330 -0
- package/cpp/src/opencascade.cpp +414 -0
- package/cpp/src/shape.cpp +447 -0
- package/cpp/src/shared.cpp +83 -0
- package/cpp/src/shared.hpp +211 -0
- package/cpp/src/transient.cpp +29 -0
- package/cpp/src/utils.cpp +114 -0
- package/cpp/src/utils.hpp +25 -0
- package/cpp/test/index.html +146 -0
- package/package.json +49 -0
- package/packages/chili/package.json +11 -0
- package/packages/chili/src/application.ts +200 -0
- package/packages/chili/src/bodys/arc.ts +61 -0
- package/packages/chili/src/bodys/boolean.ts +32 -0
- package/packages/chili/src/bodys/box.ts +73 -0
- package/packages/chili/src/bodys/circle.ts +57 -0
- package/packages/chili/src/bodys/cone.ts +64 -0
- package/packages/chili/src/bodys/cylinder.ts +69 -0
- package/packages/chili/src/bodys/ellipse.ts +85 -0
- package/packages/chili/src/bodys/face.ts +72 -0
- package/packages/chili/src/bodys/fuse.ts +44 -0
- package/packages/chili/src/bodys/index.ts +16 -0
- package/packages/chili/src/bodys/line.ts +48 -0
- package/packages/chili/src/bodys/polygon.ts +40 -0
- package/packages/chili/src/bodys/prism.ts +49 -0
- package/packages/chili/src/bodys/pyramid.ts +64 -0
- package/packages/chili/src/bodys/rect.ts +69 -0
- package/packages/chili/src/bodys/revolve.ts +54 -0
- package/packages/chili/src/bodys/sphere.ts +48 -0
- package/packages/chili/src/bodys/sweep.ts +67 -0
- package/packages/chili/src/bodys/wire.ts +36 -0
- package/packages/chili/src/commands/application/index.ts +10 -0
- package/packages/chili/src/commands/application/newDocument.ts +17 -0
- package/packages/chili/src/commands/application/openDocument.ts +35 -0
- package/packages/chili/src/commands/application/performanceTest.ts +64 -0
- package/packages/chili/src/commands/application/saveDocument.ts +24 -0
- package/packages/chili/src/commands/application/toFile.ts +35 -0
- package/packages/chili/src/commands/application/toggleDynamicWorkplane.ts +15 -0
- package/packages/chili/src/commands/application/wechatGroup.ts +42 -0
- package/packages/chili/src/commands/boolean.ts +109 -0
- package/packages/chili/src/commands/create/arc.ts +110 -0
- package/packages/chili/src/commands/create/bezier.ts +116 -0
- package/packages/chili/src/commands/create/box.ts +59 -0
- package/packages/chili/src/commands/create/circle.ts +54 -0
- package/packages/chili/src/commands/create/cone.ts +104 -0
- package/packages/chili/src/commands/create/converter.ts +159 -0
- package/packages/chili/src/commands/create/copySubShape.ts +37 -0
- package/packages/chili/src/commands/create/curveProjection.ts +61 -0
- package/packages/chili/src/commands/create/cylinder.ts +96 -0
- package/packages/chili/src/commands/create/ellipse.ts +95 -0
- package/packages/chili/src/commands/create/group.ts +205 -0
- package/packages/chili/src/commands/create/index.ts +26 -0
- package/packages/chili/src/commands/create/line.ts +61 -0
- package/packages/chili/src/commands/create/loft.ts +149 -0
- package/packages/chili/src/commands/create/offset.ts +131 -0
- package/packages/chili/src/commands/create/polygon.ts +104 -0
- package/packages/chili/src/commands/create/prism.ts +52 -0
- package/packages/chili/src/commands/create/pyramid.ts +56 -0
- package/packages/chili/src/commands/create/rect.ts +105 -0
- package/packages/chili/src/commands/create/revolve.ts +62 -0
- package/packages/chili/src/commands/create/section.ts +31 -0
- package/packages/chili/src/commands/create/sphere.ts +48 -0
- package/packages/chili/src/commands/create/sweep.ts +39 -0
- package/packages/chili/src/commands/create/thickSolid.ts +50 -0
- package/packages/chili/src/commands/createActCommand.ts +26 -0
- package/packages/chili/src/commands/createCommand.ts +41 -0
- package/packages/chili/src/commands/delete.ts +38 -0
- package/packages/chili/src/commands/folder.ts +18 -0
- package/packages/chili/src/commands/importExport.ts +97 -0
- package/packages/chili/src/commands/index.ts +17 -0
- package/packages/chili/src/commands/measure/angle.ts +130 -0
- package/packages/chili/src/commands/measure/index.ts +6 -0
- package/packages/chili/src/commands/measure/length.ts +57 -0
- package/packages/chili/src/commands/measure/select.module.css +68 -0
- package/packages/chili/src/commands/measure/select.ts +228 -0
- package/packages/chili/src/commands/modify/array.ts +447 -0
- package/packages/chili/src/commands/modify/break.ts +78 -0
- package/packages/chili/src/commands/modify/brush.ts +100 -0
- package/packages/chili/src/commands/modify/chamfer.ts +70 -0
- package/packages/chili/src/commands/modify/explode.ts +91 -0
- package/packages/chili/src/commands/modify/fillet.ts +69 -0
- package/packages/chili/src/commands/modify/index.ts +16 -0
- package/packages/chili/src/commands/modify/mirror.ts +49 -0
- package/packages/chili/src/commands/modify/move.ts +39 -0
- package/packages/chili/src/commands/modify/removeFeature.ts +56 -0
- package/packages/chili/src/commands/modify/removeSubShapes.ts +44 -0
- package/packages/chili/src/commands/modify/rotate.ts +112 -0
- package/packages/chili/src/commands/modify/split.ts +81 -0
- package/packages/chili/src/commands/modify/transformedCommand.ts +100 -0
- package/packages/chili/src/commands/modify/trim.ts +254 -0
- package/packages/chili/src/commands/multistepCommand.ts +125 -0
- package/packages/chili/src/commands/redo.ts +16 -0
- package/packages/chili/src/commands/undo.ts +16 -0
- package/packages/chili/src/commands/workingPlane.ts +150 -0
- package/packages/chili/src/comparers/NumberEqualityComparer.ts +12 -0
- package/packages/chili/src/comparers/XYZEqualityComparer.ts +12 -0
- package/packages/chili/src/comparers/index.ts +5 -0
- package/packages/chili/src/document.ts +145 -0
- package/packages/chili/src/editEventHandler.ts +20 -0
- package/packages/chili/src/index.ts +12 -0
- package/packages/chili/src/selection.ts +178 -0
- package/packages/chili/src/services/commandService.ts +105 -0
- package/packages/chili/src/services/editorService.ts +46 -0
- package/packages/chili/src/services/hotkeyService.ts +102 -0
- package/packages/chili/src/services/index.ts +6 -0
- package/packages/chili/src/snap/dimension.ts +33 -0
- package/packages/chili/src/snap/handlers/angleSnapEventHandler.ts +60 -0
- package/packages/chili/src/snap/handlers/index.ts +7 -0
- package/packages/chili/src/snap/handlers/lengthSnapEventHandler.ts +117 -0
- package/packages/chili/src/snap/handlers/pointSnapEventHandler.ts +176 -0
- package/packages/chili/src/snap/handlers/snapEventHandler.ts +288 -0
- package/packages/chili/src/snap/index.ts +6 -0
- package/packages/chili/src/snap/snap.ts +50 -0
- package/packages/chili/src/snap/snaps/axisSnap.ts +57 -0
- package/packages/chili/src/snap/snaps/baseSnap.ts +69 -0
- package/packages/chili/src/snap/snaps/featurePointStrategy.ts +64 -0
- package/packages/chili/src/snap/snaps/index.ts +7 -0
- package/packages/chili/src/snap/snaps/objectSnap.ts +264 -0
- package/packages/chili/src/snap/snaps/planeSnap.ts +55 -0
- package/packages/chili/src/snap/snaps/pointOnCurveSnap.ts +24 -0
- package/packages/chili/src/snap/tracking/axis.ts +32 -0
- package/packages/chili/src/snap/tracking/axisTracking.ts +46 -0
- package/packages/chili/src/snap/tracking/index.ts +6 -0
- package/packages/chili/src/snap/tracking/objectTracking.ts +90 -0
- package/packages/chili/src/snap/tracking/trackingBase.ts +40 -0
- package/packages/chili/src/snap/tracking/trackingSnap.ts +201 -0
- package/packages/chili/src/step/angleStep.ts +32 -0
- package/packages/chili/src/step/index.ts +8 -0
- package/packages/chili/src/step/lengthStep.ts +32 -0
- package/packages/chili/src/step/pointStep.ts +87 -0
- package/packages/chili/src/step/selectStep.ts +130 -0
- package/packages/chili/src/step/step.ts +55 -0
- package/packages/chili/src/utils.ts +19 -0
- package/packages/chili/test/command.test.ts +4 -0
- package/packages/chili-builder/package.json +13 -0
- package/packages/chili-builder/src/additionalModule.ts +15 -0
- package/packages/chili-builder/src/appBuilder.ts +176 -0
- package/packages/chili-builder/src/defaultDataExchange.ts +152 -0
- package/packages/chili-builder/src/index.ts +5 -0
- package/packages/chili-builder/src/ribbon.ts +129 -0
- package/packages/chili-controls/package.json +9 -0
- package/packages/chili-controls/src/collection.ts +96 -0
- package/packages/chili-controls/src/controls.ts +83 -0
- package/packages/chili-controls/src/converters/colorConverter.ts +39 -0
- package/packages/chili-controls/src/converters/index.ts +8 -0
- package/packages/chili-controls/src/converters/numberConverter.ts +15 -0
- package/packages/chili-controls/src/converters/stringConverter.ts +13 -0
- package/packages/chili-controls/src/converters/urlConverter.ts +10 -0
- package/packages/chili-controls/src/converters/xyzConverter.ts +28 -0
- package/packages/chili-controls/src/expander/expander.module.css +38 -0
- package/packages/chili-controls/src/expander/expander.ts +59 -0
- package/packages/chili-controls/src/expander/index.ts +4 -0
- package/packages/chili-controls/src/htmlProps.ts +10 -0
- package/packages/chili-controls/src/index.ts +10 -0
- package/packages/chili-controls/src/radioGroup.module.css +20 -0
- package/packages/chili-controls/src/radioGroup.ts +54 -0
- package/packages/chili-controls/src/utils.ts +20 -0
- package/packages/chili-controls/test/converter.test.ts +70 -0
- package/packages/chili-controls/test/styleMock.js +4 -0
- package/packages/chili-core/package.json +7 -0
- package/packages/chili-core/src/application.ts +38 -0
- package/packages/chili-core/src/command/command.ts +154 -0
- package/packages/chili-core/src/command/commandKeys.ts +8 -0
- package/packages/chili-core/src/command/decarator.ts +43 -0
- package/packages/chili-core/src/command/index.ts +6 -0
- package/packages/chili-core/src/config.ts +145 -0
- package/packages/chili-core/src/constants.ts +8 -0
- package/packages/chili-core/src/dataExchange.ts +12 -0
- package/packages/chili-core/src/document.ts +25 -0
- package/packages/chili-core/src/editor.ts +12 -0
- package/packages/chili-core/src/foundation/asyncController.ts +55 -0
- package/packages/chili-core/src/foundation/binding.ts +132 -0
- package/packages/chili-core/src/foundation/collection.ts +208 -0
- package/packages/chili-core/src/foundation/converter.ts +9 -0
- package/packages/chili-core/src/foundation/deepObserver.ts +154 -0
- package/packages/chili-core/src/foundation/disposable.ts +18 -0
- package/packages/chili-core/src/foundation/dto/index.ts +9 -0
- package/packages/chili-core/src/foundation/equalityComparer.ts +6 -0
- package/packages/chili-core/src/foundation/gc.ts +36 -0
- package/packages/chili-core/src/foundation/history.ts +237 -0
- package/packages/chili-core/src/foundation/id.ts +25 -0
- package/packages/chili-core/src/foundation/index.ts +26 -0
- package/packages/chili-core/src/foundation/lazy.ts +18 -0
- package/packages/chili-core/src/foundation/linkedList.ts +141 -0
- package/packages/chili-core/src/foundation/logger.ts +45 -0
- package/packages/chili-core/src/foundation/messageType.ts +8 -0
- package/packages/chili-core/src/foundation/objectStorage.ts +50 -0
- package/packages/chili-core/src/foundation/observer.ts +147 -0
- package/packages/chili-core/src/foundation/precision.ts +8 -0
- package/packages/chili-core/src/foundation/pubsub.ts +74 -0
- package/packages/chili-core/src/foundation/result.ts +69 -0
- package/packages/chili-core/src/foundation/storage.ts +10 -0
- package/packages/chili-core/src/foundation/transaction.ts +77 -0
- package/packages/chili-core/src/foundation/utils/debounce.ts +15 -0
- package/packages/chili-core/src/foundation/utils/download.ts +16 -0
- package/packages/chili-core/src/foundation/utils/index.ts +6 -0
- package/packages/chili-core/src/foundation/utils/readFileAsync.ts +84 -0
- package/packages/chili-core/src/i18n/i18n.ts +107 -0
- package/packages/chili-core/src/i18n/index.ts +5 -0
- package/packages/chili-core/src/i18n/keys.ts +265 -0
- package/packages/chili-core/src/index.ts +26 -0
- package/packages/chili-core/src/material.ts +269 -0
- package/packages/chili-core/src/math/boundingBox.ts +226 -0
- package/packages/chili-core/src/math/index.ts +14 -0
- package/packages/chili-core/src/math/line.ts +55 -0
- package/packages/chili-core/src/math/lineSegment.ts +166 -0
- package/packages/chili-core/src/math/mathUtils.ts +45 -0
- package/packages/chili-core/src/math/matrix4.ts +414 -0
- package/packages/chili-core/src/math/plane.ts +96 -0
- package/packages/chili-core/src/math/planeAngle.ts +53 -0
- package/packages/chili-core/src/math/quaternion.ts +131 -0
- package/packages/chili-core/src/math/ray.ts +30 -0
- package/packages/chili-core/src/math/xy.ts +104 -0
- package/packages/chili-core/src/math/xyz.ts +181 -0
- package/packages/chili-core/src/model/component.ts +305 -0
- package/packages/chili-core/src/model/facebaseNode.ts +17 -0
- package/packages/chili-core/src/model/folderNode.ts +289 -0
- package/packages/chili-core/src/model/geometryNode.ts +185 -0
- package/packages/chili-core/src/model/groupNode.ts +19 -0
- package/packages/chili-core/src/model/index.ts +12 -0
- package/packages/chili-core/src/model/meshNode.ts +53 -0
- package/packages/chili-core/src/model/node.ts +315 -0
- package/packages/chili-core/src/model/shapeNode.ts +195 -0
- package/packages/chili-core/src/model/visualNode.ts +39 -0
- package/packages/chili-core/src/modelManager.ts +147 -0
- package/packages/chili-core/src/navigation.ts +58 -0
- package/packages/chili-core/src/property.ts +60 -0
- package/packages/chili-core/src/selection.ts +33 -0
- package/packages/chili-core/src/selectionFilter.ts +28 -0
- package/packages/chili-core/src/serialize/index.ts +4 -0
- package/packages/chili-core/src/serialize/serializer.ts +231 -0
- package/packages/chili-core/src/service.ts +10 -0
- package/packages/chili-core/src/shape/curve.ts +174 -0
- package/packages/chili-core/src/shape/geometry.ts +17 -0
- package/packages/chili-core/src/shape/index.ts +12 -0
- package/packages/chili-core/src/shape/lineType.ts +7 -0
- package/packages/chili-core/src/shape/meshData.ts +347 -0
- package/packages/chili-core/src/shape/shape.ts +104 -0
- package/packages/chili-core/src/shape/shapeConverter.ts +17 -0
- package/packages/chili-core/src/shape/shapeFactory.ts +58 -0
- package/packages/chili-core/src/shape/shapeType.ts +75 -0
- package/packages/chili-core/src/shape/surface.ts +154 -0
- package/packages/chili-core/src/snapType.ts +32 -0
- package/packages/chili-core/src/ui/button.ts +16 -0
- package/packages/chili-core/src/ui/combobox.ts +27 -0
- package/packages/chili-core/src/ui/dialog.ts +7 -0
- package/packages/chili-core/src/ui/index.ts +8 -0
- package/packages/chili-core/src/ui/ribbon.ts +15 -0
- package/packages/chili-core/src/ui/window.ts +13 -0
- package/packages/chili-core/src/visual/act.ts +59 -0
- package/packages/chili-core/src/visual/cameraController.ts +22 -0
- package/packages/chili-core/src/visual/cursorType.ts +4 -0
- package/packages/chili-core/src/visual/detectedData.ts +14 -0
- package/packages/chili-core/src/visual/eventHandler.ts +15 -0
- package/packages/chili-core/src/visual/highlighter.ts +16 -0
- package/packages/chili-core/src/visual/index.ts +20 -0
- package/packages/chili-core/src/visual/meshExporter.ts +11 -0
- package/packages/chili-core/src/visual/meshUtils.ts +276 -0
- package/packages/chili-core/src/visual/textGenerator.ts +8 -0
- package/packages/chili-core/src/visual/view.ts +80 -0
- package/packages/chili-core/src/visual/viewGizmo.ts +8 -0
- package/packages/chili-core/src/visual/viewport.ts +10 -0
- package/packages/chili-core/src/visual/visual.ts +24 -0
- package/packages/chili-core/src/visual/visualContext.ts +29 -0
- package/packages/chili-core/src/visual/visualFactory.ts +10 -0
- package/packages/chili-core/src/visual/visualObject.ts +25 -0
- package/packages/chili-core/src/visual/visualShape.ts +30 -0
- package/packages/chili-core/test/binding.test.ts +95 -0
- package/packages/chili-core/test/boundingBox.test.ts +60 -0
- package/packages/chili-core/test/collection.test.ts +53 -0
- package/packages/chili-core/test/history.test.ts +42 -0
- package/packages/chili-core/test/line.test.ts +75 -0
- package/packages/chili-core/test/linesegment.test.ts +98 -0
- package/packages/chili-core/test/linkedList.test.ts +82 -0
- package/packages/chili-core/test/math.test.ts +34 -0
- package/packages/chili-core/test/matrix.test.ts +129 -0
- package/packages/chili-core/test/node.test.ts +122 -0
- package/packages/chili-core/test/nodeList.test.ts +247 -0
- package/packages/chili-core/test/observer.test.ts +91 -0
- package/packages/chili-core/test/plane.test.ts +31 -0
- package/packages/chili-core/test/quaternion.test.ts +14 -0
- package/packages/chili-core/test/result.test.ts +24 -0
- package/packages/chili-core/test/serializer.test.ts +58 -0
- package/packages/chili-core/test/snapType.test.ts +10 -0
- package/packages/chili-core/test/task.test.ts +41 -0
- package/packages/chili-core/test/testDocument.ts +70 -0
- package/packages/chili-core/test/transaction.test.ts +42 -0
- package/packages/chili-core/test/visual.test.ts +42 -0
- package/packages/chili-core/test/xyz.test.ts +260 -0
- package/packages/chili-geo/package.json +9 -0
- package/packages/chili-geo/src/index.ts +4 -0
- package/packages/chili-geo/src/utils.ts +113 -0
- package/packages/chili-i18n/package.json +9 -0
- package/packages/chili-i18n/src/en.ts +270 -0
- package/packages/chili-i18n/src/index.ts +8 -0
- package/packages/chili-i18n/src/pt-br.ts +67 -0
- package/packages/chili-i18n/src/zh-cn.ts +269 -0
- package/packages/chili-storage/package.json +9 -0
- package/packages/chili-storage/src/index.ts +4 -0
- package/packages/chili-storage/src/indexedDBStorage.ts +150 -0
- package/packages/chili-three/package.json +13 -0
- package/packages/chili-three/src/cameraController.ts +335 -0
- package/packages/chili-three/src/common.ts +65 -0
- package/packages/chili-three/src/constants.ts +12 -0
- package/packages/chili-three/src/highlightable.ts +13 -0
- package/packages/chili-three/src/index.ts +4 -0
- package/packages/chili-three/src/meshExporter.ts +69 -0
- package/packages/chili-three/src/outlinePass.js +340 -0
- package/packages/chili-three/src/texture_points.jpg +0 -0
- package/packages/chili-three/src/threeGeometry.ts +207 -0
- package/packages/chili-three/src/threeGeometryFactory.ts +120 -0
- package/packages/chili-three/src/threeHelper.ts +174 -0
- package/packages/chili-three/src/threeHighlighter.ts +257 -0
- package/packages/chili-three/src/threeView.module.css +39 -0
- package/packages/chili-three/src/threeView.ts +669 -0
- package/packages/chili-three/src/threeViewEventHandler.ts +193 -0
- package/packages/chili-three/src/threeVisual.ts +92 -0
- package/packages/chili-three/src/threeVisualContext.ts +435 -0
- package/packages/chili-three/src/threeVisualFactory.ts +12 -0
- package/packages/chili-three/src/threeVisualObject.ts +442 -0
- package/packages/chili-three/src/viewGizmo.ts +305 -0
- package/packages/chili-three/test/cameraControls.ts +10 -0
- package/packages/chili-three/test/testDocument.ts +68 -0
- package/packages/chili-three/test/testEdge.ts +171 -0
- package/packages/chili-three/test/testView.ts +78 -0
- package/packages/chili-three/test/three.test.ts +44 -0
- package/packages/chili-three/test/viewGizmo.ts +12 -0
- package/packages/chili-ui/package.json +12 -0
- package/packages/chili-ui/src/cursor/draw.cur +0 -0
- package/packages/chili-ui/src/cursor/index.ts +17 -0
- package/packages/chili-ui/src/dialog.module.css +63 -0
- package/packages/chili-ui/src/dialog.ts +42 -0
- package/packages/chili-ui/src/editor.module.css +83 -0
- package/packages/chili-ui/src/editor.ts +142 -0
- package/packages/chili-ui/src/home/home.module.css +301 -0
- package/packages/chili-ui/src/home/home.ts +243 -0
- package/packages/chili-ui/src/home/index.ts +4 -0
- package/packages/chili-ui/src/home/languageSelector.ts +27 -0
- package/packages/chili-ui/src/home/navigation3DSelector.ts +27 -0
- package/packages/chili-ui/src/home/themeSelector.ts +34 -0
- package/packages/chili-ui/src/index.ts +5 -0
- package/packages/chili-ui/src/mainWindow.module.css +144 -0
- package/packages/chili-ui/src/mainWindow.ts +154 -0
- package/packages/chili-ui/src/okCancel.module.css +54 -0
- package/packages/chili-ui/src/okCancel.ts +58 -0
- package/packages/chili-ui/src/permanent.module.css +44 -0
- package/packages/chili-ui/src/permanent.ts +31 -0
- package/packages/chili-ui/src/project/index.ts +4 -0
- package/packages/chili-ui/src/project/projectView.module.css +37 -0
- package/packages/chili-ui/src/project/projectView.ts +77 -0
- package/packages/chili-ui/src/project/toolBar.module.css +16 -0
- package/packages/chili-ui/src/project/toolBar.ts +73 -0
- package/packages/chili-ui/src/project/tree/index.ts +5 -0
- package/packages/chili-ui/src/project/tree/tree.module.css +16 -0
- package/packages/chili-ui/src/project/tree/tree.ts +265 -0
- package/packages/chili-ui/src/project/tree/treeItem.module.css +21 -0
- package/packages/chili-ui/src/project/tree/treeItem.ts +89 -0
- package/packages/chili-ui/src/project/tree/treeItemGroup.module.css +33 -0
- package/packages/chili-ui/src/project/tree/treeItemGroup.ts +85 -0
- package/packages/chili-ui/src/project/tree/treeModel.module.css +11 -0
- package/packages/chili-ui/src/project/tree/treeModel.ts +20 -0
- package/packages/chili-ui/src/property/check.ts +39 -0
- package/packages/chili-ui/src/property/colorPorperty.module.css +6 -0
- package/packages/chili-ui/src/property/colorProperty.ts +63 -0
- package/packages/chili-ui/src/property/common.module.css +14 -0
- package/packages/chili-ui/src/property/index.ts +4 -0
- package/packages/chili-ui/src/property/input.module.css +19 -0
- package/packages/chili-ui/src/property/input.ts +140 -0
- package/packages/chili-ui/src/property/material/index.ts +5 -0
- package/packages/chili-ui/src/property/material/materialDataContent.ts +44 -0
- package/packages/chili-ui/src/property/material/materialEditor.module.css +98 -0
- package/packages/chili-ui/src/property/material/materialEditor.ts +147 -0
- package/packages/chili-ui/src/property/material/textureEditor.module.css +46 -0
- package/packages/chili-ui/src/property/material/textureEditor.ts +61 -0
- package/packages/chili-ui/src/property/materialProperty.module.css +30 -0
- package/packages/chili-ui/src/property/materialProperty.ts +86 -0
- package/packages/chili-ui/src/property/matrixProperty.ts +147 -0
- package/packages/chili-ui/src/property/propertyBase.module.css +3 -0
- package/packages/chili-ui/src/property/propertyBase.ts +14 -0
- package/packages/chili-ui/src/property/propertyView.module.css +36 -0
- package/packages/chili-ui/src/property/propertyView.ts +115 -0
- package/packages/chili-ui/src/property/utils.ts +48 -0
- package/packages/chili-ui/src/ribbon/commandContext.module.css +73 -0
- package/packages/chili-ui/src/ribbon/commandContext.ts +239 -0
- package/packages/chili-ui/src/ribbon/index.ts +4 -0
- package/packages/chili-ui/src/ribbon/ribbon.module.css +286 -0
- package/packages/chili-ui/src/ribbon/ribbon.ts +288 -0
- package/packages/chili-ui/src/ribbon/ribbonButton.module.css +75 -0
- package/packages/chili-ui/src/ribbon/ribbonButton.ts +88 -0
- package/packages/chili-ui/src/ribbon/ribbonData.ts +66 -0
- package/packages/chili-ui/src/ribbon/ribbonStack.module.css +6 -0
- package/packages/chili-ui/src/ribbon/ribbonStack.ts +13 -0
- package/packages/chili-ui/src/ribbon/ribbonToggleButton.module.css +3 -0
- package/packages/chili-ui/src/ribbon/ribbonToggleButton.ts +6 -0
- package/packages/chili-ui/src/statusbar/index.ts +4 -0
- package/packages/chili-ui/src/statusbar/snapConfig.module.css +25 -0
- package/packages/chili-ui/src/statusbar/snapConfig.ts +92 -0
- package/packages/chili-ui/src/statusbar/statusbar.module.css +28 -0
- package/packages/chili-ui/src/statusbar/statusbar.ts +54 -0
- package/packages/chili-ui/src/toast/index.ts +4 -0
- package/packages/chili-ui/src/toast/toast.module.css +27 -0
- package/packages/chili-ui/src/toast/toast.ts +39 -0
- package/packages/chili-ui/src/viewport/flyout/flyout.module.css +9 -0
- package/packages/chili-ui/src/viewport/flyout/flyout.ts +77 -0
- package/packages/chili-ui/src/viewport/flyout/index.ts +6 -0
- package/packages/chili-ui/src/viewport/flyout/input.module.css +21 -0
- package/packages/chili-ui/src/viewport/flyout/input.ts +89 -0
- package/packages/chili-ui/src/viewport/flyout/tip.module.css +21 -0
- package/packages/chili-ui/src/viewport/flyout/tip.ts +45 -0
- package/packages/chili-ui/src/viewport/index.ts +4 -0
- package/packages/chili-ui/src/viewport/layoutViewport.module.css +21 -0
- package/packages/chili-ui/src/viewport/layoutViewport.ts +76 -0
- package/packages/chili-ui/src/viewport/viewport.module.css +179 -0
- package/packages/chili-ui/src/viewport/viewport.ts +296 -0
- package/packages/chili-vis/package.json +9 -0
- package/packages/chili-vis/src/index.ts +7 -0
- package/packages/chili-vis/src/nodeSelectionEventHandler.ts +122 -0
- package/packages/chili-vis/src/selectionEventHandler.ts +145 -0
- package/packages/chili-vis/src/shapeSelectionEventHandler.ts +176 -0
- package/packages/chili-vis/src/viewUtils.ts +64 -0
- package/packages/chili-wasm/lib/chili-wasm.d.ts +827 -0
- package/packages/chili-wasm/lib/chili-wasm.js +5275 -0
- package/packages/chili-wasm/lib/chili-wasm.wasm +0 -0
- package/packages/chili-wasm/package.json +10 -0
- package/packages/chili-wasm/src/converter.ts +124 -0
- package/packages/chili-wasm/src/curve.ts +589 -0
- package/packages/chili-wasm/src/factory.ts +331 -0
- package/packages/chili-wasm/src/geometry.ts +51 -0
- package/packages/chili-wasm/src/helper.ts +435 -0
- package/packages/chili-wasm/src/index.ts +5 -0
- package/packages/chili-wasm/src/mesher.ts +114 -0
- package/packages/chili-wasm/src/shape.ts +481 -0
- package/packages/chili-wasm/src/surface.ts +510 -0
- package/packages/chili-wasm/src/wasm.ts +13 -0
- package/packages/chili-web/package.json +9 -0
- package/packages/chili-web/src/index.ts +33 -0
- package/packages/chili-web/src/loading.ts +67 -0
- package/packages/global.d.ts +31 -0
- package/public/favicon.svg +10 -0
- package/public/fonts/fzhei.json +46120 -0
- package/public/iconfont.js +1 -0
- package/public/images/wechat.jpg +0 -0
- package/public/index.css +13 -0
- package/public/index.html +24 -0
- package/rspack.config.ts +93 -0
- package/rstest.config.ts +27 -0
- package/screenshots/screenshot.png +0 -0
- package/scripts/add_copyright.mjs +59 -0
- package/scripts/build-npm.mjs +105 -0
- package/scripts/common.mjs +24 -0
- package/scripts/release.mjs +92 -0
- package/scripts/restore-package-json.mjs +27 -0
- package/scripts/setup_wasm_deps.mjs +97 -0
- package/scripts/update-package-json.mjs +27 -0
- package/tsconfig.build.json +14 -0
- package/tsconfig.build.tsbuildinfo +1 -0
- package/tsconfig.json +19 -0
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This is a forked and simplified version of the OutlinePass from three.js. In order to improve performance, various
|
|
3
|
+
* features have been deleted. This is about 2x faster.
|
|
4
|
+
*/
|
|
5
|
+
import {
|
|
6
|
+
AdditiveBlending,
|
|
7
|
+
Color,
|
|
8
|
+
DoubleSide,
|
|
9
|
+
LinearFilter,
|
|
10
|
+
Matrix4,
|
|
11
|
+
MeshBasicMaterial,
|
|
12
|
+
MeshDepthMaterial,
|
|
13
|
+
NoBlending,
|
|
14
|
+
RGBADepthPacking,
|
|
15
|
+
RGBAFormat,
|
|
16
|
+
ShaderMaterial,
|
|
17
|
+
UniformsUtils,
|
|
18
|
+
Vector2,
|
|
19
|
+
Vector3,
|
|
20
|
+
WebGLRenderTarget,
|
|
21
|
+
} from "three";
|
|
22
|
+
import { FullScreenQuad, Pass } from "three/examples/jsm/postprocessing/Pass.js";
|
|
23
|
+
import { CopyShader } from "three/examples/jsm/shaders/CopyShader.js";
|
|
24
|
+
|
|
25
|
+
class OutlinePass extends Pass {
|
|
26
|
+
constructor(scene, camera) {
|
|
27
|
+
super();
|
|
28
|
+
|
|
29
|
+
this.renderScene = scene;
|
|
30
|
+
this.renderCamera = camera;
|
|
31
|
+
this.visibleEdgeColor = new Color(1, 1, 1);
|
|
32
|
+
this.hiddenEdgeColor = new Color(0.1, 0.04, 0.02);
|
|
33
|
+
this.usePatternTexture = false;
|
|
34
|
+
this.edgeStrength = 3.0;
|
|
35
|
+
this.pulsePeriod = 0;
|
|
36
|
+
|
|
37
|
+
this._visibilityCache = new Map();
|
|
38
|
+
|
|
39
|
+
this.resolution = new Vector2(256, 256);
|
|
40
|
+
|
|
41
|
+
const pars = {
|
|
42
|
+
minFilter: LinearFilter,
|
|
43
|
+
magFilter: LinearFilter,
|
|
44
|
+
format: RGBAFormat,
|
|
45
|
+
skipInvalidateFramebuffer: true,
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
this.maskBufferMaterial = new MeshBasicMaterial({ color: 0xffffff });
|
|
49
|
+
this.maskBufferMaterial.side = DoubleSide;
|
|
50
|
+
this.renderTargetMaskBuffer = new WebGLRenderTarget(this.resolution.x, this.resolution.y, pars);
|
|
51
|
+
this.renderTargetMaskBuffer.texture.name = "OutlinePass.mask";
|
|
52
|
+
this.renderTargetMaskBuffer.texture.generateMipmaps = false;
|
|
53
|
+
|
|
54
|
+
this.depthMaterial = new MeshDepthMaterial();
|
|
55
|
+
this.depthMaterial.side = DoubleSide;
|
|
56
|
+
this.depthMaterial.depthPacking = RGBADepthPacking;
|
|
57
|
+
this.depthMaterial.blending = NoBlending;
|
|
58
|
+
|
|
59
|
+
this.prepareMaskMaterial = this.getPrepareMaskMaterial();
|
|
60
|
+
this.prepareMaskMaterial.side = DoubleSide;
|
|
61
|
+
this.prepareMaskMaterial.fragmentShader = replaceDepthToViewZ(
|
|
62
|
+
this.prepareMaskMaterial.fragmentShader,
|
|
63
|
+
this.renderCamera,
|
|
64
|
+
);
|
|
65
|
+
|
|
66
|
+
this.renderTargetDepthBuffer = new WebGLRenderTarget(this.resolution.x, this.resolution.y, pars);
|
|
67
|
+
this.renderTargetDepthBuffer.texture.name = "OutlinePass.depth";
|
|
68
|
+
this.renderTargetDepthBuffer.texture.generateMipmaps = false;
|
|
69
|
+
|
|
70
|
+
this.edgeDetectionMaterial = this.getEdgeDetectionMaterial();
|
|
71
|
+
this.renderTargetEdgeBuffer1 = new WebGLRenderTarget(this.resolution.x, this.resolution.y, pars);
|
|
72
|
+
this.renderTargetEdgeBuffer1.texture.name = "OutlinePass.edge1";
|
|
73
|
+
this.renderTargetEdgeBuffer1.texture.generateMipmaps = false;
|
|
74
|
+
|
|
75
|
+
// Overlay material
|
|
76
|
+
this.overlayMaterial = this.getOverlayMaterial();
|
|
77
|
+
|
|
78
|
+
// copy material
|
|
79
|
+
if (CopyShader === undefined) console.error("THREE.OutlinePass relies on CopyShader");
|
|
80
|
+
|
|
81
|
+
const copyShader = CopyShader;
|
|
82
|
+
|
|
83
|
+
this.copyUniforms = UniformsUtils.clone(copyShader.uniforms);
|
|
84
|
+
this.copyUniforms["opacity"].value = 1.0;
|
|
85
|
+
|
|
86
|
+
this.materialCopy = new ShaderMaterial({
|
|
87
|
+
uniforms: this.copyUniforms,
|
|
88
|
+
vertexShader: copyShader.vertexShader,
|
|
89
|
+
fragmentShader: copyShader.fragmentShader,
|
|
90
|
+
blending: NoBlending,
|
|
91
|
+
depthTest: false,
|
|
92
|
+
depthWrite: false,
|
|
93
|
+
transparent: true,
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
this.enabled = true;
|
|
97
|
+
this.needsSwap = false;
|
|
98
|
+
|
|
99
|
+
this._oldClearColor = new Color();
|
|
100
|
+
this.oldClearAlpha = 1;
|
|
101
|
+
|
|
102
|
+
this.fsQuad = new FullScreenQuad(null);
|
|
103
|
+
|
|
104
|
+
this.tempPulseColor1 = new Color();
|
|
105
|
+
this.tempPulseColor2 = new Color();
|
|
106
|
+
this.textureMatrix = new Matrix4();
|
|
107
|
+
|
|
108
|
+
function replaceDepthToViewZ(string, camera) {
|
|
109
|
+
var type = camera.isPerspectiveCamera ? "perspective" : "orthographic";
|
|
110
|
+
|
|
111
|
+
return string.replace(/DEPTH_TO_VIEW_Z/g, type + "DepthToViewZ");
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
dispose() {
|
|
116
|
+
this.renderTargetMaskBuffer.dispose();
|
|
117
|
+
this.renderTargetDepthBuffer.dispose();
|
|
118
|
+
this.renderTargetEdgeBuffer1.dispose();
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
setSize(width, height) {
|
|
122
|
+
this.renderTargetMaskBuffer.setSize(width, height);
|
|
123
|
+
this.renderTargetDepthBuffer.setSize(width, height);
|
|
124
|
+
|
|
125
|
+
this.renderTargetEdgeBuffer1.setSize(width, height);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
updateTextureMatrix() {
|
|
129
|
+
this.textureMatrix.set(
|
|
130
|
+
0.5,
|
|
131
|
+
0.0,
|
|
132
|
+
0.0,
|
|
133
|
+
0.5,
|
|
134
|
+
0.0,
|
|
135
|
+
0.5,
|
|
136
|
+
0.0,
|
|
137
|
+
0.5,
|
|
138
|
+
0.0,
|
|
139
|
+
0.0,
|
|
140
|
+
0.5,
|
|
141
|
+
0.5,
|
|
142
|
+
0.0,
|
|
143
|
+
0.0,
|
|
144
|
+
0.0,
|
|
145
|
+
1.0,
|
|
146
|
+
);
|
|
147
|
+
this.textureMatrix.multiply(this.renderCamera.projectionMatrix);
|
|
148
|
+
this.textureMatrix.multiply(this.renderCamera.matrixWorldInverse);
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
render(renderer, writeBuffer, readBuffer, deltaTime, maskActive) {
|
|
152
|
+
if (this.renderScene.children.length > 0) {
|
|
153
|
+
renderer.getClearColor(this._oldClearColor);
|
|
154
|
+
this.oldClearAlpha = renderer.getClearAlpha();
|
|
155
|
+
const oldAutoClear = renderer.autoClear;
|
|
156
|
+
|
|
157
|
+
renderer.autoClear = false;
|
|
158
|
+
|
|
159
|
+
if (maskActive) renderer.state.buffers.stencil.setTest(false);
|
|
160
|
+
|
|
161
|
+
renderer.setClearColor(0xffffff, 1);
|
|
162
|
+
|
|
163
|
+
// Update Texture Matrix for Depth compare
|
|
164
|
+
this.updateTextureMatrix();
|
|
165
|
+
|
|
166
|
+
this.renderScene.overrideMaterial = this.prepareMaskMaterial;
|
|
167
|
+
this.prepareMaskMaterial.uniforms["cameraNearFar"].value.set(
|
|
168
|
+
this.renderCamera.near,
|
|
169
|
+
this.renderCamera.far,
|
|
170
|
+
);
|
|
171
|
+
this.prepareMaskMaterial.uniforms["depthTexture"].value = this.renderTargetDepthBuffer.texture;
|
|
172
|
+
this.prepareMaskMaterial.uniforms["textureMatrix"].value = this.textureMatrix;
|
|
173
|
+
renderer.setRenderTarget(this.renderTargetMaskBuffer);
|
|
174
|
+
renderer.clear();
|
|
175
|
+
renderer.render(this.renderScene, this.renderCamera);
|
|
176
|
+
this.renderScene.overrideMaterial = null;
|
|
177
|
+
|
|
178
|
+
this.tempPulseColor1.copy(this.visibleEdgeColor);
|
|
179
|
+
this.tempPulseColor2.copy(this.hiddenEdgeColor);
|
|
180
|
+
|
|
181
|
+
// 3. Apply Edge Detection Pass
|
|
182
|
+
this.fsQuad.material = this.edgeDetectionMaterial;
|
|
183
|
+
this.edgeDetectionMaterial.uniforms["maskTexture"].value = this.renderTargetMaskBuffer.texture;
|
|
184
|
+
this.edgeDetectionMaterial.uniforms["texSize"].value.set(
|
|
185
|
+
this.renderTargetMaskBuffer.width,
|
|
186
|
+
this.renderTargetMaskBuffer.height,
|
|
187
|
+
);
|
|
188
|
+
this.edgeDetectionMaterial.uniforms["visibleEdgeColor"].value = this.tempPulseColor1;
|
|
189
|
+
this.edgeDetectionMaterial.uniforms["hiddenEdgeColor"].value = this.tempPulseColor2;
|
|
190
|
+
renderer.setRenderTarget(this.renderTargetEdgeBuffer1);
|
|
191
|
+
renderer.clear();
|
|
192
|
+
this.fsQuad.render(renderer);
|
|
193
|
+
|
|
194
|
+
// Blend it additively over the input texture
|
|
195
|
+
this.fsQuad.material = this.overlayMaterial;
|
|
196
|
+
this.overlayMaterial.uniforms["maskTexture"].value = this.renderTargetMaskBuffer.texture;
|
|
197
|
+
this.overlayMaterial.uniforms["edgeTexture1"].value = this.renderTargetEdgeBuffer1.texture;
|
|
198
|
+
this.overlayMaterial.uniforms["edgeStrength"].value = this.edgeStrength;
|
|
199
|
+
|
|
200
|
+
if (maskActive) renderer.state.buffers.stencil.setTest(true);
|
|
201
|
+
|
|
202
|
+
renderer.setRenderTarget(readBuffer);
|
|
203
|
+
this.fsQuad.render(renderer);
|
|
204
|
+
|
|
205
|
+
renderer.setClearColor(this._oldClearColor, this.oldClearAlpha);
|
|
206
|
+
renderer.autoClear = oldAutoClear;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
if (this.renderToScreen) {
|
|
210
|
+
this.fsQuad.material = this.materialCopy;
|
|
211
|
+
this.copyUniforms["tDiffuse"].value = readBuffer.texture;
|
|
212
|
+
renderer.setRenderTarget(null);
|
|
213
|
+
this.fsQuad.render(renderer);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
getPrepareMaskMaterial() {
|
|
218
|
+
const result = new ShaderMaterial({
|
|
219
|
+
uniforms: {
|
|
220
|
+
depthTexture: { value: null },
|
|
221
|
+
cameraNearFar: { value: new Vector2(0.5, 0.5) },
|
|
222
|
+
textureMatrix: { value: null },
|
|
223
|
+
id: { value: null },
|
|
224
|
+
},
|
|
225
|
+
|
|
226
|
+
vertexShader: `#include <morphtarget_pars_vertex>
|
|
227
|
+
#include <skinning_pars_vertex>
|
|
228
|
+
varying vec4 projTexCoord;
|
|
229
|
+
varying vec4 vPosition;
|
|
230
|
+
uniform mat4 textureMatrix;
|
|
231
|
+
void main() {
|
|
232
|
+
#include <skinbase_vertex>
|
|
233
|
+
#include <begin_vertex>
|
|
234
|
+
#include <morphtarget_vertex>
|
|
235
|
+
#include <skinning_vertex>
|
|
236
|
+
#include <project_vertex>
|
|
237
|
+
vPosition = mvPosition;
|
|
238
|
+
vec4 worldPosition = modelMatrix * vec4( transformed, 1.0 );
|
|
239
|
+
projTexCoord = textureMatrix * worldPosition;
|
|
240
|
+
}`,
|
|
241
|
+
|
|
242
|
+
fragmentShader: `#include <packing>
|
|
243
|
+
varying vec4 vPosition;
|
|
244
|
+
varying vec4 projTexCoord;
|
|
245
|
+
uniform sampler2D depthTexture;
|
|
246
|
+
uniform vec2 cameraNearFar;
|
|
247
|
+
uniform float id;
|
|
248
|
+
void main() {
|
|
249
|
+
float depth = unpackRGBAToDepth(texture2DProj( depthTexture, projTexCoord ));
|
|
250
|
+
float viewZ = - DEPTH_TO_VIEW_Z( depth, cameraNearFar.x, cameraNearFar.y );
|
|
251
|
+
float depthTest = (-vPosition.z > viewZ) ? 1.0 : 0.0;
|
|
252
|
+
gl_FragColor = vec4(id/255.0, depthTest, 1.0, 1.0);
|
|
253
|
+
}`,
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
let idCounter = 0;
|
|
257
|
+
result.onBeforeRender = (renderer, scene, camera, geometry, object, group) => {
|
|
258
|
+
result.uniforms.id.value = idCounter;
|
|
259
|
+
result.uniformsNeedUpdate = true;
|
|
260
|
+
idCounter += 100;
|
|
261
|
+
idCounter %= 255;
|
|
262
|
+
};
|
|
263
|
+
return result;
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
getEdgeDetectionMaterial() {
|
|
267
|
+
return new ShaderMaterial({
|
|
268
|
+
uniforms: {
|
|
269
|
+
maskTexture: { value: null },
|
|
270
|
+
texSize: { value: new Vector2(0.5, 0.5) },
|
|
271
|
+
visibleEdgeColor: { value: new Vector3(1.0, 1.0, 1.0) },
|
|
272
|
+
hiddenEdgeColor: { value: new Vector3(1.0, 1.0, 1.0) },
|
|
273
|
+
},
|
|
274
|
+
|
|
275
|
+
vertexShader: `varying vec2 vUv;
|
|
276
|
+
void main() {
|
|
277
|
+
vUv = uv;
|
|
278
|
+
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
279
|
+
}`,
|
|
280
|
+
|
|
281
|
+
fragmentShader: `varying vec2 vUv;
|
|
282
|
+
uniform sampler2D maskTexture;
|
|
283
|
+
uniform vec2 texSize;
|
|
284
|
+
uniform vec3 visibleEdgeColor;
|
|
285
|
+
uniform vec3 hiddenEdgeColor;
|
|
286
|
+
void main() {
|
|
287
|
+
vec2 invSize = 1. / texSize;
|
|
288
|
+
vec4 uvOffset = vec4(1.0, 0.0, 0.0, 1.0) * vec4(invSize, invSize);
|
|
289
|
+
vec4 c1 = texture2D( maskTexture, vUv + uvOffset.xy);
|
|
290
|
+
vec4 c2 = texture2D( maskTexture, vUv - uvOffset.xy);
|
|
291
|
+
vec4 c3 = texture2D( maskTexture, vUv + uvOffset.yw);
|
|
292
|
+
vec4 c4 = texture2D( maskTexture, vUv - uvOffset.yw);
|
|
293
|
+
float diff1 = (c1.r - c2.r)*0.5;
|
|
294
|
+
float diff2 = (c3.r - c4.r)*0.5;
|
|
295
|
+
float d = length( vec2(diff1, diff2) );
|
|
296
|
+
float a1 = min(c1.g, c2.g);
|
|
297
|
+
float a2 = min(c3.g, c4.g);
|
|
298
|
+
float visibilityFactor = min(a1, a2);
|
|
299
|
+
vec3 edgeColor = 1.0 - visibilityFactor > 0.001 ? visibleEdgeColor : hiddenEdgeColor;
|
|
300
|
+
gl_FragColor = vec4(edgeColor, 1.0) * vec4(d > 0. ? 1. : 0.);
|
|
301
|
+
}`,
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
getOverlayMaterial() {
|
|
306
|
+
return new ShaderMaterial({
|
|
307
|
+
uniforms: {
|
|
308
|
+
maskTexture: { value: null },
|
|
309
|
+
edgeTexture1: { value: null },
|
|
310
|
+
patternTexture: { value: null },
|
|
311
|
+
edgeStrength: { value: 1.0 },
|
|
312
|
+
},
|
|
313
|
+
|
|
314
|
+
vertexShader: `varying vec2 vUv;
|
|
315
|
+
void main() {
|
|
316
|
+
vUv = uv;
|
|
317
|
+
gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );
|
|
318
|
+
}`,
|
|
319
|
+
|
|
320
|
+
fragmentShader: `varying vec2 vUv;
|
|
321
|
+
uniform sampler2D maskTexture;
|
|
322
|
+
uniform sampler2D edgeTexture1;
|
|
323
|
+
uniform sampler2D patternTexture;
|
|
324
|
+
uniform float edgeStrength;
|
|
325
|
+
void main() {
|
|
326
|
+
vec4 edgeValue = texture2D(edgeTexture1, vUv);
|
|
327
|
+
vec4 maskColor = texture2D(maskTexture, vUv);
|
|
328
|
+
float visibilityFactor = 1.0 - maskColor.g > 0.0 ? 1.0 : 0.5;
|
|
329
|
+
vec4 finalColor = edgeStrength * edgeValue;
|
|
330
|
+
gl_FragColor = finalColor;
|
|
331
|
+
}`,
|
|
332
|
+
blending: AdditiveBlending,
|
|
333
|
+
depthTest: false,
|
|
334
|
+
depthWrite: false,
|
|
335
|
+
transparent: true,
|
|
336
|
+
});
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
export { OutlinePass };
|
|
Binary file
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
// Part of the Chili3d Project, under the AGPL-3.0 License.
|
|
2
|
+
// See LICENSE file in the project root for full license information.
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
type BoundingBox,
|
|
6
|
+
type EdgeMeshData,
|
|
7
|
+
type FaceMeshData,
|
|
8
|
+
type GeometryNode,
|
|
9
|
+
type IShape,
|
|
10
|
+
type ISubShape,
|
|
11
|
+
type IVisualGeometry,
|
|
12
|
+
type Matrix4,
|
|
13
|
+
MeshUtils,
|
|
14
|
+
type ShapeMeshRange,
|
|
15
|
+
ShapeNode,
|
|
16
|
+
ShapeType,
|
|
17
|
+
} from "chili-core";
|
|
18
|
+
import { type Material, Mesh, type MeshLambertMaterial } from "three";
|
|
19
|
+
import type { LineMaterial } from "three/examples/jsm/lines/LineMaterial";
|
|
20
|
+
import { LineSegments2 } from "three/examples/jsm/lines/LineSegments2";
|
|
21
|
+
import { LineSegmentsGeometry } from "three/examples/jsm/lines/LineSegmentsGeometry";
|
|
22
|
+
import { defaultEdgeMaterial } from "./common";
|
|
23
|
+
import { Constants } from "./constants";
|
|
24
|
+
import { ThreeGeometryFactory } from "./threeGeometryFactory";
|
|
25
|
+
import { ThreeHelper } from "./threeHelper";
|
|
26
|
+
import type { ThreeVisualContext } from "./threeVisualContext";
|
|
27
|
+
import { ThreeVisualObject } from "./threeVisualObject";
|
|
28
|
+
|
|
29
|
+
export class ThreeGeometry extends ThreeVisualObject implements IVisualGeometry {
|
|
30
|
+
private _faceMaterial: Material | Material[];
|
|
31
|
+
private _edges?: LineSegments2;
|
|
32
|
+
private _faces?: Mesh;
|
|
33
|
+
|
|
34
|
+
constructor(
|
|
35
|
+
readonly geometryNode: GeometryNode,
|
|
36
|
+
readonly context: ThreeVisualContext,
|
|
37
|
+
) {
|
|
38
|
+
super(geometryNode);
|
|
39
|
+
this._faceMaterial = context.getMaterial(geometryNode.materialId);
|
|
40
|
+
this.generateShape();
|
|
41
|
+
geometryNode.onPropertyChanged(this.handleGeometryPropertyChanged);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
changeFaceMaterial(material: Material | Material[]) {
|
|
45
|
+
if (this._faces) {
|
|
46
|
+
this._faceMaterial = material;
|
|
47
|
+
this._faces.material = material;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
box() {
|
|
52
|
+
return this._faces?.geometry.boundingBox ?? this._edges?.geometry.boundingBox;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
override boundingBox(): BoundingBox | undefined {
|
|
56
|
+
const box = this._faces?.geometry.boundingBox ?? this._edges?.geometry.boundingBox;
|
|
57
|
+
if (!box) return undefined;
|
|
58
|
+
|
|
59
|
+
return {
|
|
60
|
+
min: ThreeHelper.toXYZ(box.min),
|
|
61
|
+
max: ThreeHelper.toXYZ(box.max),
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
private readonly handleGeometryPropertyChanged = (property: keyof GeometryNode) => {
|
|
66
|
+
if (property === "materialId") {
|
|
67
|
+
this.changeFaceMaterial(this.context.getMaterial(this.geometryNode.materialId));
|
|
68
|
+
} else if ((property as keyof ShapeNode) === "shape") {
|
|
69
|
+
this.removeMeshes();
|
|
70
|
+
this.generateShape();
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
private generateShape() {
|
|
75
|
+
const mesh = this.geometryNode.mesh;
|
|
76
|
+
if (mesh?.faces?.position.length) this.initFaces(mesh.faces);
|
|
77
|
+
if (mesh?.edges?.position.length) this.initEdges(mesh.edges);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
override dispose() {
|
|
81
|
+
super.dispose();
|
|
82
|
+
this.geometryNode.removePropertyChanged(this.handleGeometryPropertyChanged);
|
|
83
|
+
this.removeMeshes();
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
private removeMeshes() {
|
|
87
|
+
if (this._edges) {
|
|
88
|
+
this.remove(this._edges);
|
|
89
|
+
this._edges.geometry.dispose();
|
|
90
|
+
this._edges = null as any;
|
|
91
|
+
}
|
|
92
|
+
if (this._faces) {
|
|
93
|
+
this.remove(this._faces);
|
|
94
|
+
this._faces.geometry.dispose();
|
|
95
|
+
this._faces = null as any;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
private initEdges(data: EdgeMeshData) {
|
|
100
|
+
const buff = ThreeGeometryFactory.createEdgeBufferGeometry(data);
|
|
101
|
+
this._edges = new LineSegments2(buff, defaultEdgeMaterial);
|
|
102
|
+
this._edges.layers.set(Constants.Layers.Wireframe);
|
|
103
|
+
this.add(this._edges);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
private initFaces(data: FaceMeshData) {
|
|
107
|
+
const buff = ThreeGeometryFactory.createFaceBufferGeometry(data);
|
|
108
|
+
if (data.groups.length > 1) buff.groups = data.groups;
|
|
109
|
+
this._faces = new Mesh(buff, this._faceMaterial);
|
|
110
|
+
this._faces.layers.set(Constants.Layers.Solid);
|
|
111
|
+
this.add(this._faces);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
setFacesMateiralTemperary(material: MeshLambertMaterial) {
|
|
115
|
+
if (this._faces) this._faces.material = material;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
setEdgesMateiralTemperary(material: LineMaterial) {
|
|
119
|
+
if (this._edges) this._edges.material = material;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
removeTemperaryMaterial(): void {
|
|
123
|
+
if (this._edges) this._edges.material = defaultEdgeMaterial;
|
|
124
|
+
if (this._faces) this._faces.material = this._faceMaterial;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
cloneSubEdge(index: number) {
|
|
128
|
+
const positions = MeshUtils.subEdge(this.geometryNode.mesh.edges!, index);
|
|
129
|
+
if (!positions) return undefined;
|
|
130
|
+
|
|
131
|
+
const buff = new LineSegmentsGeometry();
|
|
132
|
+
buff.setPositions(positions);
|
|
133
|
+
buff.applyMatrix4(this.matrixWorld);
|
|
134
|
+
|
|
135
|
+
return new LineSegments2(buff, defaultEdgeMaterial);
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
cloneSubFace(index: number) {
|
|
139
|
+
const mesh = MeshUtils.subFace(this.geometryNode.mesh.faces!, index);
|
|
140
|
+
if (!mesh) return undefined;
|
|
141
|
+
|
|
142
|
+
const buff = ThreeGeometryFactory.createFaceBufferGeometry(mesh);
|
|
143
|
+
buff.applyMatrix4(this.matrixWorld);
|
|
144
|
+
|
|
145
|
+
return new Mesh(buff, this._faceMaterial);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
faces() {
|
|
149
|
+
return this._faces;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
edges() {
|
|
153
|
+
return this._edges;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
override getSubShapeAndIndex(shapeType: "face" | "edge", subVisualIndex: number) {
|
|
157
|
+
let subShape: ISubShape | undefined;
|
|
158
|
+
let transform: Matrix4 | undefined;
|
|
159
|
+
let index: number = -1;
|
|
160
|
+
let groups: ShapeMeshRange[] | undefined;
|
|
161
|
+
if (shapeType === "edge") {
|
|
162
|
+
groups = this.geometryNode.mesh.edges?.range;
|
|
163
|
+
if (groups) {
|
|
164
|
+
index = ThreeHelper.findGroupIndex(groups, subVisualIndex)!;
|
|
165
|
+
subShape = groups[index].shape;
|
|
166
|
+
transform = groups[index].transform;
|
|
167
|
+
}
|
|
168
|
+
} else {
|
|
169
|
+
groups = this.geometryNode.mesh.faces?.range;
|
|
170
|
+
if (groups) {
|
|
171
|
+
index = ThreeHelper.findGroupIndex(groups, subVisualIndex)!;
|
|
172
|
+
subShape = groups[index].shape;
|
|
173
|
+
transform = groups[index].transform;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
let shape: IShape | undefined = subShape;
|
|
178
|
+
if (this.geometryNode instanceof ShapeNode) {
|
|
179
|
+
shape = this.geometryNode.shape.value;
|
|
180
|
+
}
|
|
181
|
+
return { transform, shape, subShape, index, groups: groups ?? [] };
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
override subShapeVisual(shapeType: ShapeType): (Mesh | LineSegments2)[] {
|
|
185
|
+
const shapes: (Mesh | LineSegments2 | undefined)[] = [];
|
|
186
|
+
|
|
187
|
+
const isWhole =
|
|
188
|
+
shapeType === ShapeType.Shape ||
|
|
189
|
+
ShapeType.hasCompound(shapeType) ||
|
|
190
|
+
ShapeType.hasCompoundSolid(shapeType) ||
|
|
191
|
+
ShapeType.hasSolid(shapeType);
|
|
192
|
+
|
|
193
|
+
if (isWhole || ShapeType.hasEdge(shapeType) || ShapeType.hasWire(shapeType)) {
|
|
194
|
+
shapes.push(this.edges());
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
if (isWhole || ShapeType.hasFace(shapeType) || ShapeType.hasShell(shapeType)) {
|
|
198
|
+
shapes.push(this.faces());
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return shapes.filter((x) => x !== undefined);
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
override wholeVisual(): (Mesh | LineSegments2)[] {
|
|
205
|
+
return [this.edges(), this.faces()].filter((x) => x !== undefined);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
// Part of the Chili3d Project, under the AGPL-3.0 License.
|
|
2
|
+
// See LICENSE file in the project root for full license information.
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
type EdgeMeshData,
|
|
6
|
+
type FaceMeshData,
|
|
7
|
+
LineType,
|
|
8
|
+
type MeshLike,
|
|
9
|
+
type VertexMeshData,
|
|
10
|
+
} from "chili-core";
|
|
11
|
+
import {
|
|
12
|
+
AlwaysDepth,
|
|
13
|
+
BufferAttribute,
|
|
14
|
+
BufferGeometry,
|
|
15
|
+
DoubleSide,
|
|
16
|
+
Float32BufferAttribute,
|
|
17
|
+
type LineBasicMaterial,
|
|
18
|
+
Mesh,
|
|
19
|
+
MeshLambertMaterial,
|
|
20
|
+
Points,
|
|
21
|
+
PointsMaterial,
|
|
22
|
+
} from "three";
|
|
23
|
+
import { LineMaterial } from "three/examples/jsm/lines/LineMaterial";
|
|
24
|
+
import { LineSegments2 } from "three/examples/jsm/lines/LineSegments2";
|
|
25
|
+
import { LineSegmentsGeometry } from "three/examples/jsm/lines/LineSegmentsGeometry";
|
|
26
|
+
|
|
27
|
+
export class ThreeGeometryFactory {
|
|
28
|
+
static createVertexGeometry(data: VertexMeshData) {
|
|
29
|
+
const buff = ThreeGeometryFactory.createVertexBufferGeometry(data);
|
|
30
|
+
const material = ThreeGeometryFactory.createVertexMaterial(data);
|
|
31
|
+
ThreeGeometryFactory.setColor(buff, data, material);
|
|
32
|
+
|
|
33
|
+
material.depthFunc = AlwaysDepth;
|
|
34
|
+
return new Points(buff, material);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
static createVertexMaterial(data: VertexMeshData) {
|
|
38
|
+
return new PointsMaterial({
|
|
39
|
+
size: data.size,
|
|
40
|
+
sizeAttenuation: false,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
static createFaceGeometry(data: FaceMeshData, opacity?: number) {
|
|
45
|
+
const buff = ThreeGeometryFactory.createFaceBufferGeometry(data);
|
|
46
|
+
const material = ThreeGeometryFactory.createMeshMaterial(opacity);
|
|
47
|
+
ThreeGeometryFactory.setColor(buff, data, material);
|
|
48
|
+
|
|
49
|
+
return new Mesh(buff, material);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
static createMeshMaterial(opacity: number | undefined) {
|
|
53
|
+
const material = new MeshLambertMaterial({ side: DoubleSide });
|
|
54
|
+
if (opacity !== undefined) {
|
|
55
|
+
material.transparent = true;
|
|
56
|
+
material.opacity = opacity;
|
|
57
|
+
}
|
|
58
|
+
return material;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
static setColor(
|
|
62
|
+
buffer: BufferGeometry,
|
|
63
|
+
data: { color?: number | number[] },
|
|
64
|
+
material: MeshLambertMaterial | PointsMaterial | LineMaterial | LineBasicMaterial,
|
|
65
|
+
) {
|
|
66
|
+
if (typeof data.color === "number") {
|
|
67
|
+
material.color.set(data.color);
|
|
68
|
+
} else if (Array.isArray(data.color)) {
|
|
69
|
+
material.vertexColors = true;
|
|
70
|
+
buffer.setAttribute("color", new Float32BufferAttribute(data.color, 3));
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
static createFaceBufferGeometry(data: MeshLike) {
|
|
75
|
+
const buff = new BufferGeometry();
|
|
76
|
+
buff.setAttribute("position", new BufferAttribute(data.position, 3));
|
|
77
|
+
buff.setAttribute("normal", new BufferAttribute(data.normal, 3));
|
|
78
|
+
buff.setAttribute("uv", new BufferAttribute(data.uv, 2));
|
|
79
|
+
if (data.index && data.index.length > 0) buff.setIndex(new BufferAttribute(data.index, 1));
|
|
80
|
+
buff.computeBoundingBox();
|
|
81
|
+
return buff;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
static createEdgeGeometry(data: EdgeMeshData) {
|
|
85
|
+
const buff = ThreeGeometryFactory.createEdgeBufferGeometry(data);
|
|
86
|
+
const material = ThreeGeometryFactory.createEdgeMaterial(data);
|
|
87
|
+
ThreeGeometryFactory.setColor(buff, data, material);
|
|
88
|
+
return new LineSegments2(buff, material).computeLineDistances();
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
static createEdgeMaterial(data: EdgeMeshData) {
|
|
92
|
+
const material = new LineMaterial({
|
|
93
|
+
linewidth: data.lineWidth ?? 1,
|
|
94
|
+
polygonOffset: true,
|
|
95
|
+
polygonOffsetFactor: -4,
|
|
96
|
+
polygonOffsetUnits: -4,
|
|
97
|
+
});
|
|
98
|
+
if (data.lineType === LineType.Dash) {
|
|
99
|
+
material.dashed = true;
|
|
100
|
+
material.dashScale = 100;
|
|
101
|
+
material.dashSize = 100;
|
|
102
|
+
material.gapSize = 100;
|
|
103
|
+
}
|
|
104
|
+
return material;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
static createEdgeBufferGeometry(data: EdgeMeshData) {
|
|
108
|
+
const buff = new LineSegmentsGeometry();
|
|
109
|
+
buff.setPositions(data.position);
|
|
110
|
+
buff.computeBoundingBox();
|
|
111
|
+
return buff;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
static createVertexBufferGeometry(data: VertexMeshData) {
|
|
115
|
+
const buff = new BufferGeometry();
|
|
116
|
+
buff.setAttribute("position", new BufferAttribute(data.position, 3));
|
|
117
|
+
buff.computeBoundingBox();
|
|
118
|
+
return buff;
|
|
119
|
+
}
|
|
120
|
+
}
|