@cornerstonejs/tools 0.30.7 → 0.32.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 (109) hide show
  1. package/dist/cjs/index.d.ts +2 -2
  2. package/dist/cjs/index.js +2 -1
  3. package/dist/cjs/index.js.map +1 -1
  4. package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +4 -1
  5. package/dist/cjs/store/ToolGroupManager/ToolGroup.js +90 -29
  6. package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
  7. package/dist/cjs/store/state.d.ts +4 -6
  8. package/dist/cjs/tools/base/BaseTool.d.ts +1 -1
  9. package/dist/cjs/tools/index.d.ts +2 -1
  10. package/dist/cjs/tools/index.js +3 -1
  11. package/dist/cjs/tools/index.js.map +1 -1
  12. package/dist/cjs/tools/segmentation/BrushTool.d.ts +9 -5
  13. package/dist/cjs/tools/segmentation/BrushTool.js +95 -115
  14. package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
  15. package/dist/cjs/tools/segmentation/PaintFillTool.d.ts +12 -0
  16. package/dist/cjs/tools/segmentation/PaintFillTool.js +213 -0
  17. package/dist/cjs/tools/segmentation/PaintFillTool.js.map +1 -0
  18. package/dist/cjs/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
  19. package/dist/cjs/tools/segmentation/strategies/eraseCircle.js +10 -0
  20. package/dist/cjs/tools/segmentation/strategies/eraseCircle.js.map +1 -0
  21. package/dist/cjs/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
  22. package/dist/cjs/tools/segmentation/strategies/eraseSphere.js +12 -0
  23. package/dist/cjs/tools/segmentation/strategies/eraseSphere.js.map +1 -0
  24. package/dist/cjs/tools/segmentation/strategies/fillCircle.d.ts +3 -0
  25. package/dist/cjs/tools/segmentation/strategies/fillCircle.js +41 -12
  26. package/dist/cjs/tools/segmentation/strategies/fillCircle.js.map +1 -1
  27. package/dist/cjs/types/FloodFillTypes.d.ts +15 -0
  28. package/dist/cjs/types/FloodFillTypes.js +3 -0
  29. package/dist/cjs/types/FloodFillTypes.js.map +1 -0
  30. package/dist/cjs/types/IToolClassReference.d.ts +3 -0
  31. package/dist/cjs/types/IToolClassReference.js +3 -0
  32. package/dist/cjs/types/IToolClassReference.js.map +1 -0
  33. package/dist/cjs/types/IToolGroup.d.ts +3 -0
  34. package/dist/cjs/types/index.d.ts +3 -1
  35. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
  36. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js +49 -0
  37. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
  38. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
  39. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js +49 -0
  40. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
  41. package/dist/cjs/utilities/segmentation/createLabelmapVolumeForViewport.js +1 -1
  42. package/dist/cjs/utilities/segmentation/createLabelmapVolumeForViewport.js.map +1 -1
  43. package/dist/cjs/utilities/segmentation/floodFill.d.ts +3 -0
  44. package/dist/cjs/utilities/segmentation/floodFill.js +131 -0
  45. package/dist/cjs/utilities/segmentation/floodFill.js.map +1 -0
  46. package/dist/cjs/utilities/segmentation/index.d.ts +4 -1
  47. package/dist/cjs/utilities/segmentation/index.js +9 -1
  48. package/dist/cjs/utilities/segmentation/index.js.map +1 -1
  49. package/dist/cjs/utilities/segmentation/utilities.d.ts +2 -0
  50. package/dist/cjs/utilities/segmentation/utilities.js +21 -0
  51. package/dist/cjs/utilities/segmentation/utilities.js.map +1 -0
  52. package/dist/cjs/utilities/viewport/isViewportPreScaled.js +1 -1
  53. package/dist/cjs/utilities/viewport/isViewportPreScaled.js.map +1 -1
  54. package/dist/esm/index.d.ts +2 -2
  55. package/dist/esm/index.js +2 -2
  56. package/dist/esm/index.js.map +1 -1
  57. package/dist/esm/store/ToolGroupManager/ToolGroup.d.ts +4 -1
  58. package/dist/esm/store/ToolGroupManager/ToolGroup.js +90 -29
  59. package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
  60. package/dist/esm/store/state.d.ts +4 -6
  61. package/dist/esm/tools/base/BaseTool.d.ts +1 -1
  62. package/dist/esm/tools/index.d.ts +2 -1
  63. package/dist/esm/tools/index.js +2 -1
  64. package/dist/esm/tools/index.js.map +1 -1
  65. package/dist/esm/tools/segmentation/BrushTool.d.ts +9 -5
  66. package/dist/esm/tools/segmentation/BrushTool.js +98 -119
  67. package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
  68. package/dist/esm/tools/segmentation/PaintFillTool.d.ts +12 -0
  69. package/dist/esm/tools/segmentation/PaintFillTool.js +210 -0
  70. package/dist/esm/tools/segmentation/PaintFillTool.js.map +1 -0
  71. package/dist/esm/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
  72. package/dist/esm/tools/segmentation/strategies/eraseCircle.js +9 -0
  73. package/dist/esm/tools/segmentation/strategies/eraseCircle.js.map +1 -0
  74. package/dist/esm/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
  75. package/dist/esm/tools/segmentation/strategies/eraseSphere.js +8 -0
  76. package/dist/esm/tools/segmentation/strategies/eraseSphere.js.map +1 -0
  77. package/dist/esm/tools/segmentation/strategies/fillCircle.d.ts +3 -0
  78. package/dist/esm/tools/segmentation/strategies/fillCircle.js +38 -10
  79. package/dist/esm/tools/segmentation/strategies/fillCircle.js.map +1 -1
  80. package/dist/esm/types/FloodFillTypes.d.ts +15 -0
  81. package/dist/esm/types/FloodFillTypes.js +2 -0
  82. package/dist/esm/types/FloodFillTypes.js.map +1 -0
  83. package/dist/esm/types/IToolClassReference.d.ts +3 -0
  84. package/dist/esm/types/IToolClassReference.js +2 -0
  85. package/dist/esm/types/IToolClassReference.js.map +1 -0
  86. package/dist/esm/types/IToolGroup.d.ts +3 -0
  87. package/dist/esm/types/index.d.ts +3 -1
  88. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
  89. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js +41 -0
  90. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
  91. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
  92. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js +41 -0
  93. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
  94. package/dist/esm/utilities/segmentation/createLabelmapVolumeForViewport.js +1 -1
  95. package/dist/esm/utilities/segmentation/createLabelmapVolumeForViewport.js.map +1 -1
  96. package/dist/esm/utilities/segmentation/floodFill.d.ts +3 -0
  97. package/dist/esm/utilities/segmentation/floodFill.js +128 -0
  98. package/dist/esm/utilities/segmentation/floodFill.js.map +1 -0
  99. package/dist/esm/utilities/segmentation/index.d.ts +4 -1
  100. package/dist/esm/utilities/segmentation/index.js +4 -1
  101. package/dist/esm/utilities/segmentation/index.js.map +1 -1
  102. package/dist/esm/utilities/segmentation/utilities.d.ts +2 -0
  103. package/dist/esm/utilities/segmentation/utilities.js +15 -0
  104. package/dist/esm/utilities/segmentation/utilities.js.map +1 -0
  105. package/dist/esm/utilities/viewport/isViewportPreScaled.js +2 -2
  106. package/dist/esm/utilities/viewport/isViewportPreScaled.js.map +1 -1
  107. package/dist/umd/index.js +1 -1
  108. package/dist/umd/index.js.map +1 -1
  109. package/package.json +3 -3
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eraseCircle.js","sourceRoot":"","sources":["../../../../../src/tools/segmentation/strategies/eraseCircle.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAehD,MAAM,UAAU,iBAAiB,CAC/B,cAAqC,EACrC,aAA4B;IAI5B,MAAM,kBAAkB,GAAG;QACzB,GAAG,aAAa;QAChB,YAAY,EAAE,CAAC;KAChB,CAAC;IAEF,gBAAgB,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;AACvD,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ declare type OperationData = {
3
+ points: [Types.Point3, Types.Point3, Types.Point3, Types.Point3];
4
+ volume: Types.IImageVolume;
5
+ segmentIndex: number;
6
+ segmentationId: string;
7
+ segmentsLocked: number[];
8
+ viewPlaneNormal: Types.Point3;
9
+ viewUp: Types.Point3;
10
+ constraintFn: () => boolean;
11
+ };
12
+ export declare function eraseInsideSphere(enabledElement: Types.IEnabledElement, operationData: OperationData): void;
13
+ export {};
@@ -0,0 +1,8 @@
1
+ import { fillInsideSphere } from './fillSphere';
2
+ export function eraseInsideSphere(enabledElement, operationData) {
3
+ const eraseOperationData = Object.assign({}, operationData, {
4
+ segmentIndex: 0,
5
+ });
6
+ fillInsideSphere(enabledElement, eraseOperationData);
7
+ }
8
+ //# sourceMappingURL=eraseSphere.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eraseSphere.js","sourceRoot":"","sources":["../../../../../src/tools/segmentation/strategies/eraseSphere.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAahD,MAAM,UAAU,iBAAiB,CAC/B,cAAqC,EACrC,aAA4B;IAI5B,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,aAAa,EAAE;QAC1D,YAAY,EAAE,CAAC;KAChB,CAAC,CAAC;IAEH,gBAAgB,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC;AACvD,CAAC"}
@@ -1,14 +1,17 @@
1
1
  import type { Types } from '@cornerstonejs/core';
