hellfire 0.18.0 → 0.19.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/CHANGELOG.md +16 -0
- package/dist/index.js +195 -110
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,22 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
# [0.19.0](http://10.16.100.57/diffusion/115/paladin/compare/v0.18.3...v0.19.0) (2022-02-07)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
## [0.18.3](http://10.16.100.57/diffusion/115/paladin/compare/v0.18.2...v0.18.3) (2022-01-29)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
## [0.18.2](http://10.16.100.57/diffusion/115/paladin/compare/v0.18.1...v0.18.2) (2022-01-27)
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
## [0.18.1](http://10.16.100.57/diffusion/115/paladin/compare/v0.18.0...v0.18.1) (2022-01-26)
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
5
21
|
# [0.18.0](http://10.16.100.57/diffusion/115/paladin/compare/v0.17.12...v0.18.0) (2022-01-26)
|
|
6
22
|
|
|
7
23
|
|
package/dist/index.js
CHANGED
|
@@ -575,7 +575,9 @@ var WwwcDefinedList = {
|
|
|
575
575
|
WWWC_NECK: [350, 90],
|
|
576
576
|
WWWC_TOP_ABDOMEN: [150, 50]
|
|
577
577
|
};
|
|
578
|
-
var LengthTools = ['Length', 'Angle', 'ArrowAnnotate', 'EllipticalRoi', 'Probe', 'RectangleRoi', 'CobbAngle', 'CTR'];
|
|
578
|
+
var LengthTools = ['Length', 'Angle', 'ArrowAnnotate', 'EllipticalRoi', 'Probe', 'RectangleRoi', 'CobbAngle', 'CTR', 'ReferencePosition']; // 真正的测量工具 连续测量那边需要用到
|
|
579
|
+
|
|
580
|
+
var LengthToolsWithMeasure = ['Length', 'Angle', 'ArrowAnnotate', 'EllipticalRoi', 'Probe', 'RectangleRoi', 'CobbAngle', 'CTR'];
|
|
579
581
|
var LengthToolMap = {
|
|
580
582
|
Length: '直线',
|
|
581
583
|
ArrowAnnotate: '箭头',
|
|
@@ -601,6 +603,7 @@ var ToolsCursorMap = {
|
|
|
601
603
|
|
|
602
604
|
reactHotLoader.register(WwwcDefinedList, "WwwcDefinedList", "/Users/huyeqing/workspace/chainz/paladin/src/utils/constant.js");
|
|
603
605
|
reactHotLoader.register(LengthTools, "LengthTools", "/Users/huyeqing/workspace/chainz/paladin/src/utils/constant.js");
|
|
606
|
+
reactHotLoader.register(LengthToolsWithMeasure, "LengthToolsWithMeasure", "/Users/huyeqing/workspace/chainz/paladin/src/utils/constant.js");
|
|
604
607
|
reactHotLoader.register(LengthToolMap, "LengthToolMap", "/Users/huyeqing/workspace/chainz/paladin/src/utils/constant.js");
|
|
605
608
|
reactHotLoader.register(ToolsCursorMap, "ToolsCursorMap", "/Users/huyeqing/workspace/chainz/paladin/src/utils/constant.js");
|
|
606
609
|
})();
|
|
@@ -10868,7 +10871,6 @@ var triggerEvent$2 = cornerstoneTools.importInternal('util/triggerEvent');
|
|
|
10868
10871
|
var external$9 = cornerstoneTools.external,
|
|
10869
10872
|
getToolState$5 = cornerstoneTools.getToolState,
|
|
10870
10873
|
loadHandlerManager = cornerstoneTools.loadHandlerManager,
|
|
10871
|
-
requestPoolManager = cornerstoneTools.requestPoolManager,
|
|
10872
10874
|
EVENTS$2 = cornerstoneTools.EVENTS;
|
|
10873
10875
|
/**
|
|
10874
10876
|
* Scrolls through the stack to the image index requested.
|
|
@@ -11002,9 +11004,7 @@ var _default$h = function _default(element, newImageIdIndex, options, callback)
|
|
|
11002
11004
|
imagePromise = loadAndCacheImagePlus(newImageId);
|
|
11003
11005
|
}
|
|
11004
11006
|
|
|
11005
|
-
imagePromise.then(doneCallback, failCallback);
|
|
11006
|
-
|
|
11007
|
-
requestPoolManager.startGrabbing();
|
|
11007
|
+
imagePromise.then(doneCallback, failCallback);
|
|
11008
11008
|
|
|
11009
11009
|
if (_options.eventTrigger) {
|
|
11010
11010
|
triggerEvent$2(element, EVENTS$2.STACK_SCROLL, eventData);
|
|
@@ -11022,7 +11022,6 @@ var _default$h = function _default(element, newImageIdIndex, options, callback)
|
|
|
11022
11022
|
reactHotLoader.register(external$9, "external", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11023
11023
|
reactHotLoader.register(getToolState$5, "getToolState", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11024
11024
|
reactHotLoader.register(loadHandlerManager, "loadHandlerManager", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11025
|
-
reactHotLoader.register(requestPoolManager, "requestPoolManager", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11026
11025
|
reactHotLoader.register(EVENTS$2, "EVENTS", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11027
11026
|
reactHotLoader.register(_default$h, "default", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/scrollToIndex.js");
|
|
11028
11027
|
})();
|
|
@@ -23500,24 +23499,24 @@ var __signature__$1q = typeof reactHotLoaderGlobal !== 'undefined' ? reactHotLoa
|
|
|
23500
23499
|
|
|
23501
23500
|
var elementToolOptions = {};
|
|
23502
23501
|
/**
|
|
23503
|
-
* Retrieve the options object associated with a particular
|
|
23502
|
+
* Retrieve the options object associated with a particular toolName and element
|
|
23504
23503
|
* @export
|
|
23505
23504
|
* @public
|
|
23506
23505
|
* @method
|
|
23507
23506
|
* @name getToolOptions
|
|
23508
23507
|
*
|
|
23509
|
-
* @param {string}
|
|
23508
|
+
* @param {string} toolName Tool name identifier of the target options object
|
|
23510
23509
|
* @param {HTMLElement} element Element of the target options object
|
|
23511
23510
|
*
|
|
23512
23511
|
* @returns {Object} Target options object (empty if not yet set)
|
|
23513
23512
|
*/
|
|
23514
23513
|
|
|
23515
|
-
function getToolOptions(
|
|
23516
|
-
if (!elementToolOptions[
|
|
23514
|
+
function getToolOptions(toolName, element) {
|
|
23515
|
+
if (!elementToolOptions[toolName]) {
|
|
23517
23516
|
return {};
|
|
23518
23517
|
}
|
|
23519
23518
|
|
|
23520
|
-
var toolOptions = elementToolOptions[
|
|
23519
|
+
var toolOptions = elementToolOptions[toolName];
|
|
23521
23520
|
var optionsObject = toolOptions.find(function (toolOptionObject) {
|
|
23522
23521
|
return toolOptionObject.element === element;
|
|
23523
23522
|
});
|
|
@@ -23529,67 +23528,71 @@ function getToolOptions(toolType, element) {
|
|
|
23529
23528
|
return optionsObject.options;
|
|
23530
23529
|
}
|
|
23531
23530
|
/**
|
|
23532
|
-
* Set the options object associated with a particular
|
|
23531
|
+
* Set the options object associated with a particular toolName and element.
|
|
23533
23532
|
* @export
|
|
23534
23533
|
* @public
|
|
23535
23534
|
* @method
|
|
23536
23535
|
* @name setToolOptions
|
|
23537
23536
|
*
|
|
23538
|
-
* @param {string}
|
|
23537
|
+
* @param {string} toolName Tool name identifier of the target options object.
|
|
23539
23538
|
* @param {HTMLElement} element Element of the target options object.
|
|
23540
23539
|
* @param {Object} options Options object to store at target.
|
|
23541
23540
|
* @returns {void}
|
|
23542
23541
|
*/
|
|
23543
23542
|
|
|
23544
23543
|
|
|
23545
|
-
function setToolOptions(
|
|
23546
|
-
if (!elementToolOptions[
|
|
23547
|
-
elementToolOptions[
|
|
23544
|
+
function setToolOptions(toolName, element, options) {
|
|
23545
|
+
if (!elementToolOptions[toolName]) {
|
|
23546
|
+
elementToolOptions[toolName] = [{
|
|
23548
23547
|
element: element,
|
|
23549
23548
|
options: options
|
|
23550
23549
|
}];
|
|
23551
23550
|
return;
|
|
23552
23551
|
}
|
|
23553
23552
|
|
|
23554
|
-
var toolOptions = elementToolOptions[
|
|
23553
|
+
var toolOptions = elementToolOptions[toolName];
|
|
23555
23554
|
var index = toolOptions.findIndex(function (toolOptionObject) {
|
|
23556
23555
|
return toolOptionObject.element === element;
|
|
23557
23556
|
});
|
|
23558
23557
|
|
|
23559
23558
|
if (index === -1) {
|
|
23560
|
-
elementToolOptions[
|
|
23559
|
+
elementToolOptions[toolName].push({
|
|
23561
23560
|
element: element,
|
|
23562
23561
|
options: options
|
|
23563
23562
|
});
|
|
23564
23563
|
} else {
|
|
23565
|
-
var elementOptions = elementToolOptions[
|
|
23566
|
-
elementToolOptions[
|
|
23564
|
+
var elementOptions = elementToolOptions[toolName][index].options || {};
|
|
23565
|
+
elementToolOptions[toolName][index].options = Object.assign(elementOptions, options);
|
|
23567
23566
|
}
|
|
23568
23567
|
}
|
|
23569
23568
|
/**
|
|
23570
|
-
* Clear the options object associated with a particular
|
|
23569
|
+
* Clear the options object associated with a particular toolName and element.
|
|
23571
23570
|
* @export
|
|
23572
23571
|
* @public
|
|
23573
23572
|
* @method
|
|
23574
23573
|
* @name clearToolOptions
|
|
23575
23574
|
*
|
|
23576
|
-
* @param {string}
|
|
23575
|
+
* @param {string} toolName Tool name identifier of the target options object.
|
|
23577
23576
|
* @param {HTMLElement} element Element of the target options object.
|
|
23578
23577
|
* @returns {void}
|
|
23579
23578
|
*/
|
|
23580
23579
|
|
|
23581
23580
|
|
|
23582
|
-
function clearToolOptions(
|
|
23583
|
-
var toolOptions = elementToolOptions[
|
|
23581
|
+
function clearToolOptions(toolName, element) {
|
|
23582
|
+
var toolOptions = elementToolOptions[toolName];
|
|
23584
23583
|
|
|
23585
23584
|
if (toolOptions) {
|
|
23586
|
-
elementToolOptions[
|
|
23585
|
+
elementToolOptions[toolName] = toolOptions.filter(function (toolOptionObject) {
|
|
23587
23586
|
return toolOptionObject.element !== element;
|
|
23588
23587
|
});
|
|
23589
23588
|
}
|
|
23590
23589
|
}
|
|
23591
23590
|
/**
|
|
23592
23591
|
* Clear the options objects associated with a particular toolType.
|
|
23592
|
+
*
|
|
23593
|
+
* Deprecation notice: use clearToolOptionsByToolName instead
|
|
23594
|
+
* @deprecated
|
|
23595
|
+
*
|
|
23593
23596
|
* @export
|
|
23594
23597
|
* @public
|
|
23595
23598
|
* @method
|
|
@@ -23601,7 +23604,22 @@ function clearToolOptions(toolType, element) {
|
|
|
23601
23604
|
|
|
23602
23605
|
|
|
23603
23606
|
function clearToolOptionsByToolType(toolType) {
|
|
23604
|
-
|
|
23607
|
+
return clearToolOptionsByToolName(toolType);
|
|
23608
|
+
}
|
|
23609
|
+
/**
|
|
23610
|
+
* Clear the options objects associated with a particular toolName.
|
|
23611
|
+
* @export
|
|
23612
|
+
* @public
|
|
23613
|
+
* @method
|
|
23614
|
+
* @name clearToolOptionsByToolName
|
|
23615
|
+
*
|
|
23616
|
+
* @param {string} toolName Tool name identifier of the target options objects.
|
|
23617
|
+
* @returns {void}
|
|
23618
|
+
*/
|
|
23619
|
+
|
|
23620
|
+
|
|
23621
|
+
function clearToolOptionsByToolName(toolName) {
|
|
23622
|
+
delete elementToolOptions[toolName];
|
|
23605
23623
|
}
|
|
23606
23624
|
/**
|
|
23607
23625
|
* Clear the options objects associated with a particular element.
|
|
@@ -23616,8 +23634,8 @@ function clearToolOptionsByToolType(toolType) {
|
|
|
23616
23634
|
|
|
23617
23635
|
|
|
23618
23636
|
function clearToolOptionsByElement(element) {
|
|
23619
|
-
for (var
|
|
23620
|
-
elementToolOptions[
|
|
23637
|
+
for (var toolName in elementToolOptions) {
|
|
23638
|
+
elementToolOptions[toolName] = elementToolOptions[toolName].filter(function (toolOptionObject) {
|
|
23621
23639
|
return toolOptionObject.element !== element;
|
|
23622
23640
|
});
|
|
23623
23641
|
}
|
|
@@ -23635,6 +23653,7 @@ function clearToolOptionsByElement(element) {
|
|
|
23635
23653
|
reactHotLoader.register(setToolOptions, "setToolOptions", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/toolOptions.js");
|
|
23636
23654
|
reactHotLoader.register(clearToolOptions, "clearToolOptions", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/toolOptions.js");
|
|
23637
23655
|
reactHotLoader.register(clearToolOptionsByToolType, "clearToolOptionsByToolType", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/toolOptions.js");
|
|
23656
|
+
reactHotLoader.register(clearToolOptionsByToolName, "clearToolOptionsByToolName", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/toolOptions.js");
|
|
23638
23657
|
reactHotLoader.register(clearToolOptionsByElement, "clearToolOptionsByElement", "/Users/huyeqing/workspace/chainz/paladin/src/cornerstone-plus/cornerstone-tools-plus/util/toolOptions.js");
|
|
23639
23658
|
})();
|
|
23640
23659
|
|
|
@@ -26666,104 +26685,149 @@ var ReferencePositionTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
|
|
|
26666
26685
|
/**
|
|
26667
26686
|
* target element的render方法
|
|
26668
26687
|
* 计算source的点和target最近的层 翻页+绘制垂直映射的点
|
|
26688
|
+
*
|
|
26689
|
+
* 方法:
|
|
26690
|
+
* 遍历算出所有距离 做排序
|
|
26669
26691
|
*/
|
|
26670
26692
|
|
|
26671
26693
|
}, {
|
|
26672
26694
|
key: "renderTargetPosition",
|
|
26673
|
-
value: function
|
|
26674
|
-
var
|
|
26695
|
+
value: function () {
|
|
26696
|
+
var _renderTargetPosition = asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee2(evt) {
|
|
26697
|
+
var _this3 = this;
|
|
26675
26698
|
|
|
26676
|
-
|
|
26677
|
-
image = _evt$detail2.image,
|
|
26678
|
-
element = _evt$detail2.element;
|
|
26679
|
-
var sourceElements = this.synchronizationContext.getSourceElements();
|
|
26699
|
+
var _evt$detail2, image, element, sourceElements, sourceElement, sourceToolData, cornerstone, sourceImage, currentTargetImage, sourceImagePlane, currentTargetPlane, sourcePoint, sourcePointV3, imageTotalCount, targetImageIndex, min, targetImagePlane, sourcePointToTargetPlanePoint, context, handles;
|
|
26680
26700
|
|
|
26681
|
-
|
|
26682
|
-
|
|
26683
|
-
|
|
26701
|
+
return regenerator.wrap(function _callee2$(_context2) {
|
|
26702
|
+
while (1) {
|
|
26703
|
+
switch (_context2.prev = _context2.next) {
|
|
26704
|
+
case 0:
|
|
26705
|
+
_evt$detail2 = evt.detail, image = _evt$detail2.image, element = _evt$detail2.element;
|
|
26706
|
+
sourceElements = this.synchronizationContext.getSourceElements();
|
|
26684
26707
|
|
|
26685
|
-
|
|
26686
|
-
|
|
26708
|
+
if (!(!sourceElements || sourceElements.length === 0 || !this.imageIds || this.imageIds.length === 0)) {
|
|
26709
|
+
_context2.next = 4;
|
|
26710
|
+
break;
|
|
26711
|
+
}
|
|
26687
26712
|
|
|
26688
|
-
|
|
26689
|
-
return;
|
|
26690
|
-
} // 操作的element有二维定位的点
|
|
26713
|
+
return _context2.abrupt("return");
|
|
26691
26714
|
|
|
26715
|
+
case 4:
|
|
26716
|
+
sourceElement = sourceElements[0];
|
|
26717
|
+
sourceToolData = getToolState$b(sourceElement, this.name);
|
|
26692
26718
|
|
|
26693
|
-
|
|
26694
|
-
|
|
26719
|
+
if (!(!sourceToolData || !sourceToolData.data || sourceToolData.data.length === 0)) {
|
|
26720
|
+
_context2.next = 8;
|
|
26721
|
+
break;
|
|
26722
|
+
}
|
|
26695
26723
|
|
|
26696
|
-
|
|
26697
|
-
return;
|
|
26698
|
-
}
|
|
26724
|
+
return _context2.abrupt("return");
|
|
26699
26725
|
|
|
26700
|
-
|
|
26726
|
+
case 8:
|
|
26727
|
+
// 操作的element有二维定位的点
|
|
26728
|
+
cornerstone = external$j.cornerstone;
|
|
26729
|
+
sourceImage = cornerstone.getEnabledElement(sourceElement).image;
|
|
26730
|
+
currentTargetImage = cornerstone.getEnabledElement(element).image;
|
|
26701
26731
|
|
|
26702
|
-
|
|
26703
|
-
|
|
26704
|
-
|
|
26732
|
+
if (!(!sourceImage || !currentTargetImage)) {
|
|
26733
|
+
_context2.next = 13;
|
|
26734
|
+
break;
|
|
26735
|
+
}
|
|
26705
26736
|
|
|
26706
|
-
|
|
26707
|
-
var sourcePointV3 = imagePointToPatientPoint(sourcePoint, sourceImagePlane);
|
|
26708
|
-
/**
|
|
26709
|
-
* 1.在起始的外侧,就直接取第一个image
|
|
26710
|
-
* 2.在结束的外侧,直接取最后一个image
|
|
26711
|
-
* 3.在中间,把source的点击的p点投到第一张上获得p1,投到最后一张上获得p2,因为层是平行的,
|
|
26712
|
-
* 这样三个点就在一条空间的直线上了,然后计算p1到p2的距离distance,distance/层数,
|
|
26713
|
-
* 就是层厚+层间距(默认当它是等分的),然后p点到p1的距离也能知道,除以(层厚+层间距)找到index
|
|
26714
|
-
*/
|
|
26737
|
+
return _context2.abrupt("return");
|
|
26715
26738
|
|
|
26716
|
-
|
|
26717
|
-
|
|
26718
|
-
|
|
26719
|
-
if (imageTotalCount > 1) {
|
|
26720
|
-
var firstImageId = this.imageIds[0];
|
|
26721
|
-
var lastImageId = this.imageIds[imageTotalCount - 1];
|
|
26722
|
-
var firstTargetImagePlane = cornerstone.metaData.get('imagePlaneModule', firstImageId);
|
|
26723
|
-
var lastTargetImagePlane = cornerstone.metaData.get('imagePlaneModule', lastImageId);
|
|
26724
|
-
var sourcePointInFirstPlane = projectPatientPointToImagePlane$1(sourcePointV3, firstTargetImagePlane);
|
|
26725
|
-
var sourcePointInLastPlane = projectPatientPointToImagePlane$1(sourcePointV3, lastTargetImagePlane);
|
|
26726
|
-
var sourcePointInFirstPlaneV3 = imagePointToPatientPoint(sourcePointInFirstPlane, firstTargetImagePlane);
|
|
26727
|
-
var sourcePointInLastPlaneV3 = imagePointToPatientPoint(sourcePointInLastPlane, lastTargetImagePlane);
|
|
26728
|
-
var totalDistance = this.calcDistance(sourcePointInFirstPlaneV3, sourcePointInLastPlaneV3);
|
|
26729
|
-
var pointToFirstImageDistance = this.calcDistance(sourcePointInFirstPlaneV3, sourcePointV3);
|
|
26730
|
-
|
|
26731
|
-
var _targetImageIndex = lodash$1.round(pointToFirstImageDistance / (totalDistance / (imageTotalCount - 1)));
|
|
26732
|
-
|
|
26733
|
-
if (_targetImageIndex < 0 || _targetImageIndex > imageTotalCount - 1) {
|
|
26734
|
-
// 不在这个序列范围内 不翻页 不绘制
|
|
26735
|
-
return;
|
|
26736
|
-
}
|
|
26739
|
+
case 13:
|
|
26740
|
+
sourceImagePlane = cornerstone.metaData.get('imagePlaneModule', sourceImage.imageId);
|
|
26741
|
+
currentTargetPlane = cornerstone.metaData.get('imagePlaneModule', currentTargetImage.imageId);
|
|
26737
26742
|
|
|
26738
|
-
|
|
26739
|
-
|
|
26743
|
+
if (!(!sourceImagePlane || !currentTargetPlane || !sourceImagePlane.rowCosines || !sourceImagePlane.columnCosines || !sourceImagePlane.imagePositionPatient || !sourceImagePlane.frameOfReferenceUID || !currentTargetPlane.frameOfReferenceUID)) {
|
|
26744
|
+
_context2.next = 17;
|
|
26745
|
+
break;
|
|
26746
|
+
}
|
|
26740
26747
|
|
|
26741
|
-
|
|
26748
|
+
return _context2.abrupt("return");
|
|
26742
26749
|
|
|
26743
|
-
|
|
26744
|
-
|
|
26745
|
-
|
|
26750
|
+
case 17:
|
|
26751
|
+
if (!(currentTargetPlane.frameOfReferenceUID !== sourceImagePlane.frameOfReferenceUID)) {
|
|
26752
|
+
_context2.next = 19;
|
|
26753
|
+
break;
|
|
26754
|
+
}
|
|
26746
26755
|
|
|
26747
|
-
|
|
26748
|
-
var context = getNewContext$c(evt.detail.canvasContext.canvas);
|
|
26749
|
-
var handles = {
|
|
26750
|
-
end: sourcePointToTargetPlanePoint
|
|
26751
|
-
};
|
|
26752
|
-
draw$b(context, function (context) {
|
|
26753
|
-
_default$t(context, evt.detail, handles, {
|
|
26754
|
-
handleRadius: _this3.configuration.handleRadius,
|
|
26755
|
-
lineLength: 20,
|
|
26756
|
-
lineSpacing: 8,
|
|
26757
|
-
hideCenterPoint: true,
|
|
26758
|
-
color: '#eb6565',
|
|
26759
|
-
lineWidth: 2
|
|
26760
|
-
});
|
|
26756
|
+
return _context2.abrupt("return");
|
|
26761
26757
|
|
|
26762
|
-
|
|
26763
|
-
|
|
26764
|
-
|
|
26765
|
-
|
|
26766
|
-
|
|
26758
|
+
case 19:
|
|
26759
|
+
sourcePoint = sourceToolData.data[0].handles.end;
|
|
26760
|
+
sourcePointV3 = imagePointToPatientPoint(sourcePoint, sourceImagePlane);
|
|
26761
|
+
imageTotalCount = this.imageIds.length;
|
|
26762
|
+
targetImageIndex = 0;
|
|
26763
|
+
|
|
26764
|
+
if (imageTotalCount > 1) {
|
|
26765
|
+
// 遍历计算所有distance
|
|
26766
|
+
min = null;
|
|
26767
|
+
lodash$1.forEach(this.imageIds, function (imageId, index) {
|
|
26768
|
+
var imagePlane = cornerstone.metaData.get('imagePlaneModule', imageId);
|
|
26769
|
+
|
|
26770
|
+
if (!imagePlane || !imagePlane.rowCosines || !imagePlane.columnCosines || !imagePlane.imagePositionPatient) {
|
|
26771
|
+
return;
|
|
26772
|
+
}
|
|
26773
|
+
|
|
26774
|
+
var sourcePointInTargetPlane = projectPatientPointToImagePlane$1(sourcePointV3, imagePlane);
|
|
26775
|
+
var sourcePointInTargetPlaneV3 = imagePointToPatientPoint(sourcePointInTargetPlane, imagePlane);
|
|
26776
|
+
|
|
26777
|
+
var distance = _this3.calcDistance(sourcePointV3, sourcePointInTargetPlaneV3);
|
|
26778
|
+
|
|
26779
|
+
if (!min || distance < min) {
|
|
26780
|
+
min = distance;
|
|
26781
|
+
targetImageIndex = index;
|
|
26782
|
+
}
|
|
26783
|
+
});
|
|
26784
|
+
scrollToIndex(element, targetImageIndex);
|
|
26785
|
+
}
|
|
26786
|
+
|
|
26787
|
+
targetImagePlane = cornerstone.metaData.get('imagePlaneModule', this.imageIds[targetImageIndex]);
|
|
26788
|
+
|
|
26789
|
+
if (!(!targetImagePlane || !targetImagePlane.rowCosines || !targetImagePlane.columnCosines || !targetImagePlane.imagePositionPatient)) {
|
|
26790
|
+
_context2.next = 27;
|
|
26791
|
+
break;
|
|
26792
|
+
}
|
|
26793
|
+
|
|
26794
|
+
return _context2.abrupt("return");
|
|
26795
|
+
|
|
26796
|
+
case 27:
|
|
26797
|
+
sourcePointToTargetPlanePoint = projectPatientPointToImagePlane$1(sourcePointV3, targetImagePlane);
|
|
26798
|
+
context = getNewContext$c(evt.detail.canvasContext.canvas);
|
|
26799
|
+
handles = {
|
|
26800
|
+
end: sourcePointToTargetPlanePoint
|
|
26801
|
+
};
|
|
26802
|
+
draw$b(context, function (context) {
|
|
26803
|
+
_default$t(context, evt.detail, handles, {
|
|
26804
|
+
handleRadius: _this3.configuration.handleRadius,
|
|
26805
|
+
lineLength: 20,
|
|
26806
|
+
lineSpacing: 8,
|
|
26807
|
+
hideCenterPoint: true,
|
|
26808
|
+
color: '#eb6565',
|
|
26809
|
+
lineWidth: 2
|
|
26810
|
+
});
|
|
26811
|
+
|
|
26812
|
+
_this3.updateCachedStats(image, element, {
|
|
26813
|
+
handles: handles
|
|
26814
|
+
});
|
|
26815
|
+
});
|
|
26816
|
+
|
|
26817
|
+
case 31:
|
|
26818
|
+
case "end":
|
|
26819
|
+
return _context2.stop();
|
|
26820
|
+
}
|
|
26821
|
+
}
|
|
26822
|
+
}, _callee2, this);
|
|
26823
|
+
}));
|
|
26824
|
+
|
|
26825
|
+
function renderTargetPosition(_x2) {
|
|
26826
|
+
return _renderTargetPosition.apply(this, arguments);
|
|
26827
|
+
}
|
|
26828
|
+
|
|
26829
|
+
return renderTargetPosition;
|
|
26830
|
+
}()
|
|
26767
26831
|
}, {
|
|
26768
26832
|
key: "calcDistance",
|
|
26769
26833
|
value: function calcDistance(p1, p2) {
|
|
@@ -48267,7 +48331,7 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
|
|
|
48267
48331
|
|
|
48268
48332
|
var activeTool = _this.props.activeTool;
|
|
48269
48333
|
|
|
48270
|
-
if (!_this.props.continuousMeasure && lodash$1.includes(
|
|
48334
|
+
if (!_this.props.continuousMeasure && lodash$1.includes(LengthToolsWithMeasure, activeTool)) {
|
|
48271
48335
|
var toolData = _default$E.getToolState(_this.element, activeDataTool);
|
|
48272
48336
|
|
|
48273
48337
|
if (toolData && toolData.data && toolData.data.length > 0) {
|
|
@@ -48643,7 +48707,6 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
|
|
|
48643
48707
|
});
|
|
48644
48708
|
});
|
|
48645
48709
|
|
|
48646
|
-
_this.loaded = false;
|
|
48647
48710
|
_this.mouseDownViewport = null; // 记录鼠标操作前的viewport,为了相对同步
|
|
48648
48711
|
// 拷贝一份 使得作用域内stack的修改不污染外部的series
|
|
48649
48712
|
|
|
@@ -50042,6 +50105,27 @@ var mergeProps$e = function mergeProps(propsFromState, propsFromDispatch, ownPro
|
|
|
50042
50105
|
// 测量工具下不响应双击操作
|
|
50043
50106
|
if (lodash$1.includes(LengthTools, propsFromState.activeTool)) {
|
|
50044
50107
|
return;
|
|
50108
|
+
} // 有绘制的toolData被激活时 也不响应(双点击的会偶发T10283)
|
|
50109
|
+
|
|
50110
|
+
|
|
50111
|
+
var element = getElement(index);
|
|
50112
|
+
var checkToolDataActive = false;
|
|
50113
|
+
lodash$1.forEach(LengthTools, function (tool) {
|
|
50114
|
+
if (!checkToolDataActive) {
|
|
50115
|
+
var toolData = _default$E.getToolState(element, tool);
|
|
50116
|
+
|
|
50117
|
+
if (toolData && toolData.data && toolData.data.length > 0) {
|
|
50118
|
+
lodash$1.forEach(toolData.data, function (handler) {
|
|
50119
|
+
if (handler && handler.active) {
|
|
50120
|
+
checkToolDataActive = true;
|
|
50121
|
+
}
|
|
50122
|
+
});
|
|
50123
|
+
}
|
|
50124
|
+
}
|
|
50125
|
+
});
|
|
50126
|
+
|
|
50127
|
+
if (checkToolDataActive) {
|
|
50128
|
+
return;
|
|
50045
50129
|
}
|
|
50046
50130
|
|
|
50047
50131
|
var onePickMode = propsFromState.onePickMode,
|
|
@@ -50075,8 +50159,9 @@ var mergeProps$e = function mergeProps(propsFromState, propsFromDispatch, ownPro
|
|
|
50075
50159
|
|
|
50076
50160
|
setTimeout(function () {
|
|
50077
50161
|
try {
|
|
50078
|
-
var
|
|
50079
|
-
|
|
50162
|
+
var _element = getElement(resizeIndex);
|
|
50163
|
+
|
|
50164
|
+
cornerstone.resize(_element, true);
|
|
50080
50165
|
} catch (e) {
|
|
50081
50166
|
console.log('ignore element not enabled event');
|
|
50082
50167
|
}
|