@vertexvis/viewer 0.13.2-canary.44 → 0.13.2-canary.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/cjs/index.cjs.js +1 -1
  2. package/dist/cjs/vertex-viewer-dom-element_2.cjs.entry.js +1 -1
  3. package/dist/cjs/vertex-viewer-measurement-distance.cjs.entry.js +1 -1
  4. package/dist/cjs/vertex-viewer-pin-group.cjs.entry.js +1 -1
  5. package/dist/cjs/vertex-viewer-transform-widget.cjs.entry.js +61 -17
  6. package/dist/cjs/vertex-viewer.cjs.entry.js +1 -1
  7. package/dist/cjs/{viewport-a259d895.js → viewport-aeb8a3f3.js} +13 -3
  8. package/dist/collection/components/viewer-transform-widget/util.js +15 -4
  9. package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.js +5 -3
  10. package/dist/collection/components/viewer-transform-widget/widget.js +25 -5
  11. package/dist/collection/lib/transforms/hits.js +12 -4
  12. package/dist/collection/lib/transforms/mesh.js +6 -3
  13. package/dist/collection/lib/types/viewport.js +14 -4
  14. package/dist/custom-elements/index.js +73 -19
  15. package/dist/esm/index.js +1 -1
  16. package/dist/esm/index.mjs +1 -1
  17. package/dist/esm/vertex-viewer-dom-element_2.entry.js +1 -1
  18. package/dist/esm/vertex-viewer-measurement-distance.entry.js +1 -1
  19. package/dist/esm/vertex-viewer-pin-group.entry.js +1 -1
  20. package/dist/esm/vertex-viewer-transform-widget.entry.js +62 -18
  21. package/dist/esm/vertex-viewer.entry.js +1 -1
  22. package/dist/esm/{viewport-7421cd5c.js → viewport-7e612d0d.js} +13 -3
  23. package/dist/types/components/viewer-transform-widget/widget.d.ts +2 -0
  24. package/dist/types/lib/transforms/mesh.d.ts +2 -1
  25. package/dist/types/lib/types/viewport.d.ts +8 -0
  26. package/dist/viewer/index.esm.js +1 -1
  27. package/dist/viewer/p-4d6ea58f.entry.js +4 -0
  28. package/dist/viewer/{p-5d833a6d.entry.js → p-831fe8e4.entry.js} +1 -1
  29. package/dist/viewer/{p-b2a5d2ee.entry.js → p-8897b397.entry.js} +1 -1
  30. package/dist/viewer/p-8cf1d174.js +4 -0
  31. package/dist/viewer/{p-d2d6cf52.entry.js → p-b09a7169.entry.js} +1 -1
  32. package/dist/viewer/{p-10655c8a.entry.js → p-cfc93df0.entry.js} +1 -1
  33. package/dist/viewer/viewer.esm.js +1 -1
  34. package/package.json +7 -7
  35. package/dist/viewer/p-9e675bb3.entry.js +0 -4
  36. package/dist/viewer/p-aebcfde0.js +0 -4
@@ -14,7 +14,7 @@ const results = require('./results-6cab066c.js');
14
14
  const streamAttributes = require('./streamAttributes-07357da5.js');
15
15
  const entities = require('./entities-9eb7e608.js');
16
16
  const markup = require('./markup-d779dd54.js');
17
- const viewport = require('./viewport-a259d895.js');
17
+ const viewport = require('./viewport-aeb8a3f3.js');
18
18
  require('./browser.esm-739c5a8a.js');
19
19
  require('./bundle.esm-3581a1e0.js');
20
20
  require('./mapper-7ee069ef.js');
@@ -10,7 +10,7 @@ const bundle_esm = require('./bundle.esm-3581a1e0.js');
10
10
  const browser_esm = require('./browser.esm-739c5a8a.js');
11
11
  require('./streamAttributes-07357da5.js');
12
12
  require('./entities-9eb7e608.js');
13
- const viewport = require('./viewport-a259d895.js');
13
+ const viewport = require('./viewport-aeb8a3f3.js');
14
14
  require('./_commonjsHelpers-dcc4cf71.js');
15
15
 
16
16
  const viewerDomElementCss = ":host{position:absolute;pointer-events:none}:host(:not([interactions-off]))>*{pointer-events:auto}";
@@ -17,7 +17,7 @@ const model = require('./model-2dbabec1.js');
17
17
  const overlays = require('./overlays-bac05f94.js');
18
18
  const results = require('./results-6cab066c.js');
19
19
  require('./entities-9eb7e608.js');
20
- const viewport = require('./viewport-a259d895.js');
20
+ const viewport = require('./viewport-aeb8a3f3.js');
21
21
  const browser_esm = require('./browser.esm-739c5a8a.js');
22
22
  const utils = require('./utils-1bfe6fec.js');
23
23
  const index$1 = require('./index-b9d13137.js');
@@ -12,7 +12,7 @@ require('./mapper-7ee069ef.js');
12
12
  require('./grpc-web-client.umd-2af20c1b.js');
13
13
  require('./streamAttributes-07357da5.js');
14
14
  require('./entities-9eb7e608.js');
15
- const viewport = require('./viewport-a259d895.js');
15
+ const viewport = require('./viewport-aeb8a3f3.js');
16
16
  const model = require('./model-1fb38025.js');
17
17
  const utils = require('./utils-cfcdeea5.js');