2
2
  declare type OperationData = {
3
3
  segmentationId: string;
4
+ imageVolume: Types.IImageVolume;
4
5
  points: any;
5
6
  volume: Types.IImageVolume;
6
7
  segmentIndex: number;
7
8
  segmentsLocked: number[];
8
9
  viewPlaneNormal: number[];
9
10
  viewUp: number[];
11
+ strategySpecificConfiguration: any;
10
12
  constraintFn: () => boolean;
11
13
  };
12
14
  export declare function fillInsideCircle(enabledElement: Types.IEnabledElement, operationData: OperationData): void;
15
+ export declare function thresholdInsideCircle(enabledElement: Types.IEnabledElement, operationData: OperationData): void;
13
16
  export declare function fillOutsideCircle(enabledElement: Types.IEnabledElement, operationData: OperationData): void;
14
17
  export {};
@@ -5,8 +5,8 @@ import { getBoundingBoxAroundShape } from '../../../utilities/boundingBox';
5
5
  import { triggerSegmentationDataModified } from '../../../stateManagement/segmentation/triggerSegmentationEvents';
6
6
  import { pointInShapeCallback } from '../../../utilities';
7
7
  const { transformWorldToIndex } = csUtils;
8
- function fillCircle(enabledElement, operationData, inside = true) {
9
- const { volume: segmentationVolume, points, segmentsLocked, segmentIndex, segmentationId, } = operationData;
8
+ function fillCircle(enabledElement, operationData, threshold = false) {
9
+ const { volume: segmentationVolume, imageVolume, points, segmentsLocked, segmentIndex, segmentationId, strategySpecificConfiguration, } = operationData;
10
10
  const { imageData, dimensions, scalarData } = segmentationVolume;
11
11
  const { viewport } = enabledElement;
12
12
  const center = vec3.fromValues(0, 0, 0);
@@ -33,21 +33,49 @@ function fillCircle(enabledElement, operationData, inside = true) {
33
33
  zRadius: Math.abs(topLeftWorld[2] - bottomRightWorld[2]) / 2,
34
34
  };
35
35
  const modifiedSlicesToUse = new Set();
36
- const callback = ({ value, index, pointIJK }) => {
37
- if (segmentsLocked.includes(value)) {
38
- return;
39
- }
40
- scalarData[index] = segmentIndex;
41
- modifiedSlicesToUse.add(pointIJK[2]);
42
- };
36
+ let callback;
37
+ if (threshold) {
38
+ callback = ({ value, index, pointIJK }) => {
39
+ if (segmentsLocked.includes(value)) {
40
+ return;
41
+ }
42
+ if (isWithinThreshold(index, imageVolume, strategySpecificConfiguration)) {
43
+ scalarData[index] = segmentIndex;
44
+ modifiedSlicesToUse.add(pointIJK[2]);
45
+ }
46
+ };
47
+ }
48
+ else {
49
+ callback = ({ value, index, pointIJK }) => {
50
+ if (segmentsLocked.includes(value)) {
51
+ return;
52
+ }
53
+ scalarData[index] = segmentIndex;
54
+ modifiedSlicesToUse.add(pointIJK[2]);
55
+ };
56
+ }
43
57
  pointInShapeCallback(imageData, (pointLPS, pointIJK) => pointInEllipse(ellipseObj, pointLPS), callback, boundsIJK);
44
58
  const arrayOfSlices = Array.from(modifiedSlicesToUse);
45
59
  triggerSegmentationDataModified(segmentationId, arrayOfSlices);
46
60
  }
61
+ function isWithinThreshold(index, imageVolume, strategySpecificConfiguration) {
62
+ const { THRESHOLD_INSIDE_CIRCLE } = strategySpecificConfiguration;
63
+ const voxelValue = imageVolume.scalarData[index];
64
+ const { threshold } = THRESHOLD_INSIDE_CIRCLE;
65
+ return threshold[0] <= voxelValue && voxelValue <= threshold[1];
66
+ }
47
67
  export function fillInsideCircle(enabledElement, operationData) {
68
+ fillCircle(enabledElement, operationData, false);
69
+ }
70
+ export function thresholdInsideCircle(enabledElement, operationData) {
71
+ const { volume, imageVolume } = operationData;
72
+ if (!csUtils.isEqual(volume.dimensions, imageVolume.dimensions) ||
73
+ !csUtils.isEqual(volume.direction, imageVolume.direction)) {
74
+ throw new Error('Only source data the same dimensions/size/orientation as the segmentation currently supported.');
75
+ }
48
76
  fillCircle(enabledElement, operationData, true);
49
77
  }
50
78
  export function fillOutsideCircle(enabledElement, operationData) {
51
- fillCircle(enabledElement, operationData, false);
79
+ throw new Error('Not yet implemented');
52
80
  }
53
81
  //# sourceMappingURL=fillCircle.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fillCircle.js","sourceRoot":"","sources":["../../../../../src/tools/segmentation/strategies/fillCircle.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"fillCircle.js","sourceRoot":"","sources":["../../../../../src/tools/segmentation/strategies/fillCircle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { Types } from '@cornerstonejs/core';
2
+ declare type FloodFillResult = {
3
+ flooded: Types.Point2[] | Types.Point3[];
4
+ boundaries: Types.Point2[] | Types.Point3[];
5
+ };
6
+ declare type FloodFillGetter3D = (x: number, y: number, z: number) => number;
7
+ declare type FloodFillGetter2D = (x: number, y: number) => number;
8
+ declare type FloodFillGetter = FloodFillGetter2D | FloodFillGetter3D;
9
+ declare type FloodFillOptions = {
10
+ onFlood?: (x: any, y: any) => void;
11
+ onBoundary?: (x: any, y: any) => void;
12
+ equals?: (a: any, b: any) => boolean;
13
+ diagonals?: boolean;
14
+ };
15
+ export { FloodFillResult, FloodFillGetter, FloodFillOptions };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=FloodFillTypes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FloodFillTypes.js","sourceRoot":"","sources":["../../../src/types/FloodFillTypes.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ import { BaseTool } from '../tools';
2
+ declare type IToolClassReference = new <T extends BaseTool>(config: any) => T;
3
+ export default IToolClassReference;
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=IToolClassReference.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IToolClassReference.js","sourceRoot":"","sources":["../../../src/types/IToolClassReference.ts"],"names":[],"mappings":""}
@@ -13,6 +13,9 @@ export default interface IToolGroup {
13
13
  addTool: {
14
14
  (toolName: string, toolConfiguration?: any): void;
15
15
  };
16
+ addToolInstance: {
17
+ (ttoolName: string, parentClassName: string, configuration?: any): void;
18
+ };
16
19
  addViewport: {
17
20
  (viewportId: string, renderingEngineId?: string): void;
18
21
  };
@@ -19,4 +19,6 @@ import type SVGDrawingHelper from './SVGDrawingHelper';
19
19
  import type * as CINETypes from './CINETypes';
20
20
  import type { Color, ColorLUT, RepresentationConfig, SegmentationRepresentationConfig, SegmentationRepresentationData, Segmentation, ToolGroupSpecificRepresentationState, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, SegmentationState, RepresentationPublicInput } from './SegmentationStateTypes';
21
21
  import ISynchronizerEventHandler from './ISynchronizerEventHandler';
22
- export type { Annotation, Annotations, FrameOfReferenceSpecificAnnotations, AnnotationState, AnnotationStyle, ToolSpecificAnnotationTypes, JumpToSliceOptions, PlanarBoundingBox, ToolProps, PublicToolProps, EventTypes, IPoints, IToolBinding, SetToolBindingsType, ToolOptionsType, InteractionTypes, IToolGroup, ISynchronizerEventHandler, ToolHandle, AnnotationHandle, TextBoxHandle, Segmentation, SegmentationState, SegmentationRepresentationData, SegmentationRepresentationConfig, RepresentationConfig, ToolGroupSpecificRepresentationState, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, RepresentationPublicInput, Color, ColorLUT, LabelmapTypes, SVGCursorDescriptor, SVGPoint, ScrollOptions, CINETypes, BoundsIJK, SVGDrawingHelper, };
22
+ import { FloodFillGetter, FloodFillOptions, FloodFillResult } from './FloodFillTypes';
23
+ import IToolClassReference from './IToolClassReference';
24
+ export type { Annotation, Annotations, FrameOfReferenceSpecificAnnotations, AnnotationState, AnnotationStyle, ToolSpecificAnnotationTypes, JumpToSliceOptions, PlanarBoundingBox, ToolProps, PublicToolProps, EventTypes, IPoints, IToolBinding, SetToolBindingsType, ToolOptionsType, InteractionTypes, IToolGroup, IToolClassReference, ISynchronizerEventHandler, ToolHandle, AnnotationHandle, TextBoxHandle, Segmentation, SegmentationState, SegmentationRepresentationData, SegmentationRepresentationConfig, RepresentationConfig, ToolGroupSpecificRepresentationState, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, RepresentationPublicInput, Color, ColorLUT, LabelmapTypes, SVGCursorDescriptor, SVGPoint, ScrollOptions, CINETypes, BoundsIJK, SVGDrawingHelper, FloodFillResult, FloodFillGetter, FloodFillOptions, };
@@ -0,0 +1,2 @@
1
+ export declare function setBrushSizeForToolGroup(toolGroupId: string, brushSize: number): void;
2
+ export declare function getBrushSizeForToolGroup(toolGroupId: string): void;
@@ -0,0 +1,41 @@
1
+ import { getToolGroup } from '../../store/ToolGroupManager';
2
+ import triggerAnnotationRenderForViewportIds from '../triggerAnnotationRenderForViewportIds';
3
+ import { getRenderingEngine } from '@cornerstonejs/core';
4
+ import getBrushToolInstances from './utilities';
5
+ export function setBrushSizeForToolGroup(toolGroupId, brushSize) {
6
+ const toolGroup = getToolGroup(toolGroupId);
7
+ if (toolGroup === undefined) {
8
+ return;
9
+ }
10
+ const brushBasedToolInstances = getBrushToolInstances(toolGroupId);
11
+ brushBasedToolInstances.forEach((tool) => {
12
+ tool.configuration.brushSize = brushSize;
13
+ tool.invalidateBrushCursor();
14
+ });
15
+ const viewportsInfo = toolGroup.getViewportsInfo();
16
+ const viewportsInfoArray = Object.keys(viewportsInfo).map((key) => viewportsInfo[key]);
17
+ if (!viewportsInfoArray.length) {
18
+ return;
19
+ }
20
+ const { renderingEngineId } = viewportsInfoArray[0];
21
+ const viewportIds = toolGroup.getViewportIds();
22
+ const renderingEngine = getRenderingEngine(renderingEngineId);
23
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIds);
24
+ }
25
+ export function getBrushSizeForToolGroup(toolGroupId) {
26
+ const toolGroup = getToolGroup(toolGroupId);
27
+ if (toolGroup === undefined) {
28
+ return;
29
+ }
30
+ const toolInstances = toolGroup._toolInstances;
31
+ if (!Object.keys(toolInstances).length) {
32
+ return;
33
+ }
34
+ const brushBasedToolInstances = getBrushToolInstances(toolGroupId);
35
+ const brushToolInstance = brushBasedToolInstances[0];
36
+ if (!brushToolInstance) {
37
+ return;
38
+ }
39
+ return brushToolInstance.configuration.brushSize;
40
+ }
41
+ //# sourceMappingURL=brushSizeForToolGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"brushSizeForToolGroup.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/brushSizeForToolGroup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,OAAO,qCAAqC,MAAM,0CAA0C,CAAC;AAC7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,qBAAqB,MAAM,aAAa,CAAC;AAEhD,MAAM,UAAU,wBAAwB,CACtC,WAAmB,EACnB,SAAiB;IAEjB,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5C,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO;KACR;IAED,MAAM,uBAAuB,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IAEnE,uBAAuB,CAAC,OAAO,CAAC,CAAC,IAAe,EAAE,EAAE;QAClD,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,SAAS,CAAC;QAGzC,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC,CAAC,CAAC;IAGH,MAAM,aAAa,GAAG,SAAS,CAAC,gBAAgB,EAAE,CAAC;IAEnD,MAAM,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,GAAG,CACvD,CAAC,GAAG,EAAE,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,CAC5B,CAAC;IAEF,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE;QAC9B,OAAO;KACR;IAED,MAAM,EAAE,iBAAiB,EAAE,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAIpD,MAAM,WAAW,GAAG,SAAS,CAAC,cAAc,EAAE,CAAC;IAE/C,MAAM,eAAe,GAAG,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IAE9D,qCAAqC,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;AACtE,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,WAAmB;IAC1D,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5C,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO;KACR;IAED,MAAM,aAAa,GAAG,SAAS,CAAC,cAAc,CAAC;IAE/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,EAAE;QACtC,OAAO;KACR;IAED,MAAM,uBAAuB,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IAGnE,MAAM,iBAAiB,GAAG,uBAAuB,CAAC,CAAC,CAAC,CAAC;IAErD,IAAI,CAAC,iBAAiB,EAAE;QACtB,OAAO;KACR;IAGD,OAAO,iBAAiB,CAAC,aAAa,CAAC,SAAS,CAAC;AACnD,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ export declare function setBrushThresholdForToolGroup(toolGroupId: string, threshold: Types.Point2): void;
3
+ export declare function getBrushThresholdForToolGroup(toolGroupId: string): any;
@@ -0,0 +1,41 @@
1
+ import { getToolGroup } from '../../store/ToolGroupManager';
2
+ import triggerAnnotationRenderForViewportIds from '../triggerAnnotationRenderForViewportIds';
3
+ import { getRenderingEngine } from '@cornerstonejs/core';
4
+ import getBrushToolInstances from './utilities';
5
+ export function setBrushThresholdForToolGroup(toolGroupId, threshold) {
6
+ const toolGroup = getToolGroup(toolGroupId);
7
+ if (toolGroup === undefined) {
8
+ return;
9
+ }
10
+ const brushBasedToolInstances = getBrushToolInstances(toolGroupId);
11
+ brushBasedToolInstances.forEach((tool) => {
12
+ tool.configuration.strategySpecificConfiguration.THRESHOLD_INSIDE_CIRCLE.threshold =
13
+ threshold;
14
+ });
15
+ const viewportsInfo = toolGroup.getViewportsInfo();
16
+ if (!viewportsInfo.length) {
17
+ return;
18
+ }
19
+ const { renderingEngineId } = viewportsInfo[0];
20
+ const viewportIds = toolGroup.getViewportIds();
21
+ const renderingEngine = getRenderingEngine(renderingEngineId);
22
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIds);
23
+ }
24
+ export function getBrushThresholdForToolGroup(toolGroupId) {
25
+ const toolGroup = getToolGroup(toolGroupId);
26
+ if (toolGroup === undefined) {
27
+ return;
28
+ }
29
+ const toolInstances = toolGroup._toolInstances;
30
+ if (!Object.keys(toolInstances).length) {
31
+ return;
32
+ }
33
+ const brushBasedToolInstances = getBrushToolInstances(toolGroupId);
34
+ const brushToolInstance = brushBasedToolInstances[0];
35
+ if (!brushToolInstance) {
36
+ return;
37
+ }
38
+ return brushToolInstance.configuration.strategySpecificConfiguration
39
+ .THRESHOLD_INSIDE_CIRCLE.threshold;
40
+ }
41
+ //# sourceMappingURL=brushThresholdForToolGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"brushThresholdForToolGroup.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/brushThresholdForToolGroup.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,qCAAqC,MAAM,0CAA0C,CAAC;AAC7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,qBAAqB,MAAM,aAAa,CAAC;AAEhD,MAAM,UAAU,6BAA6B,CAC3C,WAAmB,EACnB,SAAuB;IAEvB,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5C,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO;KACR;IAED,MAAM,uBAAuB,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IAEnE,uBAAuB,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QACvC,IAAI,CAAC,aAAa,CAAC,6BAA6B,CAAC,uBAAuB,CAAC,SAAS;YAChF,SAAS,CAAC;IACd,CAAC,CAAC,CAAC;IAGH,MAAM,aAAa,GAAG,SAAS,CAAC,gBAAgB,EAAE,CAAC;IAEnD,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;QACzB,OAAO;KACR;IAED,MAAM,EAAE,iBAAiB,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;IAI/C,MAAM,WAAW,GAAG,SAAS,CAAC,cAAc,EAAE,CAAC;IAE/C,MAAM,eAAe,GAAG,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IAE9D,qCAAqC,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;AACtE,CAAC;AAED,MAAM,UAAU,6BAA6B,CAAC,WAAmB;IAC/D,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5C,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO;KACR;IAED,MAAM,aAAa,GAAG,SAAS,CAAC,cAAc,CAAC;IAE/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,EAAE;QACtC,OAAO;KACR;IAED,MAAM,uBAAuB,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IACnE,MAAM,iBAAiB,GAAG,uBAAuB,CAAC,CAAC,CAAC,CAAC;IAErD,IAAI,CAAC,iBAAiB,EAAE;QACtB,OAAO;KACR;IAGD,OAAO,iBAAiB,CAAC,aAAa,CAAC,6BAA6B;SACjE,uBAAuB,CAAC,SAAS,CAAC;AACvC,CAAC"}
@@ -9,7 +9,7 @@ export default async function createLabelmapVolumeForViewport(input) {
9
9
  }
