@cornerstonejs/tools 1.38.1 → 1.39.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dist/cjs/index.d.ts +2 -2
  2. package/dist/cjs/index.js +3 -2
  3. package/dist/cjs/index.js.map +1 -1
  4. package/dist/cjs/tools/annotation/LivewireContourTool.d.ts +44 -0
  5. package/dist/cjs/tools/annotation/LivewireContourTool.js +442 -0
  6. package/dist/cjs/tools/annotation/LivewireContourTool.js.map +1 -0
  7. package/dist/cjs/tools/index.d.ts +2 -1
  8. package/dist/cjs/tools/index.js +3 -1
  9. package/dist/cjs/tools/index.js.map +1 -1
  10. package/dist/cjs/types/ToolSpecificAnnotationTypes.d.ts +10 -0
  11. package/dist/cjs/utilities/BucketQueue.d.ts +20 -0
  12. package/dist/cjs/utilities/BucketQueue.js +83 -0
  13. package/dist/cjs/utilities/BucketQueue.js.map +1 -0
  14. package/dist/cjs/utilities/livewire/LiveWirePath.d.ts +16 -0
  15. package/dist/cjs/utilities/livewire/LiveWirePath.js +64 -0
  16. package/dist/cjs/utilities/livewire/LiveWirePath.js.map +1 -0
  17. package/dist/cjs/utilities/livewire/LivewireScissors.d.ts +37 -0
  18. package/dist/cjs/utilities/livewire/LivewireScissors.js +281 -0
  19. package/dist/cjs/utilities/livewire/LivewireScissors.js.map +1 -0
  20. package/dist/cjs/utilities/math/vec2/liangBarksyClip.d.ts +1 -1
  21. package/dist/esm/index.js +2 -2
  22. package/dist/esm/index.js.map +1 -1
  23. package/dist/esm/tools/annotation/LivewireContourTool.js +439 -0
  24. package/dist/esm/tools/annotation/LivewireContourTool.js.map +1 -0
  25. package/dist/esm/tools/index.js +2 -1
  26. package/dist/esm/tools/index.js.map +1 -1
  27. package/dist/esm/utilities/BucketQueue.js +79 -0
  28. package/dist/esm/utilities/BucketQueue.js.map +1 -0
  29. package/dist/esm/utilities/livewire/LiveWirePath.js +60 -0
  30. package/dist/esm/utilities/livewire/LiveWirePath.js.map +1 -0
  31. package/dist/esm/utilities/livewire/LivewireScissors.js +277 -0
  32. package/dist/esm/utilities/livewire/LivewireScissors.js.map +1 -0
  33. package/dist/types/index.d.ts +2 -2
  34. package/dist/types/index.d.ts.map +1 -1
  35. package/dist/types/tools/annotation/LivewireContourTool.d.ts +45 -0
  36. package/dist/types/tools/annotation/LivewireContourTool.d.ts.map +1 -0
  37. package/dist/types/tools/index.d.ts +2 -1
  38. package/dist/types/tools/index.d.ts.map +1 -1
  39. package/dist/types/types/ToolSpecificAnnotationTypes.d.ts +10 -0
  40. package/dist/types/types/ToolSpecificAnnotationTypes.d.ts.map +1 -1
  41. package/dist/types/utilities/BucketQueue.d.ts +21 -0
  42. package/dist/types/utilities/BucketQueue.d.ts.map +1 -0
  43. package/dist/types/utilities/livewire/LiveWirePath.d.ts +17 -0
  44. package/dist/types/utilities/livewire/LiveWirePath.d.ts.map +1 -0
  45. package/dist/types/utilities/livewire/LivewireScissors.d.ts +38 -0
  46. package/dist/types/utilities/livewire/LivewireScissors.d.ts.map +1 -0
  47. package/dist/types/utilities/math/vec2/liangBarksyClip.d.ts +1 -1
  48. package/dist/umd/index.js +1 -1
  49. package/dist/umd/index.js.map +1 -1
  50. package/package.json +3 -3
  51. package/src/index.ts +2 -0
  52. package/src/tools/annotation/LivewireContourTool.ts +799 -0
  53. package/src/tools/index.ts +2 -0
  54. package/src/types/ToolSpecificAnnotationTypes.ts +12 -0
  55. package/src/utilities/BucketQueue.ts +154 -0
  56. package/src/utilities/livewire/LiveWirePath.ts +131 -0
  57. package/src/utilities/livewire/LivewireScissors.ts +582 -0
