@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.
Files changed (228) hide show
  1. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  2. package/dist/cjs/utilities/getVOIMultipliers.d.ts +5 -0
  3. package/dist/cjs/utilities/getVOIMultipliers.js +23 -0
  4. package/dist/cjs/utilities/getVOIMultipliers.js.map +1 -0
  5. package/dist/cjs/utilities/index.d.ts +2 -1
  6. package/dist/cjs/utilities/index.js +3 -1
  7. package/dist/cjs/utilities/index.js.map +1 -1
  8. package/dist/cjs/utilities/math/vec3/interpolateVec3.d.ts +2 -0
  9. package/dist/cjs/utilities/math/vec3/interpolateVec3.js +13 -0
  10. package/dist/cjs/utilities/math/vec3/interpolateVec3.js.map +1 -0
  11. package/dist/cjs/utilities/viewport/isViewportPreScaled.js +2 -1
  12. package/dist/cjs/utilities/viewport/isViewportPreScaled.js.map +1 -1
  13. package/dist/cjs/utilities/voi/colorbar/Colorbar.d.ts +44 -0
  14. package/dist/cjs/utilities/voi/colorbar/Colorbar.js +249 -0
  15. package/dist/cjs/utilities/voi/colorbar/Colorbar.js.map +1 -0
  16. package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.d.ts +29 -0
  17. package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.js +184 -0
  18. package/dist/cjs/utilities/voi/colorbar/ColorbarCanvas.js.map +1 -0
  19. package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.d.ts +46 -0
  20. package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.js +286 -0
  21. package/dist/cjs/utilities/voi/colorbar/ColorbarTicks.js.map +1 -0
  22. package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.d.ts +23 -0
  23. package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.js +126 -0
  24. package/dist/cjs/utilities/voi/colorbar/ViewportColorbar.js.map +1 -0
  25. package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.d.ts +3 -0
  26. package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.js +9 -0
  27. package/dist/cjs/utilities/voi/colorbar/common/areColorbarRangesEqual.js.map +1 -0
  28. package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.d.ts +3 -0
  29. package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.js +9 -0
  30. package/dist/cjs/utilities/voi/colorbar/common/areColorbarSizesEqual.js.map +1 -0
  31. package/dist/cjs/utilities/voi/colorbar/common/index.d.ts +4 -0
  32. package/dist/cjs/utilities/voi/colorbar/common/index.js +12 -0
  33. package/dist/cjs/utilities/voi/colorbar/common/index.js.map +1 -0
  34. package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.d.ts +3 -0
  35. package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.js +9 -0
  36. package/dist/cjs/utilities/voi/colorbar/common/isColorbarSizeValid.js.map +1 -0
  37. package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.d.ts +3 -0
  38. package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.js +14 -0
  39. package/dist/cjs/utilities/voi/colorbar/common/isRangeTextPositionValid.js.map +1 -0
  40. package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.d.ts +3 -0
  41. package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.js +9 -0
  42. package/dist/cjs/utilities/voi/colorbar/common/isRangeValid.js.map +1 -0
  43. package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.d.ts +6 -0
  44. package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js +11 -0
  45. package/dist/cjs/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js.map +1 -0
  46. package/dist/cjs/utilities/voi/colorbar/enums/index.d.ts +1 -0
  47. package/dist/cjs/utilities/voi/colorbar/enums/index.js +6 -0
  48. package/dist/cjs/utilities/voi/colorbar/enums/index.js.map +1 -0
  49. package/dist/cjs/utilities/voi/colorbar/index.d.ts +6 -0
  50. package/dist/cjs/utilities/voi/colorbar/index.js +33 -0
  51. package/dist/cjs/utilities/voi/colorbar/index.js.map +1 -0
  52. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.d.ts +12 -0
  53. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.js +3 -0
  54. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCanvasProps.js.map +1 -0
  55. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.d.ts +11 -0
  56. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.js +3 -0
  57. package/dist/cjs/utilities/voi/colorbar/types/ColorbarCommonProps.js.map +1 -0
  58. package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.d.ts +4 -0
  59. package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.js +3 -0
  60. package/dist/cjs/utilities/voi/colorbar/types/ColorbarImageRange.js.map +1 -0
  61. package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.d.ts +7 -0
  62. package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.js +3 -0
  63. package/dist/cjs/utilities/voi/colorbar/types/ColorbarProps.js.map +1 -0
  64. package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.d.ts +4 -0
  65. package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.js +3 -0
  66. package/dist/cjs/utilities/voi/colorbar/types/ColorbarSize.js.map +1 -0
  67. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.d.ts +7 -0
  68. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.js +3 -0
  69. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksProps.js.map +1 -0
  70. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.d.ts +8 -0
  71. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.js +3 -0
  72. package/dist/cjs/utilities/voi/colorbar/types/ColorbarTicksStyle.js.map +1 -0
  73. package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.d.ts +2 -0
  74. package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.js +3 -0
  75. package/dist/cjs/utilities/voi/colorbar/types/ColorbarVOIRange.js.map +1 -0
  76. package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.d.ts +5 -0
  77. package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.js +3 -0
  78. package/dist/cjs/utilities/voi/colorbar/types/ViewportColorbarProps.js.map +1 -0
  79. package/dist/cjs/utilities/voi/colorbar/types/index.d.ts +8 -0
  80. package/dist/cjs/utilities/voi/colorbar/types/index.js +3 -0
  81. package/dist/cjs/utilities/voi/colorbar/types/index.js.map +1 -0
  82. package/dist/cjs/utilities/voi/index.d.ts +2 -0
  83. package/dist/cjs/utilities/voi/index.js +29 -0
  84. package/dist/cjs/utilities/voi/index.js.map +1 -0
  85. package/dist/cjs/widgets/Widget.d.ts +17 -0
  86. package/dist/cjs/widgets/Widget.js +71 -0
  87. package/dist/cjs/widgets/Widget.js.map +1 -0
  88. package/dist/cjs/widgets/types/WidgetProps.d.ts +4 -0
  89. package/dist/cjs/widgets/types/WidgetProps.js +3 -0
  90. package/dist/cjs/widgets/types/WidgetProps.js.map +1 -0
  91. package/dist/cjs/widgets/types/WidgetSize.d.ts +4 -0
  92. package/dist/cjs/widgets/types/WidgetSize.js +3 -0
  93. package/dist/cjs/widgets/types/WidgetSize.js.map +1 -0
  94. package/dist/cjs/widgets/types/index.d.ts +2 -0
  95. package/dist/cjs/widgets/types/index.js +3 -0
  96. package/dist/cjs/widgets/types/index.js.map +1 -0
  97. package/dist/esm/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  98. package/dist/esm/utilities/getVOIMultipliers.d.ts +5 -0
  99. package/dist/esm/utilities/getVOIMultipliers.js +19 -0
  100. package/dist/esm/utilities/getVOIMultipliers.js.map +1 -0
  101. package/dist/esm/utilities/index.d.ts +2 -1
  102. package/dist/esm/utilities/index.js +2 -1
  103. package/dist/esm/utilities/index.js.map +1 -1
  104. package/dist/esm/utilities/math/vec3/interpolateVec3.d.ts +2 -0
  105. package/dist/esm/utilities/math/vec3/interpolateVec3.js +9 -0
  106. package/dist/esm/utilities/math/vec3/interpolateVec3.js.map +1 -0
  107. package/dist/esm/utilities/viewport/isViewportPreScaled.js +2 -1
  108. package/dist/esm/utilities/viewport/isViewportPreScaled.js.map +1 -1
  109. package/dist/esm/utilities/voi/colorbar/Colorbar.d.ts +44 -0
  110. package/dist/esm/utilities/voi/colorbar/Colorbar.js +241 -0
  111. package/dist/esm/utilities/voi/colorbar/Colorbar.js.map +1 -0
  112. package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.d.ts +29 -0
  113. package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.js +177 -0
  114. package/dist/esm/utilities/voi/colorbar/ColorbarCanvas.js.map +1 -0
  115. package/dist/esm/utilities/voi/colorbar/ColorbarTicks.d.ts +46 -0
  116. package/dist/esm/utilities/voi/colorbar/ColorbarTicks.js +281 -0
  117. package/dist/esm/utilities/voi/colorbar/ColorbarTicks.js.map +1 -0
  118. package/dist/esm/utilities/voi/colorbar/ViewportColorbar.d.ts +23 -0
  119. package/dist/esm/utilities/voi/colorbar/ViewportColorbar.js +122 -0
  120. package/dist/esm/utilities/voi/colorbar/ViewportColorbar.js.map +1 -0
  121. package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.d.ts +3 -0
  122. package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.js +5 -0
  123. package/dist/esm/utilities/voi/colorbar/common/areColorbarRangesEqual.js.map +1 -0
  124. package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.d.ts +3 -0
  125. package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.js +5 -0
  126. package/dist/esm/utilities/voi/colorbar/common/areColorbarSizesEqual.js.map +1 -0
  127. package/dist/esm/utilities/voi/colorbar/common/index.d.ts +4 -0
  128. package/dist/esm/utilities/voi/colorbar/common/index.js +5 -0
  129. package/dist/esm/utilities/voi/colorbar/common/index.js.map +1 -0
  130. package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.d.ts +3 -0
  131. package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.js +5 -0
  132. package/dist/esm/utilities/voi/colorbar/common/isColorbarSizeValid.js.map +1 -0
  133. package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.d.ts +3 -0
  134. package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.js +10 -0
  135. package/dist/esm/utilities/voi/colorbar/common/isRangeTextPositionValid.js.map +1 -0
  136. package/dist/esm/utilities/voi/colorbar/common/isRangeValid.d.ts +3 -0
  137. package/dist/esm/utilities/voi/colorbar/common/isRangeValid.js +5 -0
  138. package/dist/esm/utilities/voi/colorbar/common/isRangeValid.js.map +1 -0
  139. package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.d.ts +6 -0
  140. package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js +8 -0
  141. package/dist/esm/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.js.map +1 -0
  142. package/dist/esm/utilities/voi/colorbar/enums/index.d.ts +1 -0
  143. package/dist/esm/utilities/voi/colorbar/enums/index.js +2 -0
  144. package/dist/esm/utilities/voi/colorbar/enums/index.js.map +1 -0
  145. package/dist/esm/utilities/voi/colorbar/index.d.ts +6 -0
  146. package/dist/esm/utilities/voi/colorbar/index.js +5 -0
  147. package/dist/esm/utilities/voi/colorbar/index.js.map +1 -0
  148. package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.d.ts +12 -0
  149. package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.js +2 -0
  150. package/dist/esm/utilities/voi/colorbar/types/ColorbarCanvasProps.js.map +1 -0
  151. package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.d.ts +11 -0
  152. package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.js +2 -0
  153. package/dist/esm/utilities/voi/colorbar/types/ColorbarCommonProps.js.map +1 -0
  154. package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.d.ts +4 -0
  155. package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.js +2 -0
  156. package/dist/esm/utilities/voi/colorbar/types/ColorbarImageRange.js.map +1 -0
  157. package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.d.ts +7 -0
  158. package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.js +2 -0
  159. package/dist/esm/utilities/voi/colorbar/types/ColorbarProps.js.map +1 -0
  160. package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.d.ts +4 -0
  161. package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.js +2 -0
  162. package/dist/esm/utilities/voi/colorbar/types/ColorbarSize.js.map +1 -0
  163. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.d.ts +7 -0
  164. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.js +2 -0
  165. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksProps.js.map +1 -0
  166. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.d.ts +8 -0
  167. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.js +2 -0
  168. package/dist/esm/utilities/voi/colorbar/types/ColorbarTicksStyle.js.map +1 -0
  169. package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.d.ts +2 -0
  170. package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.js +2 -0
  171. package/dist/esm/utilities/voi/colorbar/types/ColorbarVOIRange.js.map +1 -0
  172. package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.d.ts +5 -0
  173. package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.js +2 -0
  174. package/dist/esm/utilities/voi/colorbar/types/ViewportColorbarProps.js.map +1 -0
  175. package/dist/esm/utilities/voi/colorbar/types/index.d.ts +8 -0
  176. package/dist/esm/utilities/voi/colorbar/types/index.js +2 -0
  177. package/dist/esm/utilities/voi/colorbar/types/index.js.map +1 -0
  178. package/dist/esm/utilities/voi/index.d.ts +2 -0
  179. package/dist/esm/utilities/voi/index.js +3 -0
  180. package/dist/esm/utilities/voi/index.js.map +1 -0
  181. package/dist/esm/widgets/Widget.d.ts +17 -0
  182. package/dist/esm/widgets/Widget.js +67 -0
  183. package/dist/esm/widgets/Widget.js.map +1 -0
  184. package/dist/esm/widgets/types/WidgetProps.d.ts +4 -0
  185. package/dist/esm/widgets/types/WidgetProps.js +2 -0
  186. package/dist/esm/widgets/types/WidgetProps.js.map +1 -0
  187. package/dist/esm/widgets/types/WidgetSize.d.ts +4 -0
  188. package/dist/esm/widgets/types/WidgetSize.js +2 -0
  189. package/dist/esm/widgets/types/WidgetSize.js.map +1 -0
  190. package/dist/esm/widgets/types/index.d.ts +2 -0
  191. package/dist/esm/widgets/types/index.js +2 -0
  192. package/dist/esm/widgets/types/index.js.map +1 -0
  193. package/dist/umd/index.js +1 -1
  194. package/dist/umd/index.js.map +1 -1
  195. package/package.json +3 -3
  196. package/src/tools/displayTools/SegmentationDisplayTool.ts +1 -2
  197. package/src/utilities/getVOIMultipliers.ts +33 -0
  198. package/src/utilities/index.ts +2 -0
  199. package/src/utilities/math/vec3/interpolateVec3.ts +20 -0
  200. package/src/utilities/viewport/isViewportPreScaled.ts +3 -1
  201. package/src/utilities/voi/colorbar/Colorbar.ts +367 -0
  202. package/src/utilities/voi/colorbar/ColorbarCanvas.ts +287 -0
  203. package/src/utilities/voi/colorbar/ColorbarTicks.ts +500 -0
  204. package/src/utilities/voi/colorbar/ViewportColorbar.ts +194 -0
  205. package/src/utilities/voi/colorbar/common/areColorbarRangesEqual.ts +10 -0
  206. package/src/utilities/voi/colorbar/common/areColorbarSizesEqual.ts +7 -0
  207. package/src/utilities/voi/colorbar/common/index.ts +4 -0
  208. package/src/utilities/voi/colorbar/common/isColorbarSizeValid.ts +7 -0
  209. package/src/utilities/voi/colorbar/common/isRangeTextPositionValid.ts +16 -0
  210. package/src/utilities/voi/colorbar/common/isRangeValid.ts +7 -0
  211. package/src/utilities/voi/colorbar/enums/ColorbarRangeTextPosition.ts +11 -0
  212. package/src/utilities/voi/colorbar/enums/index.ts +1 -0
  213. package/src/utilities/voi/colorbar/index.ts +8 -0
  214. package/src/utilities/voi/colorbar/types/ColorbarCanvasProps.ts +14 -0
  215. package/src/utilities/voi/colorbar/types/ColorbarCommonProps.ts +23 -0
  216. package/src/utilities/voi/colorbar/types/ColorbarImageRange.ts +4 -0
  217. package/src/utilities/voi/colorbar/types/ColorbarProps.ts +8 -0
  218. package/src/utilities/voi/colorbar/types/ColorbarSize.ts +4 -0
  219. package/src/utilities/voi/colorbar/types/ColorbarTicksProps.ts +8 -0
  220. package/src/utilities/voi/colorbar/types/ColorbarTicksStyle.ts +8 -0
  221. package/src/utilities/voi/colorbar/types/ColorbarVOIRange.ts +3 -0
  222. package/src/utilities/voi/colorbar/types/ViewportColorbarProps.ts +6 -0
  223. package/src/utilities/voi/colorbar/types/index.ts +8 -0
  224. package/src/utilities/voi/index.ts +3 -0
  225. package/src/widgets/Widget.ts +169 -0
  226. package/src/widgets/types/WidgetProps.ts +4 -0
  227. package/src/widgets/types/WidgetSize.ts +4 -0
  228. 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