10
10
  const { viewport } = enabledElement;
11
11
  if (!(viewport instanceof VolumeViewport)) {
12
- throw new Error('Segmentation not ready for stackViewport');
12
+ throw new Error('Segmentation only supports VolumeViewport');
13
13
  }
14
14
  const { uid } = viewport.getDefaultActor();
15
15
  if (segmentationId === undefined) {
@@ -1 +1 @@
1
- {"version":3,"file":"createLabelmapVolumeForViewport.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/createLabelmapVolumeForViewport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EACL,sBAAsB,EACtB,YAAY,EACZ,cAAc,EACd,SAAS,IAAI,OAAO,GACrB,MAAM,qBAAqB,CAAC;AAc7B,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,+BAA+B,CAAC,KAgB7D;IACC,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IACzD,IAAI,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC;IAC/B,MAAM,cAAc,GAAG,sBAAsB,CAAC,UAAU,EAAE,iBAAiB,CAAC,CAAC;IAE7E,IAAI,CAAC,cAAc,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;KACrC;IAED,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IACpC,IAAI,CAAC,CAAC,QAAQ,YAAY,cAAc,CAAC,EAAE;QACzC,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;KAC7D;IAED,MAAM,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;IAE3C,IAAI,cAAc,KAAK,SAAS,EAAE;QAEhC,cAAc,GAAG,GAAG,GAAG,uBACrB,OAAO,EAAE,QAAQ,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAClD,EAAE,CAAC;KACJ;IAED,IAAI,OAAO,EAAE;QAGX,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,YAAY,CAAC,iBAAiB,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;KAClE;SAAM;QAEL,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;QACrD,MAAM,YAAY,CAAC,2BAA2B,CAAC,QAAQ,EAAE;YACvD,QAAQ,EAAE,cAAc;SACzB,CAAC,CAAC;KACJ;IAED,OAAO,cAAc,CAAC;AACxB,CAAC"}
1
+ {"version":3,"file":"createLabelmapVolumeForViewport.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/createLabelmapVolumeForViewport.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EACL,sBAAsB,EACtB,YAAY,EACZ,cAAc,EACd,SAAS,IAAI,OAAO,GACrB,MAAM,qBAAqB,CAAC;AAc7B,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,+BAA+B,CAAC,KAgB7D;IACC,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IACzD,IAAI,EAAE,cAAc,EAAE,GAAG,KAAK,CAAC;IAC/B,MAAM,cAAc,GAAG,sBAAsB,CAAC,UAAU,EAAE,iBAAiB,CAAC,CAAC;IAE7E,IAAI,CAAC,cAAc,EAAE;QACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;KACrC;IAED,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IACpC,IAAI,CAAC,CAAC,QAAQ,YAAY,cAAc,CAAC,EAAE;QACzC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;KAC9D;IAED,MAAM,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;IAE3C,IAAI,cAAc,KAAK,SAAS,EAAE;QAEhC,cAAc,GAAG,GAAG,GAAG,uBACrB,OAAO,EAAE,QAAQ,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAClD,EAAE,CAAC;KACJ;IAED,IAAI,OAAO,EAAE;QAGX,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,YAAY,CAAC,iBAAiB,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;KAClE;SAAM;QAEL,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;QACrD,MAAM,YAAY,CAAC,2BAA2B,CAAC,QAAQ,EAAE;YACvD,QAAQ,EAAE,cAAc;SACzB,CAAC,CAAC;KACJ;IAED,OAAO,cAAc,CAAC;AACxB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { FloodFillResult, FloodFillGetter, FloodFillOptions } from '../../types';
2
+ import { Types } from '@cornerstonejs/core';
3
+ export default function (getter: FloodFillGetter, seed: Types.Point2 | Types.Point3, options?: FloodFillOptions): FloodFillResult;
@@ -0,0 +1,128 @@
1
+ export default function (getter, seed, options = {}) {
2
+ const onFlood = options.onFlood;
3
+ const onBoundary = options.onBoundary;
4
+ const equals = options.equals || defaultEquals;
5
+ const diagonals = options.diagonals || false;
6
+ const startNode = get(seed);
7
+ const permutations = prunedPermutations();
8
+ const stack = [];
9
+ const flooded = [];
10
+ const visits = {};
11
+ const bounds = {};
12
+ stack.push({ currentArgs: seed });
13
+ while (stack.length > 0) {
14
+ flood(stack.pop());
15
+ }
16
+ return {
17
+ flooded,
18
+ boundaries: boundaries(),
19
+ };
20
+ function flood(job) {
21
+ const getArgs = job.currentArgs;
22
+ const prevArgs = job.previousArgs;
23
+ if (visited(getArgs)) {
24
+ return;
25
+ }
26
+ markAsVisited(getArgs);
27
+ if (member(getArgs)) {
28
+ markAsFlooded(getArgs);
29
+ pushAdjacent(getArgs);
30
+ }
31
+ else {
32
+ markAsBoundary(prevArgs);
33
+ }
34
+ }
35
+ function visited(key) {
36
+ return visits[key] === true;
37
+ }
38
+ function markAsVisited(key) {
39
+ visits[key] = true;
40
+ }
41
+ function member(getArgs) {
42
+ const node = safely(get, [getArgs]);
43
+ return safely(equals, [node, startNode]);
44
+ }
45
+ function markAsFlooded(getArgs) {
46
+ flooded.push(getArgs);
47
+ if (onFlood) {
48
+ onFlood(...getArgs);
49
+ }
50
+ }
51
+ function markAsBoundary(prevArgs) {
52
+ bounds[prevArgs] = prevArgs;
53
+ if (onBoundary) {
54
+ onBoundary(...prevArgs);
55
+ }
56
+ }
57
+ function pushAdjacent(getArgs) {
58
+ for (let i = 0; i < permutations.length; i += 1) {
59
+ const perm = permutations[i];
60
+ const nextArgs = getArgs.slice(0);
61
+ for (let j = 0; j < getArgs.length; j += 1) {
62
+ nextArgs[j] += perm[j];
63
+ }
64
+ stack.push({
65
+ currentArgs: nextArgs,
66
+ previousArgs: getArgs,
67
+ });
68
+ }
69
+ }
70
+ function get(getArgs) {
71
+ return getter(...getArgs);
72
+ }
73
+ function safely(f, args) {
74
+ try {
75
+ return f(...args);
76
+ }
77
+ catch (error) {
78
+ return;
79
+ }
80
+ }
81
+ function prunedPermutations() {
82
+ const permutations = permute(seed.length);
83
+ return permutations.filter(function (perm) {
84
+ const count = countNonZeroes(perm);
85
+ return count !== 0 && (count === 1 || diagonals);
86
+ });
87
+ }
88
+ function permute(length) {
89
+ const perms = [];
90
+ const permutation = function (string) {
91
+ return string.split('').map(function (c) {
92
+ return parseInt(c, 10) - 1;
93
+ });
94
+ };
95
+ for (let i = 0; i < Math.pow(3, length); i += 1) {
96
+ const string = lpad(i.toString(3), '0', length);
97
+ perms.push(permutation(string));
98
+ }
99
+ return perms;
100
+ }
101
+ function boundaries() {
102
+ const array = [];
103
+ for (const key in bounds) {
104
+ if (bounds[key] !== undefined) {
105
+ array.unshift(bounds[key]);
106
+ }
107
+ }
108
+ return array;
109
+ }
110
+ }
111
+ function defaultEquals(a, b) {
112
+ return a === b;
113
+ }
114
+ function countNonZeroes(array) {
115
+ let count = 0;
116
+ for (let i = 0; i < array.length; i += 1) {
117
+ if (array[i] !== 0) {
118
+ count += 1;
119
+ }
120
+ }
121
+ return count;
122
+ }
123
+ function lpad(string, character, length) {
124
+ const array = new Array(length + 1);
125
+ const pad = array.join(character);
126
+ return (pad + string).slice(-length);
127
+ }
128
+ //# sourceMappingURL=floodFill.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"floodFill.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/floodFill.ts"],"names":[],"mappings":"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"}
@@ -5,4 +5,7 @@ import isValidRepresentationConfig from './isValidRepresentationConfig';
5
5
  import getDefaultRepresentationConfig from './getDefaultRepresentationConfig';
6
6
  import createLabelmapVolumeForViewport from './createLabelmapVolumeForViewport';
7
7
  import { triggerSegmentationRender } from './triggerSegmentationRender';
8
- export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, };
8
+ import floodFill from './floodFill';
9
+ import { getBrushSizeForToolGroup, setBrushSizeForToolGroup } from './brushSizeForToolGroup';
10
+ import { getBrushThresholdForToolGroup, setBrushThresholdForToolGroup } from './brushThresholdForToolGroup';
11
+ export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, };
@@ -5,5 +5,8 @@ import isValidRepresentationConfig from './isValidRepresentationConfig';
5
5
  import getDefaultRepresentationConfig from './getDefaultRepresentationConfig';