18
18
  const index$1 = require('./index-b9d13137.js');
@@ -13,7 +13,7 @@ const browser_esm = require('./browser.esm-739c5a8a.js');
13
13
  const _commonjsHelpers = require('./_commonjsHelpers-dcc4cf71.js');
14
14
  require('./streamAttributes-07357da5.js');
15
15
  require('./entities-9eb7e608.js');
16
- const viewport = require('./viewport-a259d895.js');
16
+ const viewport = require('./viewport-aeb8a3f3.js');
17
17
 
18
18
  class TransformController {
19
19
  constructor(stream) {
@@ -104,9 +104,20 @@ function convertPointToCanvas(point, bounds) {
104
104
  }
105
105
  function convertCanvasPointToWorld(point, frame, viewport, position) {
106
106
  if (point != null && frame != null && viewport != null && position != null) {
107
- const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
108
- const positionPlane = bundle_esm.plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position);
109
- return bundle_esm.ray.intersectPlane(ray, positionPlane);
107
+ if (frame.scene.camera.isOrthographic()) {
108
+ const ray = viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera);
109
+ // Offset the point to past the bounding sphere of the model to
110
+ // adjust the position plane location.
111
+ const offsetPoint = bundle_esm.ray.at(bundle_esm.ray.create({
112
+ origin: position,
113
+ direction: frame.scene.camera.direction,
114
+ }), bundle_esm.vector3.magnitude(frame.scene.camera.viewVector) * 2);
115
+ return bundle_esm.ray.intersectPlane(ray, bundle_esm.plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, offsetPoint));
116
+ }
117
+ else {
118
+ const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
119
+ return bundle_esm.ray.intersectPlane(ray, bundle_esm.plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position));
120
+ }
110
121
  }
111
122
  return undefined;
112
123
  }
@@ -12464,13 +12475,16 @@ class TriangleMesh extends Mesh {
12464
12475
  : browser_esm.color.toHexString(outlineColor), typeof fillColor === 'string' ? fillColor : browser_esm.color.toHexString(fillColor), shapeProps);
12465
12476
  }
12466
12477
  }
