@cornerstonejs/tools 1.49.2 → 1.50.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/tools/annotation/LivewireContourTool.d.ts +5 -0
- package/dist/cjs/tools/annotation/LivewireContourTool.js +133 -44
- package/dist/cjs/tools/annotation/LivewireContourTool.js.map +1 -1
- package/dist/cjs/types/ToolSpecificAnnotationTypes.d.ts +1 -1
- package/dist/cjs/utilities/contours/findHandlePolylineIndex.d.ts +2 -0
- package/dist/cjs/utilities/contours/findHandlePolylineIndex.js +35 -0
- package/dist/cjs/utilities/contours/findHandlePolylineIndex.js.map +1 -0
- package/dist/cjs/utilities/contours/index.d.ts +2 -1
- package/dist/cjs/utilities/contours/index.js +3 -1
- package/dist/cjs/utilities/contours/index.js.map +1 -1
- package/dist/cjs/utilities/contours/interpolation/interpolate.js +1 -1
- package/dist/cjs/utilities/contours/interpolation/interpolate.js.map +1 -1
- package/dist/cjs/utilities/contours/reverseIfAntiClockwise.d.ts +1 -1
- package/dist/cjs/utilities/contours/reverseIfAntiClockwise.js +5 -5
- package/dist/cjs/utilities/contours/reverseIfAntiClockwise.js.map +1 -1
- package/dist/cjs/utilities/livewire/LiveWirePath.d.ts +3 -0
- package/dist/cjs/utilities/livewire/LiveWirePath.js +12 -0
- package/dist/cjs/utilities/livewire/LiveWirePath.js.map +1 -1
- package/dist/cjs/utilities/livewire/LivewireScissors.d.ts +2 -1
- package/dist/cjs/utilities/livewire/LivewireScissors.js +26 -7
- package/dist/cjs/utilities/livewire/LivewireScissors.js.map +1 -1
- package/dist/cjs/utilities/segmentation/InterpolationManager/InterpolationManager.js +1 -0
- package/dist/cjs/utilities/segmentation/InterpolationManager/InterpolationManager.js.map +1 -1
- package/dist/esm/tools/annotation/LivewireContourTool.js +131 -44
- package/dist/esm/tools/annotation/LivewireContourTool.js.map +1 -1
- package/dist/esm/utilities/contours/findHandlePolylineIndex.js +32 -0
- package/dist/esm/utilities/contours/findHandlePolylineIndex.js.map +1 -0
- package/dist/esm/utilities/contours/index.js +2 -1
- package/dist/esm/utilities/contours/index.js.map +1 -1
- package/dist/esm/utilities/contours/interpolation/interpolate.js +1 -1
- package/dist/esm/utilities/contours/interpolation/interpolate.js.map +1 -1
- package/dist/esm/utilities/contours/reverseIfAntiClockwise.js +5 -5
- package/dist/esm/utilities/contours/reverseIfAntiClockwise.js.map +1 -1
- package/dist/esm/utilities/livewire/LiveWirePath.js +12 -0
- package/dist/esm/utilities/livewire/LiveWirePath.js.map +1 -1
- package/dist/esm/utilities/livewire/LivewireScissors.js +26 -7
- package/dist/esm/utilities/livewire/LivewireScissors.js.map +1 -1
- package/dist/esm/utilities/segmentation/InterpolationManager/InterpolationManager.js +1 -0
- package/dist/esm/utilities/segmentation/InterpolationManager/InterpolationManager.js.map +1 -1
- package/dist/types/tools/annotation/LivewireContourTool.d.ts +5 -0
- package/dist/types/tools/annotation/LivewireContourTool.d.ts.map +1 -1
- package/dist/types/types/ToolSpecificAnnotationTypes.d.ts +1 -1
- package/dist/types/types/ToolSpecificAnnotationTypes.d.ts.map +1 -1
- package/dist/types/utilities/contours/findHandlePolylineIndex.d.ts +3 -0
- package/dist/types/utilities/contours/findHandlePolylineIndex.d.ts.map +1 -0
- package/dist/types/utilities/contours/index.d.ts +2 -1
- package/dist/types/utilities/contours/index.d.ts.map +1 -1
- package/dist/types/utilities/contours/interpolation/interpolate.d.ts.map +1 -1
- package/dist/types/utilities/contours/reverseIfAntiClockwise.d.ts +1 -1
- package/dist/types/utilities/contours/reverseIfAntiClockwise.d.ts.map +1 -1
- package/dist/types/utilities/livewire/LiveWirePath.d.ts +3 -0
- package/dist/types/utilities/livewire/LiveWirePath.d.ts.map +1 -1
- package/dist/types/utilities/livewire/LivewireScissors.d.ts +2 -1
- package/dist/types/utilities/livewire/LivewireScissors.d.ts.map +1 -1
- package/dist/types/utilities/segmentation/InterpolationManager/InterpolationManager.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/tools/annotation/EllipticalROITool.ts +1 -1
- package/src/tools/annotation/LivewireContourTool.ts +220 -71
- package/src/types/ToolSpecificAnnotationTypes.ts +2 -0
- package/src/utilities/contours/findHandlePolylineIndex.ts +52 -0
- package/src/utilities/contours/index.ts +2 -0
- package/src/utilities/contours/interpolation/interpolate.ts +3 -2
- package/src/utilities/contours/reverseIfAntiClockwise.ts +11 -13
- package/src/utilities/livewire/LiveWirePath.ts +24 -0
- package/src/utilities/livewire/LivewireScissors.ts +52 -8
- package/src/utilities/segmentation/InterpolationManager/InterpolationManager.ts +1 -0
|
@@ -46,6 +46,14 @@ class LivewirePath {
|
|
|
46
46
|
this._controlPointIndexes.pop();
|
|
47
47
|
}
|
|
48
48
|
}
|
|
49
|
+
getLastControlPoint() {
|
|
50
|
+
if (this._controlPointIndexes.length) {
|
|
51
|
+
return this.pointArray[this._controlPointIndexes[this._controlPointIndexes.length - 1]];
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
removeLastPoints(count) {
|
|
55
|
+
this.pointArray.splice(this.pointArray.length - count, count);
|
|
56
|
+
}
|
|
49
57
|
addPoints(newPointArray) {
|
|
50
58
|
this.pointArray = this.pointArray.concat(newPointArray);
|
|
51
59
|
}
|
|
@@ -59,6 +67,10 @@ class LivewirePath {
|
|
|
59
67
|
this._controlPointIndexes =
|
|
60
68
|
other._controlPointIndexes.concat(shiftedIndexArray);
|
|
61
69
|
}
|
|
70
|
+
appendPath(other) {
|
|
71
|
+
this.addPoints(other.pointArray);
|
|
72
|
+
other._controlPointIndexes.forEach((point) => this._controlPointIndexes.push(point));
|
|
73
|
+
}
|
|
62
74
|
}
|
|
63
75
|
exports.LivewirePath = LivewirePath;
|
|
64
76
|
//# sourceMappingURL=LiveWirePath.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LiveWirePath.js","sourceRoot":"","sources":["../../../../src/utilities/livewire/LiveWirePath.ts"],"names":[],"mappings":";;;AAKA,MAAa,YAAY;IAgBvB,YACE,eAAgC,EAChC,2BAAsC;QAEtC,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACjE,IAAI,CAAC,oBAAoB,GAAG,2BAA2B;YACrD,CAAC,CAAC,2BAA2B,CAAC,KAAK,EAAE;YACrC,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;IAQM,QAAQ,CAAC,KAAa;QAC3B,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAOM,YAAY;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACrD,CAAC;IAQM,cAAc,CAAC,KAAmB;QACvC,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC7C,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;YAChB,OAAO,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;SACxD;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;IACH,CAAC;IAOM,QAAQ,CAAC,KAAmB;QACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAOM,eAAe,CAAC,KAAmB;QACxC,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAE7C,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;YAChB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACvC;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;SACzE;IACH,CAAC;IAEM,gBAAgB;QACrB,OAAO,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IAClE,CAAC;IAEM,mBAAmB;QACxB,OAAO,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC;IAC1C,CAAC;IAEM,sBAAsB;QAC3B,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE;YACpC,IAAI,CAAC,oBAAoB,CAAC,GAAG,EAAE,CAAC;SACjC;IACH,CAAC;IAOM,SAAS,CAAC,aAA6B;QAC5C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC1D,CAAC;IAOM,WAAW,CAAC,KAAmB;QACpC,MAAM,SAAS,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;QAC1C,MAAM,iBAAiB,GAAa,EAAE,CAAC;QAEvC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAE3D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YACzD,iBAAiB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC;SACjE;QAED,IAAI,CAAC,oBAAoB;YACvB,KAAK,CAAC,oBAAoB,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACzD,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"LiveWirePath.js","sourceRoot":"","sources":["../../../../src/utilities/livewire/LiveWirePath.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { Types } from '@cornerstonejs/core';
|
|
2
2
|
export declare class LivewireScissors {
|
|
3
3
|
private searchGranularityBits;
|
|
4
4
|
private searchGranularity;
|
|
@@ -16,6 +16,7 @@ export declare class LivewireScissors {
|
|
|
16
16
|
private priorityQueueNew;
|
|
17
17
|
constructor(grayscalePixelData: Types.PixelDataTypedArray, width: number, height: number);
|
|
18
18
|
startSearch(startPoint: Types.Point2): void;
|
|
19
|
+
smoothPathCount(pathPoints: Types.Point2[], lastPoint: Types.Point2, count?: number, clipValue?: number): number;
|
|
19
20
|
findPathToPoint(targetPoint: Types.Point2): Types.Point2[];
|
|
20
21
|
private _getPointIndex;
|
|
21
22
|
private _getPointCoordinate;
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.LivewireScissors = void 0;
|
|
4
|
+
const core_1 = require("@cornerstonejs/core");
|
|
4
5
|
const BucketQueue_1 = require("../BucketQueue");
|
|
6
|
+
const { isEqual } = core_1.utilities;
|
|
5
7
|
const MAX_UINT32 = 4294967295;
|
|
6
8
|
const TWO_THIRD_PI = 2 / (3 * Math.PI);
|
|
7
9
|
class LivewireScissors {
|
|
@@ -49,6 +51,23 @@ class LivewireScissors {
|
|
|
49
51
|
this.costs[startPointIndex] = 0;
|
|
50
52
|
this.priorityQueueNew.push(startPointIndex);
|
|
51
53
|
}
|
|
54
|
+
smoothPathCount(pathPoints, lastPoint, count = 5, clipValue = 0.85) {
|
|
55
|
+
const lastIndex = (lastPoint &&
|
|
56
|
+
pathPoints.findIndex((point) => isEqual(point, lastPoint))) ||
|
|
57
|
+
-1;
|
|
58
|
+
if (pathPoints.length - lastIndex < count * 2) {
|
|
59
|
+
return 0;
|
|
60
|
+
}
|
|
61
|
+
let removeCount = 0;
|
|
62
|
+
for (let i = pathPoints.length - 1; i > pathPoints.length - count && i > 0; i--) {
|
|
63
|
+
const weighted = this._getWeightedDistance(pathPoints[i], pathPoints[i - 1]);
|
|
64
|
+
if (weighted < clipValue) {
|
|
65
|
+
return removeCount ? removeCount + 2 : 0;
|
|
66
|
+
}
|
|
67
|
+
removeCount++;
|
|
68
|
+
}
|
|
69
|
+
return 0;
|
|
70
|
+
}
|
|
52
71
|
findPathToPoint(targetPoint) {
|
|
53
72
|
if (!this.startPoint) {
|
|
54
73
|
throw new Error('There is no search in progress');
|
|
@@ -71,16 +90,16 @@ class LivewireScissors {
|
|
|
71
90
|
visited[pointIndex] = true;
|
|
72
91
|
for (let i = 0, len = neighborsPoints.length; i < len; i++) {
|
|
73
92
|
const neighborPoint = neighborsPoints[i];
|
|
74
|
-
const
|
|
93
|
+
const neighborPointIndex = index(neighborPoint[1], neighborPoint[0]);
|
|
75
94
|
const dist = this._getWeightedDistance(point, neighborPoint);
|
|
76
95
|
const neighborCost = cost[pointIndex] + dist;
|
|
77
|
-
if (neighborCost < cost[
|
|
78
|
-
if (cost[
|
|
79
|
-
priorityQueue.remove(
|
|
96
|
+
if (neighborCost < cost[neighborPointIndex]) {
|
|
97
|
+
if (cost[neighborPointIndex] !== Infinity) {
|
|
98
|
+
priorityQueue.remove(neighborPointIndex);
|
|
80
99
|
}
|
|
81
|
-
cost[
|
|
82
|
-
parents[
|
|
83
|
-
priorityQueue.push(
|
|
100
|
+
cost[neighborPointIndex] = neighborCost;
|
|
101
|
+
parents[neighborPointIndex] = pointIndex;
|
|
102
|
+
priorityQueue.push(neighborPointIndex);
|
|
84
103
|
}
|
|
85
104
|
}
|
|
86
105
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LivewireScissors.js","sourceRoot":"","sources":["../../../../src/utilities/livewire/LivewireScissors.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"LivewireScissors.js","sourceRoot":"","sources":["../../../../src/utilities/livewire/LivewireScissors.ts"],"names":[],"mappings":"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"}
|
|
@@ -116,6 +116,7 @@ InterpolationManager.handleAnnotationUpdate = (evt) => {
|
|
|
116
116
|
console.warn('Unable to find matching viewport for annotation interpolation', annotation);
|
|
117
117
|
return;
|
|
118
118
|
}
|
|
119
|
+
annotation.autoGenerated = false;
|
|
119
120
|
const sliceData = getSliceData(viewport);
|
|
120
121
|
const viewportData = {
|
|
121
122
|
viewport,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"InterpolationManager.js","sourceRoot":"","sources":["../../../../../src/utilities/segmentation/InterpolationManager/InterpolationManager.ts"],"names":[],"mappings":";;;;;;AAAA,8CAA2D;AAO3D,oEAA+E;AAE/E,iIAAyG;AAKzG,2FAAmE;AACnE,0FAAkE;AAElE,6EAAqD;AACrD,8FAAsE;AAEtE,MAAM,EAAE,MAAM,EAAE,GAAG,gBAAO,CAAC;AAE3B,MAAqB,oBAAoB;IAGvC,MAAM,CAAC,OAAO,CAAC,QAAgB;QAC7B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YACtC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC/B;IACH,CAAC;IAMD,MAAM,CAAC,mBAAmB,CACxB,uBAAgD,EAChD,WAAwC,EAAE;QAE1C,MAAM,EAAE,SAAS,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,QAAQ,CAAC;QAC7D,KAAK,MAAM,QAAQ,IAAI,SAAS,IAAI,oBAAoB,CAAC,SAAS,EAAE;YAClE,MAAM,WAAW,GAAG,kBAAe,CAAC,cAAc,CAChD,QAAQ,EACR,uBAAuB,CACxB,CAAC;YACF,IAAI,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,MAAM,CAAA,EAAE;gBACxB,SAAS;aACV;YACD,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;gBACpC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC;gBAC3C,IAAI,CAAC,aAAa,EAAE;oBAClB,SAAS;iBACV;gBACD,IAAI,YAAY,IAAI,YAAY,KAAK,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE;oBACnE,SAAS;iBACV;gBACD,IACE,cAAc;oBACd,cAAc,KAAK,IAAI,CAAC,YAAY,CAAC,cAAc,EACnD;oBACA,SAAS;iBACV;gBACD,UAAU,CAAC,aAAa,GAAG,KAAK,CAAC;aAClC;SACF;IACH,CAAC;;AA3CH,
|
|
1
|
+
{"version":3,"file":"InterpolationManager.js","sourceRoot":"","sources":["../../../../../src/utilities/segmentation/InterpolationManager/InterpolationManager.ts"],"names":[],"mappings":";;;;;;AAAA,8CAA2D;AAO3D,oEAA+E;AAE/E,iIAAyG;AAKzG,2FAAmE;AACnE,0FAAkE;AAElE,6EAAqD;AACrD,8FAAsE;AAEtE,MAAM,EAAE,MAAM,EAAE,GAAG,gBAAO,CAAC;AAE3B,MAAqB,oBAAoB;IAGvC,MAAM,CAAC,OAAO,CAAC,QAAgB;QAC7B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YACtC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC/B;IACH,CAAC;IAMD,MAAM,CAAC,mBAAmB,CACxB,uBAAgD,EAChD,WAAwC,EAAE;QAE1C,MAAM,EAAE,SAAS,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,QAAQ,CAAC;QAC7D,KAAK,MAAM,QAAQ,IAAI,SAAS,IAAI,oBAAoB,CAAC,SAAS,EAAE;YAClE,MAAM,WAAW,GAAG,kBAAe,CAAC,cAAc,CAChD,QAAQ,EACR,uBAAuB,CACxB,CAAC;YACF,IAAI,CAAC,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,MAAM,CAAA,EAAE;gBACxB,SAAS;aACV;YACD,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;gBACpC,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,UAAU,CAAC;gBAC3C,IAAI,CAAC,aAAa,EAAE;oBAClB,SAAS;iBACV;gBACD,IAAI,YAAY,IAAI,YAAY,KAAK,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE;oBACnE,SAAS;iBACV;gBACD,IACE,cAAc;oBACd,cAAc,KAAK,IAAI,CAAC,YAAY,CAAC,cAAc,EACnD;oBACA,SAAS;iBACV;gBACD,UAAU,CAAC,aAAa,GAAG,KAAK,CAAC;aAClC;SACF;IACH,CAAC;;AA3CH,uCAiLC;;AAhLQ,8BAAS,GAAG,EAAE,CAAC;AA4Cf,8CAAyB,GAAG,CAAC,GAAiC,EAAE,EAAE;;IACvE,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,UAAwC,CAAC;IACvE,IAAI,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,CAAA,EAAE;QACzB,OAAO;KACR;IACD,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,QAAQ,CAAC;IAEzC,IAAI,CAAC,EAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;QACtC,OAAO;KACR;IAED,MAAM,QAAQ,GAAG,IAAA,kCAAwB,EAAC,UAAU,CAAC,CAAC;IACtD,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,CAAC,IAAI,CAAC,6BAA6B,EAAE,UAAU,CAAC,CAAC;QACxD,OAAO;KACR;IACD,MAAM,SAAS,GAAyB,YAAY,CAAC,QAAQ,CAAC,CAAC;IAC/D,MAAM,YAAY,GAA8B;QAC9C,QAAQ;QACR,SAAS;QACT,UAAU;QACV,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;KAC9C,CAAC;IACF,MAAM,mBAAmB,GAAG,CAAC,CAAC,UAAU,CAAC,gBAAgB,CAAC;IAE1D,UAAU,CAAC,aAAa,GAAG,KAAK,CAAC;IACjC,IAAI,mBAAmB,EAAE;QAGvB,IAAA,kCAAwB,EAAC,YAAY,CAAC,CAAC;QACvC,IAAA,qBAAW,EAAC,YAAY,CAAC,CAAC;QAC1B,OAAO;KACR;IACD,MAAM,UAAU,GAAG;QACjB;YACE,GAAG,EAAE,cAAc;YACnB,KAAK,EAAE,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY;YAChD,SAAS,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY;SACxD;QACD;YACE,GAAG,EAAE,iBAAiB;YACtB,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC,eAAe;YAC1C,SAAS,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ;SAC/C;QACD;YACE,GAAG,EAAE,QAAQ;YACb,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM;YACjC,SAAS,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ;SAC/C;KACF,CAAC;IACF,IAAI,wBAAwB,GAAG,IAAA,wCAA8B,EAC3D,YAAY,EACZ,UAAU,CACX,CAAC;IAEF,wBAAwB,GAAG,wBAAwB,CAAC,MAAM,CACxD,CAAC,uBAAuB,EAAE,EAAE,CAAC,uBAAuB,CAAC,gBAAgB,CACtE,CAAC;IACF,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE;QAChC,UAAU,CAAC,gBAAgB;YACzB,CAAA,MAAA,wBAAwB,CAAC,CAAC,CAAC,0CAAE,gBAAgB,KAAI,MAAM,EAAE,CAAC;QAC5D,YAAY,CAAC,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,CAAC;KAC7D;IACD,IAAA,qBAAW,EAAC,YAAY,CAAC,CAAC;AAC5B,CAAE,CAAA;AAEK,2CAAsB,GAAG,CAAC,GAAgC,EAAE,EAAE;IACnE,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,UAAwC,CAAC;IACvE,MAAM,EAAE,UAAU,GAAG,qBAAW,CAAC,cAAc,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC;IAC/D,IAAI,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,CAAA,EAAE;QACzB,OAAO;KACR;IACD,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,QAAQ,CAAC;IAEzC,IACE,CAAC,EAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAClC,UAAU,KAAK,qBAAW,CAAC,cAAc,EACzC;QACA,OAAO;KACR;IAED,MAAM,QAAQ,GAAG,IAAA,kCAAwB,EAAC,UAAU,CAAC,CAAC;IACtD,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,CAAC,IAAI,CACV,+DAA+D,EAC/D,UAAU,CACX,CAAC;QACF,OAAO;KACR;IACD,UAAU,CAAC,aAAa,GAAG,KAAK,CAAC;IAEjC,MAAM,SAAS,GAAyB,YAAY,CAAC,QAAQ,CAAC,CAAC;IAC/D,MAAM,YAAY,GAA8B;QAC9C,QAAQ;QACR,SAAS;QACT,UAAU;QACV,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;KAC9C,CAAC;IACF,IAAA,qBAAW,EAAC,YAAY,CAAC,CAAC;AAC5B,CAAE,CAAA;AAEK,2CAAsB,GAAG,CAAC,GAA+B,EAAE,EAAE;IAClE,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,CAAC,UAAwC,CAAC;IACvE,IAAI,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,CAAA,EAAE;QACzB,OAAO;KACR;IACD,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,QAAQ,CAAC;IAEzC,IAAI,CAAC,EAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,UAAU,CAAC,aAAa,EAAE;QAClE,OAAO;KACR;IACD,MAAM,QAAQ,GAAG,IAAA,kCAAwB,EAAC,UAAU,CAAC,CAAC;IAEtD,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,CAAC,IAAI,CACV,gDAAgD,EAChD,UAAU,CACX,CAAC;QACF,OAAO;KACR;IAED,MAAM,SAAS,GAAyB,YAAY,CAAC,QAAQ,CAAC,CAAC;IAC/D,MAAM,YAAY,GAA8B;QAC9C,QAAQ;QACR,SAAS;QACT,UAAU;QACV,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;KAC9C,CAAC;IAEF,UAAU,CAAC,aAAa,GAAG,KAAK,CAAC;IACjC,IAAA,kCAAwB,EAAC,YAAY,CAAC,CAAC;AACzC,CAAE,CAAA;AAGJ,SAAS,YAAY,CAAC,QAAQ;IAC5B,MAAM,SAAS,GAAyB;QACtC,cAAc,EAAE,QAAQ,CAAC,iBAAiB,EAAE;QAC5C,UAAU,EAAE,QAAQ,CAAC,sBAAsB,EAAE;KAC9C,CAAC;IACF,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
|
@@ -6,10 +6,13 @@ import { state } from '../../store';
|
|
|
6
6
|
import { Events, ChangeTypes } from '../../enums';
|
|
7
7
|
import { resetElementCursor } from '../../cursors/elementCursor';
|
|
8
8
|
import { math, triggerAnnotationRenderForViewportIds } from '../../utilities';
|
|
9
|
+
import findHandlePolylineIndex from '../../utilities/contours/findHandlePolylineIndex';
|
|
10
|
+
import reverseIfAntiClockwise from '../../utilities/contours/reverseIfAntiClockwise';
|
|
9
11
|
import { LivewireScissors } from '../../utilities/livewire/LivewireScissors';
|
|
10
12
|
import { LivewirePath } from '../../utilities/livewire/LiveWirePath';
|
|
11
13
|
import { getViewportIdsWithToolToRender } from '../../utilities/viewportFilters';
|
|
12
14
|
import ContourSegmentationBaseTool from '../base/ContourSegmentationBaseTool';
|
|
15
|
+
const { isEqual } = csUtils;
|
|
13
16
|
const CLICK_CLOSE_CURVE_SQR_DIST = 10 ** 2;
|
|
14
17
|
class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
15
18
|
constructor(toolProps = {}, defaultToolProps = {
|
|
@@ -85,17 +88,27 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
85
88
|
this.configuration.preventHandleOutsideImage) {
|
|
86
89
|
removeAnnotation(annotation.annotationUID);
|
|
87
90
|
}
|
|
88
|
-
|
|
89
|
-
if (
|
|
90
|
-
|
|
91
|
-
const eventDetail = {
|
|
92
|
-
annotation,
|
|
93
|
-
changeType: ChangeTypes.Completed,
|
|
94
|
-
};
|
|
95
|
-
triggerEvent(eventTarget, eventType, eventDetail);
|
|
91
|
+
const { worldToSlice } = this.editData;
|
|
92
|
+
if (worldToSlice) {
|
|
93
|
+
reverseIfAntiClockwise(data.handles.points.map(worldToSlice), data.handles.points, data.contour.polyline);
|
|
96
94
|
}
|
|
95
|
+
triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
|
|
96
|
+
const eventType = newAnnotation
|
|
97
|
+
? Events.ANNOTATION_COMPLETED
|
|
98
|
+
: Events.ANNOTATION_MODIFIED;
|
|
99
|
+
const { viewportId, renderingEngineId } = enabledElement;
|
|
100
|
+
const eventDetailModified = {
|
|
101
|
+
annotation,
|
|
102
|
+
viewportId,
|
|
103
|
+
renderingEngineId,
|
|
104
|
+
changeType: newAnnotation
|
|
105
|
+
? ChangeTypes.Completed
|
|
106
|
+
: ChangeTypes.HandlesUpdated,
|
|
107
|
+
};
|
|
108
|
+
triggerEvent(eventTarget, eventType, eventDetailModified);
|
|
97
109
|
this.editData = null;
|
|
98
110
|
this.scissors = null;
|
|
111
|
+
this.scissorsRight = null;
|
|
99
112
|
this.isDrawing = false;
|
|
100
113
|
};
|
|
101
114
|
this._mouseDownCallback = (evt) => {
|
|
@@ -107,7 +120,8 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
107
120
|
const eventDetail = evt.detail;
|
|
108
121
|
const { element } = eventDetail;
|
|
109
122
|
const { currentPoints } = eventDetail;
|
|
110
|
-
const { canvas: canvasPos, world:
|
|
123
|
+
const { canvas: canvasPos, world: worldPosOriginal } = currentPoints;
|
|
124
|
+
let worldPos = worldPosOriginal;
|
|
111
125
|
const enabledElement = getEnabledElement(element);
|
|
112
126
|
const { viewport, renderingEngine } = enabledElement;
|
|
113
127
|
const controlPoints = this.editData.currentPath.getControlPoints();
|
|
@@ -134,7 +148,16 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
134
148
|
}
|
|
135
149
|
this.editData.closed = this.editData.closed || closePath;
|
|
136
150
|
this.editData.confirmedPath = this.editData.currentPath;
|
|
137
|
-
this.editData.confirmedPath.
|
|
151
|
+
const smoothPathCount = this.scissors.smoothPathCount(this.editData.confirmedPath.pointArray, this.editData.currentPath.getLastControlPoint());
|
|
152
|
+
if (smoothPathCount) {
|
|
153
|
+
this.editData.currentPath.removeLastPoints(smoothPathCount);
|
|
154
|
+
annotation.data.contour.polyline.splice(annotation.data.contour.polyline.length - smoothPathCount, smoothPathCount);
|
|
155
|
+
worldPos =
|
|
156
|
+
annotation.data.contour.polyline[annotation.data.contour.polyline.length - 1];
|
|
157
|
+
}
|
|
158
|
+
const lastPoint = this.editData.currentPath.getLastPoint();
|
|
159
|
+
this.editData.confirmedPath.addControlPoint(lastPoint);
|
|
160
|
+
annotation.data.handles.points.push(sliceToWorld(lastPoint));
|
|
138
161
|
this.scissors.startSearch(worldToSlice(worldPos));
|
|
139
162
|
annotation.invalidated = true;
|
|
140
163
|
triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
|
|
@@ -161,9 +184,7 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
161
184
|
}
|
|
162
185
|
const pathPoints = this.scissors.findPathToPoint(slicePoint);
|
|
163
186
|
const currentPath = new LivewirePath();
|
|
164
|
-
|
|
165
|
-
currentPath.addPoint(pathPoints[i]);
|
|
166
|
-
}
|
|
187
|
+
currentPath.addPoints(pathPoints);
|
|
167
188
|
currentPath.prependPath(this.editData.confirmedPath);
|
|
168
189
|
this.editData.currentPath = currentPath;
|
|
169
190
|
triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
|
|
@@ -174,25 +195,14 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
174
195
|
const eventDetail = evt.detail;
|
|
175
196
|
const { element } = eventDetail;
|
|
176
197
|
const { annotation, viewportIdsToRender, handleIndex } = this.editData;
|
|
177
|
-
const { data } = annotation;
|
|
178
198
|
if (handleIndex === undefined) {
|
|
179
|
-
|
|
180
|
-
const worldPosDelta = deltaPoints.world;
|
|
181
|
-
const points = data.contour.polyline;
|
|
182
|
-
points.forEach((point) => {
|
|
183
|
-
point[0] += worldPosDelta[0];
|
|
184
|
-
point[1] += worldPosDelta[1];
|
|
185
|
-
point[2] += worldPosDelta[2];
|
|
186
|
-
});
|
|
187
|
-
annotation.invalidated = true;
|
|
199
|
+
console.warn('No drag implemented for livewire');
|
|
188
200
|
}
|
|
189
201
|
else {
|
|
190
202
|
const { currentPoints } = eventDetail;
|
|
191
203
|
const worldPos = currentPoints.world;
|
|
192
|
-
|
|
193
|
-
annotation.invalidated = true;
|
|
204
|
+
this.editHandle(worldPos, element, annotation, handleIndex);
|
|
194
205
|
}
|
|
195
|
-
this.editData.hasMoved = true;
|
|
196
206
|
const enabledElement = getEnabledElement(element);
|
|
197
207
|
const { renderingEngine } = enabledElement;
|
|
198
208
|
triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
|
|
@@ -259,12 +269,9 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
259
269
|
element.removeEventListener(Events.TOUCH_TAP, this._mouseDownCallback);
|
|
260
270
|
};
|
|
261
271
|
}
|
|
262
|
-
|
|
263
|
-
const eventDetail = evt.detail;
|
|
264
|
-
const { currentPoints, element } = eventDetail;
|
|
265
|
-
const { world: worldPos, canvas: canvasPos } = currentPoints;
|
|
272
|
+
setupBaseEditData(worldPos, element, annotation, rightPos) {
|
|
266
273
|
const enabledElement = getEnabledElement(element);
|
|
267
|
-
const { viewport
|
|
274
|
+
const { viewport } = enabledElement;
|
|
268
275
|
this.isDrawing = true;
|
|
269
276
|
const viewportImageData = viewport.getImageData();
|
|
270
277
|
const { imageData: vtkImageData } = viewportImageData;
|
|
@@ -305,31 +312,110 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
305
312
|
const { voiRange } = viewport.getProperties();
|
|
306
313
|
const startPos = worldToSlice(worldPos);
|
|
307
314
|
this.scissors = LivewireScissors.createInstanceFromRawPixelData(scalarData, width, height, voiRange);
|
|
315
|
+
if (rightPos) {
|
|
316
|
+
this.scissorsRight = LivewireScissors.createInstanceFromRawPixelData(scalarData, width, height, voiRange);
|
|
317
|
+
this.scissorsRight.startSearch(worldToSlice(rightPos));
|
|
318
|
+
}
|
|
308
319
|
this.scissors.startSearch(startPos);
|
|
320
|
+
const newAnnotation = !rightPos;
|
|
309
321
|
const confirmedPath = new LivewirePath();
|
|
310
322
|
const currentPath = new LivewirePath();
|
|
323
|
+
const currentPathNext = newAnnotation ? undefined : new LivewirePath();
|
|
311
324
|
confirmedPath.addPoint(startPos);
|
|
312
325
|
confirmedPath.addControlPoint(startPos);
|
|
313
|
-
const annotation = this.createAnnotation(evt);
|
|
314
|
-
this.addAnnotation(annotation, element);
|
|
315
326
|
const viewportIdsToRender = getViewportIdsWithToolToRender(element, this.getToolName());
|
|
327
|
+
const lastCanvasPoint = viewport.worldToCanvas(worldPos);
|
|
316
328
|
this.editData = {
|
|
317
329
|
annotation,
|
|
318
330
|
viewportIdsToRender,
|
|
319
|
-
newAnnotation
|
|
331
|
+
newAnnotation,
|
|
320
332
|
hasMoved: false,
|
|
321
|
-
lastCanvasPoint
|
|
322
|
-
confirmedPath
|
|
323
|
-
currentPath
|
|
333
|
+
lastCanvasPoint,
|
|
334
|
+
confirmedPath,
|
|
335
|
+
currentPath,
|
|
336
|
+
confirmedPathRight: currentPathNext,
|
|
324
337
|
closed: false,
|
|
338
|
+
handleIndex: this.editData?.handleIndex ?? annotation.handles?.activeHandleIndex,
|
|
325
339
|
worldToSlice,
|
|
326
340
|
sliceToWorld,
|
|
327
341
|
};
|
|
342
|
+
}
|
|
343
|
+
addNewAnnotation(evt) {
|
|
344
|
+
const eventDetail = evt.detail;
|
|
345
|
+
const { currentPoints, element } = eventDetail;
|
|
346
|
+
const { world: worldPos } = currentPoints;
|
|
347
|
+
const { renderingEngine } = getEnabledElement(element);
|
|
348
|
+
const annotation = this.createAnnotation(evt);
|
|
349
|
+
this.setupBaseEditData(worldPos, element, annotation);
|
|
350
|
+
this.addAnnotation(annotation, element);
|
|
328
351
|
this._activateDraw(element);
|
|
329
352
|
evt.preventDefault();
|
|
330
|
-
triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
|
|
353
|
+
triggerAnnotationRenderForViewportIds(renderingEngine, this.editData.viewportIdsToRender);
|
|
331
354
|
return annotation;
|
|
332
355
|
}
|
|
356
|
+
editHandle(worldPos, element, annotation, handleIndex) {
|
|
357
|
+
const { data } = annotation;
|
|
358
|
+
const { points: handlePoints } = data.handles;
|
|
359
|
+
const { length: numHandles } = handlePoints;
|
|
360
|
+
const previousHandle = handlePoints[(handleIndex - 1 + numHandles) % numHandles];
|
|
361
|
+
const nextHandle = handlePoints[(handleIndex + 1) % numHandles];
|
|
362
|
+
if (!this.editData?.confirmedPathRight) {
|
|
363
|
+
this.setupBaseEditData(previousHandle, element, annotation, nextHandle);
|
|
364
|
+
const { polyline } = data.contour;
|
|
365
|
+
const confirmedPath = new LivewirePath();
|
|
366
|
+
const confirmedPathRight = new LivewirePath();
|
|
367
|
+
const { worldToSlice } = this.editData;
|
|
368
|
+
const previousIndex = findHandlePolylineIndex(annotation, handleIndex - 1);
|
|
369
|
+
const nextIndex = findHandlePolylineIndex(annotation, handleIndex + 1);
|
|
370
|
+
if (nextIndex === -1 || previousIndex === -1) {
|
|
371
|
+
throw new Error(`Can't find handle index ${nextIndex === -1 && nextHandle} ${previousIndex === -1 && previousHandle}`);
|
|
372
|
+
}
|
|
373
|
+
if (handleIndex === 0) {
|
|
374
|
+
confirmedPathRight.addPoints(polyline.slice(nextIndex + 1, previousIndex).map(worldToSlice));
|
|
375
|
+
}
|
|
376
|
+
else if (nextIndex < previousIndex) {
|
|
377
|
+
throw new Error(`Expected right index after left index, but were: ${previousIndex} ${nextIndex}`);
|
|
378
|
+
}
|
|
379
|
+
else {
|
|
380
|
+
confirmedPath.addPoints(polyline.slice(0, previousIndex + 1).map(worldToSlice));
|
|
381
|
+
confirmedPathRight.addPoints(polyline.slice(nextIndex, polyline.length).map(worldToSlice));
|
|
382
|
+
}
|
|
383
|
+
this.editData.confirmedPath = confirmedPath;
|
|
384
|
+
this.editData.confirmedPathRight = confirmedPathRight;
|
|
385
|
+
}
|
|
386
|
+
const { editData, scissors } = this;
|
|
387
|
+
const { worldToSlice, sliceToWorld } = editData;
|
|
388
|
+
const { activeHandleIndex } = data.handles;
|
|
389
|
+
if (activeHandleIndex === null || activeHandleIndex === undefined) {
|
|
390
|
+
data.handle.activeHandleIndex = handleIndex;
|
|
391
|
+
}
|
|
392
|
+
else if (activeHandleIndex !== handleIndex) {
|
|
393
|
+
throw new Error(`Trying to edit a different handle than the one currently being edited ${handleIndex}!==${data.handles.activeHandleIndex}`);
|
|
394
|
+
}
|
|
395
|
+
const slicePos = worldToSlice(worldPos);
|
|
396
|
+
if (slicePos[0] < 0 ||
|
|
397
|
+
slicePos[0] >= scissors.width ||
|
|
398
|
+
slicePos[1] < 0 ||
|
|
399
|
+
slicePos[1] >= scissors.height) {
|
|
400
|
+
return;
|
|
401
|
+
}
|
|
402
|
+
handlePoints[handleIndex] = sliceToWorld(slicePos);
|
|
403
|
+
const pathPointsLeft = scissors.findPathToPoint(slicePos);
|
|
404
|
+
const pathPointsRight = this.scissorsRight.findPathToPoint(slicePos);
|
|
405
|
+
const currentPath = new LivewirePath();
|
|
406
|
+
currentPath.prependPath(editData.confirmedPath);
|
|
407
|
+
if (handleIndex !== 0) {
|
|
408
|
+
currentPath.addPoints(pathPointsLeft);
|
|
409
|
+
}
|
|
410
|
+
currentPath.addPoints(pathPointsRight.reverse());
|
|
411
|
+
currentPath.appendPath(editData.confirmedPathRight);
|
|
412
|
+
if (handleIndex === 0) {
|
|
413
|
+
currentPath.addPoints(pathPointsLeft);
|
|
414
|
+
}
|
|
415
|
+
editData.currentPath = currentPath;
|
|
416
|
+
annotation.invalidated = true;
|
|
417
|
+
editData.hasMoved = true;
|
|
418
|
+
}
|
|
333
419
|
renderAnnotation(enabledElement, svgDrawingHelper) {
|
|
334
420
|
const { viewport } = enabledElement;
|
|
335
421
|
const { element } = viewport;
|
|
@@ -355,15 +441,16 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
355
441
|
const { viewport } = enabledElement;
|
|
356
442
|
const { worldToCanvas } = viewport;
|
|
357
443
|
const annotation = renderContext.annotation;
|
|
358
|
-
const { annotationUID, data } = annotation;
|
|
444
|
+
const { annotationUID, data, highlighted } = annotation;
|
|
359
445
|
const { handles } = data;
|
|
360
446
|
const newAnnotation = this.editData?.newAnnotation;
|
|
361
447
|
const { lineWidth, lineDash, color } = annotationStyle;
|
|
362
|
-
if (
|
|
363
|
-
|
|
448
|
+
if (highlighted ||
|
|
449
|
+
(newAnnotation &&
|
|
450
|
+
annotation.annotationUID === this.editData?.annotation?.annotationUID)) {
|
|
364
451
|
const handleGroupUID = '0';
|
|
365
|
-
const
|
|
366
|
-
drawHandlesSvg(svgDrawingHelper, annotationUID, handleGroupUID,
|
|
452
|
+
const canvasHandles = handles.points.map(worldToCanvas);
|
|
453
|
+
drawHandlesSvg(svgDrawingHelper, annotationUID, handleGroupUID, canvasHandles, {
|
|
367
454
|
color,
|
|
368
455
|
lineDash,
|
|
369
456
|
lineWidth,
|
|
@@ -376,9 +463,9 @@ class LivewireContourTool extends ContourSegmentationBaseTool {
|
|
|
376
463
|
if (!this.editData || !livewirePath) {
|
|
377
464
|
return;
|
|
378
465
|
}
|
|
466
|
+
const { annotation, sliceToWorld } = this.editData;
|
|
379
467
|
const { pointArray: imagePoints } = livewirePath;
|
|
380
468
|
const worldPolylinePoints = [];
|
|
381
|
-
const { annotation, sliceToWorld } = this.editData;
|
|
382
469
|
for (let i = 0, len = imagePoints.length; i < len; i++) {
|
|
383
470
|
const imagePoint = imagePoints[i];
|
|
384
471
|
const worldPoint = sliceToWorld(imagePoint);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LivewireContourTool.js","sourceRoot":"","sources":["../../../../src/tools/annotation/LivewireContourTool.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"LivewireContourTool.js","sourceRoot":"","sources":["../../../../src/tools/annotation/LivewireContourTool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { utilities as csUtils } from '@cornerstonejs/core';
|
|
2
|
+
import { vec3 } from 'gl-matrix';
|
|
3
|
+
const { isEqual } = csUtils;
|
|
4
|
+
export default function findHandlePolylineIndex(annotation, handleIndex) {
|
|
5
|
+
const { polyline } = annotation.data.contour;
|
|
6
|
+
const { points } = annotation.data.handles;
|
|
7
|
+
const { length } = points;
|
|
8
|
+
if (handleIndex === length) {
|
|
9
|
+
return polyline.length;
|
|
10
|
+
}
|
|
11
|
+
if (handleIndex < 0) {
|
|
12
|
+
handleIndex = (handleIndex + length) % length;
|
|
13
|
+
}
|
|
14
|
+
if (handleIndex === 0) {
|
|
15
|
+
return 0;
|
|
16
|
+
}
|
|
17
|
+
const handle = points[handleIndex];
|
|
18
|
+
const index = polyline.findIndex((point) => isEqual(handle, point));
|
|
19
|
+
if (index !== -1) {
|
|
20
|
+
return index;
|
|
21
|
+
}
|
|
22
|
+
let closestDistance = Infinity;
|
|
23
|
+
return polyline.reduce((closestIndex, point, testIndex) => {
|
|
24
|
+
const distance = vec3.squaredDistance(point, handle);
|
|
25
|
+
if (distance < closestDistance) {
|
|
26
|
+
closestDistance = distance;
|
|
27
|
+
return testIndex;
|
|
28
|
+
}
|
|
29
|
+
return closestIndex;
|
|
30
|
+
}, -1);
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=findHandlePolylineIndex.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findHandlePolylineIndex.js","sourceRoot":"","sources":["../../../../src/utilities/contours/findHandlePolylineIndex.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,IAAI,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,MAAM,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;AAe5B,MAAM,CAAC,OAAO,UAAU,uBAAuB,CAC7C,UAA6B,EAC7B,WAAmB;IAEnB,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC;IAC7C,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC;IAC3C,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;IAC1B,IAAI,WAAW,KAAK,MAAM,EAAE;QAC1B,OAAO,QAAQ,CAAC,MAAM,CAAC;KACxB;IACD,IAAI,WAAW,GAAG,CAAC,EAAE;QACnB,WAAW,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC;KAC/C;IACD,IAAI,WAAW,KAAK,CAAC,EAAE;QACrB,OAAO,CAAC,CAAC;KACV;IACD,MAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IACnC,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;IACpE,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;QAChB,OAAO,KAAK,CAAC;KACd;IAED,IAAI,eAAe,GAAG,QAAQ,CAAC;IAC/B,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;QACxD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACrD,IAAI,QAAQ,GAAG,eAAe,EAAE;YAC9B,eAAe,GAAG,QAAQ,CAAC;YAC3B,OAAO,SAAS,CAAC;SAClB;QACD,OAAO,YAAY,CAAC;IACtB,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AACT,CAAC"}
|
|
@@ -5,5 +5,6 @@ import { generateContourSetsFromLabelmap } from './generateContourSetsFromLabelm
|
|
|
5
5
|
import AnnotationToPointData from './AnnotationToPointData';
|
|
6
6
|
import acceptAutogeneratedInterpolations from './interpolation/acceptAutogeneratedInterpolations';
|
|
7
7
|
import * as interpolation from './interpolation';
|
|
8
|
-
|
|
8
|
+
import findHandlePolylineIndex from './findHandlePolylineIndex';
|
|
9
|
+
export { contourFinder, mergePoints, detectContourHoles, generateContourSetsFromLabelmap, AnnotationToPointData, interpolation, acceptAutogeneratedInterpolations, findHandlePolylineIndex, };
|
|
9
10
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/contours/index.ts"],"names":[],"mappings":"AAAA,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,+BAA+B,EAAE,MAAM,mCAAmC,CAAC;AACpF,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,iCAAiC,MAAM,mDAAmD,CAAC;AAClG,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/contours/index.ts"],"names":[],"mappings":"AAAA,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,+BAA+B,EAAE,MAAM,mCAAmC,CAAC;AACpF,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,iCAAiC,MAAM,mDAAmD,CAAC;AAClG,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAC;AACjD,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAEhE,OAAO,EACL,aAAa,EACb,WAAW,EACX,kBAAkB,EAClB,+BAA+B,EAC/B,qBAAqB,EACrB,aAAa,EACb,iCAAiC,EACjC,uBAAuB,GACxB,CAAC"}
|