6
6
  import createLabelmapVolumeForViewport from './createLabelmapVolumeForViewport';
7
7
  import { triggerSegmentationRender } from './triggerSegmentationRender';
8
- export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, };
8
+ import floodFill from './floodFill';
9
+ import { getBrushSizeForToolGroup, setBrushSizeForToolGroup, } from './brushSizeForToolGroup';
10
+ import { getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, } from './brushThresholdForToolGroup';
11
+ export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, };
9
12
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,kCAAkC,MAAM,sCAAsC,CAAC;AACtF,OAAO,4BAA4B,MAAM,gCAAgC,CAAC;AAC1E,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,8BAA8B,MAAM,kCAAkC,CAAC;AAC9E,OAAO,+BAA+B,MAAM,mCAAmC,CAAC;AAChF,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AAExE,OAAO,EACL,sBAAsB,EACtB,4BAA4B,EAC5B,2BAA2B,EAC3B,8BAA8B,EAC9B,+BAA+B,EAC/B,kCAAkC,EAClC,yBAAyB,GAC1B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,kCAAkC,MAAM,sCAAsC,CAAC;AACtF,OAAO,4BAA4B,MAAM,gCAAgC,CAAC;AAC1E,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,8BAA8B,MAAM,kCAAkC,CAAC;AAC9E,OAAO,+BAA+B,MAAM,mCAAmC,CAAC;AAChF,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,EACL,wBAAwB,EACxB,wBAAwB,GACzB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACL,6BAA6B,EAC7B,6BAA6B,GAC9B,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EACL,sBAAsB,EACtB,4BAA4B,EAC5B,2BAA2B,EAC3B,8BAA8B,EAC9B,+BAA+B,EAC/B,kCAAkC,EAClC,yBAAyB,EACzB,SAAS,EACT,wBAAwB,EACxB,wBAAwB,EACxB,6BAA6B,EAC7B,6BAA6B,GAC9B,CAAC"}
@@ -0,0 +1,2 @@
1
+ import BrushTool from '../../tools/segmentation/BrushTool';
2
+ export default function getBrushToolInstances(toolGroupId: any): BrushTool[];
@@ -0,0 +1,15 @@
1
+ import { getToolGroup } from '../../store/ToolGroupManager';
2
+ import BrushTool from '../../tools/segmentation/BrushTool';
3
+ export default function getBrushToolInstances(toolGroupId) {
4
+ const toolGroup = getToolGroup(toolGroupId);
5
+ if (toolGroup === undefined) {
6
+ return;
7
+ }
8
+ const toolInstances = toolGroup._toolInstances;
9
+ if (!Object.keys(toolInstances).length) {
10
+ return;
11
+ }
12
+ const brushBasedToolInstances = Object.values(toolInstances).filter((toolInstance) => toolInstance instanceof BrushTool);
13
+ return brushBasedToolInstances;
14
+ }
15
+ //# sourceMappingURL=utilities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utilities.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/utilities.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,SAAS,MAAM,oCAAoC,CAAC;AAE3D,MAAM,CAAC,OAAO,UAAU,qBAAqB,CAAC,WAAW;IACvD,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAC;IAE5C,IAAI,SAAS,KAAK,SAAS,EAAE;QAC3B,OAAO;KACR;IAED,MAAM,aAAa,GAAG,SAAS,CAAC,cAAc,CAAC;IAE/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,EAAE;QACtC,OAAO;KACR;IAGD,MAAM,uBAAuB,GAAG,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,MAAM,CACjE,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,YAAY,SAAS,CACrC,CAAC;IAEjB,OAAO,uBAAuB,CAAC;AACjC,CAAC"}
@@ -1,6 +1,6 @@
1
- import { cache, StackViewport, VolumeViewport, } from '@cornerstonejs/core';
1
+ import { cache, StackViewport, BaseVolumeViewport, } from '@cornerstonejs/core';
2
2
  function isViewportPreScaled(viewport, targetId) {
3
- if (viewport instanceof VolumeViewport) {
3
+ if (viewport instanceof BaseVolumeViewport) {
4
4
  const volumeId = targetId.split('volumeId:')[1];
5
5
  const volume = cache.getVolume(volumeId);
6
6
  return volume.scaling && Object.keys(volume.scaling).length > 0;
@@ -1 +1 @@
1
- {"version":3,"file":"isViewportPreScaled.js","sourceRoot":"","sources":["../../../../src/utilities/viewport/isViewportPreScaled.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,aAAa,EAEb,cAAc,GACf,MAAM,qBAAqB,CAAC;AAE7B,SAAS,mBAAmB,CAC1B,QAAsD,EACtD,QAAgB;IAEhB,IAAI,QAAQ,YAAY,cAAc,EAAE;QACtC,MAAM,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACzC,OAAO,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;KACjE;SAAM,IAAI,QAAQ,YAAY,aAAa,EAAE;QAC5C,MAAM,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;QAC7C,OAAO,QAAQ,CAAC,MAAM,CAAC;KACxB;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;KACjD;AACH,CAAC;AAED,OAAO,EAAE,mBAAmB,EAAE,CAAC"}
1
+ {"version":3,"file":"isViewportPreScaled.js","sourceRoot":"","sources":["../../../../src/utilities/viewport/isViewportPreScaled.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EACL,aAAa,EAEb,kBAAkB,GACnB,MAAM,qBAAqB,CAAC;AAE7B,SAAS,mBAAmB,CAC1B,QAAsD,EACtD,QAAgB;IAEhB,IAAI,QAAQ,YAAY,kBAAkB,EAAE;QAC1C,MAAM,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACzC,OAAO,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;KACjE;SAAM,IAAI,QAAQ,YAAY,aAAa,EAAE;QAC5C,MAAM,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;QAC7C,OAAO,QAAQ,CAAC,MAAM,CAAC;KACxB;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;KACjD;AACH,CAAC;AAED,OAAO,EAAE,mBAAmB,EAAE,CAAC"}