12467
- function computeMesh2dBounds(...meshes) {
12478
+ function computeMesh2dBounds(viewport, ...meshes) {
12468
12479
  let min = bundle_esm.point.create(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);
12469
12480
  let max = bundle_esm.point.create();
12470
12481
  meshes
12471
12482
  .filter((m) => m.points.valid)
12472
12483
  .map((m) => {
12473
- m.points.toArray().forEach((pt) => {
12484
+ m.points
12485
+ .toArray()
12486
+ .map((pt) => viewport.transformNdcPointToViewport(pt))
12487
+ .forEach((pt) => {
12474
12488
  min = bundle_esm.point.create(Math.min(pt.x, min.x), Math.min(pt.y, min.y));
12475
12489
  max = bundle_esm.point.create(Math.max(pt.x, max.x), Math.max(pt.y, max.y));
12476
12490
  });
@@ -12513,13 +12527,17 @@ function computeArrowNdcValues(widgetPosition, camera, direction, triangleSize)
12513
12527
  */
12514
12528
  function testTriangleMesh(mesh, frame, viewport, point) {
12515
12529
  var _a;
12516
- const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
12530
+ const ray = frame.scene.camera.isOrthographic()
12531
+ ? viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera)
12532
+ : viewport.transformPointToRay(point, frame.image, frame.scene.camera);
12517
12533
  const edge1 = bundle_esm.vector3.subtract(mesh.points.worldRight, mesh.points.worldLeft);
12518
12534
  const edge2 = bundle_esm.vector3.subtract(mesh.points.worldTip, mesh.points.worldLeft);
12519
12535
  const epsilon = bundle_esm.boundingBox.epsilon((_a = bundle_esm.boundingBox.fromVectors([ray.direction, ray.origin, edge1, edge2])) !== null && _a !== void 0 ? _a : bundle_esm.boundingBox.create(edge1, edge2));
12520
12536
  const p = bundle_esm.vector3.cross(ray.direction, edge2);
12521
12537
  const det = bundle_esm.vector3.dot(edge1, p);
12522
- if (Math.abs(det) < epsilon) {
12538
+ // This check causes a `det` of NaN or 0 to return false
12539
+ // without needing to perform the subsequent calculations.
12540
+ if (!(Math.abs(det) >= epsilon)) {
12523
12541
  return false;
12524
12542
  }
12525
12543
  const t = bundle_esm.vector3.subtract(ray.origin, mesh.points.worldLeft);
@@ -12533,9 +12551,18 @@ function testTriangleMesh(mesh, frame, viewport, point) {
12533
12551
  return false;
12534
12552
  }
12535
12553
  const r = bundle_esm.vector3.dot(edge2, q) / det;
12536
- return !isNaN(r) && r > epsilon;
12537
- }
12538
-
12554
+ // Ignore the case where the computed hit position is negative
12555
+ // if in orthographic to correctly return hit results when close
12556
+ // to the camera.
12557
+ // TODO: revisit with https://vertexvis.atlassian.net/browse/PLAT-1549
12558
+ return !isNaN(r) && (r > 0 || frame.scene.camera.isOrthographic());
12559
+ }
12560
+
12561
+ // Scalar that is used in combination with the camera
12562
+ // components to determine the relative size of the meshes.
12563
+ // This attempts to keep the widget approximately the same
12564
+ // size as zooming occurs.
12565
+ const DEFAULT_MESH_SCALAR = 0.005;
12539
12566
  class TransformWidget {
12540
12567
  constructor(canvasElement, colors = {}) {
12541
12568
  this.canvasElement = canvasElement;
@@ -12563,7 +12590,7 @@ class TransformWidget {
12563
12590
  boundsContainsPoint(point) {
12564
12591
  return (this.bounds != null &&
12565
12592
  this.frame != null &&
12566
- bundle_esm.rectangle.containsPoints(this.bounds, this.viewport.transformScreenPointToNdc(point, this.frame.image)));
12593
+ bundle_esm.rectangle.containsPoints(this.bounds, point));
12567
12594
  }
12568
12595
  updateFrame(frame, updateMeshes = true) {
12569
12596
  this.frame = frame;
@@ -12578,6 +12605,9 @@ class TransformWidget {
12578
12605
  if (cursor != null && this.frame != null) {
12579
12606
  this.updateHovered();
12580
12607
  }
12608
+ else {
12609
+ this.clearHovered();
12610
+ }
12581
12611
  }
12582
12612
  updatePosition(position) {
12583
12613
  var _a;
@@ -12630,7 +12660,9 @@ class TransformWidget {
12630
12660
  const previousHovered = this.hoveredMesh;
12631
12661
  const currentFrame = this.frame;
12632
12662
  if (currentFrame != null) {
12633
- this.hoveredMesh = this.triangleMeshes.find((m) => this.cursor != null
12663
+ this.hoveredMesh = this.triangleMeshes
12664
+ .filter((m) => m.points.valid)
12665
+ .find((m) => this.cursor != null
12634
12666
  ? testTriangleMesh(m, currentFrame, this.viewport, this.cursor)
12635
12667
  : false);
12636
12668
  if (this.hoveredMesh !== previousHovered) {
@@ -12640,6 +12672,14 @@ class TransformWidget {
12640
12672
  }
12641
12673
  }
12642
12674
  }
12675
+ clearHovered() {
12676
+ const previousHovered = this.hoveredMesh;
12677
+ this.hoveredMesh = undefined;
12678
+ if (this.hoveredMesh !== previousHovered) {
12679
+ this.hoveredChanged.emit(this.hoveredMesh);
12680
+ previousHovered.updateFillColor(previousHovered.initialFillColor);
12681
+ }
12682
+ }
12643
12683
  sortMeshes(frame, ...meshes) {
12644
12684
  const compare = (m1, m2) => m1.points.shortestDistanceFrom(frame.scene.camera.position) -
12645
12685
  m2.points.shortestDistanceFrom(frame.scene.camera.position);
@@ -12659,7 +12699,7 @@ class TransformWidget {
12659
12699
  else {
12660
12700
  this.updateMeshes(position, frame);
12661
12701
  }
12662
- this.bounds = computeMesh2dBounds(...this.triangleMeshes);
12702
+ this.bounds = computeMesh2dBounds(this.viewport, ...this.triangleMeshes);
12663
12703
  }
12664
12704
  createMeshes(position, frame) {
12665
12705
  this.reglCommand = regl({
@@ -12694,7 +12734,9 @@ class TransformWidget {
12694
12734
  }
12695
12735
  }
12696
12736
  computeTriangleSize(position, frame) {
12697
- return (bundle_esm.vector3.magnitude(bundle_esm.vector3.subtract(position, frame.scene.camera.position)) * 0.005);
12737
+ return ((frame.scene.camera.isOrthographic()
12738
+ ? frame.scene.camera.fovHeight
12739
+ : bundle_esm.vector3.magnitude(bundle_esm.vector3.subtract(position, frame.scene.camera.position))) * DEFAULT_MESH_SCALAR);
12698
12740
  }
12699
12741
  }
12700
12742
 
@@ -12748,8 +12790,10 @@ let ViewerTransformWidget = class {
12748
12790
  var _a, _b;
12749
12791
  if (this.dragging != null && this.lastWorldPosition != null) {
12750
12792
  const currentWorld = convertCanvasPointToWorld(convertPointToCanvas(bundle_esm.point.create(event.clientX, event.clientY), this.getCanvasBounds()), (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame, (_b = this.viewer) === null || _b === void 0 ? void 0 : _b.viewport, this.currentPosition);
12751
- this.transform(this.lastWorldPosition, currentWorld !== null && currentWorld !== void 0 ? currentWorld : this.lastWorldPosition);
12752
- this.lastWorldPosition = currentWorld;
12793
+ if (currentWorld != null) {
12794
+ this.transform(this.lastWorldPosition, currentWorld);
12795
+ this.lastWorldPosition = currentWorld;
12796
+ }
12753
12797
  }
12754
12798
  };
12755
12799
  this.handleEndTransform = async (event) => {
@@ -15,7 +15,7 @@ const cursors = require('./cursors-6b087455.js');
15
15
  const dom = require('./dom-b82f5a23.js');
16
16
  const scene = require('./scene-7f29039e.js');
17
17
  const entities = require('./entities-9eb7e608.js');
18
- const viewport = require('./viewport-a259d895.js');
18
+ const viewport = require('./viewport-aeb8a3f3.js');
19
19
  require('./_commonjsHelpers-dcc4cf71.js');
20
20
 
21
21
  /**
@@ -37,6 +37,16 @@ class Viewport {
37
37
  static fromDimensions(dimensions) {
38
38
  return new Viewport(dimensions.width, dimensions.height);
39
39
  }
40
+ /**
41
+ * Transforms a normalized device coordinate to a 2D point within the
42
+ * viewport.
43
+ *
44
+ * @param ndc A 2D point in NDC.
45
+ * @returns A 2D point in the coordinate space of the viewport.
46
+ */
47
+ transformNdcPointToViewport(ndc) {
48
+ return bundle_esm.point.create(ndc.x * this.center.x + this.center.x, -ndc.y * this.center.y + this.center.y);
49
+ }
40
50
  /**
41
51
  * Transforms a normalized device coordinate to a 2D point within the
42
52
  * viewport.
@@ -45,7 +55,7 @@ class Viewport {
45
55
  * @returns A 2D point in the coordinate space of the viewport.
46
56
  */
47
57
  transformVectorToViewport(ndc) {
48
- return bundle_esm.point.create(ndc.x * this.center.x + this.center.x, -ndc.y * this.center.y + this.center.y);
58
+ return this.transformNdcPointToViewport(ndc);
49
59
  }
50
60
  /**
51
61
  * Transforms a world point to 2D point in viewport space.
@@ -133,9 +143,9 @@ class Viewport {
133
143
  */
134
144
  transformPointToOrthographicRay(pt, image, camera) {
135
145
  const ndc = this.transformScreenPointToNdc(pt, image);
136
- const world = bundle_esm.vector3.transformNdcToWorldSpace(bundle_esm.vector3.create(ndc.x, ndc.y, 0.5), camera.worldMatrix, camera.projectionMatrixInverse);
146
+ const origin = bundle_esm.vector3.transformNdcToWorldSpace(bundle_esm.vector3.create(ndc.x, ndc.y, 0), camera.worldMatrix, camera.projectionMatrixInverse);
137
147
  return bundle_esm.ray.create({
138
- origin: world,
148
+ origin,
139
149
  direction: bundle_esm.vector3.normalize(camera.viewVector),
140
150
  });
141
151
  }
@@ -6,9 +6,20 @@ export function convertPointToCanvas(point, bounds) {
6
6
  }
7
7
  export function convertCanvasPointToWorld(point, frame, viewport, position) {
8
8
  if (point != null && frame != null && viewport != null && position != null) {
9
- const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
10
- const positionPlane = Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position);
11
- return Ray.intersectPlane(ray, positionPlane);
9
+ if (frame.scene.camera.isOrthographic()) {
10
+ const ray = viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera);
11
+ // Offset the point to past the bounding sphere of the model to
12
+ // adjust the position plane location.
13
+ const offsetPoint = Ray.at(Ray.create({
14
+ origin: position,
15
+ direction: frame.scene.camera.direction,
16
+ }), Vector3.magnitude(frame.scene.camera.viewVector) * 2);
17
+ return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, offsetPoint));
18
+ }
19
+ else {
20
+ const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
21
+ return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position));
22
+ }
12
23
  }
13
24
  return undefined;
14
25
  }
@@ -24,4 +35,4 @@ export function computeUpdatedPosition(current, previous, next, identifier) {
24
35
  return current;
25
36
  }
26
37
  }
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3ZpZXdlci10cmFuc2Zvcm0td2lkZ2V0L3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBSWpFLE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsS0FBa0IsRUFDbEIsTUFBZ0I7RUFFaEIsT0FBTyxNQUFNLElBQUksSUFBSTtJQUNuQixDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDO0lBQzNELENBQUMsQ0FBQyxTQUFTLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSx5QkFBeUIsQ0FDdkMsS0FBbUIsRUFDbkIsS0FBYSxFQUNiLFFBQW1CLEVBQ25CLFFBQTBCO0VBRTFCLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLFFBQVEsSUFBSSxJQUFJLElBQUksUUFBUSxJQUFJLElBQUksRUFBRTtJQUMxRSxNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsbUJBQW1CLENBQ3RDLEtBQUssRUFDTCxLQUFLLENBQUMsS0FBSyxFQUNYLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUNuQixDQUFDO0lBQ0YsTUFBTSxhQUFhLEdBQUcsS0FBSyxDQUFDLDBCQUEwQixDQUNwRCxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQzVCLFFBQVEsQ0FDVCxDQUFDO0lBRUYsT0FBTyxHQUFHLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxhQUFhLENBQUMsQ0FBQztHQUMvQztFQUNELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUM7QUFFRCxNQUFNLFVBQVUsc0JBQXNCLENBQ3BDLE9BQXdCLEVBQ3hCLFFBQXlCLEVBQ3pCLElBQXFCLEVBQ3JCLFVBQWtCO0VBRWxCLFFBQVEsVUFBVSxFQUFFO0lBQ2xCLEtBQUssYUFBYTtNQUNoQix1Q0FDSyxPQUFPLEtBQ1YsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxJQUNqRDtJQUNKLEtBQUssYUFBYTtNQUNoQix1Q0FDSyxPQUFPLEtBQ1YsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxJQUNqRDtJQUNKLEtBQUssYUFBYTtNQUNoQix1Q0FDSyxPQUFPLEtBQ1YsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxJQUNqRDtJQUNKO01BQ0UsT0FBTyxPQUFPLENBQUM7R0FDbEI7QUFDSCxDQUFDIn0=
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3ZpZXdlci10cmFuc2Zvcm0td2lkZ2V0L3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBSWpFLE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsS0FBa0IsRUFDbEIsTUFBZ0I7RUFFaEIsT0FBTyxNQUFNLElBQUksSUFBSTtJQUNuQixDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDO0lBQzNELENBQUMsQ0FBQyxTQUFTLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSx5QkFBeUIsQ0FDdkMsS0FBbUIsRUFDbkIsS0FBYSxFQUNiLFFBQW1CLEVBQ25CLFFBQTBCO0VBRTFCLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLFFBQVEsSUFBSSxJQUFJLElBQUksUUFBUSxJQUFJLElBQUksRUFBRTtJQUMxRSxJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBRSxFQUFFO01BQ3ZDLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQywrQkFBK0IsQ0FDbEQsS0FBSyxFQUNMLEtBQUssQ0FBQyxLQUFLLEVBQ1gsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQ25CLENBQUM7TUFDRiwrREFBK0Q7TUFDL0Qsc0NBQXNDO01BQ3RDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQ3hCLEdBQUcsQ0FBQyxNQUFNLENBQUM7UUFDVCxNQUFNLEVBQUUsUUFBUTtRQUNoQixTQUFTLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUztPQUN4QyxDQUFDLEVBQ0YsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQ3JELENBQUM7TUFFRixPQUFPLEdBQUcsQ0FBQyxjQUFjLENBQ3ZCLEdBQUcsRUFDSCxLQUFLLENBQUMsMEJBQTBCLENBQzlCLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFDNUIsV0FBVyxDQUNaLENBQ0YsQ0FBQztLQUNIO1NBQU07TUFDTCxNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsbUJBQW1CLENBQ3RDLEtBQUssRUFDTCxLQUFLLENBQUMsS0FBSyxFQUNYLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUNuQixDQUFDO01BRUYsT0FBTyxHQUFHLENBQUMsY0FBYyxDQUN2QixHQUFHLEVBQ0gsS0FBSyxDQUFDLDBCQUEwQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FDekUsQ0FBQztLQUNIO0dBQ0Y7RUFDRCxPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxPQUF3QixFQUN4QixRQUF5QixFQUN6QixJQUFxQixFQUNyQixVQUFrQjtFQUVsQixRQUFRLFVBQVUsRUFBRTtJQUNsQixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSjtNQUNFLE9BQU8sT0FBTyxDQUFDO0dBQ2xCO0FBQ0gsQ0FBQyJ9
@@ -51,8 +51,10 @@ export class ViewerTransformWidget {
51
51
  var _a, _b;
52
52
  if (this.dragging != null && this.lastWorldPosition != null) {
53
53
  const currentWorld = convertCanvasPointToWorld(convertPointToCanvas(Point.create(event.clientX, event.clientY), this.getCanvasBounds()), (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame, (_b = this.viewer) === null || _b === void 0 ? void 0 : _b.viewport, this.currentPosition);
54
- this.transform(this.lastWorldPosition, currentWorld !== null && currentWorld !== void 0 ? currentWorld : this.lastWorldPosition);
55
- this.lastWorldPosition = currentWorld;
54
+ if (currentWorld != null) {
55
+ this.transform(this.lastWorldPosition, currentWorld);
56
+ this.lastWorldPosition = currentWorld;
57
+ }
56
58
  }
57
59
  };
58
60
  this.handleEndTransform = async (event) => {
@@ -344,4 +346,4 @@ export class ViewerTransformWidget {
344
346
  "methodName": "handlePositionChanged"
345
347
  }]; }
346
348
  }
347
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-transform-widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/viewer-transform-widget.tsx"],"names":[],"mappings":"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"}
349
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-transform-widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/viewer-transform-widget.tsx"],"names":[],"mappings":"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"}
@@ -7,6 +7,11 @@ import { xAxisArrowPositions, yAxisArrowPositions, zAxisArrowPositions, } from '
7
7
  import { testTriangleMesh } from '../../lib/transforms/hits';
8
8
  import { AxisMesh, computeMesh2dBounds, TriangleMesh, } from '../../lib/transforms/mesh';
9
9
  import { Viewport } from '../../lib/types';
10
+ // Scalar that is used in combination with the camera
11
+ // components to determine the relative size of the meshes.
12
+ // This attempts to keep the widget approximately the same
13
+ // size as zooming occurs.
14
+ export const DEFAULT_MESH_SCALAR = 0.005;
10
15
  export class TransformWidget {
11
16
  constructor(canvasElement, colors = {}) {
12
17
  this.canvasElement = canvasElement;
@@ -34,7 +39,7 @@ export class TransformWidget {
34
39
  boundsContainsPoint(point) {
35
40
  return (this.bounds != null &&
36
41
  this.frame != null &&
37
- Rectangle.containsPoints(this.bounds, this.viewport.transformScreenPointToNdc(point, this.frame.image)));
42
+ Rectangle.containsPoints(this.bounds, point));
38
43
  }
39
44
  updateFrame(frame, updateMeshes = true) {
40
45
  this.frame = frame;
@@ -49,6 +54,9 @@ export class TransformWidget {
49
54
  if (cursor != null && this.frame != null) {
50
55
  this.updateHovered();
51
56
  }
57
+ else {
58
+ this.clearHovered();
59
+ }
52
60
  }
53
61
  updatePosition(position) {
54
62
  var _a;
@@ -101,7 +109,9 @@ export class TransformWidget {
101
109
  const previousHovered = this.hoveredMesh;
102
110
  const currentFrame = this.frame;
103
111
  if (currentFrame != null) {
104
- this.hoveredMesh = this.triangleMeshes.find((m) => this.cursor != null
112
+ this.hoveredMesh = this.triangleMeshes
113
+ .filter((m) => m.points.valid)
114
+ .find((m) => this.cursor != null
105
115
  ? testTriangleMesh(m, currentFrame, this.viewport, this.cursor)
106
116
  : false);
107
117
  if (this.hoveredMesh !== previousHovered) {
@@ -111,6 +121,14 @@ export class TransformWidget {
111
121
  }
112
122
  }
113
123
  }
124
+ clearHovered() {
125
+ const previousHovered = this.hoveredMesh;
126
+ this.hoveredMesh = undefined;
127
+ if (this.hoveredMesh !== previousHovered) {
128
+ this.hoveredChanged.emit(this.hoveredMesh);
129
+ previousHovered.updateFillColor(previousHovered.initialFillColor);
130
+ }
131
+ }
114
132
  sortMeshes(frame, ...meshes) {
115
133
  const compare = (m1, m2) => m1.points.shortestDistanceFrom(frame.scene.camera.position) -
116
134
  m2.points.shortestDistanceFrom(frame.scene.camera.position);
@@ -130,7 +148,7 @@ export class TransformWidget {
130
148
  else {
131
149
  this.updateMeshes(position, frame);
132
150
  }
133
- this.bounds = computeMesh2dBounds(...this.triangleMeshes);
151
+ this.bounds = computeMesh2dBounds(this.viewport, ...this.triangleMeshes);
134
152
  }
135
153
  createMeshes(position, frame) {
136
154
  this.reglCommand = regl({
@@ -165,7 +183,9 @@ export class TransformWidget {
165
183
  }
166
184
  }
167
185
  computeTriangleSize(position, frame) {
168
- return (Vector3.magnitude(Vector3.subtract(position, frame.scene.camera.position)) * 0.005);
186
+ return ((frame.scene.camera.isOrthographic()
187
+ ? frame.scene.camera.fovHeight
188
+ : Vector3.magnitude(Vector3.subtract(position, frame.scene.camera.position))) * DEFAULT_MESH_SCALAR);
169
189
  }
170
190
  }
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/widget.ts"],"names":[],"mappings":"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"}
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/widget.ts"],"names":[],"mappings":"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"}
@@ -4,13 +4,17 @@ import { BoundingBox, Vector3 } from '@vertexvis/geometry';
4
4
  */
5
5
  export function testTriangleMesh(mesh, frame, viewport, point) {
6
6
  var _a;
7
- const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
7
+ const ray = frame.scene.camera.isOrthographic()
8
+ ? viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera)
9
+ : viewport.transformPointToRay(point, frame.image, frame.scene.camera);
8
10
  const edge1 = Vector3.subtract(mesh.points.worldRight, mesh.points.worldLeft);
9
11
  const edge2 = Vector3.subtract(mesh.points.worldTip, mesh.points.worldLeft);
10
12
  const epsilon = BoundingBox.epsilon((_a = BoundingBox.fromVectors([ray.direction, ray.origin, edge1, edge2])) !== null && _a !== void 0 ? _a : BoundingBox.create(edge1, edge2));
11
13
  const p = Vector3.cross(ray.direction, edge2);
12
14
  const det = Vector3.dot(edge1, p);
13
- if (Math.abs(det) < epsilon) {
15
+ // This check causes a `det` of NaN or 0 to return false
16
+ // without needing to perform the subsequent calculations.
17
+ if (!(Math.abs(det) >= epsilon)) {
14
18
  return false;
15
19
  }
16
20
  const t = Vector3.subtract(ray.origin, mesh.points.worldLeft);
@@ -24,6 +28,10 @@ export function testTriangleMesh(mesh, frame, viewport, point) {
24
28
  return false;
25
29
  }
26
30
  const r = Vector3.dot(edge2, q) / det;
27
- return !isNaN(r) && r > epsilon;
31
+ // Ignore the case where the computed hit position is negative
32
+ // if in orthographic to correctly return hit results when close
33
+ // to the camera.
34
+ // TODO: revisit with https://vertexvis.atlassian.net/browse/PLAT-1549
35
+ return !isNaN(r) && (r > 0 || frame.scene.camera.isOrthographic());
28
36
  }
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGl0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9oaXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQVMsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFLbEU7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQzlCLElBQWtCLEVBQ2xCLEtBQVksRUFDWixRQUFrQixFQUNsQixLQUFrQjs7RUFFbEIsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLG1CQUFtQixDQUN0QyxLQUFLLEVBQ0wsS0FBSyxDQUFDLEtBQUssRUFDWCxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FDbkIsQ0FBQztFQUVGLE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztFQUM5RSxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFFNUUsTUFBTSxPQUFPLEdBQUcsV0FBVyxDQUFDLE9BQU8sQ0FDakMsTUFBQSxXQUFXLENBQUMsV0FBVyxDQUFDLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxHQUFHLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxtQ0FDaEUsV0FBVyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQ25DLENBQUM7RUFFRixNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7RUFDOUMsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7RUFFbEMsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLE9BQU8sRUFBRTtJQUMzQixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFDOUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRWxDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFO0lBQ2xCLE9BQU8sS0FBSyxDQUFDO0dBQ2Q7RUFFRCxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztFQUNsQyxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRTlDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtJQUN0QixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRXRDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQztBQUNsQyxDQUFDIn0=
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGl0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9oaXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQVMsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFLbEU7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQzlCLElBQWtCLEVBQ2xCLEtBQVksRUFDWixRQUFrQixFQUNsQixLQUFrQjs7RUFFbEIsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxFQUFFO0lBQzdDLENBQUMsQ0FBQyxRQUFRLENBQUMsK0JBQStCLENBQ3RDLEtBQUssRUFDTCxLQUFLLENBQUMsS0FBSyxFQUNYLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUNuQjtJQUNILENBQUMsQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztFQUV6RSxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFDOUUsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0VBRTVFLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQ2pDLE1BQUEsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsR0FBRyxDQUFDLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsbUNBQ2hFLFdBQVcsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUNuQyxDQUFDO0VBRUYsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO0VBQzlDLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO0VBRWxDLHdEQUF3RDtFQUN4RCwwREFBMEQ7RUFDMUQsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxPQUFPLENBQUMsRUFBRTtJQUMvQixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFDOUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRWxDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFO0lBQ2xCLE9BQU8sS0FBSyxDQUFDO0dBQ2Q7RUFFRCxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztFQUNsQyxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRTlDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtJQUN0QixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRXRDLDhEQUE4RDtFQUM5RCxnRUFBZ0U7RUFDaEUsaUJBQWlCO0VBQ2pCLHNFQUFzRTtFQUN0RSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsSUFBSSxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDO0FBQ3JFLENBQUMifQ==
@@ -84,17 +84,20 @@ export class TriangleMesh extends Mesh {
84
84
  : Color.toHexString(outlineColor), typeof fillColor === 'string' ? fillColor : Color.toHexString(fillColor), shapeProps);
85
85
  }
86
86
  }
87
- export function computeMesh2dBounds(...meshes) {
87
+ export function computeMesh2dBounds(viewport, ...meshes) {
88
88
  let min = Point.create(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);
89
89
  let max = Point.create();
90
90
  meshes
91
91
  .filter((m) => m.points.valid)
92
92
  .map((m) => {
93
- m.points.toArray().forEach((pt) => {
93
+ m.points
94
+ .toArray()
95
+ .map((pt) => viewport.transformNdcPointToViewport(pt))
96
+ .forEach((pt) => {
94
97
  min = Point.create(Math.min(pt.x, min.x), Math.min(pt.y, min.y));
95
98
  max = Point.create(Math.max(pt.x, max.x), Math.max(pt.y, max.y));
96
99
  });
97
100
  });
98
101
  return Rectangle.fromPoints(min, max);
99
102
  }
100
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9tZXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUl6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFXM0MsTUFBTSxPQUFnQixJQUFJO0VBT3hCLFlBQ1ksV0FBd0IsRUFDM0IsVUFBa0IsRUFDbEIsTUFBUyxFQUNULFlBQW9CLEVBQ3BCLFNBQWlCLEVBQ2pCLGFBQWtDLEVBQUU7SUFMakMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFDM0IsZUFBVSxHQUFWLFVBQVUsQ0FBUTtJQUNsQixXQUFNLEdBQU4sTUFBTSxDQUFHO0lBQ1QsaUJBQVksR0FBWixZQUFZLENBQVE7SUFDcEIsY0FBUyxHQUFULFNBQVMsQ0FBUTtJQUNqQixlQUFVLEdBQVYsVUFBVSxDQUEwQjtJQUUzQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7SUFFdkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLFlBQVksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzlELGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FDdEMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQ3BDLENBQUM7SUFFRixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsU0FBUyxDQUFDO0lBRWxDLElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLGtCQUN0QyxLQUFLLEVBQUUsYUFBYSxDQUFDLE1BQU0sRUFDM0IsU0FBUyxFQUFFLENBQUMsRUFDWixJQUFJLEVBQUUsTUFBbUIsRUFDekIsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQ3BCLEtBQUssRUFBRSxJQUFJLENBQUMsWUFBWSxJQUNyQixVQUFVLEVBQ2IsQ0FBQztFQUNMLENBQUM7RUFFTSxlQUFlLENBQUMsS0FBNEI7SUFDakQsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFO01BQ2pCLElBQUksQ0FBQyxTQUFTO1FBQ1osT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEU7RUFDSCxDQUFDO0VBRU0sWUFBWSxDQUFDLE1BQVM7SUFDM0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDckIsaUJBQWlCLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTyxDQUN6QyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FDcEMsQ0FBQztFQUNKLENBQUM7Q0FDRjtBQUVELE1BQU0sT0FBTyxjQUFjO0VBQ3pCLFlBQ1MsS0FBYyxFQUNkLFdBQTRCLEVBQzVCLFFBQXlCLEVBQ3pCLE1BQW1CLEVBQ25CLEdBQWdCO0lBSmhCLFVBQUssR0FBTCxLQUFLLENBQVM7SUFDZCxnQkFBVyxHQUFYLFdBQVcsQ0FBaUI7SUFDNUIsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7SUFDekIsV0FBTSxHQUFOLE1BQU0sQ0FBYTtJQUNuQixRQUFHLEdBQUgsR0FBRyxDQUFhO0VBQ3RCLENBQUM7RUFFRyxvQkFBb0IsQ0FBQyxNQUF1QjtJQUNqRCxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUU7T0FDdkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztPQUN2QyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7RUFDOUIsQ0FBQztFQUVNLFlBQVk7SUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0VBQzNDLENBQUM7RUFFTSxPQUFPO0lBQ1osT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0VBQ2pDLENBQUM7Q0FDRjtBQUVELE1BQU0sT0FBTyxRQUFTLFNBQVEsSUFBb0I7RUFDaEQsWUFDRSxXQUF3QixFQUN4QixVQUFrQixFQUNsQixNQUFzQixFQUN0QixlQUFxQyxTQUFTLEVBQzlDLFlBQWtDLFNBQVMsRUFDM0MsYUFBa0MsRUFBRTtJQUVwQyxLQUFLLENBQ0gsV0FBVyxFQUNYLFVBQVUsRUFDVixNQUFNLEVBQ04sT0FBTyxZQUFZLEtBQUssUUFBUTtNQUM5QixDQUFDLENBQUMsWUFBWTtNQUNkLENBQUMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxFQUNuQyxPQUFPLFNBQVMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsRUFDeEUsVUFBVSxDQUNYLENBQUM7RUFDSixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sa0JBQWtCO0VBQzdCLFlBQ1MsS0FBYyxFQUNkLFNBQTBCLEVBQzFCLFNBQTBCLEVBQzFCLFVBQTJCLEVBQzNCLFFBQXlCLEVBQ3pCLElBQWlCLEVBQ2pCLElBQWlCLEVBQ2pCLEtBQWtCLEVBQ2xCLEdBQWdCO0lBUmhCLFVBQUssR0FBTCxLQUFLLENBQVM7SUFDZCxjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUMxQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUMxQixlQUFVLEdBQVYsVUFBVSxDQUFpQjtJQUMzQixhQUFRLEdBQVIsUUFBUSxDQUFpQjtJQUN6QixTQUFJLEdBQUosSUFBSSxDQUFhO0lBQ2pCLFNBQUksR0FBSixJQUFJLENBQWE7SUFDakIsVUFBSyxHQUFMLEtBQUssQ0FBYTtJQUNsQixRQUFHLEdBQUgsR0FBRyxDQUFhO0VBQ3RCLENBQUM7RUFFRyxvQkFBb0IsQ0FBQyxNQUF1QjtJQUNqRCxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUU7T0FDdkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztPQUN2QyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7RUFDOUIsQ0FBQztFQUVNLFlBQVk7SUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztFQUMxRSxDQUFDO0VBRU0sT0FBTztJQUNaLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztFQUNqRSxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sWUFBYSxTQUFRLElBQXdCO0VBQ3hELFlBQ0UsV0FBd0IsRUFDeEIsVUFBa0IsRUFDbEIsTUFBMEIsRUFDMUIsZUFBcUMsU0FBUyxFQUM5QyxZQUFrQyxTQUFTLEVBQzNDLGFBQWtDLEVBQUU7SUFFcEMsS0FBSyxDQUNILFdBQVcsRUFDWCxVQUFVLEVBQ1YsTUFBTSxFQUNOLE9BQU8sWUFBWSxLQUFLLFFBQVE7TUFDOUIsQ0FBQyxDQUFDLFlBQVk7TUFDZCxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsRUFDbkMsT0FBTyxTQUFTLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLEVBQ3hFLFVBQVUsQ0FDWCxDQUFDO0VBQ0osQ0FBQztDQUNGO0FBRUQsTUFBTSxVQUFVLG1CQUFtQixDQUFDLEdBQUcsTUFBYztFQUNuRCxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsRUFBRSxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztFQUN6RSxJQUFJLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7RUFFekIsTUFBTTtLQUNILE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7S0FDN0IsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDVCxDQUFDLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLEVBQUUsRUFBRSxFQUFFO01BQ2hDLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO01BQ2pFLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25FLENBQUMsQ0FBQyxDQUFDO0VBQ0wsQ0FBQyxDQUFDLENBQUM7RUFFTCxPQUFPLFNBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3hDLENBQUMifQ==
103
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9tZXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUt6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFXM0MsTUFBTSxPQUFnQixJQUFJO0VBT3hCLFlBQ1ksV0FBd0IsRUFDM0IsVUFBa0IsRUFDbEIsTUFBUyxFQUNULFlBQW9CLEVBQ3BCLFNBQWlCLEVBQ2pCLGFBQWtDLEVBQUU7SUFMakMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFDM0IsZUFBVSxHQUFWLFVBQVUsQ0FBUTtJQUNsQixXQUFNLEdBQU4sTUFBTSxDQUFHO0lBQ1QsaUJBQVksR0FBWixZQUFZLENBQVE7SUFDcEIsY0FBUyxHQUFULFNBQVMsQ0FBUTtJQUNqQixlQUFVLEdBQVYsVUFBVSxDQUEwQjtJQUUzQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7SUFFdkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLFlBQVksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzlELGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FDdEMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQ3BDLENBQUM7SUFFRixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsU0FBUyxDQUFDO0lBRWxDLElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLGtCQUN0QyxLQUFLLEVBQUUsYUFBYSxD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