@cornerstonejs/tools 1.72.6 → 1.73.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (22) hide show
  1. package/dist/cjs/tools/annotation/PlanarFreehandROITool.d.ts +1 -0
  2. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js +15 -2
  3. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  4. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js +32 -0
  5. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -1
  6. package/dist/cjs/tools/displayTools/Contour/contourHandler/handleContourSegmentation.js +1 -1
  7. package/dist/cjs/tools/displayTools/Contour/contourHandler/handleContourSegmentation.js.map +1 -1
  8. package/dist/esm/tools/annotation/PlanarFreehandROITool.js +15 -2
  9. package/dist/esm/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  10. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js +32 -0
  11. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -1
  12. package/dist/esm/tools/displayTools/Contour/contourHandler/handleContourSegmentation.js +1 -1
  13. package/dist/esm/tools/displayTools/Contour/contourHandler/handleContourSegmentation.js.map +1 -1
  14. package/dist/types/tools/annotation/PlanarFreehandROITool.d.ts +1 -0
  15. package/dist/types/tools/annotation/PlanarFreehandROITool.d.ts.map +1 -1
  16. package/dist/types/tools/annotation/planarFreehandROITool/renderMethods.d.ts.map +1 -1
  17. package/dist/umd/index.js +1 -1
  18. package/dist/umd/index.js.map +1 -1
  19. package/package.json +3 -3
  20. package/src/tools/annotation/PlanarFreehandROITool.ts +31 -2
  21. package/src/tools/annotation/planarFreehandROITool/renderMethods.ts +67 -0
  22. package/src/tools/displayTools/Contour/contourHandler/handleContourSegmentation.ts +1 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cornerstonejs/tools",
3
- "version": "1.72.6",
3
+ "version": "1.73.0",
4
4
  "description": "Cornerstone3D Tools",
5
5
  "main": "src/index.ts",
6
6
  "types": "dist/types/index.d.ts",
@@ -29,7 +29,7 @@
29
29
  "webpack:watch": "webpack --mode development --progress --watch --config ./.webpack/webpack.dev.js"
30
30
  },
31
31
  "dependencies": {
32
- "@cornerstonejs/core": "^1.72.6",
32
+ "@cornerstonejs/core": "^1.73.0",
33
33
  "@icr/polyseg-wasm": "0.4.0",
34
34
  "@types/offscreencanvas": "2019.7.3",
35
35
  "comlink": "^4.4.1",
@@ -59,5 +59,5 @@
59
59
  "type": "individual",
60
60
  "url": "https://ohif.org/donate"
61
61
  },
62
- "gitHead": "992f6c69b8f57a3344a1e8ec676376be693ec555"
62
+ "gitHead": "7d9375494668c1b3857c560643e490470d35523d"
63
63
  }
@@ -170,6 +170,12 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
170
170
  annotation: PlanarFreehandROIAnnotation
171
171
  ) => void;
172
172
 
173
+ private renderPointContourWithMarker: (
174
+ enabledElement: Types.IEnabledElement,
175
+ svgDrawingHelper: SVGDrawingHelper,
176
+ annotation: PlanarFreehandROIAnnotation
177
+ ) => void;
178
+
173
179
  constructor(
174
180
  toolProps: PublicToolProps = {},
175
181
  defaultToolProps: ToolProps = {
@@ -242,6 +248,7 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
242
248
  */
243
249
  epsilon: 0.1,
244
250
  },
251
+ displayOnePointAsCrosshairs: false,
245
252
  calculateStats: true,
246
253
  getTextLines: defaultGetTextLines,
247
254
  statsCalculator: BasicStatsCalculator,
@@ -578,7 +585,18 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
578
585
  if (!(isDrawing || isEditingOpen || isEditingClosed)) {
579
586
  // No annotations are currently being modified, so we can just use the
580
587
  // render contour method to render all of them
581
- this.renderContour(enabledElement, svgDrawingHelper, annotation);
588
+ if (
589
+ this.configuration.displayOnePointAsCrosshairs &&
590
+ annotation.data.contour.polyline.length === 1
591
+ ) {
592
+ this.renderPointContourWithMarker(
593
+ enabledElement,
594
+ svgDrawingHelper,
595
+ annotation
596
+ );
597
+ } else {
598
+ this.renderContour(enabledElement, svgDrawingHelper, annotation);
599
+ }
582
600
  } else {
583
601
  // The active annotation will need special rendering treatment. Render all
584
602
  // other annotations not being interacted with using the standard renderContour
@@ -610,7 +628,18 @@ class PlanarFreehandROITool extends ContourSegmentationBaseTool {
610
628
  );
611
629
  }
612
630
  } else {
613
- this.renderContour(enabledElement, svgDrawingHelper, annotation);
631
+ if (
632
+ this.configuration.displayOnePointAsCrosshairs &&
633
+ annotation.data.contour.polyline.length === 1
634
+ ) {
635
+ this.renderPointContourWithMarker(
636
+ enabledElement,
637
+ svgDrawingHelper,
638
+ annotation
639
+ );
640
+ } else {
641
+ this.renderContour(enabledElement, svgDrawingHelper, annotation);
642
+ }
614
643
  }