@@ -0,0 +1,439 @@
1
+ import { vec3 } from 'gl-matrix';
2
+ import { AnnotationTool } from '../base';
3
+ import { getEnabledElement, eventTarget, triggerEvent, utilities as csUtils, StackViewport, VolumeViewport, } from '@cornerstonejs/core';
4
+ import { addAnnotation, getAnnotations, removeAnnotation, } from '../../stateManagement/annotation/annotationState';
5
+ import { isAnnotationVisible } from '../../stateManagement/annotation/annotationVisibility';
6
+ import { drawHandles as drawHandlesSvg, drawPolyline as drawPolylineSvg, } from '../../drawingSvg';
7
+ import { state } from '../../store';
8
+ import { Events } from '../../enums';
9
+ import { resetElementCursor } from '../../cursors/elementCursor';
10
+ import { math, viewportFilters, triggerAnnotationRenderForViewportIds, } from '../../utilities';
11
+ import { LivewireScissors } from '../../utilities/livewire/LivewireScissors';
12
+ import { LivewirePath } from '../../utilities/livewire/LiveWirePath';
13
+ const { getViewportIdsWithToolToRender } = viewportFilters;
14
+ const CLICK_CLOSE_CURVE_SQR_DIST = 10 ** 2;
15
+ class LivewireContourTool extends AnnotationTool {
16
+ constructor(toolProps = {}, defaultToolProps = {
17
+ supportedInteractionTypes: ['Mouse', 'Touch'],
18
+ configuration: {
19
+ preventHandleOutsideImage: false,
20
+ },
21
+ }) {
22
+ super(toolProps, defaultToolProps);
23
+ this.isHandleOutsideImage = false;
24
+ this.addNewAnnotation = (evt) => {
25
+ const eventDetail = evt.detail;
26
+ const { currentPoints, element } = eventDetail;
27
+ const { world: worldPos, canvas: canvasPos } = currentPoints;
28
+ const enabledElement = getEnabledElement(element);
29
+ const { viewport, renderingEngine } = enabledElement;
30
+ this.isDrawing = true;
31
+ const camera = viewport.getCamera();
32
+ const { viewPlaneNormal, viewUp } = camera;
33
+ const referencedImageId = this.getReferencedImageId(viewport, worldPos, viewPlaneNormal, viewUp);
34
+ const FrameOfReferenceUID = viewport.getFrameOfReferenceUID();
35
+ const defaultActor = viewport.getDefaultActor();
36
+ if (!defaultActor || !csUtils.isImageActor(defaultActor)) {
37
+ throw new Error('Default actor must be an image actor');
38
+ }
39
+ const viewportImageData = viewport.getImageData();
40
+ const { imageData: vtkImageData } = viewportImageData;
41
+ let worldToSlice;
42
+ let sliceToWorld;
43
+ let scalarData;
44
+ let width;
45
+ let height;
46
+ if (viewport instanceof StackViewport) {
47
+ scalarData = viewportImageData.scalarData;
48
+ width = viewportImageData.dimensions[0];
49
+ height = viewportImageData.dimensions[1];
50
+ worldToSlice = (point) => {
51
+ const ijkPoint = csUtils.transformWorldToIndex(vtkImageData, point);
52
+ return [ijkPoint[0], ijkPoint[1]];
53
+ };
54
+ sliceToWorld = (point) => csUtils.transformIndexToWorld(vtkImageData, [point[0], point[1], 0]);
55
+ }
56
+ else if (viewport instanceof VolumeViewport) {
57
+ const sliceImageData = csUtils.getCurrentVolumeViewportSlice(viewport);
58
+ const { sliceToIndexMatrix, indexToSliceMatrix } = sliceImageData;
59
+ worldToSlice = (point) => {
60
+ const ijkPoint = csUtils.transformWorldToIndex(vtkImageData, point);
61
+ const slicePoint = vec3.transformMat4([0, 0, 0], ijkPoint, indexToSliceMatrix);
62
+ return [slicePoint[0], slicePoint[1]];
63
+ };
64
+ sliceToWorld = (point) => {
65
+ const ijkPoint = vec3.transformMat4([0, 0, 0], [point[0], point[1], 0], sliceToIndexMatrix);
66
+ return csUtils.transformIndexToWorld(vtkImageData, ijkPoint);
67
+ };
68
+ scalarData = sliceImageData.scalarData;
69
+ width = sliceImageData.width;
70
+ height = sliceImageData.height;
71
+ }
72
+ else {
73
+ throw new Error('Viewport not supported');
74
+ }
75
+ const { voiRange } = viewport.getProperties();
76
+ const startPos = worldToSlice(worldPos);
77
+ this.scissors = LivewireScissors.createInstanceFromRawPixelData(scalarData, width, height, voiRange);
78
+ this.scissors.startSearch(startPos);
79
+ const confirmedPath = new LivewirePath();
80
+ const currentPath = new LivewirePath();
81
+ confirmedPath.addPoint(startPos);
82
+ confirmedPath.addControlPoint(startPos);
83
+ const annotation = {
84
+ highlighted: true,
85
+ invalidated: true,
86
+ metadata: {
87
+ toolName: this.getToolName(),
88
+ viewPlaneNormal: [...viewPlaneNormal],
89
+ viewUp: [...viewUp],
90
+ FrameOfReferenceUID,
91
+ referencedImageId,
92
+ },
93
+ data: {
94
+ polyline: [],
95
+ handles: {
96
+ points: [[...worldPos]],
97
+ activeHandleIndex: null,
98
+ },
99
+ },
100
+ };
101
+ addAnnotation(annotation, element);
102
+ const viewportIdsToRender = getViewportIdsWithToolToRender(element, this.getToolName());
103
+ this.editData = {
104
+ annotation,
105
+ viewportIdsToRender,
106
+ newAnnotation: true,
107
+ hasMoved: false,
108
+ lastCanvasPoint: canvasPos,
109
+ confirmedPath: confirmedPath,
110
+ currentPath: currentPath,
111
+ closed: false,
112
+ worldToSlice,
113
+ sliceToWorld,
114
+ };
115
+ this._activateDraw(element);
116
+ evt.preventDefault();
117
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
118
+ return annotation;
119
+ };
120
+ this.isPointNearTool = (element, annotation, canvasCoords, proximity) => {
121
+ const enabledElement = getEnabledElement(element);
122
+ const { viewport } = enabledElement;
123
+ const proximitySquared = proximity * proximity;
124
+ const canvasPoints = annotation.data.polyline.map((p) => viewport.worldToCanvas(p));
125
+ let startPoint = canvasPoints[canvasPoints.length - 1];
126
+ for (let i = 0; i < canvasPoints.length; i++) {
127
+ const endPoint = canvasPoints[i];
128
+ const distanceToPointSquared = math.lineSegment.distanceToPointSquared(startPoint, endPoint, canvasCoords);
129
+ if (distanceToPointSquared <= proximitySquared) {
130
+ return true;
131
+ }
132
+ startPoint = endPoint;
133
+ }
134
+ return false;
135
+ };
136
+ this.toolSelectedCallback = (evt, annotation) => {
137
+ const eventDetail = evt.detail;
138
+ const { element } = eventDetail;
139
+ annotation.highlighted = true;
140
+ const viewportIdsToRender = getViewportIdsWithToolToRender(element, this.getToolName());
141
+ this.editData = {
142
+ annotation,
143
+ viewportIdsToRender,
144
+ };
145
+ const enabledElement = getEnabledElement(element);
146
+ const { renderingEngine } = enabledElement;
147
+ this._activateModify(element);
148
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
149
+ evt.preventDefault();
150
+ };
151
+ this.handleSelectedCallback = (evt, annotation, handle) => {
152
+ const eventDetail = evt.detail;
153
+ const { element } = eventDetail;
154
+ const { data } = annotation;
155
+ annotation.highlighted = true;
156
+ const { points } = data.handles;
157
+ const handleIndex = points.findIndex((p) => p === handle);
158
+ const viewportIdsToRender = getViewportIdsWithToolToRender(element, this.getToolName());
159
+ this.editData = {
160
+ annotation,
161
+ viewportIdsToRender,
162
+ handleIndex,
163
+ };
164
+ this._activateModify(element);
165
+ const enabledElement = getEnabledElement(element);
166
+ const { renderingEngine } = enabledElement;
167
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
168
+ evt.preventDefault();
169
+ };
170
+ this._endCallback = (evt) => {
171
+ const eventDetail = evt.detail;
172
+ const { element } = eventDetail;
173
+ const { annotation, viewportIdsToRender, newAnnotation } = this.editData;
174
+ const { data } = annotation;
175
+ data.handles.activeHandleIndex = null;
176
+ this._deactivateModify(element);
177
+ this._deactivateDraw(element);
178
+ resetElementCursor(element);
179
+ const enabledElement = getEnabledElement(element);
180
+ const { renderingEngine } = enabledElement;
181
+ if (this.isHandleOutsideImage &&
182
+ this.configuration.preventHandleOutsideImage) {
183
+ removeAnnotation(annotation.annotationUID);
184
+ }
185
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
186
+ if (newAnnotation) {
187
+ const eventType = Events.ANNOTATION_COMPLETED;
188
+ const eventDetail = {
189
+ annotation,
190
+ };
191
+ triggerEvent(eventTarget, eventType, eventDetail);
192
+ }
193
+ this.editData = null;
194
+ this.scissors = null;
195
+ this.isDrawing = false;
196
+ };
197
+ this._mouseDownCallback = (evt) => {
198
+ const doubleClick = evt.type === Events.MOUSE_DOUBLE_CLICK;
199
+ const { annotation, viewportIdsToRender, worldToSlice, sliceToWorld } = this.editData;
200
+ if (this.editData.closed) {
201
+ return;
202
+ }
203
+ const eventDetail = evt.detail;
204
+ const { element } = eventDetail;
205
+ const { currentPoints } = eventDetail;
206
+ const { canvas: canvasPos, world: worldPos } = currentPoints;
207
+ const enabledElement = getEnabledElement(element);
208
+ const { viewport, renderingEngine } = enabledElement;
209
+ const controlPoints = this.editData.currentPath.getControlPoints();
210
+ let closePath = controlPoints.length >= 2 && doubleClick;
211
+ let addNewPoint = true;
212
+ if (controlPoints.length >= 2) {
213
+ const closestHandlePoint = {
214
+ index: -1,
215
+ distSquared: Infinity,
216
+ };
217
+ for (let i = 0, len = controlPoints.length; i < len; i++) {
218
+ const controlPoint = controlPoints[i];
219
+ const worldControlPoint = sliceToWorld(controlPoint);
220
+ const canvasControlPoint = viewport.worldToCanvas(worldControlPoint);
221
+ const distSquared = math.point.distanceToPointSquared(canvasPos, canvasControlPoint);
222
+ if (distSquared <= CLICK_CLOSE_CURVE_SQR_DIST &&
223
+ distSquared < closestHandlePoint.distSquared) {
224
+ closestHandlePoint.distSquared = distSquared;
225
+ closestHandlePoint.index = i;
226
+ }
227
+ }
228
+ if (closestHandlePoint.index === 0) {
229
+ addNewPoint = false;
230
+ closePath = true;
231
+ }
232
+ }
233
+ this.editData.closed = this.editData.closed || closePath;
234
+ if (addNewPoint) {
235
+ this.editData.confirmedPath = this.editData.currentPath;
236
+ this.editData.confirmedPath.addControlPoint(this.editData.currentPath.getLastPoint());
237
+ this.scissors.startSearch(worldToSlice(worldPos));
238
+ }
239
+ annotation.invalidated = true;
240
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
241
+ if (this.editData.closed) {
242
+ this._updateAnnotation(element, this.editData.confirmedPath);
243
+ this._endCallback(evt);
244
+ }
245
+ evt.preventDefault();
246
+ };
247
+ this._mouseMoveCallback = (evt) => {
248
+ const { element, currentPoints } = evt.detail;
249
+ const { world: worldPos, canvas: canvasPos } = currentPoints;
250
+ const { renderingEngine } = getEnabledElement(element);
251
+ const viewportIdsToRender = getViewportIdsWithToolToRender(element, this.getToolName());
252
+ this.editData.lastCanvasPoint = canvasPos;
253
+ const { width: imgWidth, height: imgHeight } = this.scissors;
254
+ const { worldToSlice } = this.editData;
255
+ const slicePoint = worldToSlice(worldPos);
256
+ if (slicePoint[0] < 0 ||
257
+ slicePoint[1] < 0 ||
258
+ slicePoint[0] >= imgWidth ||
259
+ slicePoint[1] >= imgHeight) {
260
+ return;
261
+ }
262
+ const pathPoints = this.scissors.findPathToPoint(slicePoint);
263
+ const currentPath = new LivewirePath();
264
+ for (let i = 0, len = pathPoints.length; i < len; i++) {
265
+ currentPath.addPoint(pathPoints[i]);
266
+ }
267
+ currentPath.prependPath(this.editData.confirmedPath);
268
+ this.editData.currentPath = currentPath;
269
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
270
+ evt.preventDefault();
271
+ };
272
+ this._dragCallback = (evt) => {
273
+ this.isDrawing = true;
274
+ const eventDetail = evt.detail;
275
+ const { element } = eventDetail;
276
+ const { annotation, viewportIdsToRender, handleIndex } = this.editData;
277
+ const { data } = annotation;
278
+ if (handleIndex === undefined) {
279
+ const { deltaPoints } = eventDetail;
280
+ const worldPosDelta = deltaPoints.world;
281
+ const points = data.polyline;
282
+ points.forEach((point) => {
283
+ point[0] += worldPosDelta[0];
284
+ point[1] += worldPosDelta[1];
285
+ point[2] += worldPosDelta[2];
286
+ });
287
+ annotation.invalidated = true;
288
+ }
289
+ else {
290
+ const { currentPoints } = eventDetail;
291
+ const worldPos = currentPoints.world;
292
+ data.handles.points[handleIndex] = [...worldPos];
293
+ annotation.invalidated = true;
294
+ }
295
+ this.editData.hasMoved = true;
296
+ const enabledElement = getEnabledElement(element);
297
+ const { renderingEngine } = enabledElement;
298
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
299
+ };
300
+ this.cancel = (element) => {
301
+ if (!this.isDrawing) {
302
+ return;
303
+ }
304
+ this.isDrawing = false;
305
+ this._deactivateDraw(element);
306
+ this._deactivateModify(element);
307
+ resetElementCursor(element);
308
+ const { annotation, viewportIdsToRender, newAnnotation } = this.editData;
309
+ if (newAnnotation) {
310
+ removeAnnotation(annotation.annotationUID);
311
+ }
312
+ const enabledElement = getEnabledElement(element);
313
+ const { renderingEngine } = enabledElement;
314
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
315
+ this.editData = null;
316
+ this.scissors = null;
317
+ return annotation.annotationUID;
318
+ };
319
+ this.triggerAnnotationModified = (annotation, enabledElement) => {
320
+ const { viewportId, renderingEngineId } = enabledElement;
321
+ const eventType = Events.ANNOTATION_MODIFIED;
322
+ const eventDetail = {
323
+ annotation,
324
+ viewportId,
325
+ renderingEngineId,
326
+ };
327
+ triggerEvent(eventTarget, eventType, eventDetail);
328
+ };
329
+ this._activateModify = (element) => {
330
+ state.isInteractingWithTool = true;
331
+ element.addEventListener(Events.MOUSE_UP, this._endCallback);
332
+ element.addEventListener(Events.MOUSE_DRAG, this._dragCallback);
333
+ element.addEventListener(Events.MOUSE_CLICK, this._endCallback);
334
+ element.addEventListener(Events.TOUCH_END, this._endCallback);
335
+ element.addEventListener(Events.TOUCH_DRAG, this._dragCallback);
336
+ element.addEventListener(Events.TOUCH_TAP, this._endCallback);
337
+ };
338
+ this._deactivateModify = (element) => {
339
+ state.isInteractingWithTool = false;
340
+ element.removeEventListener(Events.MOUSE_UP, this._endCallback);
341
+ element.removeEventListener(Events.MOUSE_DRAG, this._dragCallback);
342
+ element.removeEventListener(Events.MOUSE_CLICK, this._endCallback);
343
+ element.removeEventListener(Events.TOUCH_END, this._endCallback);
344
+ element.removeEventListener(Events.TOUCH_DRAG, this._dragCallback);
345
+ element.removeEventListener(Events.TOUCH_TAP, this._endCallback);
346
+ };
347
+ this._activateDraw = (element) => {
348
+ state.isInteractingWithTool = true;
349
+ element.addEventListener(Events.MOUSE_MOVE, this._mouseMoveCallback);
350
+ element.addEventListener(Events.MOUSE_DOWN, this._mouseDownCallback);
351
+ element.addEventListener(Events.MOUSE_DOUBLE_CLICK, this._mouseDownCallback);
352
+ element.addEventListener(Events.TOUCH_TAP, this._mouseDownCallback);
353
+ };
354
+ this._deactivateDraw = (element) => {
355
+ state.isInteractingWithTool = false;
356
+ element.removeEventListener(Events.MOUSE_MOVE, this._mouseMoveCallback);
357
+ element.removeEventListener(Events.MOUSE_DOWN, this._mouseDownCallback);
358
+ element.removeEventListener(Events.MOUSE_DOUBLE_CLICK, this._mouseDownCallback);
359
+ element.removeEventListener(Events.TOUCH_TAP, this._mouseDownCallback);
360
+ };
361
+ this.renderAnnotation = (enabledElement, svgDrawingHelper) => {
362
+ let renderStatus = false;
363
+ const { viewport } = enabledElement;
364
+ const { worldToCanvas } = viewport;
365
+ const { element } = viewport;
366
+ if (!viewport.getRenderingEngine()) {
367
+ console.warn('Rendering Engine has been destroyed');
368
+ return renderStatus;
369
+ }
370
+ let annotations = getAnnotations(this.getToolName(), element);
371
+ if (!annotations?.length) {
372
+ return renderStatus;
373
+ }
374
+ annotations = this.filterInteractableAnnotationsForElement(element, annotations);
375
+ if (!annotations?.length) {
376
+ return renderStatus;
377
+ }
378
+ const newAnnotation = this.editData?.newAnnotation;
379
+ const styleSpecifier = {
380
+ toolGroupId: this.toolGroupId,
381
+ toolName: this.getToolName(),
382
+ viewportId: enabledElement.viewport.id,
383
+ };
384
+ this._updateAnnotation(element, this.editData?.currentPath);
385
+ for (let i = 0; i < annotations.length; i++) {
386
+ const annotation = annotations[i];
387
+ const { annotationUID, data } = annotation;
388
+ const { handles } = data;
389
+ const { points } = handles;
390
+ styleSpecifier.annotationUID = annotationUID;
391
+ const lineWidth = this.getStyle('lineWidth', styleSpecifier, annotation);
392
+ const lineDash = this.getStyle('lineDash', styleSpecifier, annotation);
393
+ const color = this.getStyle('color', styleSpecifier, annotation);
394
+ const canvasCoordinates = points.map((p) => worldToCanvas(p));
395
+ if (!isAnnotationVisible(annotationUID)) {
396
+ continue;
397
+ }
398
+ if (newAnnotation &&
399
+ annotation.annotationUID === this.editData?.annotation?.annotationUID) {
400
+ const handleGroupUID = '0';
401
+ drawHandlesSvg(svgDrawingHelper, annotationUID, handleGroupUID, [canvasCoordinates[0]], {
402
+ color,
403
+ lineDash,
404
+ lineWidth,
405
+ });
406
+ }
407
+ const canvasPolyline = data.polyline.map((worldPoint) => viewport.worldToCanvas(worldPoint));
408
+ drawPolylineSvg(svgDrawingHelper, annotationUID, 'polyline', canvasPolyline, {
409
+ color,
410
+ lineDash,
411
+ lineWidth,
412
+ });
413
+ renderStatus = true;
414
+ annotation.invalidated = false;
415
+ }
416
+ return renderStatus;
417
+ };
418
+ }
419
+ _updateAnnotation(element, livewirePath) {
420
+ if (!this.editData || !livewirePath) {
421
+ return;
422
+ }
423
+ const { pointArray: imagePoints } = livewirePath;
424
+ const worldPolylinePoints = [];
425
+ const { sliceToWorld } = this.editData;
426
+ for (let i = 0, len = imagePoints.length; i < len; i++) {
427
+ const imagePoint = imagePoints[i];
428
+ const worldPoint = sliceToWorld(imagePoint);
429
+ worldPolylinePoints.push(worldPoint);
430
+ }
431
+ if (worldPolylinePoints.length > 1) {
432
+ worldPolylinePoints.push([...worldPolylinePoints[0]]);
433
+ }
434
+ this.editData.annotation.data.polyline = worldPolylinePoints;
435
+ }
436
+ }
437
+ LivewireContourTool.toolName = 'LivewireContour';
438
+ export default LivewireContourTool;
439
+ //# sourceMappingURL=LivewireContourTool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LivewireContourTool.js","sourceRoot":"","sources":["../../../../src/tools/annotation/LivewireContourTool.ts"],"names":[],"mappings":"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"}
@@ -26,6 +26,7 @@ import EllipticalROITool from './annotation/EllipticalROITool';
26
26
  import CircleROITool from './annotation/CircleROITool';
