@cornerstonejs/tools 1.23.3 → 1.24.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/displayTools/SegmentationDisplayTool.js.map +1 -1
- package/dist/cjs/utilities/getVOIMultipliers.d.ts +5 -0
- package/dist/cjs/utilities/getVOIMultipliers.js +23 -0
- package/dist/cjs/utilities/getVOIMultipliers.js.map +1 -0
- package/dist/cjs/utilities/index.d.ts +2 -1
- package/dist/cjs/utilities/index.js +3 -1
- package/dist/cjs/utilities/index.js.map +1 -1
- package/dist/cjs/utilities/math/vec3/interpolateVec3.d.ts +2 -0
- package/dist/cjs/utilities/math/vec3/interpolateVec3.js +13 -0
- package/dist/cjs/utilities/math/vec3/interpolateVec3.js.map +1 -0
- package/dist/cjs/utilities/viewport/isViewportPreScaled.js +2 -1
- package/dist/cjs/utilities/viewport/isViewportPreScaled.js.map +1 -1
- package/dist/cjs/utilities/voi/colorbar/Colorbar.d.ts +44 -0
- package/dist/cjs/utilities/voi/colorbar/Colorbar.js +249 -0
- package/dist/cjs/utilities/voi/colorbar/Colorbar.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.d.ts +29 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.js +184 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.d.ts +46 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.js +286 -0
- package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.d.ts +23 -0
- package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.js +126 -0
- package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.d.ts +3 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.js +9 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.d.ts +3 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.js +9 -0
- package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/index.d.ts +4 -0
- package/dist/cjs/utilities/voi/colorbar/common/index.js +12 -0
- package/dist/cjs/utilities/voi/colorbar/common/index.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.d.ts +3 -0
- package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.js +9 -0
- package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.d.ts +3 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.js +14 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.d.ts +3 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.js +9 -0
- package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.d.ts +6 -0
- package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js +11 -0
- package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/enums/index.d.ts +1 -0
- package/dist/cjs/utilities/voi/colorbar/enums/index.js +6 -0
- package/dist/cjs/utilities/voi/colorbar/enums/index.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/index.d.ts +6 -0
- package/dist/cjs/utilities/voi/colorbar/index.js +33 -0
- package/dist/cjs/utilities/voi/colorbar/index.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.d.ts +12 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.d.ts +11 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.d.ts +4 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.d.ts +7 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.d.ts +4 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.d.ts +7 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.d.ts +8 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.d.ts +2 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.d.ts +5 -0
- package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.js.map +1 -0
- package/dist/cjs/utilities/voi/colorbar/types/index.d.ts +8 -0
- package/dist/cjs/utilities/voi/colorbar/types/index.js +3 -0
- package/dist/cjs/utilities/voi/colorbar/types/index.js.map +1 -0
- package/dist/cjs/utilities/voi/index.d.ts +2 -0
- package/dist/cjs/utilities/voi/index.js +29 -0
- package/dist/cjs/utilities/voi/index.js.map +1 -0
- package/dist/cjs/widgets/Widget.d.ts +17 -0
- package/dist/cjs/widgets/Widget.js +71 -0
- package/dist/cjs/widgets/Widget.js.map +1 -0
- package/dist/cjs/widgets/types/WidgetProps.d.ts +4 -0
- package/dist/cjs/widgets/types/WidgetProps.js +3 -0
- package/dist/cjs/widgets/types/WidgetProps.js.map +1 -0
- package/dist/cjs/widgets/types/WidgetSize.d.ts +4 -0
- package/dist/cjs/widgets/types/WidgetSize.js +3 -0
- package/dist/cjs/widgets/types/WidgetSize.js.map +1 -0
- package/dist/cjs/widgets/types/index.d.ts +2 -0
- package/dist/cjs/widgets/types/index.js +3 -0
- package/dist/cjs/widgets/types/index.js.map +1 -0
- package/dist/esm/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
- package/dist/esm/utilities/getVOIMultipliers.d.ts +5 -0
- package/dist/esm/utilities/getVOIMultipliers.js +19 -0
- package/dist/esm/utilities/getVOIMultipliers.js.map +1 -0
- package/dist/esm/utilities/index.d.ts +2 -1
- package/dist/esm/utilities/index.js +2 -1
- package/dist/esm/utilities/index.js.map +1 -1
- package/dist/esm/utilities/math/vec3/interpolateVec3.d.ts +2 -0
- package/dist/esm/utilities/math/vec3/interpolateVec3.js +9 -0
- package/dist/esm/utilities/math/vec3/interpolateVec3.js.map +1 -0
- package/dist/esm/utilities/viewport/isViewportPreScaled.js +2 -1
- package/dist/esm/utilities/viewport/isViewportPreScaled.js.map +1 -1
- package/dist/esm/utilities/voi/colorbar/Colorbar.d.ts +44 -0
- package/dist/esm/utilities/voi/colorbar/Colorbar.js +241 -0
- package/dist/esm/utilities/voi/colorbar/Colorbar.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.d.ts +29 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.js +177 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarTicks.d.ts +46 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarTicks.js +281 -0
- package/dist/esm/utilities/voi/colorbar/ColorbarTicks.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/ViewportColorbar.d.ts +23 -0
- package/dist/esm/utilities/voi/colorbar/ViewportColorbar.js +122 -0
- package/dist/esm/utilities/voi/colorbar/ViewportColorbar.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.d.ts +3 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.js +5 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.d.ts +3 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.js +5 -0
- package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/index.d.ts +4 -0
- package/dist/esm/utilities/voi/colorbar/common/index.js +5 -0
- package/dist/esm/utilities/voi/colorbar/common/index.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.d.ts +3 -0
- package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.js +5 -0
- package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.d.ts +3 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.js +10 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeValid.d.ts +3 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeValid.js +5 -0
- package/dist/esm/utilities/voi/colorbar/common/isRangeValid.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.d.ts +6 -0
- package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js +8 -0
- package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/enums/index.d.ts +1 -0
- package/dist/esm/utilities/voi/colorbar/enums/index.js +2 -0
- package/dist/esm/utilities/voi/colorbar/enums/index.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/index.d.ts +6 -0
- package/dist/esm/utilities/voi/colorbar/index.js +5 -0
- package/dist/esm/utilities/voi/colorbar/index.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.d.ts +12 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.d.ts +11 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.d.ts +4 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.d.ts +7 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.d.ts +4 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.d.ts +7 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.d.ts +8 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.d.ts +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.d.ts +5 -0
- package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.js.map +1 -0
- package/dist/esm/utilities/voi/colorbar/types/index.d.ts +8 -0
- package/dist/esm/utilities/voi/colorbar/types/index.js +2 -0
- package/dist/esm/utilities/voi/colorbar/types/index.js.map +1 -0
- package/dist/esm/utilities/voi/index.d.ts +2 -0
- package/dist/esm/utilities/voi/index.js +3 -0
- package/dist/esm/utilities/voi/index.js.map +1 -0
- package/dist/esm/widgets/Widget.d.ts +17 -0
- package/dist/esm/widgets/Widget.js +67 -0
- package/dist/esm/widgets/Widget.js.map +1 -0
- package/dist/esm/widgets/types/WidgetProps.d.ts +4 -0
- package/dist/esm/widgets/types/WidgetProps.js +2 -0
- package/dist/esm/widgets/types/WidgetProps.js.map +1 -0
- package/dist/esm/widgets/types/WidgetSize.d.ts +4 -0
- package/dist/esm/widgets/types/WidgetSize.js +2 -0
- package/dist/esm/widgets/types/WidgetSize.js.map +1 -0
- package/dist/esm/widgets/types/index.d.ts +2 -0
- package/dist/esm/widgets/types/index.js +2 -0
- package/dist/esm/widgets/types/index.js.map +1 -0
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +3 -3
- package/src/tools/displayTools/SegmentationDisplayTool.ts +1 -2
- package/src/utilities/getVOIMultipliers.ts +33 -0
- package/src/utilities/index.ts +2 -0
- package/src/utilities/math/vec3/interpolateVec3.ts +20 -0
- package/src/utilities/viewport/isViewportPreScaled.ts +3 -1
- package/src/utilities/voi/colorbar/Colorbar.ts +367 -0
- package/src/utilities/voi/colorbar/ColorbarCanvas.ts +287 -0
- package/src/utilities/voi/colorbar/ColorbarTicks.ts +500 -0
- package/src/utilities/voi/colorbar/ViewportColorbar.ts +194 -0
- package/src/utilities/voi/colorbar/common/areColorbarRangesEqual.ts +10 -0
- package/src/utilities/voi/colorbar/common/areColorbarSizesEqual.ts +7 -0
- package/src/utilities/voi/colorbar/common/index.ts +4 -0
- package/src/utilities/voi/colorbar/common/isColorbarSizeValid.ts +7 -0
- package/src/utilities/voi/colorbar/common/isRangeTextPositionValid.ts +16 -0
- package/src/utilities/voi/colorbar/common/isRangeValid.ts +7 -0
- package/src/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.ts +11 -0
- package/src/utilities/voi/colorbar/enums/index.ts +1 -0
- package/src/utilities/voi/colorbar/index.ts +8 -0
- package/src/utilities/voi/colorbar/types/ColorbarCanvasProps.ts +14 -0
- package/src/utilities/voi/colorbar/types/ColorbarCommonProps.ts +23 -0
- package/src/utilities/voi/colorbar/types/ColorbarImageRange.ts +4 -0
- package/src/utilities/voi/colorbar/types/ColorbarProps.ts +8 -0
- package/src/utilities/voi/colorbar/types/ColorbarSize.ts +4 -0
- package/src/utilities/voi/colorbar/types/ColorbarTicksProps.ts +8 -0
- package/src/utilities/voi/colorbar/types/ColorbarTicksStyle.ts +8 -0
- package/src/utilities/voi/colorbar/types/ColorbarVOIRange.ts +3 -0
- package/src/utilities/voi/colorbar/types/ViewportColorbarProps.ts +6 -0
- package/src/utilities/voi/colorbar/types/index.ts +8 -0
- package/src/utilities/voi/index.ts +3 -0
- package/src/widgets/Widget.ts +169 -0
- package/src/widgets/types/WidgetProps.ts +4 -0
- package/src/widgets/types/WidgetSize.ts +4 -0
- package/src/widgets/types/index.ts +2 -0
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { utilities } from '@cornerstonejs/core';
|
|
2
|
+
import interpolateVec3 from '../../math/vec3/interpolateVec3';
|
|
3
|
+
import { isRangeValid, areColorbarRangesEqual, isColorbarSizeValid, areColorbarSizesEqual, } from './common';
|
|
4
|
+
const { clamp } = utilities;
|
|
5
|
+
class ColorbarCanvas {
|
|
6
|
+
constructor(props) {
|
|
7
|
+
ColorbarCanvas.validateProps(props);
|
|
8
|
+
const { colormap, size = { width: 20, height: 100 }, imageRange = { lower: 0, upper: 1 }, voiRange = { lower: 0, upper: 1 }, container, showFullPixelValueRange = false, } = props;
|
|
9
|
+
this._colormap = colormap;
|
|
10
|
+
this._imageRange = imageRange;
|
|
11
|
+
this._voiRange = voiRange;
|
|
12
|
+
this._showFullImageRange = showFullPixelValueRange;
|
|
13
|
+
this._canvas = this._createRootElement(size);
|
|
14
|
+
if (container) {
|
|
15
|
+
this.appendTo(container);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
get colormap() {
|
|
19
|
+
return this._colormap;
|
|
20
|
+
}
|
|
21
|
+
set colormap(colormap) {
|
|
22
|
+
this._colormap = colormap;
|
|
23
|
+
this.render();
|
|
24
|
+
}
|
|
25
|
+
get size() {
|
|
26
|
+
const { width, height } = this._canvas;
|
|
27
|
+
return { width, height };
|
|
28
|
+
}
|
|
29
|
+
set size(size) {
|
|
30
|
+
const { _canvas: canvas } = this;
|
|
31
|
+
if (!isColorbarSizeValid(size) || areColorbarSizesEqual(canvas, size)) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
this._setCanvasSize(canvas, size);
|
|
35
|
+
this.render();
|
|
36
|
+
}
|
|
37
|
+
get imageRange() {
|
|
38
|
+
return { ...this._imageRange };
|
|
39
|
+
}
|
|
40
|
+
set imageRange(imageRange) {
|
|
41
|
+
if (!isRangeValid(imageRange) ||
|
|
42
|
+
areColorbarRangesEqual(imageRange, this._imageRange)) {
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
this._imageRange = imageRange;
|
|
46
|
+
this.render();
|
|
47
|
+
}
|
|
48
|
+
get voiRange() {
|
|
49
|
+
return { ...this._voiRange };
|
|
50
|
+
}
|
|
51
|
+
set voiRange(voiRange) {
|
|
52
|
+
if (!isRangeValid(voiRange) ||
|
|
53
|
+
areColorbarRangesEqual(voiRange, this._voiRange)) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
this._voiRange = voiRange;
|
|
57
|
+
this.render();
|
|
58
|
+
}
|
|
59
|
+
get showFullImageRange() {
|
|
60
|
+
return this._showFullImageRange;
|
|
61
|
+
}
|
|
62
|
+
set showFullImageRange(showFullImageRange) {
|
|
63
|
+
if (showFullImageRange === this._showFullImageRange) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
this._showFullImageRange = showFullImageRange;
|
|
67
|
+
this.render();
|
|
68
|
+
}
|
|
69
|
+
appendTo(container) {
|
|
70
|
+
container.appendChild(this._canvas);
|
|
71
|
+
this.render();
|
|
72
|
+
}
|
|
73
|
+
dispose() {
|
|
74
|
+
const { _canvas: canvas } = this;
|
|
75
|
+
const { parentElement } = canvas;
|
|
76
|
+
parentElement?.removeChild(canvas);
|
|
77
|
+
}
|
|
78
|
+
static validateProps(props) {
|
|
79
|
+
const { size, imageRange, voiRange } = props;
|
|
80
|
+
if (size && !isColorbarSizeValid(size)) {
|
|
81
|
+
throw new Error('Invalid "size"');
|
|
82
|
+
}
|
|
83
|
+
if (imageRange && !isRangeValid(imageRange)) {
|
|
84
|
+
throw new Error('Invalid "imageRange"');
|
|
85
|
+
}
|
|
86
|
+
if (voiRange && !isRangeValid(voiRange)) {
|
|
87
|
+
throw new Error('Invalid "voiRange"');
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
_setCanvasSize(canvas, size) {
|
|
91
|
+
const { width, height } = size;
|
|
92
|
+
canvas.width = width;
|
|
93
|
+
canvas.height = height;
|
|
94
|
+
Object.assign(canvas.style, {
|
|
95
|
+
width: `${width}px`,
|
|
96
|
+
height: `${height}px`,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
_createRootElement(size) {
|
|
100
|
+
const canvas = document.createElement('canvas');
|
|
101
|
+
Object.assign(canvas.style, {
|
|
102
|
+
pointerEvents: 'none',
|
|
103
|
+
boxSizing: 'border-box',
|
|
104
|
+
});
|
|
105
|
+
this._setCanvasSize(canvas, size);
|
|
106
|
+
return canvas;
|
|
107
|
+
}
|
|
108
|
+
render() {
|
|
109
|
+
if (!this._canvas.isConnected) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
const { _colormap: colormap } = this;
|
|
113
|
+
const { RGBPoints: rgbPoints } = colormap;
|
|
114
|
+
const colorsCount = rgbPoints.length / 4;
|
|
115
|
+
const getColorPoint = (index) => {
|
|
116
|
+
const offset = 4 * index;
|
|
117
|
+
if (index < 0 || index >= colorsCount) {
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
return {
|
|
121
|
+
index,
|
|
122
|
+
position: rgbPoints[offset],
|
|
123
|
+
color: [
|
|
124
|
+
rgbPoints[offset + 1],
|
|
125
|
+
rgbPoints[offset + 2],
|
|
126
|
+
rgbPoints[offset + 3],
|
|
127
|
+
],
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
const { width, height } = this._canvas;
|
|
131
|
+
const canvasContext = this._canvas.getContext('2d');
|
|
132
|
+
const isHorizontal = width > height;
|
|
133
|
+
const maxValue = isHorizontal ? width : height;
|
|
134
|
+
const { _voiRange: voiRange } = this;
|
|
135
|
+
const range = this._showFullImageRange ? this._imageRange : { ...voiRange };
|
|
136
|
+
const { windowWidth } = utilities.windowLevel.toWindowLevel(voiRange.lower, voiRange.upper);
|
|
137
|
+
let previousColorPoint = undefined;
|
|
138
|
+
let currentColorPoint = getColorPoint(0);
|
|
139
|
+
const incRawPixelValue = (range.upper - range.lower) / (maxValue - 1);
|
|
140
|
+
let rawPixelValue = range.lower;
|
|
141
|
+
for (let i = 0; i < maxValue; i++) {
|
|
142
|
+
const tVoiRange = (rawPixelValue - voiRange.lower) / windowWidth;
|
|
143
|
+
if (currentColorPoint) {
|
|
144
|
+
for (let i = currentColorPoint.index; i < colorsCount; i++) {
|
|
145
|
+
if (tVoiRange <= currentColorPoint.position) {
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
previousColorPoint = currentColorPoint;
|
|
149
|
+
currentColorPoint = getColorPoint(i + 1);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
let normColor;
|
|
153
|
+
if (!previousColorPoint) {
|
|
154
|
+
normColor = [...currentColorPoint.color];
|
|
155
|
+
}
|
|
156
|
+
else if (!currentColorPoint) {
|
|
157
|
+
normColor = [...previousColorPoint.color];
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
const tColorRange = (tVoiRange - previousColorPoint.position) /
|
|
161
|
+
(currentColorPoint.position - previousColorPoint.position);
|
|
162
|
+
normColor = interpolateVec3(previousColorPoint.color, currentColorPoint.color, tColorRange);
|
|
163
|
+
}
|
|
164
|
+
const color = normColor.map((color) => clamp(Math.round(color * 255), 0, 255));
|
|
165
|
+
canvasContext.fillStyle = `rgb(${color[0]}, ${color[1]}, ${color[2]})`;
|
|
166
|
+
if (isHorizontal) {
|
|
167
|
+
canvasContext.fillRect(i, 0, 1, height);
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
canvasContext.fillRect(0, height - i - 1, width, 1);
|
|
171
|
+
}
|
|
172
|
+
rawPixelValue += incRawPixelValue;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
export { ColorbarCanvas as default, ColorbarCanvas };
|
|
177
|
+
//# sourceMappingURL=ColorbarCanvas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColorbarCanvas.js","sourceRoot":"","sources":["../../../../../src/utilities/voi/colorbar/ColorbarCanvas.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import type { ColorbarVOIRange, ColorbarSize, ColorbarTicksProps } from './types';
|
|
2
|
+
declare class ColorbarTicks {
|
|
3
|
+
private _canvas;
|
|
4
|
+
private _imageRange;
|
|
5
|
+
private _voiRange;
|
|
6
|
+
private _color;
|
|
7
|
+
private _tickSize;
|
|
8
|
+
private _tickWidth;
|
|
9
|
+
private _labelMargin;
|
|
10
|
+
private _maxNumTicks;
|
|
11
|
+
private _rangeTextPosition;
|
|
12
|
+
private _showFullPixelValueRange;
|
|
13
|
+
private _font;
|
|
14
|
+
constructor(props: ColorbarTicksProps);
|
|
15
|
+
get size(): ColorbarSize;
|
|
16
|
+
set size(size: ColorbarSize);
|
|
17
|
+
get top(): number;
|
|
18
|
+
set top(top: number);
|
|
19
|
+
get left(): number;
|
|
20
|
+
set left(left: number);
|
|
21
|
+
get imageRange(): ColorbarVOIRange;
|
|
22
|
+
set imageRange(imageRange: ColorbarVOIRange);
|
|
23
|
+
get voiRange(): ColorbarVOIRange;
|
|
24
|
+
set voiRange(voiRange: ColorbarVOIRange);
|
|
25
|
+
get tickSize(): number;
|
|
26
|
+
set tickSize(tickSize: number);
|
|
27
|
+
get tickWidth(): number;
|
|
28
|
+
set tickWidth(tickWidth: number);
|
|
29
|
+
get color(): string;
|
|
30
|
+
set color(color: string);
|
|
31
|
+
get showFullPixelValueRange(): boolean;
|
|
32
|
+
set showFullPixelValueRange(showFullRange: boolean);
|
|
33
|
+
get visible(): boolean;
|
|
34
|
+
set visible(visible: boolean);
|
|
35
|
+
appendTo(container: HTMLElement): void;
|
|
36
|
+
private static validateProps;
|
|
37
|
+
private _setCanvasSize;
|
|
38
|
+
private _createCanvasElement;
|
|
39
|
+
private _getTicks;
|
|
40
|
+
private _getLeftTickInfo;
|
|
41
|
+
private _getRightTickInfo;
|
|
42
|
+
private _getTopTickInfo;
|
|
43
|
+
private _getBottomTickInfo;
|
|
44
|
+
private render;
|
|
45
|
+
}
|
|
46
|
+
export { ColorbarTicks as default, ColorbarTicks };
|
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
import { isColorbarSizeValid, isRangeValid, areColorbarRangesEqual, areColorbarSizesEqual, } from './common';
|
|
2
|
+
import { ColorbarRangeTextPosition } from './enums/ColorbarRangeTextPosition';
|
|
3
|
+
const DEFAULTS = {
|
|
4
|
+
FONT: '10px Arial',
|
|
5
|
+
COLOR: 'white',
|
|
6
|
+
TICK_SIZE: 5,
|
|
7
|
+
TICK_WIDTH: 1,
|
|
8
|
+
TICK_LABEL_MARGIN: 3,
|
|
9
|
+
MAX_NUM_TICKS: 8,
|
|
10
|
+
TICKS_STEPS: [1, 2.5, 5, 10],
|
|
11
|
+
};
|
|
12
|
+
class ColorbarTicks {
|
|
13
|
+
constructor(props) {
|
|
14
|
+
ColorbarTicks.validateProps(props);
|
|
15
|
+
const { top = 0, left = 0, size = { width: 20, height: 100 }, imageRange = { lower: 0, upper: 1 }, voiRange = { lower: 0, upper: 1 }, ticks: ticksProps, container, showFullPixelValueRange = false, } = props;
|
|
16
|
+
const { style: ticksStyle, position: rangeTextPosition } = ticksProps ?? {};
|
|
17
|
+
this._imageRange = imageRange;
|
|
18
|
+
this._voiRange = voiRange;
|
|
19
|
+
this._font = ticksStyle?.font ?? DEFAULTS.FONT;
|
|
20
|
+
this._color = ticksStyle?.color ?? DEFAULTS.COLOR;
|
|
21
|
+
this._tickSize = ticksStyle?.tickSize ?? DEFAULTS.TICK_SIZE;
|
|
22
|
+
this._tickWidth = ticksStyle?.tickWidth ?? DEFAULTS.TICK_WIDTH;
|
|
23
|
+
this._labelMargin = ticksStyle?.labelMargin ?? DEFAULTS.TICK_LABEL_MARGIN;
|
|
24
|
+
this._maxNumTicks = ticksStyle?.maxNumTicks ?? DEFAULTS.MAX_NUM_TICKS;
|
|
25
|
+
this._rangeTextPosition =
|
|
26
|
+
rangeTextPosition ?? ColorbarRangeTextPosition.Right;
|
|
27
|
+
this._showFullPixelValueRange = showFullPixelValueRange;
|
|
28
|
+
this._canvas = this._createCanvasElement(size, top, left);
|
|
29
|
+
if (container) {
|
|
30
|
+
this.appendTo(container);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
get size() {
|
|
34
|
+
const { width, height } = this._canvas;
|
|
35
|
+
return { width, height };
|
|
36
|
+
}
|
|
37
|
+
set size(size) {
|
|
38
|
+
const { _canvas: canvas } = this;
|
|
39
|
+
if (!isColorbarSizeValid(size) || areColorbarSizesEqual(canvas, size)) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
this._setCanvasSize(canvas, size);
|
|
43
|
+
this.render();
|
|
44
|
+
}
|
|
45
|
+
get top() {
|
|
46
|
+
return Number.parseInt(this._canvas.style.top);
|
|
47
|
+
}
|
|
48
|
+
set top(top) {
|
|
49
|
+
const { _canvas: canvas } = this;
|
|
50
|
+
const currentTop = this.top;
|
|
51
|
+
if (top === currentTop) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
canvas.style.top = `${top}px`;
|
|
55
|
+
this.render();
|
|
56
|
+
}
|
|
57
|
+
get left() {
|
|
58
|
+
return Number.parseInt(this._canvas.style.left);
|
|
59
|
+
}
|
|
60
|
+
set left(left) {
|
|
61
|
+
const { _canvas: canvas } = this;
|
|
62
|
+
const currentLeft = this.left;
|
|
63
|
+
if (left === currentLeft) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
canvas.style.left = `${left}px`;
|
|
67
|
+
this.render();
|
|
68
|
+
}
|
|
69
|
+
get imageRange() {
|
|
70
|
+
return { ...this._imageRange };
|
|
71
|
+
}
|
|
72
|
+
set imageRange(imageRange) {
|
|
73
|
+
if (!isRangeValid(imageRange) ||
|
|
74
|
+
areColorbarRangesEqual(imageRange, this._imageRange)) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
this._imageRange = imageRange;
|
|
78
|
+
this.render();
|
|
79
|
+
}
|
|
80
|
+
get voiRange() {
|
|
81
|
+
return { ...this._voiRange };
|
|
82
|
+
}
|
|
83
|
+
set voiRange(voiRange) {
|
|
84
|
+
if (!isRangeValid(voiRange) ||
|
|
85
|
+
areColorbarRangesEqual(voiRange, this._voiRange)) {
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
this._voiRange = voiRange;
|
|
89
|
+
this.render();
|
|
90
|
+
}
|
|
91
|
+
get tickSize() {
|
|
92
|
+
return this._tickSize;
|
|
93
|
+
}
|
|
94
|
+
set tickSize(tickSize) {
|
|
95
|
+
if (tickSize === this._tickSize) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this._tickSize = tickSize;
|
|
99
|
+
this.render();
|
|
100
|
+
}
|
|
101
|
+
get tickWidth() {
|
|
102
|
+
return this._tickWidth;
|
|
103
|
+
}
|
|
104
|
+
set tickWidth(tickWidth) {
|
|
105
|
+
if (tickWidth === this._tickWidth) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
this._tickWidth = tickWidth;
|
|
109
|
+
this.render();
|
|
110
|
+
}
|
|
111
|
+
get color() {
|
|
112
|
+
return this._color;
|
|
113
|
+
}
|
|
114
|
+
set color(color) {
|
|
115
|
+
if (color === this._color) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
this._color = color;
|
|
119
|
+
this.render();
|
|
120
|
+
}
|
|
121
|
+
get showFullPixelValueRange() {
|
|
122
|
+
return this._showFullPixelValueRange;
|
|
123
|
+
}
|
|
124
|
+
set showFullPixelValueRange(showFullRange) {
|
|
125
|
+
if (showFullRange === this._showFullPixelValueRange) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
this._showFullPixelValueRange = showFullRange;
|
|
129
|
+
this.render();
|
|
130
|
+
}
|
|
131
|
+
get visible() {
|
|
132
|
+
return this._canvas.style.display === 'block';
|
|
133
|
+
}
|
|
134
|
+
set visible(visible) {
|
|
135
|
+
if (visible === this.visible) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
this._canvas.style.display = visible ? 'block' : 'none';
|
|
139
|
+
if (visible) {
|
|
140
|
+
this.render();
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
appendTo(container) {
|
|
144
|
+
container.appendChild(this._canvas);
|
|
145
|
+
this.render();
|
|
146
|
+
}
|
|
147
|
+
static validateProps(props) {
|
|
148
|
+
const { size, imageRange, voiRange } = props;
|
|
149
|
+
if (size && !isColorbarSizeValid(size)) {
|
|
150
|
+
throw new Error('Invalid "size"');
|
|
151
|
+
}
|
|
152
|
+
if (imageRange && !isRangeValid(imageRange)) {
|
|
153
|
+
throw new Error('Invalid "imageRange"');
|
|
154
|
+
}
|
|
155
|
+
if (voiRange && !isRangeValid(voiRange)) {
|
|
156
|
+
throw new Error('Invalid "voiRange"');
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
_setCanvasSize(canvas, size) {
|
|
160
|
+
const { width, height } = size;
|
|
161
|
+
canvas.width = width;
|
|
162
|
+
canvas.height = height;
|
|
163
|
+
Object.assign(canvas.style, {
|
|
164
|
+
width: `${width}px`,
|
|
165
|
+
height: `${height}px`,
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
_createCanvasElement(size, top, left) {
|
|
169
|
+
const canvas = document.createElement('canvas');
|
|
170
|
+
Object.assign(canvas.style, {
|
|
171
|
+
display: 'none',
|
|
172
|
+
position: 'absolute',
|
|
173
|
+
boxSizing: 'border-box',
|
|
174
|
+
top: `${top}px`,
|
|
175
|
+
left: `${left}px`,
|
|
176
|
+
});
|
|
177
|
+
this._setCanvasSize(canvas, size);
|
|
178
|
+
return canvas;
|
|
179
|
+
}
|
|
180
|
+
_getTicks(range) {
|
|
181
|
+
const { lower, upper } = range;
|
|
182
|
+
const rangeValue = upper - lower;
|
|
183
|
+
const roughStep = rangeValue / (this._maxNumTicks - 1);
|
|
184
|
+
const stepPower = Math.pow(10, -Math.floor(Math.log10(Math.abs(roughStep))));
|
|
185
|
+
const roughtStepNormalized = roughStep * stepPower;
|
|
186
|
+
const normalizedStep = DEFAULTS.TICKS_STEPS.find((n) => n >= roughtStepNormalized);
|
|
187
|
+
const step = normalizedStep / stepPower;
|
|
188
|
+
const scaleMax = Math.ceil(upper / step) * step;
|
|
189
|
+
const scaleMin = Math.floor(lower / step) * step;
|
|
190
|
+
const ticksCount = Math.round((scaleMax - scaleMin) / step) + 1;
|
|
191
|
+
const ticks = [];
|
|
192
|
+
for (let i = 0; i < ticksCount; i++) {
|
|
193
|
+
ticks.push(scaleMin + i * step);
|
|
194
|
+
}
|
|
195
|
+
return { scaleMin, scaleMax, step, ticks };
|
|
196
|
+
}
|
|
197
|
+
_getLeftTickInfo({ position, labelMeasure }) {
|
|
198
|
+
const { width } = this._canvas;
|
|
199
|
+
const labelX = width - this.tickSize - labelMeasure.width - this._labelMargin;
|
|
200
|
+
const labelPoint = [labelX, position];
|
|
201
|
+
const tickPoints = {
|
|
202
|
+
start: [width - this._tickSize, position],
|
|
203
|
+
end: [width, position],
|
|
204
|
+
};
|
|
205
|
+
return { labelPoint, tickPoints };
|
|
206
|
+
}
|
|
207
|
+
_getRightTickInfo({ position }) {
|
|
208
|
+
const labelPoint = [this._tickSize + this._labelMargin, position];
|
|
209
|
+
const tickPoints = {
|
|
210
|
+
start: [0, position],
|
|
211
|
+
end: [this._tickSize, position],
|
|
212
|
+
};
|
|
213
|
+
return { labelPoint, tickPoints };
|
|
214
|
+
}
|
|
215
|
+
_getTopTickInfo({ position, labelMeasure }) {
|
|
216
|
+
throw new Error('Not implemented');
|
|
217
|
+
}
|
|
218
|
+
_getBottomTickInfo({ position, labelMeasure }) {
|
|
219
|
+
throw new Error('Not implemented');
|
|
220
|
+
}
|
|
221
|
+
render() {
|
|
222
|
+
const { _canvas: canvas } = this;
|
|
223
|
+
if (!canvas.isConnected || !this.visible) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
const { width, height } = canvas;
|
|
227
|
+
const isHorizontal = width >= height;
|
|
228
|
+
const maxCanvasPixelValue = isHorizontal ? width : height;
|
|
229
|
+
const canvasContext = canvas.getContext('2d');
|
|
230
|
+
const { _voiRange: voiRange } = this;
|
|
231
|
+
const range = this._showFullPixelValueRange
|
|
232
|
+
? this._imageRange
|
|
233
|
+
: { ...voiRange };
|
|
234
|
+
const rangeWidth = range.upper - range.lower;
|
|
235
|
+
const { ticks } = this._getTicks(range);
|
|
236
|
+
canvasContext.clearRect(0, 0, width, height);
|
|
237
|
+
canvasContext.font = this._font;
|
|
238
|
+
canvasContext.textBaseline = 'middle';
|
|
239
|
+
canvasContext.fillStyle = this._color;
|
|
240
|
+
canvasContext.strokeStyle = this._color;
|
|
241
|
+
canvasContext.lineWidth = this.tickWidth;
|
|
242
|
+
ticks.forEach((tick) => {
|
|
243
|
+
let position = Math.round(maxCanvasPixelValue * ((tick - range.lower) / rangeWidth));
|
|
244
|
+
if (!isHorizontal) {
|
|
245
|
+
position = height - position;
|
|
246
|
+
}
|
|
247
|
+
if (position < 0 || position > maxCanvasPixelValue) {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
const label = tick.toString();
|
|
251
|
+
const labelMeasure = canvasContext.measureText(label);
|
|
252
|
+
let tickInfo;
|
|
253
|
+
if (isHorizontal) {
|
|
254
|
+
if (this._rangeTextPosition === ColorbarRangeTextPosition.Top) {
|
|
255
|
+
tickInfo = this._getTopTickInfo({ position, labelMeasure });
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
tickInfo = this._getBottomTickInfo({ position, labelMeasure });
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
if (this._rangeTextPosition === ColorbarRangeTextPosition.Left) {
|
|
263
|
+
tickInfo = this._getLeftTickInfo({ position, labelMeasure });
|
|
264
|
+
}
|
|
265
|
+
else {
|
|
266
|
+
tickInfo = this._getRightTickInfo({ position });
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
const { labelPoint, tickPoints } = tickInfo;
|
|
270
|
+
const { start: tickStart, end: tickEnd } = tickPoints;
|
|
271
|
+
canvasContext.beginPath();
|
|
272
|
+
canvasContext.moveTo(tickStart[0], tickStart[1]);
|
|
273
|
+
canvasContext.lineTo(tickEnd[0], tickEnd[1]);
|
|
274
|
+
canvasContext.fillText(label, labelPoint[0], labelPoint[1]);
|
|
275
|
+
canvasContext.stroke();
|
|
276
|
+
return position;
|
|
277
|
+
});
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
export { ColorbarTicks as default, ColorbarTicks };
|
|
281
|
+
//# sourceMappingURL=ColorbarTicks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ColorbarTicks.js","sourceRoot":"","sources":["../../../../../src/utilities/voi/colorbar/ColorbarTicks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Types } from '@cornerstonejs/core';
|
|
2
|
+
import { Colorbar } from './Colorbar';
|
|
3
|
+
import type { ViewportColorbarProps, ColorbarVOIRange } from './types';
|
|
4
|
+
declare class ViewportColorbar extends Colorbar {
|
|
5
|
+
private _element;
|
|
6
|
+
private _volumeId;
|
|
7
|
+
private _hideTicksTime;
|
|
8
|
+
private _hideTicksTimeoutId;
|
|
9
|
+
constructor(props: ViewportColorbarProps);
|
|
10
|
+
get element(): HTMLDivElement;
|
|
11
|
+
get enabledElement(): Types.IEnabledElement;
|
|
12
|
+
protected getVOIMultipliers(): [number, number];
|
|
13
|
+
protected onVoiChange(voiRange: ColorbarVOIRange): void;
|
|
14
|
+
private static _getImageRange;
|
|
15
|
+
private static _getVOIRange;
|
|
16
|
+
private autoHideTicks;
|
|
17
|
+
private showAndAutoHideTicks;
|
|
18
|
+
private _stackNewImageCallback;
|
|
19
|
+
private _imageVolumeModifiedCallback;
|
|
20
|
+
private _viewportVOIModifiedCallback;
|
|
21
|
+
private _addCornerstoneEventListener;
|
|
22
|
+
}
|
|
23
|
+
export { ViewportColorbar as default, ViewportColorbar };
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { eventTarget, VolumeViewport, StackViewport, Enums, utilities, getEnabledElement, } from '@cornerstonejs/core';
|
|
2
|
+
import { Colorbar } from './Colorbar';
|
|
3
|
+
import { getVOIMultipliers } from '../../getVOIMultipliers';
|
|
4
|
+
const { Events } = Enums;
|
|
5
|
+
const defaultImageRange = { lower: -1000, upper: 1000 };
|
|
6
|
+
class ViewportColorbar extends Colorbar {
|
|
7
|
+
constructor(props) {
|
|
8
|
+
const { element, volumeId } = props;
|
|
9
|
+
const imageRange = ViewportColorbar._getImageRange(element, volumeId);
|
|
10
|
+
const voiRange = ViewportColorbar._getVOIRange(element, volumeId);
|
|
11
|
+
super({ ...props, imageRange, voiRange });
|
|
12
|
+
this.autoHideTicks = () => {
|
|
13
|
+
if (this._hideTicksTimeoutId) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
const timeLeft = this._hideTicksTime - Date.now();
|
|
17
|
+
if (timeLeft <= 0) {
|
|
18
|
+
this.hideTicks();
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this._hideTicksTimeoutId = window.setTimeout(() => {
|
|
22
|
+
this._hideTicksTimeoutId = 0;
|
|
23
|
+
this.autoHideTicks();
|
|
24
|
+
}, timeLeft);
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
this._stackNewImageCallback = () => {
|
|
28
|
+
this.imageRange = ViewportColorbar._getImageRange(this._element);
|
|
29
|
+
};
|
|
30
|
+
this._imageVolumeModifiedCallback = (evt) => {
|
|
31
|
+
const { volumeId } = evt.detail.imageVolume;
|
|
32
|
+
if (volumeId !== this._volumeId) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
const { _element: element } = this;
|
|
36
|
+
this.imageRange = ViewportColorbar._getImageRange(element, volumeId);
|
|
37
|
+
};
|
|
38
|
+
this._viewportVOIModifiedCallback = (evt) => {
|
|
39
|
+
const { viewportId, volumeId, range: voiRange } = evt.detail;
|
|
40
|
+
const { viewport } = this.enabledElement;
|
|
41
|
+
if (viewportId !== viewport.id || volumeId !== this._volumeId) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
this.voiRange = voiRange;
|
|
45
|
+
this.showAndAutoHideTicks();
|
|
46
|
+
};
|
|
47
|
+
this._element = element;
|
|
48
|
+
this._volumeId = volumeId;
|
|
49
|
+
this._addCornerstoneEventListener();
|
|
50
|
+
}
|
|
51
|
+
get element() {
|
|
52
|
+
return this._element;
|
|
53
|
+
}
|
|
54
|
+
get enabledElement() {
|
|
55
|
+
return getEnabledElement(this._element);
|
|
56
|
+
}
|
|
57
|
+
getVOIMultipliers() {
|
|
58
|
+
const { viewport } = this.enabledElement;
|
|
59
|
+
return getVOIMultipliers(viewport, this._volumeId);
|
|
60
|
+
}
|
|
61
|
+
onVoiChange(voiRange) {
|
|
62
|
+
super.onVoiChange(voiRange);
|
|
63
|
+
const { viewport } = this.enabledElement;
|
|
64
|
+
if (viewport instanceof StackViewport) {
|
|
65
|
+
viewport.setProperties({
|
|
66
|
+
voiRange: voiRange,
|
|
67
|
+
});
|
|
68
|
+
viewport.render();
|
|
69
|
+
}
|
|
70
|
+
else if (viewport instanceof VolumeViewport) {
|
|
71
|
+
const { _volumeId: volumeId } = this;
|
|
72
|
+
const viewportsContainingVolumeUID = utilities.getViewportsWithVolumeId(volumeId, viewport.renderingEngineId);
|
|
73
|
+
viewport.setProperties({ voiRange }, volumeId);
|
|
74
|
+
viewportsContainingVolumeUID.forEach((vp) => vp.render());
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
static _getImageRange(element, volumeId) {
|
|
78
|
+
const enabledElement = getEnabledElement(element);
|
|
79
|
+
const { viewport } = enabledElement;
|
|
80
|
+
const actor = volumeId
|
|
81
|
+
? viewport.getActor(volumeId)
|
|
82
|
+
: viewport.getDefaultActor();
|
|
83
|
+
if (!actor) {
|
|
84
|
+
return defaultImageRange;
|
|
85
|
+
}
|
|
86
|
+
const imageData = actor.actor.getMapper().getInputData();
|
|
87
|
+
const imageRange = imageData.getPointData().getScalars().getRange();
|
|
88
|
+
return imageRange[0] === 0 && imageRange[1] === 0
|
|
89
|
+
? defaultImageRange
|
|
90
|
+
: { lower: imageRange[0], upper: imageRange[1] };
|
|
91
|
+
}
|
|
92
|
+
static _getVOIRange(element, volumeId) {
|
|
93
|
+
const enabledElement = getEnabledElement(element);
|
|
94
|
+
const { viewport } = enabledElement;
|
|
95
|
+
const volumeActor = volumeId
|
|
96
|
+
? viewport.getActor(volumeId)
|
|
97
|
+
: viewport.getDefaultActor();
|
|
98
|
+
if (!volumeActor || !utilities.isImageActor(volumeActor)) {
|
|
99
|
+
return defaultImageRange;
|
|
100
|
+
}
|
|
101
|
+
const voiRange = volumeActor.actor
|
|
102
|
+
.getProperty()
|
|
103
|
+
.getRGBTransferFunction(0)
|
|
104
|
+
.getRange();
|
|
105
|
+
return voiRange[0] === 0 && voiRange[1] === 0
|
|
106
|
+
? defaultImageRange
|
|
107
|
+
: { lower: voiRange[0], upper: voiRange[1] };
|
|
108
|
+
}
|
|
109
|
+
showAndAutoHideTicks(interval = 1000) {
|
|
110
|
+
this._hideTicksTime = Date.now() + interval;
|
|
111
|
+
this.showTicks();
|
|
112
|
+
this.autoHideTicks();
|
|
113
|
+
}
|
|
114
|
+
_addCornerstoneEventListener() {
|
|
115
|
+
const { _element: element } = this;
|
|
116
|
+
eventTarget.addEventListener(Events.IMAGE_VOLUME_MODIFIED, this._imageVolumeModifiedCallback);
|
|
117
|
+
element.addEventListener(Events.STACK_NEW_IMAGE, this._stackNewImageCallback);
|
|
118
|
+
element.addEventListener(Events.VOI_MODIFIED, this._viewportVOIModifiedCallback);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
export { ViewportColorbar as default, ViewportColorbar };
|
|
122
|
+
//# sourceMappingURL=ViewportColorbar.js.map
|