@cornerstonejs/tools 1.35.2 → 1.36.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/drawingSvg/drawEllipse.js +6 -42
- package/dist/cjs/drawingSvg/drawEllipse.js.map +1 -1
- package/dist/cjs/drawingSvg/drawEllipseByCoordinates.d.ts +4 -0
- package/dist/cjs/drawingSvg/drawEllipseByCoordinates.js +53 -0
- package/dist/cjs/drawingSvg/drawEllipseByCoordinates.js.map +1 -0
- package/dist/cjs/drawingSvg/index.d.ts +2 -1
- package/dist/cjs/drawingSvg/index.js +3 -1
- package/dist/cjs/drawingSvg/index.js.map +1 -1
- package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js +3 -0
- package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/SegmentationStateManager.d.ts +5 -4
- package/dist/cjs/stateManagement/segmentation/SegmentationStateManager.js +6 -10
- package/dist/cjs/stateManagement/segmentation/SegmentationStateManager.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentation.d.ts +3 -0
- package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentation.js +87 -0
- package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentation.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentations.js +2 -29
- package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentations.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/config/segmentationColor.d.ts +4 -5
- package/dist/cjs/stateManagement/segmentation/config/segmentationColor.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.d.ts +2 -0
- package/dist/cjs/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.js +19 -0
- package/dist/cjs/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/segmentationState.d.ts +6 -4
- package/dist/cjs/stateManagement/segmentation/segmentationState.js +6 -1
- package/dist/cjs/stateManagement/segmentation/segmentationState.js.map +1 -1
- package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +1 -1
- package/dist/cjs/store/ToolGroupManager/ToolGroup.js +2 -1
- package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
- package/dist/cjs/tools/annotation/EllipticalROITool.js +2 -12
- package/dist/cjs/tools/annotation/EllipticalROITool.js.map +1 -1
- package/dist/cjs/tools/annotation/SplineROITool.js +9 -34
- package/dist/cjs/tools/annotation/SplineROITool.js.map +1 -1
- package/dist/cjs/tools/displayTools/Contour/contourDisplay.d.ts +1 -3
- package/dist/cjs/tools/displayTools/Contour/contourDisplay.js +0 -33
- package/dist/cjs/tools/displayTools/Contour/contourDisplay.js.map +1 -1
- package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.d.ts +9 -3
- package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +13 -37
- package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.d.ts +1 -3
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js +0 -32
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
- package/dist/cjs/types/SegmentationStateTypes.d.ts +5 -3
- package/dist/cjs/types/index.d.ts +2 -2
- package/dist/esm/drawingSvg/drawEllipse.js +6 -42
- package/dist/esm/drawingSvg/drawEllipse.js.map +1 -1
- package/dist/esm/drawingSvg/drawEllipseByCoordinates.js +48 -0
- package/dist/esm/drawingSvg/drawEllipseByCoordinates.js.map +1 -0
- package/dist/esm/drawingSvg/index.js +2 -1
- package/dist/esm/drawingSvg/index.js.map +1 -1
- package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js +3 -0
- package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/SegmentationStateManager.js +6 -10
- package/dist/esm/stateManagement/segmentation/SegmentationStateManager.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/addSegmentationRepresentation.js +49 -0
- package/dist/esm/stateManagement/segmentation/addSegmentationRepresentation.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/addSegmentationRepresentations.js +2 -24
- package/dist/esm/stateManagement/segmentation/addSegmentationRepresentations.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/config/segmentationColor.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.js +12 -0
- package/dist/esm/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/segmentationState.js +5 -1
- package/dist/esm/stateManagement/segmentation/segmentationState.js.map +1 -1
- package/dist/esm/store/ToolGroupManager/ToolGroup.js +2 -1
- package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
- package/dist/esm/tools/annotation/EllipticalROITool.js +3 -13
- package/dist/esm/tools/annotation/EllipticalROITool.js.map +1 -1
- package/dist/esm/tools/annotation/SplineROITool.js +2 -4
- package/dist/esm/tools/annotation/SplineROITool.js.map +1 -1
- package/dist/esm/tools/displayTools/Contour/contourDisplay.js +1 -34
- package/dist/esm/tools/displayTools/Contour/contourDisplay.js.map +1 -1
- package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +6 -33
- package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
- package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js +1 -33
- package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
- package/dist/types/drawingSvg/drawEllipse.d.ts.map +1 -1
- package/dist/types/drawingSvg/drawEllipseByCoordinates.d.ts +5 -0
- package/dist/types/drawingSvg/drawEllipseByCoordinates.d.ts.map +1 -0
- package/dist/types/drawingSvg/index.d.ts +2 -1
- package/dist/types/drawingSvg/index.d.ts.map +1 -1
- package/dist/types/eventListeners/segmentation/imageChangeEventListener.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/SegmentationStateManager.d.ts +5 -4
- package/dist/types/stateManagement/segmentation/SegmentationStateManager.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/addSegmentationRepresentation.d.ts +4 -0
- package/dist/types/stateManagement/segmentation/addSegmentationRepresentation.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/addSegmentationRepresentations.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/config/segmentationColor.d.ts +4 -5
- package/dist/types/stateManagement/segmentation/config/segmentationColor.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.d.ts +3 -0
- package/dist/types/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/segmentationState.d.ts +6 -4
- package/dist/types/stateManagement/segmentation/segmentationState.d.ts.map +1 -1
- package/dist/types/store/ToolGroupManager/ToolGroup.d.ts +1 -1
- package/dist/types/store/ToolGroupManager/ToolGroup.d.ts.map +1 -1
- package/dist/types/tools/annotation/EllipticalROITool.d.ts.map +1 -1
- package/dist/types/tools/annotation/SplineROITool.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts +1 -3
- package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Labelmap/labelmapDisplay.d.ts +9 -3
- package/dist/types/tools/displayTools/Labelmap/labelmapDisplay.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts +1 -3
- package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts.map +1 -1
- package/dist/types/types/SegmentationStateTypes.d.ts +5 -3
- package/dist/types/types/SegmentationStateTypes.d.ts.map +1 -1
- package/dist/types/types/index.d.ts +2 -2
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +3 -3
- package/src/drawingSvg/drawEllipse.ts +15 -55
- package/src/drawingSvg/drawEllipseByCoordinates.ts +73 -0
- package/src/drawingSvg/index.ts +2 -0
- package/src/eventListeners/segmentation/imageChangeEventListener.ts +5 -0
- package/src/stateManagement/segmentation/SegmentationStateManager.ts +10 -17
- package/src/stateManagement/segmentation/addSegmentationRepresentation.ts +86 -0
- package/src/stateManagement/segmentation/addSegmentationRepresentations.ts +2 -43
- package/src/stateManagement/segmentation/config/segmentationColor.ts +4 -6
- package/src/stateManagement/segmentation/helpers/getRepresentationSpecificConfig.ts +15 -0
- package/src/stateManagement/segmentation/segmentationState.ts +9 -3
- package/src/store/ToolGroupManager/ToolGroup.ts +4 -6
- package/src/tools/annotation/EllipticalROITool.ts +5 -15
- package/src/tools/annotation/SplineROITool.ts +3 -3
- package/src/tools/displayTools/Contour/contourDisplay.ts +0 -61
- package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +11 -66
- package/src/tools/displayTools/Surface/surfaceDisplay.ts +0 -60
- package/src/types/SegmentationStateTypes.ts +7 -12
- package/src/types/index.ts +0 -4
|
@@ -35,11 +35,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
35
35
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
36
|
};
|
|
37
37
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
+
exports.removeSegmentationRepresentation = exports.render = exports.getRepresentationRenderingConfig = void 0;
|
|
38
39
|
const PiecewiseFunction_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/PiecewiseFunction"));
|
|
39
40
|
const ColorTransferFunction_1 = __importDefault(require("@kitware/vtk.js/Rendering/Core/ColorTransferFunction"));
|
|
40
41
|
const core_1 = require("@cornerstonejs/core");
|
|
41
42
|
const SegmentationRepresentations_1 = __importDefault(require("../../../enums/SegmentationRepresentations"));
|
|
42
|
-
const SegmentationConfig = __importStar(require("../../../stateManagement/segmentation/config/segmentationConfig"));
|
|
43
43
|
const SegmentationState = __importStar(require("../../../stateManagement/segmentation/segmentationState"));
|
|
44
44
|
const ToolGroupManager_1 = require("../../../store/ToolGroupManager");
|
|
45
45
|
const addLabelmapToElement_1 = __importDefault(require("./addLabelmapToElement"));
|
|
@@ -47,42 +47,16 @@ const removeLabelmapFromElement_1 = __importDefault(require("./removeLabelmapFro
|
|
|
47
47
|
const stackVolumeCheck_1 = require("../../segmentation/strategies/utils/stackVolumeCheck");
|
|
48
48
|
const MAX_NUMBER_COLORS = 255;
|
|
49
49
|
const labelMapConfigCache = new Map();
|
|
50
|
-
function
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
const ofun = PiecewiseFunction_1.default.newInstance();
|
|
59
|
-
ofun.addPoint(0, 0);
|
|
60
|
-
const toolGroupSpecificRepresentation = {
|
|
61
|
-
segmentationId,
|
|
62
|
-
segmentationRepresentationUID,
|
|
63
|
-
type: SegmentationRepresentations_1.default.Labelmap,
|
|
64
|
-
segmentsHidden,
|
|
65
|
-
colorLUTIndex,
|
|
66
|
-
active,
|
|
67
|
-
segmentationRepresentationSpecificConfig: {},
|
|
68
|
-
segmentSpecificConfig: {},
|
|
69
|
-
config: {
|
|
70
|
-
cfun,
|
|
71
|
-
ofun,
|
|
72
|
-
},
|
|
73
|
-
};
|
|
74
|
-
if (toolGroupSpecificConfig) {
|
|
75
|
-
const currentToolGroupConfig = SegmentationConfig.getToolGroupSpecificConfig(toolGroupId);
|
|
76
|
-
const mergedConfig = core_1.utilities.deepMerge(currentToolGroupConfig, toolGroupSpecificConfig);
|
|
77
|
-
SegmentationConfig.setToolGroupSpecificConfig(toolGroupId, {
|
|
78
|
-
renderInactiveSegmentations: mergedConfig.renderInactiveSegmentations || true,
|
|
79
|
-
representations: Object.assign({}, mergedConfig.representations),
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
SegmentationState.addSegmentationRepresentation(toolGroupId, toolGroupSpecificRepresentation);
|
|
83
|
-
return segmentationRepresentationUID;
|
|
84
|
-
});
|
|
50
|
+
function getRepresentationRenderingConfig() {
|
|
51
|
+
const cfun = ColorTransferFunction_1.default.newInstance();
|
|
52
|
+
const ofun = PiecewiseFunction_1.default.newInstance();
|
|
53
|
+
ofun.addPoint(0, 0);
|
|
54
|
+
return {
|
|
55
|
+
ofun,
|
|
56
|
+
cfun,
|
|
57
|
+
};
|
|
85
58
|
}
|
|
59
|
+
exports.getRepresentationRenderingConfig = getRepresentationRenderingConfig;
|
|
86
60
|
function removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID, renderImmediate = false) {
|
|
87
61
|
_removeLabelmapFromToolGroupViewports(toolGroupId, segmentationRepresentationUID);
|
|
88
62
|
SegmentationState.removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID);
|
|
@@ -94,6 +68,7 @@ function removeSegmentationRepresentation(toolGroupId, segmentationRepresentatio
|
|
|
94
68
|
});
|
|
95
69
|
}
|
|
96
70
|
}
|
|
71
|
+
exports.removeSegmentationRepresentation = removeSegmentationRepresentation;
|
|
97
72
|
function isSameFrameOfReference(viewport, referencedVolumeId) {
|
|
98
73
|
if (!referencedVolumeId) {
|
|
99
74
|
return true;
|
|
@@ -153,6 +128,7 @@ function render(viewport, representation, toolGroupConfig) {
|
|
|
153
128
|
_setLabelmapColorAndOpacity(viewport.id, actorEntry, cfun, ofun, colorLUTIndex, toolGroupConfig.representations[SegmentationRepresentations_1.default.Labelmap], representation, active, renderInactiveSegmentations, segmentsHidden);
|
|
154
129
|
});
|
|
155
130
|
}
|
|
131
|
+
exports.render = render;
|
|
156
132
|
function _setLabelmapColorAndOpacity(viewportId, actorEntry, cfun, ofun, colorLUTIndex, toolGroupLabelmapConfig, segmentationRepresentation, isActiveLabelmap, renderInactiveSegmentations, segmentsHidden) {
|
|
157
133
|
var _a;
|
|
158
134
|
const { segmentSpecificConfig, segmentationRepresentationSpecificConfig } = segmentationRepresentation;
|
|
@@ -285,8 +261,8 @@ function _addLabelmapToViewport(viewport, labelmapData, segmentationRepresentati
|
|
|
285
261
|
});
|
|
286
262
|
}
|
|
287
263
|
exports.default = {
|
|
264
|
+
getRepresentationRenderingConfig,
|
|
288
265
|
render,
|
|
289
|
-
addSegmentationRepresentation,
|
|
290
266
|
removeSegmentationRepresentation,
|
|
291
267
|
};
|
|
292
268
|
//# sourceMappingURL=labelmapDisplay.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"labelmapDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Labelmap/labelmapDisplay.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"labelmapDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Labelmap/labelmapDisplay.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { Types } from '@cornerstonejs/core';
|
|
2
|
-
import {
|
|
3
|
-
declare function addSegmentationRepresentation(toolGroupId: string, representationInput: RepresentationPublicInput, toolGroupSpecificConfig?: SegmentationRepresentationConfig): Promise<string>;
|
|
2
|
+
import { SegmentationRepresentationConfig, ToolGroupSpecificRepresentation } from '../../../types/SegmentationStateTypes';
|
|
4
3
|
declare function removeSegmentationRepresentation(toolGroupId: string, segmentationRepresentationUID: string, renderImmediate?: boolean): void;
|
|
5
4
|
declare function render(viewport: Types.IVolumeViewport, representation: ToolGroupSpecificRepresentation, toolGroupConfig: SegmentationRepresentationConfig): Promise<void>;
|
|
6
5
|
declare const _default: {
|
|
7
6
|
render: typeof render;
|
|
8
|
-
addSegmentationRepresentation: typeof addSegmentationRepresentation;
|
|
9
7
|
removeSegmentationRepresentation: typeof removeSegmentationRepresentation;
|
|
10
8
|
};
|
|
11
9
|
export default _default;
|
|
@@ -37,41 +37,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
37
37
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
38
|
const core_1 = require("@cornerstonejs/core");
|
|
39
39
|
const SegmentationState = __importStar(require("../../../stateManagement/segmentation/segmentationState"));
|
|
40
|
-
const SegmentationConfig = __importStar(require("../../../stateManagement/segmentation/config/segmentationConfig"));
|
|
41
40
|
const SegmentationRepresentations_1 = __importDefault(require("../../../enums/SegmentationRepresentations"));
|
|
42
41
|
const ToolGroupManager_1 = require("../../../store/ToolGroupManager");
|
|
43
42
|
const removeSurfaceFromElement_1 = __importDefault(require("./removeSurfaceFromElement"));
|
|
44
43
|
const addSurfaceToElement_1 = __importDefault(require("./addSurfaceToElement"));
|
|
45
|
-
function addSegmentationRepresentation(toolGroupId, representationInput, toolGroupSpecificConfig) {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const { segmentationId } = representationInput;
|
|
48
|
-
const segmentationRepresentationUID = core_1.utilities.uuidv4();
|
|
49
|
-
const segmentsHidden = new Set();
|
|
50
|
-
const colorLUTIndex = 0;
|
|
51
|
-
const active = true;
|
|
52
|
-
const toolGroupSpecificRepresentation = {
|
|
53
|
-
segmentationId,
|
|
54
|
-
segmentationRepresentationUID,
|
|
55
|
-
type: SegmentationRepresentations_1.default.Surface,
|
|
56
|
-
segmentsHidden,
|
|
57
|
-
colorLUTIndex,
|
|
58
|
-
active,
|
|
59
|
-
segmentationRepresentationSpecificConfig: {},
|
|
60
|
-
segmentSpecificConfig: {},
|
|
61
|
-
config: {},
|
|
62
|
-
};
|
|
63
|
-
if (toolGroupSpecificConfig) {
|
|
64
|
-
const currentToolGroupConfig = SegmentationConfig.getToolGroupSpecificConfig(toolGroupId);
|
|
65
|
-
const mergedConfig = core_1.utilities.deepMerge(currentToolGroupConfig, toolGroupSpecificConfig);
|
|
66
|
-
SegmentationConfig.setToolGroupSpecificConfig(toolGroupId, {
|
|
67
|
-
renderInactiveSegmentations: mergedConfig.renderInactiveSegmentations || true,
|
|
68
|
-
representations: Object.assign({}, mergedConfig.representations),
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
SegmentationState.addSegmentationRepresentation(toolGroupId, toolGroupSpecificRepresentation);
|
|
72
|
-
return segmentationRepresentationUID;
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
44
|
function removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID, renderImmediate = false) {
|
|
76
45
|
_removeSurfaceFromToolGroupViewports(toolGroupId, segmentationRepresentationUID);
|
|
77
46
|
SegmentationState.removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID);
|
|
@@ -134,7 +103,6 @@ function _removeSurfaceFromToolGroupViewports(toolGroupId, segmentationRepresent
|
|
|
134
103
|
}
|
|
135
104
|
exports.default = {
|
|
136
105
|
render,
|
|
137
|
-
addSegmentationRepresentation,
|
|
138
106
|
removeSegmentationRepresentation,
|
|
139
107
|
};
|
|
140
108
|
//# sourceMappingURL=surfaceDisplay.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"surfaceDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/surfaceDisplay.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"surfaceDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/surfaceDisplay.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
+
import type { Types } from '@cornerstonejs/core';
|
|
1
2
|
import * as Enums from '../enums';
|
|
2
3
|
import { ContourConfig, ContourRenderingConfig, ContourSegmentationData } from './ContourTypes';
|
|
3
4
|
import type { LabelmapConfig, LabelmapRenderingConfig, LabelmapSegmentationData } from './LabelmapTypes';
|
|
4
5
|
import { SurfaceSegmentationData, SurfaceRenderingConfig } from './SurfaceTypes';
|
|
5
|
-
export declare type Color = [number, number, number, number];
|
|
6
|
-
export declare type ColorLUT = Array<Color>;
|
|
7
6
|
export declare type SegmentSpecificRepresentationConfig = {
|
|
8
7
|
[key: number | string]: RepresentationConfig;
|
|
9
8
|
};
|
|
@@ -61,7 +60,7 @@ export declare type ToolGroupSpecificSurfaceRepresentation = ToolGroupSpecificRe
|
|
|
61
60
|
export declare type ToolGroupSpecificRepresentation = ToolGroupSpecificLabelmapRepresentation | ToolGroupSpecificContourRepresentation;
|
|
62
61
|
export declare type ToolGroupSpecificRepresentations = Array<ToolGroupSpecificRepresentation>;
|
|
63
62
|
export declare type SegmentationState = {
|
|
64
|
-
colorLUT: ColorLUT[];
|
|
63
|
+
colorLUT: Types.ColorLUT[];
|
|
65
64
|
segmentations: Segmentation[];
|
|
66
65
|
globalConfig: SegmentationRepresentationConfig;
|
|
67
66
|
toolGroups: {
|
|
@@ -81,4 +80,7 @@ export declare type SegmentationPublicInput = {
|
|
|
81
80
|
export declare type RepresentationPublicInput = {
|
|
82
81
|
segmentationId: string;
|
|
83
82
|
type: Enums.SegmentationRepresentations;
|
|
83
|
+
options?: {
|
|
84
|
+
colorLUTOrIndex?: Types.ColorLUT | number;
|
|
85
|
+
};
|
|
84
86
|
};
|
|
@@ -20,7 +20,7 @@ import type ScrollOptions from './ScrollOptions';
|
|
|
20
20
|
import type BoundsIJK from './BoundsIJK';
|
|
21
21
|
import type SVGDrawingHelper from './SVGDrawingHelper';
|
|
22
22
|
import type * as CINETypes from './CINETypes';
|
|
23
|
-
import type {
|
|
23
|
+
import type { RepresentationConfig, SegmentationRepresentationConfig, SegmentationRepresentationData, Segmentation, ToolGroupSpecificRepresentationState, ToolGroupSpecificContourRepresentation, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, SegmentationState, RepresentationPublicInput } from './SegmentationStateTypes';
|
|
24
24
|
import type ISynchronizerEventHandler from './ISynchronizerEventHandler';
|
|
25
25
|
import type { FloodFillGetter, FloodFillOptions, FloodFillResult } from './FloodFillTypes';
|
|
26
26
|
import type IToolClassReference from './IToolClassReference';
|
|
@@ -38,4 +38,4 @@ import type { ISpline } from './ISpline';
|
|
|
38
38
|
import type { SplineCurveSegment } from './SplineCurveSegment';
|
|
39
39
|
import type { SplineLineSegment } from './SplineLineSegment';
|
|
40
40
|
import type { SplineProps } from './SplineProps';
|
|
41
|
-
export type { Annotation, Annotations, IAnnotationManager, GroupSpecificAnnotations, AnnotationState, AnnotationStyle, ToolSpecificAnnotationTypes, JumpToSliceOptions, AnnotationGroupSelector, PlanarBoundingBox, ToolProps, PublicToolProps, ToolConfiguration, EventTypes, IPoints, ITouchPoints, IDistance, IToolBinding, SetToolBindingsType, ToolOptionsType, InteractionTypes, ToolAction, IToolGroup, IToolClassReference, ISynchronizerEventHandler, ToolHandle, AnnotationHandle, TextBoxHandle, Segmentation, SegmentationState, SegmentationRepresentationData, SegmentationRepresentationConfig, RepresentationConfig, ToolGroupSpecificRepresentationState, ToolGroupSpecificContourRepresentation, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, RepresentationPublicInput,
|
|
41
|
+
export type { Annotation, Annotations, IAnnotationManager, GroupSpecificAnnotations, AnnotationState, AnnotationStyle, ToolSpecificAnnotationTypes, JumpToSliceOptions, AnnotationGroupSelector, PlanarBoundingBox, ToolProps, PublicToolProps, ToolConfiguration, EventTypes, IPoints, ITouchPoints, IDistance, IToolBinding, SetToolBindingsType, ToolOptionsType, InteractionTypes, ToolAction, IToolGroup, IToolClassReference, ISynchronizerEventHandler, ToolHandle, AnnotationHandle, TextBoxHandle, Segmentation, SegmentationState, SegmentationRepresentationData, SegmentationRepresentationConfig, RepresentationConfig, ToolGroupSpecificRepresentationState, ToolGroupSpecificContourRepresentation, ToolGroupSpecificLabelmapRepresentation, ToolGroupSpecificRepresentation, RepresentationPublicInput, LabelmapTypes, SVGCursorDescriptor, SVGPoint, ScrollOptions, CINETypes, BoundsIJK, SVGDrawingHelper, FloodFillResult, FloodFillGetter, FloodFillOptions, ContourSegmentationData, Statistics, LabelmapToolOperationData, LabelmapToolOperationDataStack, LabelmapToolOperationDataVolume, CardinalSplineProps, ClosestControlPoint, ClosestPoint, ClosestSplinePoint, ControlPointInfo, ISpline, SplineCurveSegment, SplineLineSegment, SplineProps, };
|
|
@@ -1,46 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
import setAttributesIfNecessary from './setAttributesIfNecessary';
|
|
3
|
-
import setNewAttributesIfValid from './setNewAttributesIfValid';
|
|
1
|
+
import drawEllipseByCoordinates from './drawEllipseByCoordinates';
|
|
4
2
|
function drawEllipse(svgDrawingHelper, annotationUID, ellipseUID, corner1, corner2, options = {}, dataId = '') {
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
}, options);
|
|
11
|
-
const strokeWidth = lineWidth || width;
|
|
12
|
-
const svgns = 'http://www.w3.org/2000/svg';
|
|
13
|
-
const svgNodeHash = _getHash(annotationUID, 'ellipse', ellipseUID);
|
|
14
|
-
const existingEllipse = svgDrawingHelper.getSvgNode(svgNodeHash);
|
|
15
|
-
const w = Math.abs(corner1[0] - corner2[0]);
|
|
16
|
-
const h = Math.abs(corner1[1] - corner2[1]);
|
|
17
|
-
const xMin = Math.min(corner1[0], corner2[0]);
|
|
18
|
-
const yMin = Math.min(corner1[1], corner2[1]);
|
|
19
|
-
const center = [xMin + w / 2, yMin + h / 2];
|
|
20
|
-
const radiusX = w / 2;
|
|
21
|
-
const radiusY = h / 2;
|
|
22
|
-
const attributes = {
|
|
23
|
-
cx: `${center[0]}`,
|
|
24
|
-
cy: `${center[1]}`,
|
|
25
|
-
rx: `${radiusX}`,
|
|
26
|
-
ry: `${radiusY}`,
|
|
27
|
-
stroke: color,
|
|
28
|
-
fill: 'transparent',
|
|
29
|
-
'stroke-width': strokeWidth,
|
|
30
|
-
'stroke-dasharray': lineDash,
|
|
31
|
-
};
|
|
32
|
-
if (existingEllipse) {
|
|
33
|
-
setAttributesIfNecessary(attributes, existingEllipse);
|
|
34
|
-
svgDrawingHelper.setNodeTouched(svgNodeHash);
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
const svgEllipseElement = document.createElementNS(svgns, 'ellipse');
|
|
38
|
-
if (dataId !== '') {
|
|
39
|
-
svgEllipseElement.setAttribute('data-id', dataId);
|
|
40
|
-
}
|
|
41
|
-
setNewAttributesIfValid(attributes, svgEllipseElement);
|
|
42
|
-
svgDrawingHelper.appendNode(svgEllipseElement, svgNodeHash);
|
|
43
|
-
}
|
|
3
|
+
const top = [(corner1[0] + corner2[0]) / 2, corner1[1]];
|
|
4
|
+
const bottom = [(corner1[0] + corner2[0]) / 2, corner2[1]];
|
|
5
|
+
const left = [corner1[0], (corner1[1] + corner2[1]) / 2];
|
|
6
|
+
const right = [corner2[0], (corner1[1] + corner2[1]) / 2];
|
|
7
|
+
drawEllipseByCoordinates(svgDrawingHelper, annotationUID, ellipseUID, [bottom, top, left, right], options = {}, dataId = '');
|
|
44
8
|
}
|
|
45
9
|
export default drawEllipse;
|
|
46
10
|
//# sourceMappingURL=drawEllipse.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawEllipse.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawEllipse.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"drawEllipse.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawEllipse.ts"],"names":[],"mappings":"AAIA,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAElE,SAAS,WAAW,CAClB,gBAAkC,EAClC,aAAqB,EACrB,UAAkB,EAClB,OAAqB,EACrB,OAAqB,EACrB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE;IAEX,MAAM,GAAG,GAAiB,CAAE,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAE,CAAC;IACxE,MAAM,MAAM,GAAiB,CAAE,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAE,CAAC;IAC3E,MAAM,IAAI,GAAiB,CAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IACxE,MAAM,KAAK,GAAiB,CAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAEzE,wBAAwB,CACtB,gBAAgB,EAChB,aAAa,EACb,UAAU,EACV,CAAC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,EAC1B,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE,CACZ,CAAA;AACH,CAAC;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
2;
|
|
2
|
+
import _getHash from './_getHash';
|
|
3
|
+
import setAttributesIfNecessary from './setAttributesIfNecessary';
|
|
4
|
+
import setNewAttributesIfValid from './setNewAttributesIfValid';
|
|
5
|
+
function drawEllipseByCoordinates(svgDrawingHelper, annotationUID, ellipseUID, canvasCoordinates, options = {}, dataId = '') {
|
|
6
|
+
const { color, width, lineWidth, lineDash } = Object.assign({
|
|
7
|
+
color: 'dodgerblue',
|
|
8
|
+
width: '2',
|
|
9
|
+
lineWidth: undefined,
|
|
10
|
+
lineDash: undefined,
|
|
11
|
+
}, options);
|
|
12
|
+
const strokeWidth = lineWidth || width;
|
|
13
|
+
const svgns = 'http://www.w3.org/2000/svg';
|
|
14
|
+
const svgNodeHash = _getHash(annotationUID, 'ellipse', ellipseUID);
|
|
15
|
+
const existingEllipse = svgDrawingHelper.getSvgNode(svgNodeHash);
|
|
16
|
+
const [bottom, top, left, right] = canvasCoordinates;
|
|
17
|
+
const w = Math.hypot(left[0] - right[0], left[1] - right[1]);
|
|
18
|
+
const h = Math.hypot(top[0] - bottom[0], top[1] - bottom[1]);
|
|
19
|
+
const angle = Math.atan2(left[1] - right[1], left[0] - right[0]) * 180 / Math.PI;
|
|
20
|
+
const center = [(left[0] + right[0]) / 2, (top[1] + bottom[1]) / 2];
|
|
21
|
+
const radiusX = w / 2;
|
|
22
|
+
const radiusY = h / 2;
|
|
23
|
+
const attributes = {
|
|
24
|
+
cx: `${center[0]}`,
|
|
25
|
+
cy: `${center[1]}`,
|
|
26
|
+
rx: `${radiusX}`,
|
|
27
|
+
ry: `${radiusY}`,
|
|
28
|
+
stroke: color,
|
|
29
|
+
fill: 'transparent',
|
|
30
|
+
'transform': `rotate(${angle} ${center[0]} ${center[1]})`,
|
|
31
|
+
'stroke-width': strokeWidth,
|
|
32
|
+
'stroke-dasharray': lineDash,
|
|
33
|
+
};
|
|
34
|
+
if (existingEllipse) {
|
|
35
|
+
setAttributesIfNecessary(attributes, existingEllipse);
|
|
36
|
+
svgDrawingHelper.setNodeTouched(svgNodeHash);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
const svgEllipseElement = document.createElementNS(svgns, 'ellipse');
|
|
40
|
+
if (dataId !== '') {
|
|
41
|
+
svgEllipseElement.setAttribute('data-id', dataId);
|
|
42
|
+
}
|
|
43
|
+
setNewAttributesIfValid(attributes, svgEllipseElement);
|
|
44
|
+
svgDrawingHelper.appendNode(svgEllipseElement, svgNodeHash);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
export default drawEllipseByCoordinates;
|
|
48
|
+
//# sourceMappingURL=drawEllipseByCoordinates.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"drawEllipseByCoordinates.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawEllipseByCoordinates.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import draw from './draw';
|
|
2
2
|
import drawCircle from './drawCircle';
|
|
3
3
|
import drawEllipse from './drawEllipse';
|
|
4
|
+
import drawEllipseByCoordinates from './drawEllipseByCoordinates';
|
|
4
5
|
import drawHandles from './drawHandles';
|
|
5
6
|
import drawLine from './drawLine';
|
|
6
7
|
import drawPolyline from './drawPolyline';
|
|
@@ -11,5 +12,5 @@ import drawArrow from './drawArrow';
|
|
|
11
12
|
import drawRedactionRect from './drawRedactionRect';
|
|
12
13
|
import setAttributesIfNecessary from './setAttributesIfNecessary';
|
|
13
14
|
import setNewAttributesIfValid from './setNewAttributesIfValid';
|
|
14
|
-
export { draw, drawCircle, drawEllipse, drawHandles, drawLine, drawPolyline, drawLinkedTextBox, drawRect, drawTextBox, drawArrow, drawRedactionRect, setAttributesIfNecessary, setNewAttributesIfValid, };
|
|
15
|
+
export { draw, drawCircle, drawEllipse, drawEllipseByCoordinates, drawHandles, drawLine, drawPolyline, drawLinkedTextBox, drawRect, drawTextBox, drawArrow, drawRedactionRect, setAttributesIfNecessary, setNewAttributesIfValid, };
|
|
15
16
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/drawingSvg/index.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,QAAQ,CAAC;AAC1B,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAEhE,OAAO,EACL,IAAI,EACJ,UAAU,EACV,WAAW,EACX,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,iBAAiB,EACjB,QAAQ,EACR,WAAW,EACX,SAAS,EACT,iBAAiB,EACjB,wBAAwB,EACxB,uBAAuB,GACxB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/drawingSvg/index.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,QAAQ,CAAC;AAC1B,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAEhE,OAAO,EACL,IAAI,EACJ,UAAU,EACV,WAAW,EACX,wBAAwB,EACxB,WAAW,EACX,QAAQ,EACR,YAAY,EACZ,iBAAiB,EACjB,QAAQ,EACR,WAAW,EACX,SAAS,EACT,iBAAiB,EACjB,wBAAwB,EACxB,uBAAuB,GACxB,CAAC"}
|
|
@@ -27,6 +27,9 @@ function _imageChangeEventListener(evt) {
|
|
|
27
27
|
const { viewportId, renderingEngineId } = eventData;
|
|
28
28
|
const { viewport } = getEnabledElementByIds(viewportId, renderingEngineId);
|
|
29
29
|
const toolGroup = getToolGroupForViewport(viewportId, renderingEngineId);
|
|
30
|
+
if (!toolGroup) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
30
33
|
let toolGroupSegmentationRepresentations = SegmentationState.getSegmentationRepresentations(toolGroup.id) || [];
|
|
31
34
|
toolGroupSegmentationRepresentations =
|
|
32
35
|
toolGroupSegmentationRepresentations.filter((representation) => representation.type === Representations.Labelmap);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imageChangeEventListener.js","sourceRoot":"","sources":["../../../../src/eventListeners/segmentation/imageChangeEventListener.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,iBAAiB,EACjB,KAAK,EACL,sBAAsB,EACtB,KAAK,EACL,SAAS,GAGV,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,eAAe,MAAM,yCAAyC,CAAC;AACtE,OAAO,KAAK,iBAAiB,MAAM,sDAAsD,CAAC;AAE1F,OAAO,EAAE,oBAAoB,EAAE,MAAM,4DAA4D,CAAC;AAClG,OAAO,YAAY,MAAM,uCAAuC,CAAC;AACjE,OAAO,YAAY,MAAM,4CAA4C,CAAC;AACtE,OAAO,yBAAyB,MAAM,wDAAwD,CAAC;AAE/F,MAAM,MAAM,GAAG,UAAU,OAAuB;IAC9C,MAAM,EAAE,QAAQ,EAAE,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAEhD,IAAI,CAAC,CAAC,QAAQ,YAAY,aAAa,CAAC,EAAE;QACxC,OAAO;KACR;IAED,OAAO,CAAC,gBAAgB,CACtB,KAAK,CAAC,MAAM,CAAC,eAAe,EAC5B,yBAA0C,CAC3C,CAAC;IAEF,OAAO,CAAC,gBAAgB,CACtB,KAAK,CAAC,MAAM,CAAC,cAAc,EAC3B,yBAA0C,CAC3C,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,OAAO,GAAG,UAAU,OAAuB;IAC/C,MAAM,EAAE,QAAQ,EAAE,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAEhD,IAAI,CAAC,CAAC,QAAQ,YAAY,aAAa,CAAC,EAAE;QACxC,OAAO;KACR;IAED,OAAO,CAAC,mBAAmB,CACzB,KAAK,CAAC,MAAM,CAAC,eAAe,EAC5B,yBAA0C,CAC3C,CAAC;IACF,OAAO,CAAC,mBAAmB,CACzB,KAAK,CAAC,MAAM,CAAC,cAAc,EAC3B,yBAA0C,CAC3C,CAAC;AACJ,CAAC,CAAC;AAYF,SAAS,yBAAyB,CAAC,GAAG;IACpC,MAAM,SAAS,GAAG,GAAG,CAAC,MAAM,CAAC;IAC7B,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,GAAG,SAAS,CAAC;IACpD,MAAM,EAAE,QAAQ,EAAE,GAAG,sBAAsB,CACzC,UAAU,EACV,iBAAiB,CACoB,CAAC;IAExC,MAAM,SAAS,GAAG,uBAAuB,CAAC,UAAU,EAAE,iBAAiB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"imageChangeEventListener.js","sourceRoot":"","sources":["../../../../src/eventListeners/segmentation/imageChangeEventListener.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { utilities as csUtils } from '@cornerstonejs/core';
|
|
2
1
|
import cloneDeep from 'lodash.clonedeep';
|
|
3
|
-
import
|
|
2
|
+
import { utilities as csUtils } from '@cornerstonejs/core';
|
|
4
3
|
import { SegmentationRepresentations } from '../../enums';
|
|
5
4
|
import getDefaultContourConfig from '../../tools/displayTools/Contour/contourConfig';
|
|
6
5
|
import getDefaultLabelmapConfig from '../../tools/displayTools/Labelmap/labelmapConfig';
|
|
@@ -36,6 +35,9 @@ export default class SegmentationStateManager {
|
|
|
36
35
|
getColorLUT(lutIndex) {
|
|
37
36
|
return this.state.colorLUT[lutIndex];
|
|
38
37
|
}
|
|
38
|
+
getNextColorLUTIndex() {
|
|
39
|
+
return this.state.colorLUT.length;
|
|
40
|
+
}
|
|
39
41
|
resetState() {
|
|
40
42
|
this.state = cloneDeep(initialDefaultState);
|
|
41
43
|
}
|
|
@@ -43,7 +45,6 @@ export default class SegmentationStateManager {
|
|
|
43
45
|
return this.state.segmentations.find((segmentation) => segmentation.segmentationId === segmentationId);
|
|
44
46
|
}
|
|
45
47
|
addSegmentation(segmentation) {
|
|
46
|
-
this._initDefaultColorLUTIfNecessary();
|
|
47
48
|
if (this.getSegmentation(segmentation.segmentationId)) {
|
|
48
49
|
throw new Error(`Segmentation with id ${segmentation.segmentationId} already exists`);
|
|
49
50
|
}
|
|
@@ -172,9 +173,9 @@ export default class SegmentationStateManager {
|
|
|
172
173
|
}
|
|
173
174
|
addColorLUT(colorLUT, lutIndex) {
|
|
174
175
|
if (this.state.colorLUT[lutIndex]) {
|
|
175
|
-
console.
|
|
176
|
+
console.warn('Color LUT table already exists, overwriting');
|
|
176
177
|
}
|
|
177
|
-
this.state.colorLUT[lutIndex] = colorLUT;
|
|
178
|
+
this.state.colorLUT[lutIndex] = structuredClone(colorLUT);
|
|
178
179
|
}
|
|
179
180
|
removeColorLUT(colorLUTIndex) {
|
|
180
181
|
delete this.state.colorLUT[colorLUTIndex];
|
|
@@ -202,11 +203,6 @@ export default class SegmentationStateManager {
|
|
|
202
203
|
});
|
|
203
204
|
}
|
|
204
205
|
}
|
|
205
|
-
_initDefaultColorLUTIfNecessary() {
|
|
206
|
-
if (this.state.colorLUT.length === 0 || !this.state.colorLUT[0]) {
|
|
207
|
-
this.addColorLUT(CORNERSTONE_COLOR_LUT, 0);
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
206
|
}
|
|
211
207
|
const defaultSegmentationStateManager = new SegmentationStateManager('DEFAULT');
|
|
212
208
|
export { defaultSegmentationStateManager };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SegmentationStateManager.js","sourceRoot":"","sources":["../../../../src/stateManagement/segmentation/SegmentationStateManager.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"SegmentationStateManager.js","sourceRoot":"","sources":["../../../../src/stateManagement/segmentation/SegmentationStateManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { utilities } from '@cornerstonejs/core';
|
|
2
|
+
import Representations from '../../enums/SegmentationRepresentations';
|
|
3
|
+
import * as SegmentationConfig from './config/segmentationConfig';
|
|
4
|
+
import { addSegmentationRepresentation as addSegmentationRepresentationToState, getNextColorLUTIndex, addColorLUT, } from './segmentationState';
|
|
5
|
+
import { getRepresentationSpecificConfig } from './helpers/getRepresentationSpecificConfig';
|
|
6
|
+
import CORNERSTONE_COLOR_LUT from '../../constants/COLOR_LUT';
|
|
7
|
+
async function addSegmentationRepresentation(toolGroupId, representationInput, toolGroupSpecificConfig) {
|
|
8
|
+
const { segmentationId, options = {} } = representationInput;
|
|
9
|
+
const segmentationRepresentationUID = utilities.uuidv4();
|
|
10
|
+
const segmentsHidden = new Set();
|
|
11
|
+
const colorLUTOrIndexInput = options.colorLUTOrIndex;
|
|
12
|
+
let colorLUTIndexToUse;
|
|
13
|
+
if (typeof colorLUTOrIndexInput === 'number') {
|
|
14
|
+
colorLUTIndexToUse = colorLUTOrIndexInput;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
const nextIndex = getNextColorLUTIndex();
|
|
18
|
+
const colorLUTToAdd = Array.isArray(colorLUTOrIndexInput)
|
|
19
|
+
? colorLUTOrIndexInput
|
|
20
|
+
: CORNERSTONE_COLOR_LUT;
|
|
21
|
+
addColorLUT(colorLUTToAdd, nextIndex);
|
|
22
|
+
colorLUTIndexToUse = nextIndex;
|
|
23
|
+
}
|
|
24
|
+
const toolGroupSpecificRepresentation = {
|
|
25
|
+
segmentationId,
|
|
26
|
+
segmentationRepresentationUID,
|
|
27
|
+
type: Representations.Labelmap,
|
|
28
|
+
segmentsHidden,
|
|
29
|
+
colorLUTIndex: colorLUTIndexToUse,
|
|
30
|
+
active: true,
|
|
31
|
+
segmentationRepresentationSpecificConfig: {},
|
|
32
|
+
segmentSpecificConfig: {},
|
|
33
|
+
config: getRepresentationSpecificConfig(representationInput),
|
|
34
|
+
};
|
|
35
|
+
if (toolGroupSpecificConfig) {
|
|
36
|
+
const currentToolGroupConfig = SegmentationConfig.getToolGroupSpecificConfig(toolGroupId);
|
|
37
|
+
const mergedConfig = utilities.deepMerge(currentToolGroupConfig, toolGroupSpecificConfig);
|
|
38
|
+
SegmentationConfig.setToolGroupSpecificConfig(toolGroupId, {
|
|
39
|
+
renderInactiveSegmentations: mergedConfig.renderInactiveSegmentations || true,
|
|
40
|
+
representations: {
|
|
41
|
+
...mergedConfig.representations,
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
addSegmentationRepresentationToState(toolGroupId, toolGroupSpecificRepresentation);
|
|
46
|
+
return segmentationRepresentationUID;
|
|
47
|
+
}
|
|
48
|
+
export { addSegmentationRepresentation };
|
|
49
|
+
//# sourceMappingURL=addSegmentationRepresentation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addSegmentationRepresentation.js","sourceRoot":"","sources":["../../../../src/stateManagement/segmentation/addSegmentationRepresentation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAOhD,OAAO,eAAe,MAAM,yCAAyC,CAAC;AACtE,OAAO,KAAK,kBAAkB,MAAM,6BAA6B,CAAC;AAClE,OAAO,EACL,6BAA6B,IAAI,oCAAoC,EACrE,oBAAoB,EACpB,WAAW,GACZ,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,+BAA+B,EAAE,MAAM,2CAA2C,CAAC;AAC5F,OAAO,qBAAqB,MAAM,2BAA2B,CAAC;AAE9D,KAAK,UAAU,6BAA6B,CAC1C,WAAmB,EACnB,mBAA8C,EAC9C,uBAA0D;IAE1D,MAAM,EAAE,cAAc,EAAE,OAAO,GAAG,EAAE,EAAE,GAAG,mBAAmB,CAAC;IAC7D,MAAM,6BAA6B,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;IAIzD,MAAM,cAAc,GAAG,IAAI,GAAG,EAAiB,CAAC;IAEhD,MAAM,oBAAoB,GAAG,OAAO,CAAC,eAAe,CAAC;IACrD,IAAI,kBAAkB,CAAC;IAEvB,IAAI,OAAO,oBAAoB,KAAK,QAAQ,EAAE;QAC5C,kBAAkB,GAAG,oBAAoB,CAAC;KAC3C;SAAM;QACL,MAAM,SAAS,GAAG,oBAAoB,EAAE,CAAC;QACzC,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,oBAAoB,CAAC;YACvD,CAAC,CAAC,oBAAoB;YACtB,CAAC,CAAC,qBAAqB,CAAC;QAC1B,WAAW,CAAC,aAA+B,EAAE,SAAS,CAAC,CAAC;QACxD,kBAAkB,GAAG,SAAS,CAAC;KAChC;IAED,MAAM,+BAA+B,GAAoC;QACvE,cAAc;QACd,6BAA6B;QAC7B,IAAI,EAAE,eAAe,CAAC,QAAQ;QAC9B,cAAc;QACd,aAAa,EAAE,kBAAkB;QACjC,MAAM,EAAE,IAAI;QACZ,wCAAwC,EAAE,EAAE;QAC5C,qBAAqB,EAAE,EAAE;QACzB,MAAM,EAAE,+BAA+B,CAAC,mBAAmB,CAAC;KAC7D,CAAC;IAGF,IAAI,uBAAuB,EAAE;QAI3B,MAAM,sBAAsB,GAC1B,kBAAkB,CAAC,0BAA0B,CAAC,WAAW,CAAC,CAAC;QAE7D,MAAM,YAAY,GAAG,SAAS,CAAC,SAAS,CACtC,sBAAsB,EACtB,uBAAuB,CACxB,CAAC;QAEF,kBAAkB,CAAC,0BAA0B,CAAC,WAAW,EAAE;YACzD,2BAA2B,EACzB,YAAY,CAAC,2BAA2B,IAAI,IAAI;YAClD,eAAe,EAAE;gBACf,GAAG,YAAY,CAAC,eAAe;aAChC;SACF,CAAC,CAAC;KACJ;IAED,oCAAoC,CAClC,WAAW,EACX,+BAA+B,CAChC,CAAC;IAEF,OAAO,6BAA6B,CAAC;AACvC,CAAC;AAED,OAAO,EAAE,6BAA6B,EAAE,CAAC"}
|