27
27
  import SplineROITool from './annotation/SplineROITool';
28
28
  import PlanarFreehandROITool from './annotation/PlanarFreehandROITool';
29
+ import LivewireContourTool from './annotation/LivewireContourTool';
29
30
  import ArrowAnnotateTool from './annotation/ArrowAnnotateTool';
30
31
  import AngleTool from './annotation/AngleTool';
31
32
  import CobbAngleTool from './annotation/CobbAngleTool';
@@ -39,5 +40,5 @@ import RectangleROIStartEndThresholdTool from './segmentation/RectangleROIStartE
39
40
  import BrushTool from './segmentation/BrushTool';
40
41
  import PaintFillTool from './segmentation/PaintFillTool';
41
42
  import OrientationMarkerTool from './OrientationMarkerTool';
42
- export { BaseTool, AnnotationTool, AnnotationDisplayTool, PanTool, TrackballRotateTool, DragProbeTool, WindowLevelTool, StackScrollTool, PlanarRotateTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, ReferenceCursors, CrosshairsTool, ReferenceLinesTool, OverlayGridTool, SegmentationIntersectionTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, CircleROITool, SplineROITool, PlanarFreehandROITool, ArrowAnnotateTool, AngleTool, CobbAngleTool, KeyImageTool, SegmentationDisplayTool, RectangleScissorsTool, CircleScissorsTool, SphereScissorsTool, RectangleROIThresholdTool, RectangleROIStartEndThresholdTool, BrushTool, MagnifyTool, AdvancedMagnifyTool, ReferenceLines, PaintFillTool, ScaleOverlayTool, OrientationMarkerTool, };
43
+ export { BaseTool, AnnotationTool, AnnotationDisplayTool, PanTool, TrackballRotateTool, DragProbeTool, WindowLevelTool, StackScrollTool, PlanarRotateTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, ReferenceCursors, CrosshairsTool, ReferenceLinesTool, OverlayGridTool, SegmentationIntersectionTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, CircleROITool, SplineROITool, PlanarFreehandROITool, LivewireContourTool, ArrowAnnotateTool, AngleTool, CobbAngleTool, KeyImageTool, SegmentationDisplayTool, RectangleScissorsTool, CircleScissorsTool, SphereScissorsTool, RectangleROIThresholdTool, RectangleROIStartEndThresholdTool, BrushTool, MagnifyTool, AdvancedMagnifyTool, ReferenceLines, PaintFillTool, ScaleOverlayTool, OrientationMarkerTool, };
43
44
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAClD,OAAO,yBAAyB,MAAM,iCAAiC,CAAC;AACxE,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,0BAA0B,MAAM,8BAA8B,CAAC;AACtE,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,4BAA4B,MAAM,gCAAgC,CAAC;AAC1E,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAClD,OAAO,cAAc,MAAM,sBAAsB,CAAC;AAClD,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAGlD,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,UAAU,MAAM,yBAAyB,CAAC;AACjD,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,gBAAgB,MAAM,+BAA+B,CAAC;AAC7D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,qBAAqB,MAAM,oCAAoC,CAAC;AACvE,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,YAAY,MAAM,2BAA2B,CAAC;AAGrD,OAAO,uBAAuB,MAAM,wCAAwC,CAAC;AAG7E,OAAO,qBAAqB,MAAM,sCAAsC,CAAC;AACzE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,yBAAyB,MAAM,0CAA0C,CAAC;AACjF,OAAO,iCAAiC,MAAM,kDAAkD,CAAC;AACjG,OAAO,SAAS,MAAM,0BAA0B,CAAC;AACjD,OAAO,aAAa,MAAM,8BAA8B,CAAC;AACzD,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAE5D,OAAO,EAEL,QAAQ,EACR,cAAc,EACd,qBAAqB,EAErB,OAAO,EACP,mBAAmB,EACnB,aAAa,EACb,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,yBAAyB,EACzB,QAAQ,EACR,0BAA0B,EAC1B,kBAAkB,EAClB,gBAAgB,EAEhB,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,4BAA4B,EAC5B,iBAAiB,EACjB,UAAU,EACV,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EACjB,aAAa,EACb,aAAa,EACb,qBAAqB,EACrB,iBAAiB,EACjB,SAAS,EACT,aAAa,EACb,YAAY,EAEZ,uBAAuB,EAEvB,qBAAqB,EACrB,kBAAkB,EAClB,kBAAkB,EAClB,yBAAyB,EACzB,iCAAiC,EACjC,SAAS,EACT,WAAW,EACX,mBAAmB,EACnB,cAAc,EACd,aAAa,EACb,gBAAgB,EAChB,qBAAqB,GACtB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AACzE,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAClD,OAAO,yBAAyB,MAAM,iCAAiC,CAAC;AACxE,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,0BAA0B,MAAM,8BAA8B,CAAC;AACtE,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,4BAA4B,MAAM,gCAAgC,CAAC;AAC1E,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAClD,OAAO,cAAc,MAAM,sBAAsB,CAAC;AAClD,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAGlD,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,UAAU,MAAM,yBAAyB,CAAC;AACjD,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,gBAAgB,MAAM,+BAA+B,CAAC;AAC7D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,qBAAqB,MAAM,oCAAoC,CAAC;AACvE,OAAO,mBAAmB,MAAM,kCAAkC,CAAC;AACnE,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,YAAY,MAAM,2BAA2B,CAAC;AAGrD,OAAO,uBAAuB,MAAM,wCAAwC,CAAC;AAG7E,OAAO,qBAAqB,MAAM,sCAAsC,CAAC;AACzE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,yBAAyB,MAAM,0CAA0C,CAAC;AACjF,OAAO,iCAAiC,MAAM,kDAAkD,CAAC;AACjG,OAAO,SAAS,MAAM,0BAA0B,CAAC;AACjD,OAAO,aAAa,MAAM,8BAA8B,CAAC;AACzD,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAE5D,OAAO,EAEL,QAAQ,EACR,cAAc,EACd,qBAAqB,EAErB,OAAO,EACP,mBAAmB,EACnB,aAAa,EACb,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,yBAAyB,EACzB,QAAQ,EACR,0BAA0B,EAC1B,kBAAkB,EAClB,gBAAgB,EAEhB,cAAc,EACd,kBAAkB,EAClB,eAAe,EACf,4BAA4B,EAC5B,iBAAiB,EACjB,UAAU,EACV,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EACjB,aAAa,EACb,aAAa,EACb,qBAAqB,EACrB,mBAAmB,EACnB,iBAAiB,EACjB,SAAS,EACT,aAAa,EACb,YAAY,EAEZ,uBAAuB,EAEvB,qBAAqB,EACrB,kBAAkB,EAClB,kBAAkB,EAClB,yBAAyB,EACzB,iCAAiC,EACjC,SAAS,EACT,WAAW,EACX,mBAAmB,EACnB,cAAc,EACd,aAAa,EACb,gBAAgB,EAChB,qBAAqB,GACtB,CAAC"}
@@ -0,0 +1,79 @@
1
+ export class BucketQueue {
2
+ constructor({ numBits, getPriority, areEqual, }) {
3
+ this._bucketCount = 1 << numBits;
4
+ this._mask = this._bucketCount - 1;
5
+ this._size = 0;
6
+ this._currentBucketIndex = 0;
7
+ this._buckets = this._buildArray(this._bucketCount);
8
+ this._getPriority =
9
+ typeof getPriority !== 'undefined'
10
+ ? getPriority
11
+ : (item) => item;
12
+ this._areEqual =
13
+ typeof areEqual === 'function'
14
+ ? areEqual
15
+ : (itemA, itemB) => itemA === itemB;
16
+ }
17
+ push(item) {
18
+ const bucketIndex = this._getBucketIndex(item);
19
+ const oldHead = this._buckets[bucketIndex];
20
+ const newHead = {
21
+ value: item,
22
+ next: oldHead,
23
+ };
24
+ this._buckets[bucketIndex] = newHead;
25
+ this._size++;
26
+ }
27
+ pop() {
28
+ if (this._size === 0) {
29
+ throw new Error('Cannot pop because the queue is empty.');
30
+ }
31
+ while (this._buckets[this._currentBucketIndex] === null) {
32
+ this._currentBucketIndex =
33
+ (this._currentBucketIndex + 1) % this._bucketCount;
34
+ }
35
+ const ret = this._buckets[this._currentBucketIndex];
36
+ this._buckets[this._currentBucketIndex] = ret.next;
37
+ this._size--;
38
+ return ret.value;
39
+ }
40
+ remove(item) {
41
+ if (!item) {
42
+ return false;
43
+ }
44
+ const bucketIndex = this._getBucketIndex(item);
45
+ const firstBucketNode = this._buckets[bucketIndex];
46
+ let node = firstBucketNode;
47
+ let prevNode;
48
+ while (node !== null) {
49
+ if (this._areEqual(item, node.value)) {
50
+ break;
51
+ }
52
+ prevNode = node;
53
+ node = node.next;
54
+ }
55
+ if (node === null) {
56
+ return false;
57
+ }
58
+ if (node === firstBucketNode) {
59
+ this._buckets[bucketIndex] = node.next;
60
+ }
61
+ else {
62
+ prevNode.next = node.next;
63
+ }
64
+ this._size--;
65
+ return true;
66
+ }
67
+ isEmpty() {
68
+ return this._size === 0;
69
+ }
70
+ _getBucketIndex(item) {
71
+ return this._getPriority(item) & this._mask;
72
+ }
73
+ _buildArray(size) {
74
+ const buckets = new Array(size);
75
+ buckets.fill(null);
76
+ return buckets;
77
+ }
78
+ }
79
+ //# sourceMappingURL=BucketQueue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BucketQueue.js","sourceRoot":"","sources":["../../../src/utilities/BucketQueue.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ export class LivewirePath {
2
+ constructor(inputPointArray, inputControlPointIndexArray) {
3
+ this.pointArray = inputPointArray ? inputPointArray.slice() : [];
4
+ this._controlPointIndexes = inputControlPointIndexArray
5
+ ? inputControlPointIndexArray.slice()
6
+ : [];
7
+ }
8
+ getPoint(index) {
9
+ return this.pointArray[index];
10
+ }
11
+ getLastPoint() {
12
+ return this.pointArray[this.pointArray.length - 1];
13
+ }
14
+ isControlPoint(point) {
15
+ const index = this.pointArray.indexOf(point);
16
+ if (index !== -1) {
17
+ return this._controlPointIndexes.indexOf(index) !== -1;
18
+ }
19
+ else {
20
+ throw new Error('Error: isControlPoint called with not in list point.');
21
+ }
22
+ }
23
+ addPoint(point) {
24
+ this.pointArray.push(point);
25
+ }
26
+ addControlPoint(point) {
27
+ const index = this.pointArray.indexOf(point);
28
+ if (index !== -1) {
29
+ this._controlPointIndexes.push(index);
30
+ }
31
+ else {
32
+ throw new Error('Cannot mark a non registered point as control point.');
33
+ }
34
+ }
35
+ getControlPoints() {
36
+ return this._controlPointIndexes.map((i) => this.pointArray[i]);
37
+ }
38
+ getNumControlPoints() {
39
+ return this._controlPointIndexes.length;
40
+ }
41
+ removeLastControlPoint() {
42
+ if (this._controlPointIndexes.length) {
43
+ this._controlPointIndexes.pop();
44
+ }
45
+ }
46
+ addPoints(newPointArray) {
47
+ this.pointArray = this.pointArray.concat(newPointArray);
48
+ }
49
+ prependPath(other) {
50
+ const otherSize = other.pointArray.length;
51
+ const shiftedIndexArray = [];
52
+ this.pointArray = other.pointArray.concat(this.pointArray);
53
+ for (let i = 0; i < this._controlPointIndexes.length; ++i) {
54
+ shiftedIndexArray[i] = this._controlPointIndexes[i] + otherSize;
55
+ }
56
+ this._controlPointIndexes =
57
+ other._controlPointIndexes.concat(shiftedIndexArray);
58
+ }
59
+ }
60
+ //# sourceMappingURL=LiveWirePath.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveWirePath.js","sourceRoot":"","sources":["../../../../src/utilities/livewire/LiveWirePath.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,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"}