@vertexvis/viewer 0.13.2-canary.9 → 0.14.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/dist/cjs/{_commonjsHelpers-537d719a.js → _commonjsHelpers-dcc4cf71.js} +21 -0
- package/dist/cjs/{app-globals-3671e828.js → app-globals-2035678d.js} +1 -1
- package/dist/cjs/{browser.esm-075810bf.js → browser.esm-0bcdc581.js} +1 -1
- package/dist/cjs/{bundle.esm-618a5fe9.js → bundle.esm-22b6f2d6.js} +35 -1
- package/dist/cjs/{config-fb124bac.js → config-c63caa4f.js} +3 -2
- package/dist/cjs/{cursors-d71f6a74.js → cursors-f5d3c9a6.js} +13 -1
- package/dist/cjs/{dom-57ef84e9.js → dom-8d90bfaf.js} +1 -1
- package/dist/cjs/dom-d1bbd67c.js +10 -0
- package/dist/cjs/elementRectObserver-9b28f182.js +25 -0
- package/dist/cjs/entities-9eb7e608.js +41 -0
- package/dist/cjs/{entities-90f1347a.js → entities-e71231d8.js} +4 -4
- package/dist/cjs/{grpc-web-client.umd-60a79aae.js → grpc-web-client.umd-2af20c1b.js} +1 -1
- package/dist/cjs/{index-e100709a.js → index-4138aa2c.js} +1 -0
- package/dist/cjs/{index-3bc6bac0.js → index-b9d13137.js} +1 -1
- package/dist/cjs/index.cjs.js +25 -22
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{mapper-80ee2957.js → mapper-08bbab48.js} +4 -4
- package/dist/cjs/{markup-7f7de5f2.js → markup-f7e61d16.js} +2 -2
- package/dist/cjs/{measurement-f1ae9248.js → measurement-3367e9b7.js} +2 -2
- package/dist/cjs/{model-55abd9ab.js → model-5ca87867.js} +1 -1
- package/dist/cjs/model-a9cfd037.js +246 -0
- package/dist/cjs/{overlays-68e8eff2.js → overlays-b0ba69fd.js} +2 -2
- package/dist/cjs/{png-decoder-076131d8.js → png-decoder-ef097f37.js} +2 -2
- package/dist/cjs/{results-e9496869.js → results-178e89a3.js} +1 -1
- package/dist/cjs/{scene-92728420.js → scene-b6b78909.js} +49 -12
- package/dist/cjs/{stencil-a664cd10.js → stencil-ef19638e.js} +5 -1
- package/dist/cjs/{streamAttributes-81eb52f2.js → streamAttributes-c343bdc8.js} +1993 -78
- package/dist/cjs/utils-78928e4e.js +162 -0
- package/dist/cjs/{utils-6397efca.js → utils-b157b0af.js} +1 -1
- package/dist/cjs/{utils-463cd52e.js → utils-c74b8bf0.js} +1 -1
- package/dist/cjs/vertex-scene-tree-search_3.cjs.entry.js +16 -6
- package/dist/cjs/vertex-scene-tree-table-cell.cjs.entry.js +16 -14
- package/dist/cjs/vertex-scene-tree-table-column.cjs.entry.js +1 -1
- package/dist/cjs/vertex-scene-tree-table-header.cjs.entry.js +1 -1
- package/dist/cjs/vertex-scene-tree-table-resize-divider.cjs.entry.js +3 -3
- package/dist/cjs/vertex-scene-tree-toolbar-group.cjs.entry.js +1 -1
- package/dist/cjs/vertex-scene-tree.cjs.entry.js +154 -27
- package/dist/cjs/vertex-viewer-button_3.cjs.entry.js +3 -3
- package/dist/cjs/vertex-viewer-default-toolbar.cjs.entry.js +1 -1
- package/dist/cjs/{vertex-viewer-dom-element_3.cjs.entry.js → vertex-viewer-dom-element_2.cjs.entry.js} +20 -178
- package/dist/cjs/vertex-viewer-dom-group.cjs.entry.js +191 -0
- package/dist/cjs/vertex-viewer-icon.cjs.entry.js +6 -3
- package/dist/cjs/vertex-viewer-layer.cjs.entry.js +1 -1
- package/dist/cjs/vertex-viewer-markup-arrow_3.cjs.entry.js +49 -196
- package/dist/cjs/vertex-viewer-markup-tool.cjs.entry.js +5 -5
- package/dist/cjs/vertex-viewer-markup.cjs.entry.js +5 -5
- package/dist/cjs/vertex-viewer-measurement-details.cjs.entry.js +8 -7
- package/dist/cjs/vertex-viewer-measurement-distance.cjs.entry.js +16 -15
- package/dist/cjs/vertex-viewer-measurement-line_2.cjs.entry.js +10 -9
- package/dist/cjs/vertex-viewer-measurement-precise.cjs.entry.js +18 -35
- package/dist/cjs/vertex-viewer-measurement-tool.cjs.entry.js +8 -7
- package/dist/cjs/vertex-viewer-measurements.cjs.entry.js +12 -11
- package/dist/cjs/vertex-viewer-pin-group.cjs.entry.js +167 -0
- package/dist/cjs/vertex-viewer-pin-label_2.cjs.entry.js +276 -0
- package/dist/cjs/vertex-viewer-pin-tool.cjs.entry.js +322 -0
- package/dist/cjs/vertex-viewer-transform-widget.cjs.entry.js +13272 -0
- package/dist/cjs/vertex-viewer-view-cube.cjs.entry.js +8 -7
- package/dist/cjs/vertex-viewer.cjs.entry.js +119 -52
- package/dist/cjs/viewer.cjs.js +4 -4
- package/dist/cjs/{viewport-54b1389d.js → viewport-5ca619f7.js} +14 -4
- package/dist/collection/__mocks__/regl-shape.js +6 -0
- package/dist/collection/__mocks__/regl.js +3 -0
- package/dist/collection/collection-manifest.json +5 -0
- package/dist/collection/components/scene-tree/lib/controller.js +17 -5
- package/dist/collection/components/scene-tree/lib/errors.js +7 -1
- package/dist/collection/components/scene-tree/lib/viewer-ops.js +12 -1
- package/dist/collection/components/scene-tree/scene-tree.js +112 -22
- package/dist/collection/components/scene-tree-table-cell/scene-tree-table-cell.css +0 -7
- package/dist/collection/components/scene-tree-table-cell/scene-tree-table-cell.js +34 -12
- package/dist/collection/components/scene-tree-table-layout/scene-tree-table-layout.js +14 -2
- package/dist/collection/components/viewer/viewer.js +79 -14
- package/dist/collection/components/viewer-dom-element/viewer-dom-element.js +32 -4
- package/dist/collection/components/viewer-dom-group/utils.js +3 -2
- package/dist/collection/components/viewer-dom-group/viewer-dom-group.js +30 -2
- package/dist/collection/components/viewer-icon/viewer-icon.js +5 -2
- package/dist/collection/components/viewer-markup/utils.js +3 -2
- package/dist/collection/components/viewer-measurement-details/viewer-measurement-details-results.js +2 -2
- package/dist/collection/components/viewer-pin-group/pin-renderer.js +12 -0
- package/dist/collection/components/viewer-pin-group/utils.js +24 -0
- package/dist/collection/components/viewer-pin-group/viewer-pin-group.css +83 -0
- package/dist/collection/components/viewer-pin-group/viewer-pin-group.js +276 -0
- package/dist/collection/components/viewer-pin-label/utils.js +4 -0
- package/dist/collection/components/viewer-pin-label/viewer-pin-label.css +154 -0
- package/dist/collection/components/viewer-pin-label/viewer-pin-label.js +410 -0
- package/dist/collection/components/viewer-pin-label-line/viewer-pin-label-line.css +36 -0
- package/dist/collection/components/viewer-pin-label-line/viewer-pin-label-line.js +61 -0
- package/dist/collection/components/viewer-pin-tool/viewer-pin-tool.css +9 -0
- package/dist/collection/components/viewer-pin-tool/viewer-pin-tool.js +277 -0
- package/dist/collection/components/viewer-transform-widget/__mocks__/widget.js +21 -0
- package/dist/collection/components/viewer-transform-widget/util.js +78 -0
- package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.css +48 -0
- package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.js +442 -0
- package/dist/collection/components/viewer-transform-widget/widget.js +259 -0
- package/dist/collection/lib/cursors.js +11 -1
- package/dist/collection/lib/interactions/baseInteractionHandler.js +9 -2
- package/dist/collection/lib/interactions/flyToPositionKeyInteraction.js +4 -3
- package/dist/collection/lib/interactions/interactionApi.js +21 -1
- package/dist/collection/lib/interactions/interactionApiOrthographic.js +18 -1
- package/dist/collection/lib/interactions/mouseInteractionHandler.js +4 -4
- package/dist/collection/lib/interactions/mouseInteractions.js +24 -1
- package/dist/collection/lib/interactions/multiTouchInteractionHandler.js +1 -2
- package/dist/collection/lib/interactions/pointerInteractionHandler.js +3 -3
- package/dist/collection/lib/mappers/streamAttributes.js +4 -2
- package/dist/collection/lib/pins/controller.js +100 -0
- package/dist/collection/lib/pins/interactions.js +183 -0
- package/dist/collection/lib/pins/model.js +136 -0
- package/dist/collection/lib/rendering/canvas.js +6 -28
- package/dist/collection/lib/scenes/camera.js +34 -2
- package/dist/collection/lib/scenes/colorMaterial.js +8 -8
- package/dist/collection/lib/scenes/mapper.js +2 -1
- package/dist/collection/lib/scenes/queries.js +6 -4
- package/dist/collection/lib/transforms/axis-lines.js +31 -0
- package/dist/collection/lib/transforms/axis-rotation.js +34 -0
- package/dist/collection/lib/transforms/axis-translation.js +30 -0
- package/dist/collection/lib/transforms/controller.js +117 -0
- package/dist/collection/lib/transforms/drawable.js +47 -0
- package/dist/collection/lib/transforms/hits.js +51 -0
- package/dist/collection/lib/transforms/line.js +58 -0
- package/dist/collection/lib/transforms/mesh.js +35 -0
- package/dist/collection/lib/transforms/shape.js +2 -0
- package/dist/collection/lib/transforms/util.js +4 -0
- package/dist/collection/lib/types/depthBuffer.js +2 -2
- package/dist/collection/lib/types/frameCamera.js +4 -6
- package/dist/collection/lib/types/viewport.js +14 -4
- package/dist/custom-elements/index.d.ts +30 -0
- package/dist/custom-elements/index.js +16835 -335
- package/dist/esm/{_commonjsHelpers-9943807e.js → _commonjsHelpers-11ca3be1.js} +20 -1
- package/dist/esm/{app-globals-3a04a531.js → app-globals-40df99a0.js} +1 -1
- package/dist/esm/{browser.esm-e72d80ad.js → browser.esm-1ddb69c9.js} +1 -1
- package/dist/esm/{bundle.esm-8ceccb91.js → bundle.esm-ce2c7ad3.js} +36 -2
- package/dist/esm/{config-fb7cd8ff.js → config-7075833a.js} +3 -2
- package/dist/esm/{cursors-fc2deed7.js → cursors-98b7d89d.js} +12 -2
- package/dist/esm/{dom-2cd18856.js → dom-5b164305.js} +1 -1
- package/dist/esm/dom-be140992.js +8 -0
- package/dist/esm/elementRectObserver-39cf7b95.js +23 -0
- package/dist/esm/{entities-78557270.js → entities-46be90d5.js} +4 -4
- package/dist/esm/entities-ce81dd7f.js +41 -0
- package/dist/esm/{grpc-web-client.umd-5982b7b0.js → grpc-web-client.umd-5409853c.js} +1 -1
- package/dist/esm/{index-10c1495a.js → index-a9fb8318.js} +1 -1
- package/dist/esm/{index-455380d0.js → index-e841d91b.js} +1 -1
- package/dist/esm/index.js +15 -14
- package/dist/esm/index.mjs +15 -14
- package/dist/esm/loader.js +4 -4
- package/dist/esm/loader.mjs +4 -4
- package/dist/esm/{mapper-da36de17.js → mapper-bde6c607.js} +4 -4
- package/dist/esm/{markup-c313d99c.js → markup-8904f2fe.js} +2 -2
- package/dist/esm/{measurement-544b69d5.js → measurement-3f9b0ae0.js} +2 -2
- package/dist/esm/{model-2a34b443.js → model-e54b081f.js} +1 -1
- package/dist/esm/model-f679c493.js +241 -0
- package/dist/esm/{overlays-354e275c.js → overlays-ea2d45ec.js} +2 -2
- package/dist/esm/{png-decoder-07de80d1.js → png-decoder-d4b65417.js} +2 -2
- package/dist/esm/{results-4d0c3568.js → results-3b4df2cf.js} +1 -1
- package/dist/esm/{scene-2bfcce74.js → scene-22ebacfd.js} +49 -12
- package/dist/esm/{stencil-9bf7fb9e.js → stencil-8b20e5a8.js} +5 -2
- package/dist/esm/{streamAttributes-d0b384b3.js → streamAttributes-72a92676.js} +1982 -67
- package/dist/esm/{utils-3ea0acdd.js → utils-0b980078.js} +1 -1
- package/dist/esm/utils-c714e2f7.js +153 -0
- package/dist/esm/{utils-e0941c61.js → utils-f11bd6f7.js} +1 -1
- package/dist/esm/vertex-scene-tree-search_3.entry.js +16 -6
- package/dist/esm/vertex-scene-tree-table-cell.entry.js +16 -14
- package/dist/esm/vertex-scene-tree-table-column.entry.js +1 -1
- package/dist/esm/vertex-scene-tree-table-header.entry.js +1 -1
- package/dist/esm/vertex-scene-tree-table-resize-divider.entry.js +3 -3
- package/dist/esm/vertex-scene-tree-toolbar-group.entry.js +1 -1
- package/dist/esm/vertex-scene-tree.entry.js +154 -27
- package/dist/esm/vertex-viewer-button_3.entry.js +3 -3
- package/dist/esm/vertex-viewer-default-toolbar.entry.js +1 -1
- package/dist/esm/{vertex-viewer-dom-element_3.entry.js → vertex-viewer-dom-element_2.entry.js} +21 -178
- package/dist/esm/vertex-viewer-dom-group.entry.js +187 -0
- package/dist/esm/vertex-viewer-icon.entry.js +6 -3
- package/dist/esm/vertex-viewer-layer.entry.js +1 -1
- package/dist/esm/vertex-viewer-markup-arrow_3.entry.js +8 -155
- package/dist/esm/vertex-viewer-markup-tool.entry.js +5 -5
- package/dist/esm/vertex-viewer-markup.entry.js +5 -5
- package/dist/esm/vertex-viewer-measurement-details.entry.js +8 -7
- package/dist/esm/vertex-viewer-measurement-distance.entry.js +16 -15
- package/dist/esm/vertex-viewer-measurement-line_2.entry.js +10 -9
- package/dist/esm/vertex-viewer-measurement-precise.entry.js +15 -32
- package/dist/esm/vertex-viewer-measurement-tool.entry.js +8 -7
- package/dist/esm/vertex-viewer-measurements.entry.js +12 -11
- package/dist/esm/vertex-viewer-pin-group.entry.js +163 -0
- package/dist/esm/vertex-viewer-pin-label_2.entry.js +271 -0
- package/dist/esm/vertex-viewer-pin-tool.entry.js +318 -0
- package/dist/esm/vertex-viewer-transform-widget.entry.js +13268 -0
- package/dist/esm/vertex-viewer-view-cube.entry.js +8 -7
- package/dist/esm/vertex-viewer.entry.js +118 -51
- package/dist/esm/viewer.js +4 -4
- package/dist/esm/{viewport-5cc7b128.js → viewport-e39e2eba.js} +14 -4
- package/dist/types/__mocks__/regl-shape.d.ts +5 -0
- package/dist/types/__mocks__/regl.d.ts +5 -0
- package/dist/types/components/scene-tree/lib/controller.d.ts +13 -1
- package/dist/types/components/scene-tree/lib/errors.d.ts +3 -1
- package/dist/types/components/scene-tree/lib/viewer-ops.d.ts +1 -0
- package/dist/types/components/scene-tree/scene-tree.d.ts +16 -4
- package/dist/types/components/scene-tree-table-cell/scene-tree-table-cell.d.ts +6 -2
- package/dist/types/components/scene-tree-table-layout/scene-tree-table-layout.d.ts +2 -0
- package/dist/types/components/viewer/viewer.d.ts +13 -1
- package/dist/types/components/viewer-dom-element/viewer-dom-element.d.ts +10 -2
- package/dist/types/components/viewer-dom-group/viewer-dom-group.d.ts +9 -1
- package/dist/types/components/viewer-icon/viewer-icon.d.ts +1 -1
- package/dist/types/components/viewer-pin-group/pin-renderer.d.ts +8 -0
- package/dist/types/components/viewer-pin-group/utils.d.ts +2 -0
- package/dist/types/components/viewer-pin-group/viewer-pin-group.d.ts +49 -0
- package/dist/types/components/viewer-pin-label/utils.d.ts +1 -0
- package/dist/types/components/viewer-pin-label/viewer-pin-label.d.ts +77 -0
- package/dist/types/components/viewer-pin-label-line/viewer-pin-label-line.d.ts +7 -0
- package/dist/types/components/viewer-pin-tool/viewer-pin-tool.d.ts +68 -0
- package/dist/types/components/viewer-transform-widget/__mocks__/widget.d.ts +11 -0
- package/dist/types/components/viewer-transform-widget/util.d.ts +5 -0
- package/dist/types/components/viewer-transform-widget/viewer-transform-widget.d.ts +81 -0
- package/dist/types/components/viewer-transform-widget/widget.d.ts +74 -0
- package/dist/types/components.d.ts +303 -12
- package/dist/types/interfaces.d.ts +1 -0
- package/dist/types/lib/cursors.d.ts +10 -0
- package/dist/types/lib/interactions/baseInteractionHandler.d.ts +4 -3
- package/dist/types/lib/interactions/interactionApi.d.ts +10 -1
- package/dist/types/lib/interactions/interactionApiOrthographic.d.ts +7 -0
- package/dist/types/lib/interactions/mouseInteractionHandler.d.ts +2 -2
- package/dist/types/lib/interactions/mouseInteractions.d.ts +6 -0
- package/dist/types/lib/pins/controller.d.ts +70 -0
- package/dist/types/lib/pins/interactions.d.ts +30 -0
- package/dist/types/lib/pins/model.d.ts +104 -0
- package/dist/types/lib/rendering/canvas.d.ts +1 -2
- package/dist/types/lib/scenes/camera.d.ts +10 -0
- package/dist/types/lib/scenes/colorMaterial.d.ts +1 -0
- package/dist/types/lib/scenes/queries.d.ts +4 -2
- package/dist/types/lib/transforms/axis-lines.d.ts +6 -0
- package/dist/types/lib/transforms/axis-rotation.d.ts +6 -0
- package/dist/types/lib/transforms/axis-translation.d.ts +6 -0
- package/dist/types/lib/transforms/controller.d.ts +17 -0
- package/dist/types/lib/transforms/drawable.d.ts +26 -0
- package/dist/types/lib/transforms/hits.d.ts +10 -0
- package/dist/types/lib/transforms/line.d.ts +31 -0
- package/dist/types/lib/transforms/mesh.d.ts +23 -0
- package/dist/types/lib/transforms/shape.d.ts +3 -0
- package/dist/types/lib/transforms/util.d.ts +2 -0
- package/dist/types/lib/types/frameCamera.d.ts +1 -0
- package/dist/types/lib/types/viewport.d.ts +8 -0
- package/dist/types/regl-shape.d.ts +26 -0
- package/dist/viewer/index.esm.js +1 -1
- package/dist/viewer/p-058632f4.js +4 -0
- package/dist/viewer/p-07aeee89.js +10 -0
- package/dist/viewer/{p-e75bba97.js → p-083f427e.js} +1 -1
- package/dist/viewer/{p-a455ae02.entry.js → p-08eda2b2.entry.js} +1 -1
- package/dist/viewer/{p-bcb66f97.js → p-096e60bd.js} +1 -1
- package/dist/viewer/p-0bc4b3f7.js +4 -0
- package/dist/viewer/p-148c5f1a.js +4 -0
- package/dist/viewer/p-1db9bd1a.entry.js +4 -0
- package/dist/viewer/{p-70ca1ea7.entry.js → p-1f251549.entry.js} +1 -1
- package/dist/viewer/p-29986489.js +4 -0
- package/dist/viewer/{p-cafa57a6.js → p-2e581b2a.js} +1 -1
- package/dist/viewer/{p-d2bcf788.entry.js → p-33daeb09.entry.js} +1 -1
- package/dist/viewer/p-39803f8f.js +4 -0
- package/dist/viewer/p-465a92d9.entry.js +4 -0
- package/dist/viewer/p-4a65ddb3.entry.js +4 -0
- package/dist/viewer/{p-099fe6ca.entry.js → p-4aaf02b4.entry.js} +1 -1
- package/dist/viewer/{p-31658489.entry.js → p-4c3a3738.entry.js} +1 -1
- package/dist/viewer/{p-e38458da.js → p-4d37d97c.js} +1 -1
- package/dist/viewer/p-4fdf8553.entry.js +4 -0
- package/dist/viewer/p-5679f46b.entry.js +4 -0
- package/dist/viewer/p-5809b400.js +4 -0
- package/dist/viewer/{p-fa9a0bed.js → p-58dacdce.js} +1 -1
- package/dist/viewer/p-61a042f0.entry.js +4 -0
- package/dist/viewer/{p-b8774c9c.js → p-6c377932.js} +1 -1
- package/dist/viewer/p-6d379d4a.js +4 -0
- package/dist/viewer/p-6d70b198.entry.js +4 -0
- package/dist/viewer/p-6e7e094a.entry.js +4 -0
- package/dist/viewer/{p-661f0612.js → p-70e5e8a8.js} +1 -1
- package/dist/viewer/p-74102b29.entry.js +32 -0
- package/dist/viewer/p-7a5a9a93.entry.js +4 -0
- package/dist/viewer/p-7c755e0e.entry.js +4 -0
- package/dist/viewer/{p-3a20a038.js → p-92fe4417.js} +1 -1
- package/dist/viewer/{p-7e0328aa.js → p-98e6a50e.js} +1 -1
- package/dist/viewer/{p-388a43f7.js → p-990f98c2.js} +1 -1
- package/dist/viewer/{p-487e054a.js → p-99352cf0.js} +1 -1
- package/dist/viewer/{p-1ca95f9a.entry.js → p-99799a71.entry.js} +1 -1
- package/dist/viewer/p-9acd1b44.js +4 -0
- package/dist/viewer/{p-69058178.js → p-9bcde9c8.js} +1 -1
- package/dist/viewer/{p-5b342e97.js → p-a2ef15e5.js} +1 -1
- package/dist/viewer/{p-61b1097b.entry.js → p-a32cc378.entry.js} +1 -1
- package/dist/viewer/p-a380f0c2.js +4 -0
- package/dist/viewer/{p-41028d3b.entry.js → p-af37b63e.entry.js} +1 -1
- package/dist/viewer/p-b6b727a6.entry.js +4 -0
- package/dist/viewer/p-c2e3312b.js +4 -0
- package/dist/viewer/{p-4717c98e.entry.js → p-c9f91798.entry.js} +1 -1
- package/dist/viewer/p-ca518dcb.entry.js +4 -0
- package/dist/viewer/p-d828fd18.entry.js +4 -0
- package/dist/viewer/p-d996b1d2.entry.js +4 -0
- package/dist/viewer/{p-3f0f83ad.js → p-db01460a.js} +1 -1
- package/dist/viewer/p-db716103.entry.js +4 -0
- package/dist/viewer/p-df8fbe56.js +4 -0
- package/dist/viewer/p-dfe5a97d.js +4 -0
- package/dist/viewer/p-e42cb163.js +4 -0
- package/dist/viewer/p-eb8e5db5.js +4 -0
- package/dist/viewer/{p-46459921.entry.js → p-ebb801c3.entry.js} +1 -1
- package/dist/viewer/p-ebd85d58.entry.js +4 -0
- package/dist/viewer/p-eefae62a.entry.js +4 -0
- package/dist/viewer/viewer.esm.js +1 -1
- package/package.json +12 -10
- package/readme.md +4 -4
- package/dist/viewer/p-0a189e62.entry.js +0 -4
- package/dist/viewer/p-112455b1.js +0 -4
- package/dist/viewer/p-3561d910.js +0 -4
- package/dist/viewer/p-49d36e94.entry.js +0 -4
- package/dist/viewer/p-73a5eacc.entry.js +0 -4
- package/dist/viewer/p-77be081a.js +0 -4
- package/dist/viewer/p-809d09d9.js +0 -4
- package/dist/viewer/p-858bd2c7.entry.js +0 -4
- package/dist/viewer/p-89b66838.entry.js +0 -32
- package/dist/viewer/p-90bb0a1f.entry.js +0 -4
- package/dist/viewer/p-a93a63a9.js +0 -4
- package/dist/viewer/p-b043b076.entry.js +0 -4
- package/dist/viewer/p-b0ac6b3c.entry.js +0 -4
- package/dist/viewer/p-bcde5521.entry.js +0 -4
- package/dist/viewer/p-d1584404.js +0 -4
- package/dist/viewer/p-d32b54cb.js +0 -4
- package/dist/viewer/p-d3a20af4.entry.js +0 -4
- package/dist/viewer/p-d9f99f4d.entry.js +0 -4
- package/dist/viewer/p-ebd55df7.entry.js +0 -4
- package/dist/viewer/p-f0411993.entry.js +0 -4
- package/dist/viewer/p-f482325b.js +0 -10
- package/dist/viewer/p-fad9693e.js +0 -4
- package/dist/viewer/p-ffdeb08c.js +0 -4
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
import { Component, Element,
|
|
2
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
3
|
+
h, Host, Prop, State, Watch, } from '@stencil/core';
|
|
4
|
+
import { PinController } from '../../lib/pins/controller';
|
|
5
|
+
import { PinsInteractionHandler } from '../../lib/pins/interactions';
|
|
6
|
+
import { PinModel, } from '../../lib/pins/model';
|
|
7
|
+
import { getMarkupBoundingClientRect } from '../viewer-markup/dom';
|
|
8
|
+
export class ViewerPinTool {
|
|
9
|
+
constructor() {
|
|
10
|
+
/**
|
|
11
|
+
* The model that contains the entities and outcomes from performing pin annotations
|
|
12
|
+
*/
|
|
13
|
+
this.pinModel = new PinModel();
|
|
14
|
+
this.pins = [];
|
|
15
|
+
/**
|
|
16
|
+
* The type of pin.
|
|
17
|
+
*
|
|
18
|
+
* This property will automatically be set.
|
|
19
|
+
*/
|
|
20
|
+
this.tool = 'pin';
|
|
21
|
+
/**
|
|
22
|
+
* The mode of the pin tool
|
|
23
|
+
*/
|
|
24
|
+
this.mode = 'view';
|
|
25
|
+
this.handleSetProjectionMatrix = () => {
|
|
26
|
+
var _a, _b;
|
|
27
|
+
this.projectionViewMatrix =
|
|
28
|
+
(_b = (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame) === null || _b === void 0 ? void 0 : _b.scene.camera.projectionViewMatrix;
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* @ignore
|
|
33
|
+
*/
|
|
34
|
+
watchModeChange() {
|
|
35
|
+
var _a;
|
|
36
|
+
(_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setToolMode(this.mode);
|
|
37
|
+
this.setupInteractionHandler();
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* @ignore
|
|
41
|
+
*/
|
|
42
|
+
watchTypeChange() {
|
|
43
|
+
var _a;
|
|
44
|
+
(_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setToolType(this.tool);
|
|
45
|
+
this.setupInteractionHandler();
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* @ignore
|
|
49
|
+
*/
|
|
50
|
+
connectedCallback() {
|
|
51
|
+
this.setupInteractionHandler();
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* @ignore
|
|
55
|
+
*/
|
|
56
|
+
componentWillLoad() {
|
|
57
|
+
this.updateViewport();
|
|
58
|
+
this.setupController();
|
|
59
|
+
this.setupInteractionHandler();
|
|
60
|
+
this.pinModel.onEntitiesChanged((entities) => {
|
|
61
|
+
this.pins = entities;
|
|
62
|
+
});
|
|
63
|
+
this.pinModel.onSelectionChange((selectedId) => {
|
|
64
|
+
this.selectedPinId = selectedId;
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
componentDidLoad() {
|
|
68
|
+
this.resizeObserver = new ResizeObserver(() => this.updateViewport());
|
|
69
|
+
this.resizeObserver.observe(this.hostEl);
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* @ignore
|
|
73
|
+
*/
|
|
74
|
+
disconnectedCallback() {
|
|
75
|
+
this.clearInteractionHandler();
|
|
76
|
+
this.clearModelListeners();
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* @ignore
|
|
80
|
+
*/
|
|
81
|
+
handleViewerChanged(newViewer, oldViewer) {
|
|
82
|
+
this.setupInteractionHandler();
|
|
83
|
+
if (oldViewer != null) {
|
|
84
|
+
oldViewer.removeEventListener('frameDrawn', this.handleSetProjectionMatrix);
|
|
85
|
+
}
|
|
86
|
+
if (newViewer != null) {
|
|
87
|
+
newViewer.addEventListener('frameDrawn', this.handleSetProjectionMatrix);
|
|
88
|
+
}
|
|
89
|
+
this.handleSetProjectionMatrix();
|
|
90
|
+
}
|
|
91
|
+
render() {
|
|
92
|
+
return (h(Host, null,
|
|
93
|
+
h("vertex-viewer-dom-renderer", { viewer: this.viewer, drawMode: "2d" }, this.pins.map((pin) => {
|
|
94
|
+
return (h("vertex-viewer-pin-group", { id: `pin-group-${pin.id}`, "data-is-dom-group-element": true, pin: pin, elementBounds: this.elementBounds, pinModel: this.pinModel, pinController: this.pinController, projectionViewMatrix: this.projectionViewMatrix, selected: this.selectedPinId === pin.id }));
|
|
95
|
+
}))));
|
|
96
|
+
}
|
|
97
|
+
setupController() {
|
|
98
|
+
this.pinController = new PinController(this.pinModel, this.mode, this.tool);
|
|
99
|
+
}
|
|
100
|
+
clearInteractionHandler() {
|
|
101
|
+
var _a;
|
|
102
|
+
(_a = this.registeredInteractionHandler) === null || _a === void 0 ? void 0 : _a.then((handler) => handler.dispose());
|
|
103
|
+
this.registeredInteractionHandler = undefined;
|
|
104
|
+
}
|
|
105
|
+
setupInteractionHandler() {
|
|
106
|
+
var _a;
|
|
107
|
+
this.clearInteractionHandler();
|
|
108
|
+
if (this.pinController != null) {
|
|
109
|
+
this.registeredInteractionHandler =
|
|
110
|
+
(_a = this.viewer) === null || _a === void 0 ? void 0 : _a.registerInteractionHandler(new PinsInteractionHandler(this.pinController));
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
clearModelListeners() {
|
|
114
|
+
var _a, _b;
|
|
115
|
+
(_a = this.onEntitiesChangedHandler) === null || _a === void 0 ? void 0 : _a.dispose();
|
|
116
|
+
this.onEntitiesChangedHandler = undefined;
|
|
117
|
+
(_b = this.resizeObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
|
|
118
|
+
}
|
|
119
|
+
updateViewport() {
|
|
120
|
+
const rect = getMarkupBoundingClientRect(this.hostEl);
|
|
121
|
+
this.elementBounds = rect;
|
|
122
|
+
}
|
|
123
|
+
static get is() { return "vertex-viewer-pin-tool"; }
|
|
124
|
+
static get encapsulation() { return "shadow"; }
|
|
125
|
+
static get originalStyleUrls() { return {
|
|
126
|
+
"$": ["viewer-pin-tool.css"]
|
|
127
|
+
}; }
|
|
128
|
+
static get styleUrls() { return {
|
|
129
|
+
"$": ["viewer-pin-tool.css"]
|
|
130
|
+
}; }
|
|
131
|
+
static get properties() { return {
|
|
132
|
+
"pinController": {
|
|
133
|
+
"type": "unknown",
|
|
134
|
+
"mutable": true,
|
|
135
|
+
"complexType": {
|
|
136
|
+
"original": "PinController",
|
|
137
|
+
"resolved": "PinController | undefined",
|
|
138
|
+
"references": {
|
|
139
|
+
"PinController": {
|
|
140
|
+
"location": "import",
|
|
141
|
+
"path": "../../lib/pins/controller"
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
},
|
|
145
|
+
"required": false,
|
|
146
|
+
"optional": true,
|
|
147
|
+
"docs": {
|
|
148
|
+
"tags": [],
|
|
149
|
+
"text": "The controller that is responsible for drawing pins and updating the model"
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
"pinModel": {
|
|
153
|
+
"type": "unknown",
|
|
154
|
+
"mutable": false,
|
|
155
|
+
"complexType": {
|
|
156
|
+
"original": "PinModel",
|
|
157
|
+
"resolved": "PinModel",
|
|
158
|
+
"references": {
|
|
159
|
+
"PinModel": {
|
|
160
|
+
"location": "import",
|
|
161
|
+
"path": "../../lib/pins/model"
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
},
|
|
165
|
+
"required": false,
|
|
166
|
+
"optional": false,
|
|
167
|
+
"docs": {
|
|
168
|
+
"tags": [],
|
|
169
|
+
"text": "The model that contains the entities and outcomes from performing pin annotations"
|
|
170
|
+
},
|
|
171
|
+
"defaultValue": "new PinModel()"
|
|
172
|
+
},
|
|
173
|
+
"pins": {
|
|
174
|
+
"type": "unknown",
|
|
175
|
+
"mutable": true,
|
|
176
|
+
"complexType": {
|
|
177
|
+
"original": "Pin[]",
|
|
178
|
+
"resolved": "Pin[]",
|
|
179
|
+
"references": {
|
|
180
|
+
"Pin": {
|
|
181
|
+
"location": "import",
|
|
182
|
+
"path": "../../lib/pins/model"
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
},
|
|
186
|
+
"required": false,
|
|
187
|
+
"optional": false,
|
|
188
|
+
"docs": {
|
|
189
|
+
"tags": [],
|
|
190
|
+
"text": ""
|
|
191
|
+
},
|
|
192
|
+
"defaultValue": "[]"
|
|
193
|
+
},
|
|
194
|
+
"viewer": {
|
|
195
|
+
"type": "unknown",
|
|
196
|
+
"mutable": false,
|
|
197
|
+
"complexType": {
|
|
198
|
+
"original": "HTMLVertexViewerElement",
|
|
199
|
+
"resolved": "HTMLVertexViewerElement | undefined",
|
|
200
|
+
"references": {
|
|
201
|
+
"HTMLVertexViewerElement": {
|
|
202
|
+
"location": "global"
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
},
|
|
206
|
+
"required": false,
|
|
207
|
+
"optional": true,
|
|
208
|
+
"docs": {
|
|
209
|
+
"tags": [],
|
|
210
|
+
"text": "The viewer that this component is bound to. This is automatically assigned\nif added to the light-dom of a parent viewer element."
|
|
211
|
+
}
|
|
212
|
+
},
|
|
213
|
+
"tool": {
|
|
214
|
+
"type": "string",
|
|
215
|
+
"mutable": true,
|
|
216
|
+
"complexType": {
|
|
217
|
+
"original": "ViewerPinToolType",
|
|
218
|
+
"resolved": "\"pin\" | \"pin-label\"",
|
|
219
|
+
"references": {
|
|
220
|
+
"ViewerPinToolType": {
|
|
221
|
+
"location": "import",
|
|
222
|
+
"path": "../../lib/pins/model"
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
},
|
|
226
|
+
"required": false,
|
|
227
|
+
"optional": false,
|
|
228
|
+
"docs": {
|
|
229
|
+
"tags": [],
|
|
230
|
+
"text": "The type of pin.\n\nThis property will automatically be set."
|
|
231
|
+
},
|
|
232
|
+
"attribute": "tool",
|
|
233
|
+
"reflect": false,
|
|
234
|
+
"defaultValue": "'pin'"
|
|
235
|
+
},
|
|
236
|
+
"mode": {
|
|
237
|
+
"type": "string",
|
|
238
|
+
"mutable": true,
|
|
239
|
+
"complexType": {
|
|
240
|
+
"original": "ViewerPinToolMode",
|
|
241
|
+
"resolved": "\"edit\" | \"view\"",
|
|
242
|
+
"references": {
|
|
243
|
+
"ViewerPinToolMode": {
|
|
244
|
+
"location": "import",
|
|
245
|
+
"path": "../../lib/pins/model"
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
},
|
|
249
|
+
"required": false,
|
|
250
|
+
"optional": false,
|
|
251
|
+
"docs": {
|
|
252
|
+
"tags": [],
|
|
253
|
+
"text": "The mode of the pin tool"
|
|
254
|
+
},
|
|
255
|
+
"attribute": "mode",
|
|
256
|
+
"reflect": false,
|
|
257
|
+
"defaultValue": "'view'"
|
|
258
|
+
}
|
|
259
|
+
}; }
|
|
260
|
+
static get states() { return {
|
|
261
|
+
"selectedPinId": {},
|
|
262
|
+
"elementBounds": {},
|
|
263
|
+
"projectionViewMatrix": {}
|
|
264
|
+
}; }
|
|
265
|
+
static get elementRef() { return "hostEl"; }
|
|
266
|
+
static get watchers() { return [{
|
|
267
|
+
"propName": "mode",
|
|
268
|
+
"methodName": "watchModeChange"
|
|
269
|
+
}, {
|
|
270
|
+
"propName": "tool",
|
|
271
|
+
"methodName": "watchTypeChange"
|
|
272
|
+
}, {
|
|
273
|
+
"propName": "viewer",
|
|
274
|
+
"methodName": "handleViewerChanged"
|
|
275
|
+
}]; }
|
|
276
|
+
}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2VyLXBpbi10b29sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdmlld2VyLXBpbi10b29sL3ZpZXdlci1waW4tdG9vbC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxPQUFPO0FBQ1AsNkRBQTZEO0FBQzdELENBQUMsRUFDRCxJQUFJLEVBQ0osSUFBSSxFQUNKLEtBQUssRUFDTCxLQUFLLEdBQ04sTUFBTSxlQUFlLENBQUM7QUFJdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzFELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3JFLE9BQU8sRUFFTCxRQUFRLEdBR1QsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQU9uRSxNQUFNLE9BQU8sYUFBYTtFQUwxQjtJQVlFOztPQUVHO0lBRUksYUFBUSxHQUFhLElBQUksUUFBUSxFQUFFLENBQUM7SUFHcEMsU0FBSSxHQUFVLEVBQUUsQ0FBQztJQVl4Qjs7OztPQUlHO0lBRUksU0FBSSxHQUFzQixLQUFLLENBQUM7SUFFdkM7O09BRUc7SUFFSSxTQUFJLEdBQXNCLE1BQU0sQ0FBQztJQStGaEMsOEJBQXlCLEdBQUcsR0FBUyxFQUFFOztNQUM3QyxJQUFJLENBQUMsb0JBQW9CO1FBQ3ZCLE1BQUEsTUFBQSxJQUFJLENBQUMsTUFBTSwwQ0FBRSxLQUFLLDBDQUFFLEtBQUssQ0FBQyxNQUFNLENBQUMsb0JBQW9CLENBQUM7SUFDMUQsQ0FBQyxDQUFDO0dBdURIO0VBeklDOztLQUVHO0VBRU8sZUFBZTs7SUFDdkIsTUFBQSxJQUFJLENBQUMsYUFBYSwwQ0FBRSxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzNDLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO0VB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
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
const mockTransformWidgetConstructor = jest.fn();
|
|
2
|
+
const mockBoundsContainsPoint = jest.fn();
|
|
3
|
+
const mockOnHoveredChanged = jest.fn();
|
|
4
|
+
const mockUpdateTransform = jest.fn();
|
|
5
|
+
const mockUpdateFrame = jest.fn();
|
|
6
|
+
const mockUpdateCursor = jest.fn();
|
|
7
|
+
const mockUpdateColors = jest.fn();
|
|
8
|
+
const mockUpdateDimensions = jest.fn();
|
|
9
|
+
export class TransformWidget {
|
|
10
|
+
constructor(...args) {
|
|
11
|
+
this.boundsContainsPoint = mockBoundsContainsPoint;
|
|
12
|
+
this.onHoveredChanged = mockOnHoveredChanged;
|
|
13
|
+
this.updateTransform = mockUpdateTransform;
|
|
14
|
+
this.updateFrame = mockUpdateFrame;
|
|
15
|
+
this.updateCursor = mockUpdateCursor;
|
|
16
|
+
this.updateColors = mockUpdateColors;
|
|
17
|
+
this.updateDimensions = mockUpdateDimensions;
|
|
18
|
+
mockTransformWidgetConstructor(...args);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvdmlld2VyLXRyYW5zZm9ybS13aWRnZXQvX19tb2Nrc19fL3dpZGdldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLDhCQUE4QixHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztBQUNqRCxNQUFNLHVCQUF1QixHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztBQUMxQyxNQUFNLG9CQUFvQixHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztBQUN2QyxNQUFNLG1CQUFtQixHQUFHLElBQUksQ0FBQyxFQUFFLEVBQUUsQ0FBQztBQUN0QyxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7QUFDbEMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7QUFDbkMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7QUFDbkMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUM7QUFFdkMsTUFBTSxPQUFPLGVBQWU7RUFTMUIsWUFBbUIsR0FBRyxJQUFlO0lBUjlCLHdCQUFtQixHQUFHLHVCQUF1QixDQUFDO0lBQzlDLHFCQUFnQixHQUFHLG9CQUFvQixDQUFDO0lBQ3hDLG9CQUFlLEdBQUcsbUJBQW1CLENBQUM7SUFDdEMsZ0JBQVcsR0FBRyxlQUFlLENBQUM7SUFDOUIsaUJBQVksR0FBRyxnQkFBZ0IsQ0FBQztJQUNoQyxpQkFBWSxHQUFHLGdCQUFnQixDQUFDO0lBQ2hDLHFCQUFnQixHQUFHLG9CQUFvQixDQUFDO0lBRzdDLDhCQUE4QixDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7RUFDMUMsQ0FBQztDQUNGIn0=
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { Matrix4, Plane, Point, Quaternion, Ray, Vector3, } from '@vertexvis/geometry';
|
|
2
|
+
export function convertPointToCanvas(point, bounds) {
|
|
3
|
+
return bounds != null
|
|
4
|
+
? Point.create(point.x - bounds.left, point.y - bounds.top)
|
|
5
|
+
: undefined;
|
|
6
|
+
}
|
|
7
|
+
export function convertCanvasPointToWorld(point, frame, viewport, transform) {
|
|
8
|
+
const position = transform != null ? Vector3.fromMatrixPosition(transform) : undefined;
|
|
9
|
+
if (point != null && frame != null && viewport != null && position != null) {
|
|
10
|
+
if (frame.scene.camera.isOrthographic()) {
|
|
11
|
+
const ray = viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera);
|
|
12
|
+
// Offset the point to past the bounding sphere of the model to
|
|
13
|
+
// adjust the position plane location.
|
|
14
|
+
const offsetPoint = Ray.at(Ray.create({
|
|
15
|
+
origin: position,
|
|
16
|
+
direction: frame.scene.camera.direction,
|
|
17
|
+
}), Vector3.magnitude(frame.scene.camera.viewVector) * 2);
|
|
18
|
+
return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, offsetPoint));
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
|
|
22
|
+
return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position));
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
export function computeUpdatedTransform(current, previous, next, viewVector, angle, identifier) {
|
|
28
|
+
switch (identifier) {
|
|
29
|
+
case 'x-translate': {
|
|
30
|
+
return Matrix4.multiply(current, Matrix4.makeTranslation(Vector3.create(computeTranslation(current, previous, next, Vector3.right()), 0, 0)));
|
|
31
|
+
}
|
|
32
|
+
case 'y-translate':
|
|
33
|
+
return Matrix4.multiply(current, Matrix4.makeTranslation(Vector3.create(0, computeTranslation(current, previous, next, Vector3.up()), 0)));
|
|
34
|
+
case 'z-translate':
|
|
35
|
+
return Matrix4.multiply(current, Matrix4.makeTranslation(Vector3.create(0, 0, computeTranslation(current, previous, next, Vector3.back()))));
|
|
36
|
+
case 'x-rotate': {
|
|
37
|
+
const rotation = Quaternion.fromMatrixRotation(current);
|
|
38
|
+
const rotatedRight = Vector3.transformMatrix(Vector3.right(), Matrix4.makeRotation(rotation));
|
|
39
|
+
const rotatedLeft = Vector3.transformMatrix(Vector3.left(), Matrix4.makeRotation(rotation));
|
|
40
|
+
const rotationAxis = Vector3.dot(viewVector, rotatedRight) >
|
|
41
|
+
Vector3.dot(viewVector, rotatedLeft)
|
|
42
|
+
? rotatedRight
|
|
43
|
+
: rotatedLeft;
|
|
44
|
+
return computeRotation(Quaternion.fromAxisAngle(rotationAxis, angle), current);
|
|
45
|
+
}
|
|
46
|
+
case 'y-rotate': {
|
|
47
|
+
const rotation = Quaternion.fromMatrixRotation(current);
|
|
48
|
+
const rotatedUp = Vector3.transformMatrix(Vector3.up(), Matrix4.makeRotation(rotation));
|
|
49
|
+
const rotatedDown = Vector3.transformMatrix(Vector3.down(), Matrix4.makeRotation(rotation));
|
|
50
|
+
const rotationAxis = Vector3.dot(viewVector, rotatedUp) >
|
|
51
|
+
Vector3.dot(viewVector, rotatedDown)
|
|
52
|
+
? rotatedUp
|
|
53
|
+
: rotatedDown;
|
|
54
|
+
return computeRotation(Quaternion.fromAxisAngle(rotationAxis, angle), current);
|
|
55
|
+
}
|
|
56
|
+
case 'z-rotate': {
|
|
57
|
+
const rotation = Quaternion.fromMatrixRotation(current);
|
|
58
|
+
const rotatedForward = Vector3.transformMatrix(Vector3.forward(), Matrix4.makeRotation(rotation));
|
|
59
|
+
const rotatedBack = Vector3.transformMatrix(Vector3.back(), Matrix4.makeRotation(rotation));
|
|
60
|
+
const rotationAxis = Vector3.dot(viewVector, rotatedForward) >
|
|
61
|
+
Vector3.dot(viewVector, rotatedBack)
|
|
62
|
+
? rotatedForward
|
|
63
|
+
: rotatedBack;
|
|
64
|
+
return computeRotation(Quaternion.fromAxisAngle(rotationAxis, angle), current);
|
|
65
|
+
}
|
|
66
|
+
default:
|
|
67
|
+
return current;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function computeTranslation(current, previous, next, direction) {
|
|
71
|
+
const rotatedTranslationAxis = Vector3.transformMatrix(direction, Matrix4.makeRotation(Quaternion.fromMatrixRotation(current)));
|
|
72
|
+
const rotatedDelta = Vector3.multiply(rotatedTranslationAxis, Vector3.subtract(next, previous));
|
|
73
|
+
return rotatedDelta.x + rotatedDelta.y + rotatedDelta.z;
|
|
74
|
+
}
|
|
75
|
+
function computeRotation(rotationAxis, current) {
|
|
76
|
+
return Matrix4.multiply(Matrix4.multiply(Matrix4.multiply(Matrix4.makeTranslation(Vector3.fromMatrixPosition(current)), Matrix4.makeRotation(rotationAxis)), Matrix4.makeTranslation(Vector3.negate(Vector3.fromMatrixPosition(current)))), current);
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3ZpZXdlci10cmFuc2Zvcm0td2lkZ2V0L3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFVBQVUsRUFDVixHQUFHLEVBQ0gsT0FBTyxHQUNSLE1BQU0scUJBQXFCLENBQUM7QUFJN0IsTUFBTSxVQUFVLG9CQUFvQixDQUNsQyxLQUFrQixFQUNsQixNQUFnQjtFQUVoQixPQUFPLE1BQU0sSUFBSSxJQUFJO0lBQ25CLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUM7SUFDM0QsQ0FBQyxDQUFDLFNBQVMsQ0FBQztBQUNoQixDQUFDO0FBRUQsTUFBTSxVQUFVLHlCQUF5QixDQUN2QyxLQUFtQixFQUNuQixLQUFhLEVBQ2IsUUFBbUIsRUFDbkIsU0FBMkI7RUFFM0IsTUFBTSxRQUFRLEdBQ1osU0FBUyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7RUFFeEUsSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLEtBQUssSUFBSSxJQUFJLElBQUksUUFBUSxJQUFJLElBQUksSUFBSSxRQUFRLElBQUksSUFBSSxFQUFFO0lBQzFFLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxFQUFFLEVBQUU7TUFDdkMsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLCtCQUErQixDQUNsRCxLQUFLLEVBQ0wsS0FBSyxDQUFDLEtBQUssRUFDWCxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FDbkIsQ0FBQztNQUNGLCtEQUEr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
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
:host {
|
|
2
|
+
position: absolute;
|
|
3
|
+
top: 0;
|
|
4
|
+
left: 0;
|
|
5
|
+
width: 100%;
|
|
6
|
+
height: 100%;
|
|
7
|
+
pointer-events: none;
|
|
8
|
+
/**
|
|
9
|
+
* @prop --viewer-transform-widget-x-axis-arrow-color: A CSS color for the arrow
|
|
10
|
+
* at the end of the X axis on this widget. Defaults to `#ea3324`.
|
|
11
|
+
*/
|
|
12
|
+
--viewer-transform-widget-x-axis-arrow-color: var(--x-axis-color);
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* @prop --viewer-transform-widget-y-axis-arrow-color: A CSS color for the arrow
|
|
16
|
+
* at the end of the Y axis on this widget. Defaults to `#4faf32`.
|
|
17
|
+
*/
|
|
18
|
+
--viewer-transform-widget-y-axis-arrow-color: var(--y-axis-color);
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @prop --viewer-transform-widget-z-axis-arrow-color: A CSS color for the arrow
|
|
22
|
+
* at the end of the Z axis on this widget. Defaults to `#0000ff`.
|
|
23
|
+
*/
|
|
24
|
+
--viewer-transform-widget-z-axis-arrow-color: var(--z-axis-color);
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* @prop --viewer-transform-widget-hovered-arrow-color: A CSS color for the arrow
|
|
29
|
+
* when it is hovered. Defaults to `#ffff00`.
|
|
30
|
+
*/
|
|
31
|
+
--viewer-transform-widget-hovered-arrow-color: #ffff00;
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* @prop --viewer-transform-widget-disabled-arrow-color: A CSS color for the arrow
|
|
35
|
+
* when it is disabled. Defaults to `#cccccc`.
|
|
36
|
+
*/
|
|
37
|
+
--viewer-transform-widget-disabled-arrow-color: #cccccc;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.widget {
|
|
41
|
+
position: absolute;
|
|
42
|
+
top: 0;
|
|
43
|
+
left: 0;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.widget.hovered {
|
|
47
|
+
pointer-events: auto;
|
|
48
|
+
}
|