@cornerstonejs/tools 0.53.1 → 0.54.1
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/drawLine.js +3 -1
- package/dist/cjs/drawingSvg/drawLine.js.map +1 -1
- package/dist/cjs/drawingSvg/drawTextBox.js +3 -3
- package/dist/cjs/drawingSvg/drawTextBox.js.map +1 -1
- package/dist/cjs/store/addEnabledElement.js +5 -4
- package/dist/cjs/store/addEnabledElement.js.map +1 -1
- package/dist/cjs/utilities/segmentation/index.d.ts +2 -1
- package/dist/cjs/utilities/segmentation/index.js +3 -1
- package/dist/cjs/utilities/segmentation/index.js.map +1 -1
- package/dist/cjs/utilities/segmentation/rectangleROIThresholdVolumeByRange.d.ts +1 -5
- package/dist/cjs/utilities/segmentation/rectangleROIThresholdVolumeByRange.js.map +1 -1
- package/dist/cjs/utilities/segmentation/thresholdSegmentationByRange.d.ts +4 -0
- package/dist/cjs/utilities/segmentation/thresholdSegmentationByRange.js +54 -0
- package/dist/cjs/utilities/segmentation/thresholdSegmentationByRange.js.map +1 -0
- package/dist/cjs/utilities/segmentation/thresholdVolumeByRange.d.ts +1 -5
- package/dist/cjs/utilities/segmentation/thresholdVolumeByRange.js +4 -49
- package/dist/cjs/utilities/segmentation/thresholdVolumeByRange.js.map +1 -1
- package/dist/cjs/utilities/segmentation/utilities.d.ts +11 -0
- package/dist/cjs/utilities/segmentation/utilities.js +55 -0
- package/dist/cjs/utilities/segmentation/utilities.js.map +1 -1
- package/dist/esm/drawingSvg/drawLine.js +3 -1
- package/dist/esm/drawingSvg/drawLine.js.map +1 -1
- package/dist/esm/drawingSvg/drawTextBox.js +3 -3
- package/dist/esm/drawingSvg/drawTextBox.js.map +1 -1
- package/dist/esm/store/addEnabledElement.js +5 -4
- package/dist/esm/store/addEnabledElement.js.map +1 -1
- package/dist/esm/utilities/segmentation/index.d.ts +2 -1
- package/dist/esm/utilities/segmentation/index.js +2 -1
- package/dist/esm/utilities/segmentation/index.js.map +1 -1
- package/dist/esm/utilities/segmentation/rectangleROIThresholdVolumeByRange.d.ts +1 -5
- package/dist/esm/utilities/segmentation/rectangleROIThresholdVolumeByRange.js.map +1 -1
- package/dist/esm/utilities/segmentation/thresholdSegmentationByRange.d.ts +4 -0
- package/dist/esm/utilities/segmentation/thresholdSegmentationByRange.js +52 -0
- package/dist/esm/utilities/segmentation/thresholdSegmentationByRange.js.map +1 -0
- package/dist/esm/utilities/segmentation/thresholdVolumeByRange.d.ts +1 -5
- package/dist/esm/utilities/segmentation/thresholdVolumeByRange.js +3 -45
- package/dist/esm/utilities/segmentation/thresholdVolumeByRange.js.map +1 -1
- package/dist/esm/utilities/segmentation/utilities.d.ts +11 -0
- package/dist/esm/utilities/segmentation/utilities.js +52 -0
- package/dist/esm/utilities/segmentation/utilities.js.map +1 -1
- package/dist/umd/index.js +1 -2
- package/dist/umd/index.js.map +1 -1
- package/package.json +2 -2
- package/dist/umd/index.js.LICENSE.txt +0 -6
|
@@ -21,7 +21,9 @@ function drawLine(svgDrawingHelper, annotationUID, lineUID, start, end, options
|
|
|
21
21
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
22
22
|
const svgNodeHash = (0, _getHash_1.default)(annotationUID, 'line', lineUID);
|
|
23
23
|
const existingLine = svgDrawingHelper.getSvgNode(svgNodeHash);
|
|
24
|
-
const dropShadowStyle = shadow
|
|
24
|
+
const dropShadowStyle = shadow
|
|
25
|
+
? `filter:url(#shadow-${svgDrawingHelper.svgLayerElement.id});`
|
|
26
|
+
: '';
|
|
25
27
|
const attributes = {
|
|
26
28
|
x1: `${start[0]}`,
|
|
27
29
|
y1: `${start[1]}`,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawLine.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawLine.ts"],"names":[],"mappings":";;;;;AAEA,0DAAkC;AAClC,0FAAkE;AAClE,4FAAoE;AAGpE,SAAwB,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,KAAmB,EACnB,GAAiB,EACjB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE;IAGX,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QACxE,OAAO;KACR;IAED,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CACjE;QACE,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,GAAG;QACV,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,SAAS;QACnB,MAAM,EAAE,SAAS;KAClB,EACD,OAAO,CACR,CAAC;IAGF,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,IAAA,kBAAQ,EAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,MAAM,eAAe,GAAG,MAAM,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"drawLine.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawLine.ts"],"names":[],"mappings":";;;;;AAEA,0DAAkC;AAClC,0FAAkE;AAClE,4FAAoE;AAGpE,SAAwB,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,KAAmB,EACnB,GAAiB,EACjB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE;IAGX,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QACxE,OAAO;KACR;IAED,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CACjE;QACE,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,GAAG;QACV,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,SAAS;QACnB,MAAM,EAAE,SAAS;KAClB,EACD,OAAO,CACR,CAAC;IAGF,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,IAAA,kBAAQ,EAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,MAAM,eAAe,GAAG,MAAM;QAC5B,CAAC,CAAC,sBAAsB,gBAAgB,CAAC,eAAe,CAAC,EAAE,IAAI;QAC/D,CAAC,CAAC,EAAE,CAAC;IAEP,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE;QACjB,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE;QACjB,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE;QACf,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE;QACf,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,eAAe;QACtB,cAAc,EAAE,WAAW;QAC3B,kBAAkB,EAAE,QAAQ;KAC7B,CAAC;IAEF,IAAI,YAAY,EAAE;QAEhB,IAAA,mCAAyB,EAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAEpD,gBAAgB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;KAC9C;SAAM;QACL,MAAM,OAAO,GAAG,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAExD,IAAI,MAAM,KAAK,EAAE,EAAE;YACjB,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;SACzC;QAED,IAAA,kCAAwB,EAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAE9C,gBAAgB,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;KACnD;AACH,CAAC;AA9DD,2BA8DC"}
|
|
@@ -58,7 +58,7 @@ function _drawTextGroup(svgDrawingHelper, annotationUID, textUID, textLines = ['
|
|
|
58
58
|
else {
|
|
59
59
|
const textGroup = document.createElementNS(svgns, 'g');
|
|
60
60
|
textGroup.setAttribute('transform', `translate(${x} ${y})`);
|
|
61
|
-
const textElement = _createTextElement(options);
|
|
61
|
+
const textElement = _createTextElement(svgDrawingHelper, options);
|
|
62
62
|
for (let i = 0; i < textLines.length; i++) {
|
|
63
63
|
const textLine = textLines[i];
|
|
64
64
|
const textSpan = _createTextSpan(textLine);
|
|
@@ -75,12 +75,12 @@ function _drawTextGroup(svgDrawingHelper, annotationUID, textUID, textLines = ['
|
|
|
75
75
|
width: textGroupBoundingBox.width + padding,
|
|
76
76
|
});
|
|
77
77
|
}
|
|
78
|
-
function _createTextElement(options) {
|
|
78
|
+
function _createTextElement(svgDrawingHelper, options) {
|
|
79
79
|
const { color, fontFamily, fontSize } = options;
|
|
80
80
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
81
81
|
const textElement = document.createElementNS(svgns, 'text');
|
|
82
82
|
const noSelectStyle = 'user-select: none; pointer-events: none; -webkit-tap-highlight-color: rgba(255, 255, 255, 0);';
|
|
83
|
-
const dropShadowStyle =
|
|
83
|
+
const dropShadowStyle = `filter:url(#shadow-${svgDrawingHelper.svgLayerElement.id});`;
|
|
84
84
|
const combinedStyle = `${noSelectStyle}${dropShadowStyle}`;
|
|
85
85
|
textElement.setAttribute('x', '0');
|
|
86
86
|
textElement.setAttribute('y', '0');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawTextBox.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawTextBox.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"drawTextBox.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawTextBox.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@ const state_1 = require("./state");
|
|
|
6
6
|
const triggerAnnotationRender_1 = require("../utilities/triggerAnnotationRender");
|
|
7
7
|
function addEnabledElement(evt) {
|
|
8
8
|
const { element, viewportId } = evt.detail;
|
|
9
|
-
const svgLayer = _createSvgAnnotationLayer();
|
|
9
|
+
const svgLayer = _createSvgAnnotationLayer(viewportId);
|
|
10
10
|
_setSvgNodeCache(element);
|
|
11
11
|
_appendChild(svgLayer, element);
|
|
12
12
|
triggerAnnotationRender_1.annotationRenderingEngine.addViewportElement(viewportId, element);
|
|
@@ -23,11 +23,12 @@ function addEnabledElement(evt) {
|
|
|
23
23
|
state_1.state.enabledElements.push(element);
|
|
24
24
|
}
|
|
25
25
|
exports.default = addEnabledElement;
|
|
26
|
-
function _createSvgAnnotationLayer() {
|
|
26
|
+
function _createSvgAnnotationLayer(viewportId) {
|
|
27
27
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
28
28
|
const svgLayer = document.createElementNS(svgns, 'svg');
|
|
29
|
+
const svgLayerId = `svg-layer-${viewportId}`;
|
|
29
30
|
svgLayer.classList.add('svg-layer');
|
|
30
|
-
svgLayer.setAttribute('id',
|
|
31
|
+
svgLayer.setAttribute('id', svgLayerId);
|
|
31
32
|
svgLayer.setAttribute('xmlns', 'http://www.w3.org/2000/svg');
|
|
32
33
|
svgLayer.style.width = '100%';
|
|
33
34
|
svgLayer.style.height = '100%';
|
|
@@ -38,7 +39,7 @@ function _createSvgAnnotationLayer() {
|
|
|
38
39
|
const feOffset = document.createElementNS(svgns, 'feOffset');
|
|
39
40
|
const feColorMatrix = document.createElementNS(svgns, 'feColorMatrix');
|
|
40
41
|
const feBlend = document.createElementNS(svgns, 'feBlend');
|
|
41
|
-
filter.setAttribute('id',
|
|
42
|
+
filter.setAttribute('id', `shadow-${svgLayerId}`);
|
|
42
43
|
filter.setAttribute('filterUnits', 'userSpaceOnUse');
|
|
43
44
|
feOffset.setAttribute('result', 'offOut');
|
|
44
45
|
feOffset.setAttribute('in', 'SourceGraphic');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addEnabledElement.js","sourceRoot":"","sources":["../../../src/store/addEnabledElement.ts"],"names":[],"mappings":";;AACA,sDAK2B;AAC3B,0DAO6B;AAC7B,mCAAgC;AAEhC,kFAAiF;AAQjF,SAAwB,iBAAiB,CACvC,GAAyC;IAEzC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC;IAC3C,MAAM,QAAQ,GAAG,yBAAyB,
|
|
1
|
+
{"version":3,"file":"addEnabledElement.js","sourceRoot":"","sources":["../../../src/store/addEnabledElement.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,4 +8,5 @@ import { triggerSegmentationRender } from './triggerSegmentationRender';
|
|
|
8
8
|
import floodFill from './floodFill';
|
|
9
9
|
import { getBrushSizeForToolGroup, setBrushSizeForToolGroup } from './brushSizeForToolGroup';
|
|
10
10
|
import { getBrushThresholdForToolGroup, setBrushThresholdForToolGroup } from './brushThresholdForToolGroup';
|
|
11
|
-
|
|
11
|
+
import thresholdSegmentationByRange from './thresholdSegmentationByRange';
|
|
12
|
+
export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, thresholdSegmentationByRange, };
|
|
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.setBrushThresholdForToolGroup = exports.getBrushThresholdForToolGroup = exports.setBrushSizeForToolGroup = exports.getBrushSizeForToolGroup = exports.floodFill = exports.triggerSegmentationRender = exports.rectangleROIThresholdVolumeByRange = exports.createLabelmapVolumeForViewport = exports.getDefaultRepresentationConfig = exports.isValidRepresentationConfig = exports.createMergedLabelmapForIndex = exports.thresholdVolumeByRange = void 0;
|
|
6
|
+
exports.thresholdSegmentationByRange = exports.setBrushThresholdForToolGroup = exports.getBrushThresholdForToolGroup = exports.setBrushSizeForToolGroup = exports.getBrushSizeForToolGroup = exports.floodFill = exports.triggerSegmentationRender = exports.rectangleROIThresholdVolumeByRange = exports.createLabelmapVolumeForViewport = exports.getDefaultRepresentationConfig = exports.isValidRepresentationConfig = exports.createMergedLabelmapForIndex = exports.thresholdVolumeByRange = void 0;
|
|
7
7
|
const thresholdVolumeByRange_1 = __importDefault(require("./thresholdVolumeByRange"));
|
|
8
8
|
exports.thresholdVolumeByRange = thresholdVolumeByRange_1.default;
|
|
9
9
|
const rectangleROIThresholdVolumeByRange_1 = __importDefault(require("./rectangleROIThresholdVolumeByRange"));
|
|
@@ -26,4 +26,6 @@ Object.defineProperty(exports, "setBrushSizeForToolGroup", { enumerable: true, g
|
|
|
26
26
|
const brushThresholdForToolGroup_1 = require("./brushThresholdForToolGroup");
|
|
27
27
|
Object.defineProperty(exports, "getBrushThresholdForToolGroup", { enumerable: true, get: function () { return brushThresholdForToolGroup_1.getBrushThresholdForToolGroup; } });
|
|
28
28
|
Object.defineProperty(exports, "setBrushThresholdForToolGroup", { enumerable: true, get: function () { return brushThresholdForToolGroup_1.setBrushThresholdForToolGroup; } });
|
|
29
|
+
const thresholdSegmentationByRange_1 = __importDefault(require("./thresholdSegmentationByRange"));
|
|
30
|
+
exports.thresholdSegmentationByRange = thresholdSegmentationByRange_1.default;
|
|
29
31
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":";;;;;;AAAA,sFAA8D;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":";;;;;;AAAA,sFAA8D;AAmB5D,iCAnBK,gCAAsB,CAmBL;AAlBxB,8GAAsF;AAuBpF,6CAvBK,4CAAkC,CAuBL;AAtBpC,kGAA0E;AAkBxE,uCAlBK,sCAA4B,CAkBL;AAjB9B,gGAAwE;AAkBtE,sCAlBK,qCAA2B,CAkBL;AAjB7B,sGAA8E;AAkB5E,yCAlBK,wCAA8B,CAkBL;AAjBhC,wGAAgF;AAkB9E,0CAlBK,yCAA+B,CAkBL;AAjBjC,2EAAwE;AAmBtE,0GAnBO,qDAAyB,OAmBP;AAlB3B,4DAAoC;AAmBlC,oBAnBK,mBAAS,CAmBL;AAlBX,mEAGiC;AAgB/B,yGAlBA,gDAAwB,OAkBA;AACxB,yGAlBA,gDAAwB,OAkBA;AAhB1B,6EAGsC;AAcpC,8GAhBA,0DAA6B,OAgBA;AAC7B,8GAhBA,0DAA6B,OAgBA;AAd/B,kGAA0E;AAexE,uCAfK,sCAA4B,CAeL"}
|
|
@@ -1,9 +1,5 @@
|
|
|
1
1
|
import type { Types } from '@cornerstonejs/core';
|
|
2
|
-
|
|
3
|
-
volume: Types.IImageVolume;
|
|
4
|
-
lower: number;
|
|
5
|
-
upper: number;
|
|
6
|
-
};
|
|
2
|
+
import { ThresholdInformation } from './utilities';
|
|
7
3
|
export declare type ThresholdOptions = {
|
|
8
4
|
numSlicesToProject?: number;
|
|
9
5
|
overwrite: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rectangleROIThresholdVolumeByRange.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/rectangleROIThresholdVolumeByRange.ts"],"names":[],"mappings":";;;;;AACA,iEAAyD;AACzD,uCAGqB;AAErB,sFAA8D;AAC9D,oIAA4G;
|
|
1
|
+
{"version":3,"file":"rectangleROIThresholdVolumeByRange.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/rectangleROIThresholdVolumeByRange.ts"],"names":[],"mappings":";;;;;AACA,iEAAyD;AACzD,uCAGqB;AAErB,sFAA8D;AAC9D,oIAA4G;AA+B5G,SAAS,kCAAkC,CACzC,cAAwB,EACxB,kBAAsC,EACtC,0BAAkD,EAClD,OAAyB;IAEzB,MAAM,WAAW,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE;QACvD,OAAO,kBAAK,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,oBAAoB,CAAC,WAAW,CAAC,CAAC;IAElC,IAAI,SAAS,CAAC;IACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,0BAA0B,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAE1D,MAAM,UAAU,GACd,0BAA0B,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,MAAM,CAAC;QAC9D,IAAI,UAAU,KAAK,kBAAkB,CAAC,aAAa,EAAE,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,EAAE;YACvE,SAAS,GAAG,IAAA,8CAAoC,EAC9C,WAAW,EACX,0BAA0B,CAAC,CAAC,CAAC,CAAC,MAAM,EACpC,OAAO,CACR,CAAC;SACH;KACF;IAED,MAAM,wBAAwB,GAAG,IAAA,gCAAsB,EACrD,kBAAkB,EAClB,0BAA0B,kCACrB,OAAO,KAAE,SAAS,IACxB,CAAC;IAEF,OAAO,wBAAwB,CAAC;AAClC,CAAC;AAED,SAAS,oBAAoB,CAAC,WAAW;IACvC,MAAM,cAAc,GAAG;QACrB,iCAAyB,CAAC,QAAQ;QAClC,yCAAiC,CAAC,QAAQ;KAC3C,CAAC;IAEF,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;QACpC,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YAClC,MAAM,IAAI,KAAK,CACb,sHAAsH,CACvH,CAAC;SACH;KACF;AACH,CAAC;AAED,kBAAe,kCAAkC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Types } from '@cornerstonejs/core';
|
|
2
|
+
import { ThresholdInformation } from './utilities';
|
|
3
|
+
declare function thresholdSegmentationByRange(segmentationVolume: Types.IImageVolume, segmentationIndex: number, thresholdVolumeInformation: ThresholdInformation[], overlapType: number): Types.IImageVolume;
|
|
4
|
+
export default thresholdSegmentationByRange;
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const utilities_1 = require("../../utilities");
|
|
4
|
+
const triggerSegmentationEvents_1 = require("../../stateManagement/segmentation/triggerSegmentationEvents");
|
|
5
|
+
const utilities_2 = require("./utilities");
|
|
6
|
+
function thresholdSegmentationByRange(segmentationVolume, segmentationIndex, thresholdVolumeInformation, overlapType) {
|
|
7
|
+
const scalarData = segmentationVolume.getScalarData();
|
|
8
|
+
const { baseVolumeIdx, volumeInfoList } = (0, utilities_2.processVolumes)(segmentationVolume, thresholdVolumeInformation);
|
|
9
|
+
volumeInfoList.forEach((volumeInfo) => {
|
|
10
|
+
const { volumeSize } = volumeInfo;
|
|
11
|
+
if (volumeSize === scalarData.length) {
|
|
12
|
+
_handleSameSizeVolume(scalarData, segmentationIndex, volumeInfo);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
_handleDifferentSizeVolume(scalarData, segmentationIndex, volumeInfo, volumeInfoList, baseVolumeIdx, overlapType);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
(0, triggerSegmentationEvents_1.triggerSegmentationDataModified)(segmentationVolume.volumeId);
|
|
19
|
+
return segmentationVolume;
|
|
20
|
+
}
|
|
21
|
+
function _handleDifferentSizeVolume(scalarData, segmentationIndex, volumeInfo, volumeInfoList, baseVolumeIdx, overlapType) {
|
|
22
|
+
const { imageData, lower, upper, dimensions } = volumeInfo;
|
|
23
|
+
let total, overlaps, range;
|
|
24
|
+
for (let i = 0; i < scalarData.length; i++) {
|
|
25
|
+
if (scalarData[i] === segmentationIndex) {
|
|
26
|
+
const overlapBounds = (0, utilities_2.getVoxelOverlap)(imageData, dimensions, volumeInfoList[baseVolumeIdx].spacing, volumeInfoList[baseVolumeIdx].imageData.getPoint(i));
|
|
27
|
+
const callbackOverlap = ({ value }) => {
|
|
28
|
+
total = total + 1;
|
|
29
|
+
if (value >= range.lower && value <= range.upper) {
|
|
30
|
+
overlaps = overlaps + 1;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
total = 0;
|
|
34
|
+
overlaps = 0;
|
|
35
|
+
range = { lower, upper };
|
|
36
|
+
let overlapTest = false;
|
|
37
|
+
(0, utilities_1.pointInShapeCallback)(imageData, () => true, callbackOverlap, overlapBounds);
|
|
38
|
+
overlapTest = overlapType === 0 ? overlaps > 0 : overlaps === total;
|
|
39
|
+
scalarData[i] = overlapTest ? segmentationIndex : 0;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return { total, range, overlaps };
|
|
43
|
+
}
|
|
44
|
+
function _handleSameSizeVolume(scalarData, segmentationIndex, volumeInfo) {
|
|
45
|
+
const { referenceValues, lower, upper } = volumeInfo;
|
|
46
|
+
for (let i = 0; i < scalarData.length; i++) {
|
|
47
|
+
if (scalarData[i] === segmentationIndex) {
|
|
48
|
+
const value = referenceValues[i];
|
|
49
|
+
scalarData[i] = value >= lower && value <= upper ? segmentationIndex : 0;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
exports.default = thresholdSegmentationByRange;
|
|
54
|
+
//# sourceMappingURL=thresholdSegmentationByRange.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"thresholdSegmentationByRange.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/thresholdSegmentationByRange.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,10 @@
|
|
|
1
1
|
import { Types } from '@cornerstonejs/core';
|
|
2
2
|
import { BoundsIJK } from '../../types';
|
|
3
|
+
import { ThresholdInformation } from './utilities';
|
|
3
4
|
export declare type ThresholdRangeOptions = {
|
|
4
5
|
overwrite: boolean;
|
|
5
6
|
boundsIJK: BoundsIJK;
|
|
6
7
|
overlapType?: number;
|
|
7
8
|
};
|
|
8
|
-
export declare type ThresholdInformation = {
|
|
9
|
-
volume: Types.IImageVolume;
|
|
10
|
-
lower: number;
|
|
11
|
-
upper: number;
|
|
12
|
-
};
|
|
13
9
|
declare function thresholdVolumeByRange(segmentationVolume: Types.IImageVolume, thresholdVolumeInformation: ThresholdInformation[], options: ThresholdRangeOptions): Types.IImageVolume;
|
|
14
10
|
export default thresholdVolumeByRange;
|
|
@@ -1,17 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const core_1 = require("@cornerstonejs/core");
|
|
7
3
|
const utilities_1 = require("../../utilities");
|
|
8
4
|
const triggerSegmentationEvents_1 = require("../../stateManagement/segmentation/triggerSegmentationEvents");
|
|
9
|
-
const
|
|
10
|
-
const equalsCheck = (a, b) => {
|
|
11
|
-
return JSON.stringify(a) === JSON.stringify(b);
|
|
12
|
-
};
|
|
5
|
+
const utilities_2 = require("./utilities");
|
|
13
6
|
function thresholdVolumeByRange(segmentationVolume, thresholdVolumeInformation, options) {
|
|
14
|
-
const {
|
|
7
|
+
const { imageData: segmentationImageData } = segmentationVolume;
|
|
15
8
|
const scalarData = segmentationVolume.getScalarData();
|
|
16
9
|
const { overwrite, boundsIJK } = options;
|
|
17
10
|
const overlapType = (options === null || options === void 0 ? void 0 : options.overlapType) || 0;
|
|
@@ -20,28 +13,7 @@ function thresholdVolumeByRange(segmentationVolume, thresholdVolumeInformation,
|
|
|
20
13
|
scalarData[i] = 0;
|
|
21
14
|
}
|
|
22
15
|
}
|
|
23
|
-
const volumeInfoList =
|
|
24
|
-
let baseVolumeIdx = 0;
|
|
25
|
-
for (let i = 0; i < thresholdVolumeInformation.length; i++) {
|
|
26
|
-
const { imageData, spacing, dimensions } = thresholdVolumeInformation[i].volume;
|
|
27
|
-
const volumeSize = thresholdVolumeInformation[i].volume.getScalarData().length;
|
|
28
|
-
if (volumeSize === scalarData.length &&
|
|
29
|
-
equalsCheck(spacing, segmentationSpacing)) {
|
|
30
|
-
baseVolumeIdx = i;
|
|
31
|
-
}
|
|
32
|
-
const referenceValues = imageData.getPointData().getScalars().getData();
|
|
33
|
-
const lower = thresholdVolumeInformation[i].lower;
|
|
34
|
-
const upper = thresholdVolumeInformation[i].upper;
|
|
35
|
-
volumeInfoList.push({
|
|
36
|
-
imageData,
|
|
37
|
-
referenceValues,
|
|
38
|
-
lower,
|
|
39
|
-
upper,
|
|
40
|
-
spacing,
|
|
41
|
-
dimensions,
|
|
42
|
-
volumeSize,
|
|
43
|
-
});
|
|
44
|
-
}
|
|
16
|
+
const { baseVolumeIdx, volumeInfoList } = (0, utilities_2.processVolumes)(segmentationVolume, thresholdVolumeInformation);
|
|
45
17
|
let overlaps, total, range;
|
|
46
18
|
const testOverlapRange = (volumeInfo, voxelSpacing, voxelCenter) => {
|
|
47
19
|
const callbackOverlap = ({ value }) => {
|
|
@@ -51,7 +23,7 @@ function thresholdVolumeByRange(segmentationVolume, thresholdVolumeInformation,
|
|
|
51
23
|
}
|
|
52
24
|
};
|
|
53
25
|
const { imageData, dimensions, lower, upper } = volumeInfo;
|
|
54
|
-
const overlapBounds = getVoxelOverlap(imageData, dimensions, voxelSpacing, voxelCenter);
|
|
26
|
+
const overlapBounds = (0, utilities_2.getVoxelOverlap)(imageData, dimensions, voxelSpacing, voxelCenter);
|
|
55
27
|
total = 0;
|
|
56
28
|
overlaps = 0;
|
|
57
29
|
range = { lower, upper };
|
|
@@ -76,23 +48,6 @@ function thresholdVolumeByRange(segmentationVolume, thresholdVolumeInformation,
|
|
|
76
48
|
return true;
|
|
77
49
|
}
|
|
78
50
|
};
|
|
79
|
-
const getVoxelOverlap = (imageData, dimensions, voxelSpacing, voxelCenter) => {
|
|
80
|
-
const voxelCornersWorld = [];
|
|
81
|
-
for (let i = 0; i < 2; i++) {
|
|
82
|
-
for (let j = 0; j < 2; j++) {
|
|
83
|
-
for (let k = 0; k < 2; k++) {
|
|
84
|
-
const point = voxelCenter;
|
|
85
|
-
point[0] = point[0] + ((i * 2 - 1) * voxelSpacing[0]) / 2;
|
|
86
|
-
point[1] = point[1] + ((j * 2 - 1) * voxelSpacing[1]) / 2;
|
|
87
|
-
point[2] = point[2] + ((k * 2 - 1) * voxelSpacing[2]) / 2;
|
|
88
|
-
voxelCornersWorld.push(point);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
const voxelCornersIJK = voxelCornersWorld.map((world) => core_1.utilities.transformWorldToIndex(imageData, world));
|
|
93
|
-
const overlapBounds = (0, getBoundingBoxAroundShape_1.default)(voxelCornersIJK, dimensions);
|
|
94
|
-
return overlapBounds;
|
|
95
|
-
};
|
|
96
51
|
const callback = ({ index, pointIJK, pointLPS }) => {
|
|
97
52
|
let insert = volumeInfoList.length > 0;
|
|
98
53
|
for (let i = 0; i < volumeInfoList.length; i++) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thresholdVolumeByRange.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/thresholdVolumeByRange.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"thresholdVolumeByRange.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/thresholdVolumeByRange.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,13 @@
|
|
|
1
|
+
import { Types } from '@cornerstonejs/core';
|
|
1
2
|
import BrushTool from '../../tools/segmentation/BrushTool';
|
|
3
|
+
export declare type ThresholdInformation = {
|
|
4
|
+
volume: Types.IImageVolume;
|
|
5
|
+
lower: number;
|
|
6
|
+
upper: number;
|
|
7
|
+
};
|
|
2
8
|
export default function getBrushToolInstances(toolGroupId: any): BrushTool[];
|
|
9
|
+
export declare function getVoxelOverlap(imageData: any, dimensions: any, voxelSpacing: any, voxelCenter: any): [Types.Point2, Types.Point2, Types.Point2];
|
|
10
|
+
export declare function processVolumes(segmentationVolume: Types.IImageVolume, thresholdVolumeInformation: ThresholdInformation[]): {
|
|
11
|
+
volumeInfoList: any[];
|
|
12
|
+
baseVolumeIdx: number;
|
|
13
|
+
};
|
|
@@ -3,8 +3,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.processVolumes = exports.getVoxelOverlap = void 0;
|
|
7
|
+
const core_1 = require("@cornerstonejs/core");
|
|
6
8
|
const ToolGroupManager_1 = require("../../store/ToolGroupManager");
|
|
7
9
|
const BrushTool_1 = __importDefault(require("../../tools/segmentation/BrushTool"));
|
|
10
|
+
const getBoundingBoxAroundShape_1 = __importDefault(require("../boundingBox/getBoundingBoxAroundShape"));
|
|
8
11
|
function getBrushToolInstances(toolGroupId) {
|
|
9
12
|
const toolGroup = (0, ToolGroupManager_1.getToolGroup)(toolGroupId);
|
|
10
13
|
if (toolGroup === undefined) {
|
|
@@ -18,4 +21,56 @@ function getBrushToolInstances(toolGroupId) {
|
|
|
18
21
|
return brushBasedToolInstances;
|
|
19
22
|
}
|
|
20
23
|
exports.default = getBrushToolInstances;
|
|
24
|
+
const equalsCheck = (a, b) => {
|
|
25
|
+
return JSON.stringify(a) === JSON.stringify(b);
|
|
26
|
+
};
|
|
27
|
+
function getVoxelOverlap(imageData, dimensions, voxelSpacing, voxelCenter) {
|
|
28
|
+
const voxelCornersWorld = [];
|
|
29
|
+
for (let i = 0; i < 2; i++) {
|
|
30
|
+
for (let j = 0; j < 2; j++) {
|
|
31
|
+
for (let k = 0; k < 2; k++) {
|
|
32
|
+
const point = voxelCenter;
|
|
33
|
+
point[0] = point[0] + ((i * 2 - 1) * voxelSpacing[0]) / 2;
|
|
34
|
+
point[1] = point[1] + ((j * 2 - 1) * voxelSpacing[1]) / 2;
|
|
35
|
+
point[2] = point[2] + ((k * 2 - 1) * voxelSpacing[2]) / 2;
|
|
36
|
+
voxelCornersWorld.push(point);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
const voxelCornersIJK = voxelCornersWorld.map((world) => core_1.utilities.transformWorldToIndex(imageData, world));
|
|
41
|
+
const overlapBounds = (0, getBoundingBoxAroundShape_1.default)(voxelCornersIJK, dimensions);
|
|
42
|
+
return overlapBounds;
|
|
43
|
+
}
|
|
44
|
+
exports.getVoxelOverlap = getVoxelOverlap;
|
|
45
|
+
function processVolumes(segmentationVolume, thresholdVolumeInformation) {
|
|
46
|
+
const { spacing: segmentationSpacing, imageData: segmentationImageData } = segmentationVolume;
|
|
47
|
+
const scalarData = segmentationVolume.getScalarData();
|
|
48
|
+
const volumeInfoList = [];
|
|
49
|
+
let baseVolumeIdx = 0;
|
|
50
|
+
for (let i = 0; i < thresholdVolumeInformation.length; i++) {
|
|
51
|
+
const { imageData, spacing, dimensions } = thresholdVolumeInformation[i].volume;
|
|
52
|
+
const volumeSize = thresholdVolumeInformation[i].volume.getScalarData().length;
|
|
53
|
+
if (volumeSize === scalarData.length &&
|
|
54
|
+
equalsCheck(spacing, segmentationSpacing)) {
|
|
55
|
+
baseVolumeIdx = i;
|
|
56
|
+
}
|
|
57
|
+
const referenceValues = imageData.getPointData().getScalars().getData();
|
|
58
|
+
const lower = thresholdVolumeInformation[i].lower;
|
|
59
|
+
const upper = thresholdVolumeInformation[i].upper;
|
|
60
|
+
volumeInfoList.push({
|
|
61
|
+
imageData,
|
|
62
|
+
referenceValues,
|
|
63
|
+
lower,
|
|
64
|
+
upper,
|
|
65
|
+
spacing,
|
|
66
|
+
dimensions,
|
|
67
|
+
volumeSize,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
return {
|
|
71
|
+
volumeInfoList,
|
|
72
|
+
baseVolumeIdx,
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
exports.processVolumes = processVolumes;
|
|
21
76
|
//# sourceMappingURL=utilities.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/utilities.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utilities.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/utilities.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,7 +16,9 @@ export default function drawLine(svgDrawingHelper, annotationUID, lineUID, start
|
|
|
16
16
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
17
17
|
const svgNodeHash = _getHash(annotationUID, 'line', lineUID);
|
|
18
18
|
const existingLine = svgDrawingHelper.getSvgNode(svgNodeHash);
|
|
19
|
-
const dropShadowStyle = shadow
|
|
19
|
+
const dropShadowStyle = shadow
|
|
20
|
+
? `filter:url(#shadow-${svgDrawingHelper.svgLayerElement.id});`
|
|
21
|
+
: '';
|
|
20
22
|
const attributes = {
|
|
21
23
|
x1: `${start[0]}`,
|
|
22
24
|
y1: `${start[1]}`,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawLine.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawLine.ts"],"names":[],"mappings":"AAEA,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,yBAAyB,MAAM,6BAA6B,CAAC;AAGpE,MAAM,CAAC,OAAO,UAAU,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,KAAmB,EACnB,GAAiB,EACjB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE;IAGX,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QACxE,OAAO;KACR;IAED,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CACjE;QACE,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,GAAG;QACV,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,SAAS;QACnB,MAAM,EAAE,SAAS;KAClB,EACD,OAAO,CACR,CAAC;IAGF,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,MAAM,eAAe,GAAG,MAAM,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"drawLine.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawLine.ts"],"names":[],"mappings":"AAEA,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,yBAAyB,MAAM,6BAA6B,CAAC;AAGpE,MAAM,CAAC,OAAO,UAAU,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,KAAmB,EACnB,GAAiB,EACjB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE;IAGX,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QACxE,OAAO;KACR;IAED,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,CACjE;QACE,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,GAAG;QACV,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,SAAS;QACnB,MAAM,EAAE,SAAS;KAClB,EACD,OAAO,CACR,CAAC;IAGF,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,MAAM,eAAe,GAAG,MAAM;QAC5B,CAAC,CAAC,sBAAsB,gBAAgB,CAAC,eAAe,CAAC,EAAE,IAAI;QAC/D,CAAC,CAAC,EAAE,CAAC;IAEP,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE;QACjB,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE;QACjB,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE;QACf,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE;QACf,MAAM,EAAE,KAAK;QACb,KAAK,EAAE,eAAe;QACtB,cAAc,EAAE,WAAW;QAC3B,kBAAkB,EAAE,QAAQ;KAC7B,CAAC;IAEF,IAAI,YAAY,EAAE;QAEhB,yBAAyB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAEpD,gBAAgB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;KAC9C;SAAM;QACL,MAAM,OAAO,GAAG,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAExD,IAAI,MAAM,KAAK,EAAE,EAAE;YACjB,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;SACzC;QAED,wBAAwB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAE9C,gBAAgB,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;KACnD;AACH,CAAC"}
|
|
@@ -53,7 +53,7 @@ function _drawTextGroup(svgDrawingHelper, annotationUID, textUID, textLines = ['
|
|
|
53
53
|
else {
|
|
54
54
|
const textGroup = document.createElementNS(svgns, 'g');
|
|
55
55
|
textGroup.setAttribute('transform', `translate(${x} ${y})`);
|
|
56
|
-
const textElement = _createTextElement(options);
|
|
56
|
+
const textElement = _createTextElement(svgDrawingHelper, options);
|
|
57
57
|
for (let i = 0; i < textLines.length; i++) {
|
|
58
58
|
const textLine = textLines[i];
|
|
59
59
|
const textSpan = _createTextSpan(textLine);
|
|
@@ -70,12 +70,12 @@ function _drawTextGroup(svgDrawingHelper, annotationUID, textUID, textLines = ['
|
|
|
70
70
|
width: textGroupBoundingBox.width + padding,
|
|
71
71
|
});
|
|
72
72
|
}
|
|
73
|
-
function _createTextElement(options) {
|
|
73
|
+
function _createTextElement(svgDrawingHelper, options) {
|
|
74
74
|
const { color, fontFamily, fontSize } = options;
|
|
75
75
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
76
76
|
const textElement = document.createElementNS(svgns, 'text');
|
|
77
77
|
const noSelectStyle = 'user-select: none; pointer-events: none; -webkit-tap-highlight-color: rgba(255, 255, 255, 0);';
|
|
78
|
-
const dropShadowStyle =
|
|
78
|
+
const dropShadowStyle = `filter:url(#shadow-${svgDrawingHelper.svgLayerElement.id});`;
|
|
79
79
|
const combinedStyle = `${noSelectStyle}${dropShadowStyle}`;
|
|
80
80
|
textElement.setAttribute('x', '0');
|
|
81
81
|
textElement.setAttribute('y', '0');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawTextBox.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawTextBox.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"drawTextBox.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawTextBox.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,7 +4,7 @@ import { state } from './state';
|
|
|
4
4
|
import { annotationRenderingEngine } from '../utilities/triggerAnnotationRender';
|
|
5
5
|
export default function addEnabledElement(evt) {
|
|
6
6
|
const { element, viewportId } = evt.detail;
|
|
7
|
-
const svgLayer = _createSvgAnnotationLayer();
|
|
7
|
+
const svgLayer = _createSvgAnnotationLayer(viewportId);
|
|
8
8
|
_setSvgNodeCache(element);
|
|
9
9
|
_appendChild(svgLayer, element);
|
|
10
10
|
annotationRenderingEngine.addViewportElement(viewportId, element);
|
|
@@ -20,11 +20,12 @@ export default function addEnabledElement(evt) {
|
|
|
20
20
|
touchToolEventDispatcher.enable(element);
|
|
21
21
|
state.enabledElements.push(element);
|
|
22
22
|
}
|
|
23
|
-
function _createSvgAnnotationLayer() {
|
|
23
|
+
function _createSvgAnnotationLayer(viewportId) {
|
|
24
24
|
const svgns = 'http://www.w3.org/2000/svg';
|
|
25
25
|
const svgLayer = document.createElementNS(svgns, 'svg');
|
|
26
|
+
const svgLayerId = `svg-layer-${viewportId}`;
|
|
26
27
|
svgLayer.classList.add('svg-layer');
|
|
27
|
-
svgLayer.setAttribute('id',
|
|
28
|
+
svgLayer.setAttribute('id', svgLayerId);
|
|
28
29
|
svgLayer.setAttribute('xmlns', 'http://www.w3.org/2000/svg');
|
|
29
30
|
svgLayer.style.width = '100%';
|
|
30
31
|
svgLayer.style.height = '100%';
|
|
@@ -35,7 +36,7 @@ function _createSvgAnnotationLayer() {
|
|
|
35
36
|
const feOffset = document.createElementNS(svgns, 'feOffset');
|
|
36
37
|
const feColorMatrix = document.createElementNS(svgns, 'feColorMatrix');
|
|
37
38
|
const feBlend = document.createElementNS(svgns, 'feBlend');
|
|
38
|
-
filter.setAttribute('id',
|
|
39
|
+
filter.setAttribute('id', `shadow-${svgLayerId}`);
|
|
39
40
|
filter.setAttribute('filterUnits', 'userSpaceOnUse');
|
|
40
41
|
feOffset.setAttribute('result', 'offOut');
|
|
41
42
|
feOffset.setAttribute('in', 'SourceGraphic');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addEnabledElement.js","sourceRoot":"","sources":["../../../src/store/addEnabledElement.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,gBAAgB,GACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EACL,4BAA4B,EAC5B,6BAA6B,EAC7B,wBAAwB,EACxB,wBAAwB,EACxB,2BAA2B,EAC3B,qCAAqC,GACtC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AAQjF,MAAM,CAAC,OAAO,UAAU,iBAAiB,CACvC,GAAyC;IAEzC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC;IAC3C,MAAM,QAAQ,GAAG,yBAAyB,
|
|
1
|
+
{"version":3,"file":"addEnabledElement.js","sourceRoot":"","sources":["../../../src/store/addEnabledElement.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,4 +8,5 @@ import { triggerSegmentationRender } from './triggerSegmentationRender';
|
|
|
8
8
|
import floodFill from './floodFill';
|
|
9
9
|
import { getBrushSizeForToolGroup, setBrushSizeForToolGroup } from './brushSizeForToolGroup';
|
|
10
10
|
import { getBrushThresholdForToolGroup, setBrushThresholdForToolGroup } from './brushThresholdForToolGroup';
|
|
11
|
-
|
|
11
|
+
import thresholdSegmentationByRange from './thresholdSegmentationByRange';
|
|
12
|
+
export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, thresholdSegmentationByRange, };
|