615
644
 
616
645
  // Todo: return boolean flag for each rendering route in the planar tool.
@@ -407,6 +407,71 @@ function renderOpenContourBeingEdited(
407
407
  );
408
408
  }
409
409
 
410
+ /**
411
+ * Renders a point `PlanarFreehandROIAnnotation` annotation by drawing a circle and a crosshair
412
+ */
413
+
414
+ function renderPointContourWithMarker(
415
+ enabledElement: Types.IEnabledElement,
416
+ svgDrawingHelper: SVGDrawingHelper,
417
+ annotation: PlanarFreehandROIAnnotation
418
+ ): void {
419
+ if (annotation.parentAnnotationUID) {
420
+ return;
421
+ }
422
+ const { viewport } = enabledElement;
423
+ const options = this._getRenderingOptions(enabledElement, annotation);
424
+ const canvasPolyline = annotation.data.contour.polyline.map((worldPos) =>
425
+ viewport.worldToCanvas(worldPos)
426
+ );
427
+ const childContours = getContourHolesDataCanvas(annotation, viewport);
428
+ const polylineUID = '1';
429
+
430
+ const center = canvasPolyline[0];
431
+ const radius = 6;
432
+ const numberOfPoints = 100;
433
+ const circlePoints = [];
434
+
435
+ for (let i = 0; i < numberOfPoints; i++) {
436
+ const angle = (i / numberOfPoints) * 2 * Math.PI;
437
+ const x = center[0] + radius * Math.cos(angle);
438
+ const y = center[1] + radius * Math.sin(angle);
439
+ circlePoints.push([x, y]);
440
+ }
441
+
442
+ const crosshair = [
443
+ [center[0] - radius * 2, center[1]],
444
+ [center[0] + radius * 2, center[1]],
445
+ [center[0], center[1] - radius * 2],
446
+ [center[0], center[1] + radius * 2],
447
+ ] as Types.Point2[];
448
+
449
+ drawPathSvg(
450
+ svgDrawingHelper,
451
+ annotation.annotationUID,
452
+ polylineUID + '-crosshair_v',
453
+ [crosshair[0], crosshair[1]],
454
+ options
455
+ );
456
+
457
+ drawPathSvg(
458
+ svgDrawingHelper,
459
+ annotation.annotationUID,
460
+ polylineUID + '-crosshair_h',
461
+ [crosshair[2], crosshair[3]],
462
+ options
463
+ );
464
+
465
+ const allContours = [circlePoints, ...childContours];
466
+
467
+ drawPathSvg(
468
+ svgDrawingHelper,
469
+ annotation.annotationUID,
470
+ polylineUID,
471
+ allContours,
472
+ options
473
+ );
474
+ }
410
475
  /**
411
476
  * Registers the render methods of various contour states to the tool instance.
412
477
  */
@@ -414,6 +479,8 @@ function registerRenderMethods(toolInstance) {
414
479
  toolInstance.renderContour = renderContour.bind(toolInstance);
415
480
  toolInstance.renderClosedContour = renderClosedContour.bind(toolInstance);
416
481
  toolInstance.renderOpenContour = renderOpenContour.bind(toolInstance);
482
+ toolInstance.renderPointContourWithMarker =
483
+ renderPointContourWithMarker.bind(toolInstance);
417
484
  toolInstance.renderOpenUShapedContour =
418
485
  renderOpenUShapedContour.bind(toolInstance);
419
486
 
@@ -163,7 +163,7 @@ function addContourSetsToElement(
163
163
  highlighted: false,
164
164
  autoGenerated: false,
165
165
  invalidated: false,
166
- isLocked: false,
166
+ isLocked: true,
167
167
  isVisible: true,
168
168
  metadata: {
169
169
  referencedImageId: viewport.getCurrentImageId(),