@labelbee/lb-annotation 1.14.0-alpha.2 → 1.14.0-alpha.3

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 (187) hide show
  1. package/dist/_virtual/MathUtilsWorker.js +8 -1
  2. package/dist/_virtual/_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js +35 -2
  3. package/dist/_virtual/filterBoxWorker.js +8 -1
  4. package/dist/_virtual/highlightWorker.js +8 -1
  5. package/dist/assets/attributeIcon/icon_canvasEdit0.svg.js +5 -1
  6. package/dist/assets/attributeIcon/icon_canvasEdit1.svg.js +5 -1
  7. package/dist/assets/attributeIcon/icon_canvasEdit2.svg.js +5 -1
  8. package/dist/assets/attributeIcon/icon_canvasEdit3.svg.js +5 -1
  9. package/dist/assets/attributeIcon/icon_canvasEdit4.svg.js +5 -1
  10. package/dist/assets/attributeIcon/icon_canvasEdit5.svg.js +5 -1
  11. package/dist/assets/attributeIcon/icon_canvasEdit6.svg.js +5 -1
  12. package/dist/assets/attributeIcon/icon_canvasEdit7.svg.js +5 -1
  13. package/dist/assets/attributeIcon/icon_canvasEdit8.svg.js +5 -1
  14. package/dist/assets/attributeIcon/icon_canvasEdit_miss.svg.js +5 -1
  15. package/dist/assets/attributeIcon/icon_cuboidFAB.svg.js +5 -5
  16. package/dist/assets/attributeIcon/icon_cuboidLeft.svg.js +5 -7
  17. package/dist/assets/attributeIcon/icon_cuboidMore.svg.js +5 -5
  18. package/dist/assets/attributeIcon/icon_cuboidRight.svg.js +5 -5
  19. package/dist/assets/attributeIcon/icon_cuboidTop.svg.js +5 -12
  20. package/dist/assets/attributeIcon/icon_editFEN.svg.js +5 -1
  21. package/dist/assets/attributeIcon/icon_editHUANG.svg.js +5 -1
  22. package/dist/assets/attributeIcon/icon_editLAN.svg.js +5 -1
  23. package/dist/assets/attributeIcon/icon_editLV.svg.js +5 -1
  24. package/dist/assets/attributeIcon/icon_editQING.svg.js +5 -1
  25. package/dist/constant/annotation.js +127 -1
  26. package/dist/constant/annotationTask.js +30 -1
  27. package/dist/constant/defaultConfig.js +266 -1
  28. package/dist/constant/keyCode.js +38 -1
  29. package/dist/constant/style.js +98 -1
  30. package/dist/constant/tool.js +236 -1
  31. package/dist/core/index.js +150 -1
  32. package/dist/core/pointCloud/OrbitControls.js +665 -1
  33. package/dist/core/pointCloud/PCDLoader.js +260 -2
  34. package/dist/core/pointCloud/annotation.js +215 -1
  35. package/dist/core/pointCloud/cache.js +53 -1
  36. package/dist/core/pointCloud/index.js +991 -5
  37. package/dist/core/pointCloud/matrix.js +138 -1
  38. package/dist/core/pointCloud/segmentation.js +144 -0
  39. package/dist/core/pointCloud/selector/Sse3dLassoSelector.js +26 -0
  40. package/dist/core/pointCloud/selector/Sse3dSelector.js +16 -0
  41. package/dist/core/scheduler.js +233 -1
  42. package/dist/core/toolOperation/LineToolOperation.js +1434 -1
  43. package/dist/core/toolOperation/ScribbleTool.js +292 -1
  44. package/dist/core/toolOperation/TextToolOperation.js +131 -1
  45. package/dist/core/toolOperation/ViewOperation.js +556 -1
  46. package/dist/core/toolOperation/basicToolOperation.js +881 -1
  47. package/dist/core/toolOperation/checkOperation.js +208 -1
  48. package/dist/core/toolOperation/cuboidOperation.js +754 -1
  49. package/dist/core/toolOperation/cuboidToggleButtonClass.js +152 -7
  50. package/dist/core/toolOperation/eventListener.js +37 -1
  51. package/dist/core/toolOperation/measureOperation.js +41 -1
  52. package/dist/core/toolOperation/pointCloud2dOperation.js +365 -1
  53. package/dist/core/toolOperation/pointOperation.js +696 -1
  54. package/dist/core/toolOperation/polygonOperation.js +1251 -1
  55. package/dist/core/toolOperation/rectOperation.js +1233 -1
  56. package/dist/core/toolOperation/segmentByRect.js +174 -1
  57. package/dist/core/toolOperation/tagOperation.js +201 -3
  58. package/dist/core/toolOperation/textAttributeClass.js +182 -16
  59. package/dist/index.js +185 -1
  60. package/dist/locales/constants.js +24 -1
  61. package/dist/locales/en_US/message.js +25 -1
  62. package/dist/locales/index.js +19 -1
  63. package/dist/locales/zh_CN/message.js +25 -1
  64. package/dist/newCore/CanvasScheduler.js +35 -1
  65. package/dist/types/core/pointCloud/segmentation.d.ts +0 -0
  66. package/dist/types/core/pointCloud/selector/Sse3dLassoSelector.d.ts +0 -0
  67. package/dist/types/core/pointCloud/selector/Sse3dSelector.d.ts +0 -0
  68. package/dist/utils/ActionsHistory.js +84 -1
  69. package/dist/utils/ImgUtils.js +23 -1
  70. package/dist/utils/MathUtils.js +385 -2
  71. package/dist/utils/VectorUtils.js +25 -1
  72. package/dist/utils/tool/AttributeUtils.js +218 -1
  73. package/dist/utils/tool/AxisUtils.js +340 -1
  74. package/dist/utils/tool/CanvasUtils.js +62 -1
  75. package/dist/utils/tool/CommonToolUtils.js +174 -1
  76. package/dist/utils/tool/CuboidUtils.js +704 -1
  77. package/dist/utils/tool/DblClickEventListener.js +102 -1
  78. package/dist/utils/tool/DrawUtils.js +492 -3
  79. package/dist/utils/tool/EnhanceCommonToolUtils.js +53 -1
  80. package/dist/utils/tool/ImgPosUtils.js +58 -1
  81. package/dist/utils/tool/LineToolUtils.js +261 -1
  82. package/dist/utils/tool/MarkerUtils.js +56 -1
  83. package/dist/utils/tool/PolygonUtils.js +460 -1
  84. package/dist/utils/tool/RectUtils.js +155 -1
  85. package/dist/utils/tool/RenderDomClass.js +57 -7
  86. package/dist/utils/tool/RenderDomUtils.js +21 -4
  87. package/dist/utils/tool/StyleUtils.js +31 -1
  88. package/dist/utils/tool/TagUtils.js +129 -1
  89. package/dist/utils/tool/UnitUtils.js +12 -1
  90. package/dist/utils/tool/ZoomUtils.js +72 -1
  91. package/dist/utils/tool/polygonTool.js +133 -1
  92. package/dist/utils/uuid.js +26 -1
  93. package/es/_virtual/MathUtilsWorker.js +6 -1
  94. package/es/_virtual/_rollup-plugin-web-worker-loader__helper__auto__createBase64WorkerFactory.js +12 -0
  95. package/es/_virtual/_rollup-plugin-web-worker-loader__helper__auto__isNodeJS.js +7 -0
  96. package/es/_virtual/_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js +31 -2
  97. package/es/_virtual/_rollup-plugin-web-worker-loader__helper__node__WorkerClass.js +11 -0
  98. package/es/_virtual/_rollup-plugin-web-worker-loader__helper__node__createBase64WorkerFactory.js +18 -0
  99. package/es/_virtual/filterBoxWorker.js +6 -1
  100. package/es/_virtual/highlightWorker.js +6 -1
  101. package/es/assets/attributeIcon/icon_canvasEdit0.svg.js +3 -1
  102. package/es/assets/attributeIcon/icon_canvasEdit1.svg.js +3 -1
  103. package/es/assets/attributeIcon/icon_canvasEdit2.svg.js +3 -1
  104. package/es/assets/attributeIcon/icon_canvasEdit3.svg.js +3 -1
  105. package/es/assets/attributeIcon/icon_canvasEdit4.svg.js +3 -1
  106. package/es/assets/attributeIcon/icon_canvasEdit5.svg.js +3 -1
  107. package/es/assets/attributeIcon/icon_canvasEdit6.svg.js +3 -1
  108. package/es/assets/attributeIcon/icon_canvasEdit7.svg.js +3 -1
  109. package/es/assets/attributeIcon/icon_canvasEdit8.svg.js +3 -1
  110. package/es/assets/attributeIcon/icon_canvasEdit_miss.svg.js +3 -1
  111. package/es/assets/attributeIcon/icon_cuboidFAB.svg.js +3 -5
  112. package/es/assets/attributeIcon/icon_cuboidLeft.svg.js +3 -7
  113. package/es/assets/attributeIcon/icon_cuboidMore.svg.js +3 -5
  114. package/es/assets/attributeIcon/icon_cuboidRight.svg.js +3 -5
  115. package/es/assets/attributeIcon/icon_cuboidTop.svg.js +3 -12
  116. package/es/assets/attributeIcon/icon_editFEN.svg.js +3 -1
  117. package/es/assets/attributeIcon/icon_editHUANG.svg.js +3 -1
  118. package/es/assets/attributeIcon/icon_editLAN.svg.js +3 -1
  119. package/es/assets/attributeIcon/icon_editLV.svg.js +3 -1
  120. package/es/assets/attributeIcon/icon_editQING.svg.js +3 -1
  121. package/es/constant/annotation.js +113 -1
  122. package/es/constant/annotationTask.js +25 -1
  123. package/es/constant/defaultConfig.js +260 -1
  124. package/es/constant/keyCode.js +36 -1
  125. package/es/constant/style.js +74 -1
  126. package/es/constant/tool.js +220 -1
  127. package/es/core/index.js +148 -1
  128. package/es/core/pointCloud/OrbitControls.js +661 -1
  129. package/es/core/pointCloud/PCDLoader.js +256 -2
  130. package/es/core/pointCloud/annotation.js +211 -1
  131. package/es/core/pointCloud/cache.js +49 -1
  132. package/es/core/pointCloud/index.js +962 -5
  133. package/es/core/pointCloud/matrix.js +109 -1
  134. package/es/core/pointCloud/segmentation.js +120 -0
  135. package/es/core/pointCloud/selector/Sse3dLassoSelector.js +24 -0
  136. package/es/core/pointCloud/selector/Sse3dSelector.js +14 -0
  137. package/es/core/scheduler.js +228 -1
  138. package/es/core/toolOperation/LineToolOperation.js +1421 -1
  139. package/es/core/toolOperation/ScribbleTool.js +290 -1
  140. package/es/core/toolOperation/TextToolOperation.js +129 -1
  141. package/es/core/toolOperation/ViewOperation.js +549 -1
  142. package/es/core/toolOperation/basicToolOperation.js +877 -1
  143. package/es/core/toolOperation/checkOperation.js +206 -1
  144. package/es/core/toolOperation/cuboidOperation.js +752 -1
  145. package/es/core/toolOperation/cuboidToggleButtonClass.js +150 -7
  146. package/es/core/toolOperation/eventListener.js +35 -1
  147. package/es/core/toolOperation/measureOperation.js +39 -1
  148. package/es/core/toolOperation/pointCloud2dOperation.js +359 -1
  149. package/es/core/toolOperation/pointOperation.js +690 -1
  150. package/es/core/toolOperation/polygonOperation.js +1245 -1
  151. package/es/core/toolOperation/rectOperation.js +1228 -1
  152. package/es/core/toolOperation/scribbleTool2.js +249 -0
  153. package/es/core/toolOperation/segmentByRect.js +172 -1
  154. package/es/core/toolOperation/tagOperation.js +199 -3
  155. package/es/core/toolOperation/textAttributeClass.js +180 -16
  156. package/es/index.js +46 -1
  157. package/es/locales/constants.js +22 -1
  158. package/es/locales/en_US/message.js +23 -1
  159. package/es/locales/index.js +17 -1
  160. package/es/locales/zh_CN/message.js +23 -1
  161. package/es/newCore/CanvasScheduler.js +31 -1
  162. package/es/utils/ActionsHistory.js +78 -1
  163. package/es/utils/ImgUtils.js +21 -1
  164. package/es/utils/MathUtils.js +380 -2
  165. package/es/utils/VectorUtils.js +23 -1
  166. package/es/utils/tool/AttributeUtils.js +212 -1
  167. package/es/utils/tool/AxisUtils.js +335 -1
  168. package/es/utils/tool/CanvasUtils.js +60 -1
  169. package/es/utils/tool/CommonToolUtils.js +172 -1
  170. package/es/utils/tool/CuboidUtils.js +680 -1
  171. package/es/utils/tool/DblClickEventListener.js +100 -1
  172. package/es/utils/tool/DrawUtils.js +490 -3
  173. package/es/utils/tool/EnhanceCommonToolUtils.js +48 -1
  174. package/es/utils/tool/ImgPosUtils.js +56 -1
  175. package/es/utils/tool/LineToolUtils.js +255 -1
  176. package/es/utils/tool/MarkerUtils.js +54 -1
  177. package/es/utils/tool/PolygonUtils.js +458 -1
  178. package/es/utils/tool/RectUtils.js +153 -1
  179. package/es/utils/tool/RenderDomClass.js +55 -7
  180. package/es/utils/tool/RenderDomUtils.js +19 -4
  181. package/es/utils/tool/StyleUtils.js +29 -1
  182. package/es/utils/tool/TagUtils.js +127 -1
  183. package/es/utils/tool/UnitUtils.js +10 -1
  184. package/es/utils/tool/ZoomUtils.js +70 -1
  185. package/es/utils/tool/polygonTool.js +126 -1
  186. package/es/utils/uuid.js +24 -1
  187. package/package.json +7 -5
@@ -1,20 +1,70 @@
1
- "use strict";var DrawUtils=require("./DrawUtils.js"),StyleUtils=require("./StyleUtils.js");class RenderDomClass{constructor(t){this._domMap=new Map,this._container=t.container,this._height=t.height}wheelChange(t){t.stopPropagation()}clearTag(t){const o=this._container,s=window.self.document.getElementById(t);s&&o&&o.contains(s)&&(s.removeEventListener("wheel",this.wheelChange),o==null||o.removeChild(s))}render(t){const o=Array.from(this._domMap.keys()),s=t.map(e=>e.id);t.forEach(e=>{const{text:a,textMaxWidth:r,color:n="white",background:h="rgba(0, 0, 0, 0.6)",style:l}=e;if(this._domMap.has(e.id)){const i=this._domMap.get(e.id);i&&(i.innerHTML=a)}else{const i=DrawUtils.drawTagByDom(this._container,a,e.id);i&&(i.setAttribute("style",`
1
+ 'use strict';
2
+
3
+ var DrawUtils = require('./DrawUtils.js');
4
+ var StyleUtils = require('./StyleUtils.js');
5
+
6
+ class RenderDomClass {
7
+ constructor(props) {
8
+ this._domMap = new Map();
9
+ this._container = props.container;
10
+ this._height = props.height;
11
+ }
12
+ wheelChange(e) {
13
+ e.stopPropagation();
14
+ }
15
+ clearTag(id) {
16
+ const parentNode = this._container;
17
+ const oldDom = window.self.document.getElementById(id);
18
+ if (oldDom && parentNode && parentNode.contains(oldDom)) {
19
+ oldDom.removeEventListener("wheel", this.wheelChange);
20
+ parentNode == null ? void 0 : parentNode.removeChild(oldDom);
21
+ }
22
+ }
23
+ render(annotations) {
24
+ const oldKeys = Array.from(this._domMap.keys());
25
+ const newKeys = annotations.map((v) => v.id);
26
+ annotations.forEach((v) => {
27
+ const {text, textMaxWidth, color = "white", background = "rgba(0, 0, 0, 0.6)", style} = v;
28
+ if (this._domMap.has(v.id)) {
29
+ const dom = this._domMap.get(v.id);
30
+ if (dom) {
31
+ dom.innerHTML = text;
32
+ }
33
+ } else {
34
+ const dom = DrawUtils.drawTagByDom(this._container, text, v.id);
35
+ if (dom) {
36
+ dom.setAttribute("style", `
2
37
  position: absolute;
3
38
  top: 0;
4
39
  right: 0;
5
40
  z-index: 20;
6
41
  padding: 8px 20px;
7
42
  font-size: 15px;
8
- max-width: ${r}px;
9
- color: ${n};
43
+ max-width: ${textMaxWidth}px;
44
+ color: ${color};
10
45
  text-align: left;
11
46
  line-height: 32px;
12
47
  word-break: break-all;
13
48
  white-space: pre-wrap;
14
- background: ${h};
49
+ background: ${background};
15
50
  opacity: 0.9;
16
- max-height: ${this._height*.8}px;
51
+ max-height: ${this._height * 0.8}px;
17
52
  overflow-y: scroll;
18
53
  clear: both;
19
- ${StyleUtils.getStyle2String(l)}
20
- `),i.addEventListener("wheel",this.wheelChange),this._domMap.set(e.id,i))}}),o.forEach(e=>{s.indexOf(e)===-1&&(this.clearTag(e),this._domMap.delete(e))})}}module.exports=RenderDomClass;
54
+ ${StyleUtils.getStyle2String(style)}
55
+ `);
56
+ dom.addEventListener("wheel", this.wheelChange);
57
+ this._domMap.set(v.id, dom);
58
+ }
59
+ }
60
+ });
61
+ oldKeys.forEach((key) => {
62
+ if (newKeys.indexOf(key) === -1) {
63
+ this.clearTag(key);
64
+ this._domMap.delete(key);
65
+ }
66
+ });
67
+ }
68
+ }
69
+
70
+ module.exports = RenderDomClass;
@@ -1,9 +1,18 @@
1
- "use strict";var index=require("../../locales/index.js"),constants=require("../../locales/constants.js");const INVALID_PAGE_CLASS_NAME="bee-invalid-page";class RenderDomUtils{static renderInvalidPage(i,t,s){const e=document.createElement("div");return e.setAttribute("style",`
1
+ 'use strict';
2
+
3
+ var index = require('../../locales/index.js');
4
+ var constants = require('../../locales/constants.js');
5
+
6
+ const INVALID_PAGE_CLASS_NAME = "bee-invalid-page";
7
+ class RenderDomUtils {
8
+ static renderInvalidPage(container, size, lang) {
9
+ const invalidDOM = document.createElement("div");
10
+ invalidDOM.setAttribute("style", `
2
11
  position: absolute;
3
12
  left: 0px;
4
13
  top: 0px;
5
- width: ${t.width}px;
6
- height: ${t.height}px;
14
+ width: ${size.width}px;
15
+ height: ${size.height}px;
7
16
  background: rgba(255, 87, 34, 1);
8
17
  overflow: hidden;
9
18
  color: white;
@@ -13,4 +22,12 @@
13
22
  font-size: 30px;
14
23
  opacity: 0.7;
15
24
  z-index: 30;
16
- `),e.innerHTML=index.getMessagesByLocale(constants.EMessage.InvalidImage,s),e.className=INVALID_PAGE_CLASS_NAME,i.appendChild(e),e}}module.exports=RenderDomUtils;
25
+ `);
26
+ invalidDOM.innerHTML = index.getMessagesByLocale(constants.EMessage.InvalidImage, lang);
27
+ invalidDOM.className = INVALID_PAGE_CLASS_NAME;
28
+ container.appendChild(invalidDOM);
29
+ return invalidDOM;
30
+ }
31
+ }
32
+
33
+ module.exports = RenderDomUtils;
@@ -1 +1,31 @@
1
- "use strict";class StyleUtils{static getStrokeAndFill(e,i=!0,r={}){const{isSelected:s=!1,isHover:l=!1}=r;return s?{stroke:i?e.validSelected.stroke:e.invalidSelected.stroke,fill:i?e.validSelected.fill:e.invalidSelected.fill}:l?{stroke:i?e.validHover.stroke:e.invalidHover.stroke,fill:i?e.validHover.fill:e.invalidHover.fill}:{stroke:i?e.valid.stroke:e.invalid.stroke,fill:i?e.valid.fill:e.invalid.fill}}static getStyle2String(e){if(!!e)return Object.entries(e).reduce((i,r)=>`${i} ${r[0]}: ${r[1]};`,"")}}module.exports=StyleUtils;
1
+ 'use strict';
2
+
3
+ class StyleUtils {
4
+ static getStrokeAndFill(toolStyle, valid = true, options = {}) {
5
+ const {isSelected = false, isHover = false} = options;
6
+ if (isSelected) {
7
+ return {
8
+ stroke: valid ? toolStyle.validSelected.stroke : toolStyle.invalidSelected.stroke,
9
+ fill: valid ? toolStyle.validSelected.fill : toolStyle.invalidSelected.fill
10
+ };
11
+ }
12
+ if (isHover) {
13
+ return {
14
+ stroke: valid ? toolStyle.validHover.stroke : toolStyle.invalidHover.stroke,
15
+ fill: valid ? toolStyle.validHover.fill : toolStyle.invalidHover.fill
16
+ };
17
+ }
18
+ return {
19
+ stroke: valid ? toolStyle.valid.stroke : toolStyle.invalid.stroke,
20
+ fill: valid ? toolStyle.valid.fill : toolStyle.invalid.fill
21
+ };
22
+ }
23
+ static getStyle2String(style) {
24
+ if (!style) {
25
+ return;
26
+ }
27
+ return Object.entries(style).reduce((acc, cur) => `${acc} ${cur[0]}: ${cur[1]};`, "");
28
+ }
29
+ }
30
+
31
+ module.exports = StyleUtils;
@@ -1 +1,129 @@
1
- "use strict";var uuid=require("../uuid.js"),__defProp=Object.defineProperty,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(l,t,e)=>t in l?__defProp(l,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):l[t]=e,__spreadValues=(l,t)=>{for(var e in t||(t={}))__hasOwnProp.call(t,e)&&__defNormalProp(l,e,t[e]);if(__getOwnPropSymbols)for(var e of __getOwnPropSymbols(t))__propIsEnum.call(t,e)&&__defNormalProp(l,e,t[e]);return l};class TagUtil{static getTagKeyName(t,e){var r,i;if(!!e)return(i=(r=e.find(u=>u.value===t))==null?void 0:r.key)!=null?i:""}static getTagName([t="",e=""],r){if(!!r){for(const i of r)if(i.value===t){if(!i.subSelected)return console.error("\u6807\u7B7E\u89E3\u6790\u9519\u8BEF",t,e),"";for(const u of i.subSelected)if(u.value===e)return u.key}}}static getTagNameList(t,e){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((r,i)=>{const[u,s]=i;if(s&&s.length>0){const n=s.split(";"),a={keyName:this.getTagKeyName(u,e),value:n.map(o=>this.getTagName([u,o],e))};return[...r,a]}return r},[]).filter(r=>r)}static getTagnameListWithoutConfig(t){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((e,r)=>{const[i,u]=r,s=u.split(";"),n={keyName:i,value:s};return[...e,n]},[]).filter(e=>e)}static judgeResultIsInInputList(t,e,r){return!t||!e||!r?!1:r.filter(u=>{if(u.value===t&&u.subSelected){const s=e==null?void 0:e.split(";");return(u==null?void 0:u.subSelected.filter(n=>s.indexOf(n.value)>-1).length)>0}return!1}).length>0}static getDefaultResultByConfig(t){return t.reduce((e,r)=>(r.subSelected&&r.subSelected.forEach(i=>{var u;if(i.isDefault){const s=(u=e[r.value])!=null?u:"";let n=[];s.length>0&&(n=s.split(";")),n.push(i.value),e[r.value]=n.join(";")}}),e),{})}static getDefaultTagResult(t,e){const r=this.getDefaultResultByConfig(t);return e.length>0?e.map(i=>({id:uuid(),sourceID:i.id,result:__spreadValues({},r)})):[{id:uuid(),sourceID:"",result:__spreadValues({},r)}]}}module.exports=TagUtil;
1
+ 'use strict';
2
+
3
+ var uuid = require('../uuid.js');
4
+
5
+ var __defProp = Object.defineProperty;
6
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
9
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {enumerable: true, configurable: true, writable: true, value}) : obj[key] = value;
10
+ var __spreadValues = (a, b) => {
11
+ for (var prop in b || (b = {}))
12
+ if (__hasOwnProp.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ if (__getOwnPropSymbols)
15
+ for (var prop of __getOwnPropSymbols(b)) {
16
+ if (__propIsEnum.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ }
19
+ return a;
20
+ };
21
+ class TagUtil {
22
+ static getTagKeyName(key, labelInfoSet) {
23
+ var _a, _b;
24
+ if (!labelInfoSet) {
25
+ return;
26
+ }
27
+ return (_b = (_a = labelInfoSet.find((v) => v.value === key)) == null ? void 0 : _a.key) != null ? _b : "";
28
+ }
29
+ static getTagName([key = "", value = ""], labelInfoSet) {
30
+ if (!labelInfoSet) {
31
+ return;
32
+ }
33
+ for (const i of labelInfoSet) {
34
+ if (i.value === key) {
35
+ if (!i.subSelected) {
36
+ console.error("\u6807\u7B7E\u89E3\u6790\u9519\u8BEF", key, value);
37
+ return "";
38
+ }
39
+ for (const j of i.subSelected) {
40
+ if (j.value === value) {
41
+ return j.key;
42
+ }
43
+ }
44
+ }
45
+ }
46
+ }
47
+ static getTagNameList(result, labelInfoSet) {
48
+ if (Object.keys(result).length <= 0) {
49
+ return [];
50
+ }
51
+ return Object.entries(result).reduce((acc, cur) => {
52
+ const [key, value] = cur;
53
+ if (value && value.length > 0) {
54
+ const valueList = value.split(";");
55
+ const nameList = {
56
+ keyName: this.getTagKeyName(key, labelInfoSet),
57
+ value: valueList.map((v) => this.getTagName([key, v], labelInfoSet))
58
+ };
59
+ return [...acc, nameList];
60
+ }
61
+ return acc;
62
+ }, []).filter((v) => v);
63
+ }
64
+ static getTagnameListWithoutConfig(result) {
65
+ if (Object.keys(result).length <= 0) {
66
+ return [];
67
+ }
68
+ return Object.entries(result).reduce((acc, cur) => {
69
+ const [key, value] = cur;
70
+ const valueList = value.split(";");
71
+ const nameList = {
72
+ keyName: key,
73
+ value: valueList
74
+ };
75
+ return [...acc, nameList];
76
+ }, []).filter((v) => v);
77
+ }
78
+ static judgeResultIsInInputList(key, value, inputList) {
79
+ if (!key || !value || !inputList) {
80
+ return false;
81
+ }
82
+ const a = inputList.filter((v) => {
83
+ if (v.value === key && v.subSelected) {
84
+ const resultValue = value == null ? void 0 : value.split(";");
85
+ return (v == null ? void 0 : v.subSelected.filter((i) => resultValue.indexOf(i.value) > -1).length) > 0;
86
+ }
87
+ return false;
88
+ });
89
+ return a.length > 0;
90
+ }
91
+ static getDefaultResultByConfig(inputList) {
92
+ return inputList.reduce((acc, cur) => {
93
+ if (cur.subSelected) {
94
+ cur.subSelected.forEach((data) => {
95
+ var _a;
96
+ if (data.isDefault) {
97
+ const originResult = (_a = acc[cur.value]) != null ? _a : "";
98
+ let originResultList = [];
99
+ if (originResult.length > 0) {
100
+ originResultList = originResult.split(";");
101
+ }
102
+ originResultList.push(data.value);
103
+ acc[cur.value] = originResultList.join(";");
104
+ }
105
+ });
106
+ }
107
+ return acc;
108
+ }, {});
109
+ }
110
+ static getDefaultTagResult(inputList, basicResultList) {
111
+ const defaultResult = this.getDefaultResultByConfig(inputList);
112
+ if (basicResultList.length > 0) {
113
+ return basicResultList.map((v) => ({
114
+ id: uuid(),
115
+ sourceID: v.id,
116
+ result: __spreadValues({}, defaultResult)
117
+ }));
118
+ }
119
+ return [
120
+ {
121
+ id: uuid(),
122
+ sourceID: "",
123
+ result: __spreadValues({}, defaultResult)
124
+ }
125
+ ];
126
+ }
127
+ }
128
+
129
+ module.exports = TagUtil;
@@ -1 +1,12 @@
1
- "use strict";class UnitUtils{static deg2rad(t){return t*Math.PI/180}static rad2deg(t){return t*180/Math.PI}}module.exports=UnitUtils;
1
+ 'use strict';
2
+
3
+ class UnitUtils {
4
+ static deg2rad(angleDeg) {
5
+ return angleDeg * Math.PI / 180;
6
+ }
7
+ static rad2deg(angleRad) {
8
+ return angleRad * 180 / Math.PI;
9
+ }
10
+ }
11
+
12
+ module.exports = UnitUtils;
@@ -1 +1,72 @@
1
- "use strict";var annotation=require("../../constant/annotation.js"),MathUtils=require("../MathUtils.js");const ZOOM_LEVEL=[1,5,10,20,30,50,80,100].concat(Array.from({length:9}).map((t,n)=>(n+2)*100));class ZoomUtils{}ZoomUtils.zoomChanged=(t,n,l=annotation.EGrowthMode.Linear)=>{switch(l){case annotation.EGrowthMode.Intelligence:{const e=Math.max(...ZOOM_LEVEL),c=Math.min(...ZOOM_LEVEL),a=ZOOM_LEVEL.slice(0,ZOOM_LEVEL.length).findIndex((i,u)=>t>=i&&(t<ZOOM_LEVEL[u+1]||i===e));let o;if(a===-1)t>=c&&t<=e?o=n?e:c:o=n?c:t;else{const i=n?a+1:a-(ZOOM_LEVEL.includes(t)?1:0);o=ZOOM_LEVEL[MathUtils.default.withinRange(i,[0,ZOOM_LEVEL.length-1])]}return o}default:{const e=n?2:1/2;return t*e}}},ZoomUtils.wheelChangePos=(t,n,l,e,c={})=>{const{zoom:a=1,innerZoom:o=1,basicZoom:i=1,zoomMax:u=1e3,rotate:x=0}=c,{x:f,y:g}=e,d=parseFloat((a+1/10).toFixed(1))/5;if(t&&n){let{width:r,height:h}=t;[90,270].includes(x)&&(r=t.height,h=t.width);const M=r*o,Z=h*o,m=n.x-f,w=n.y-g,p=m/M,y=w/Z;let s=a+l*d;s=MathUtils.default.withinRange(s,[i,u]);const E=r*s*p,L=h*s*y,U=f+(m-E),X=g+(w-L);return{zoom:s,currentPos:{x:U,y:X},imgInfo:{width:r*s,height:h*s},ratio:d}}return null},module.exports=ZoomUtils;
1
+ 'use strict';
2
+
3
+ var annotation = require('../../constant/annotation.js');
4
+ var MathUtils = require('../MathUtils.js');
5
+
6
+ const ZOOM_LEVEL = [1, 5, 10, 20, 30, 50, 80, 100].concat(Array.from({length: 9}).map((i, index) => (index + 2) * 100));
7
+ class ZoomUtils {
8
+ }
9
+ ZoomUtils.zoomChanged = (zoom, isZoomIn, growthMode = annotation.EGrowthMode.Linear) => {
10
+ switch (growthMode) {
11
+ case annotation.EGrowthMode.Intelligence: {
12
+ const maxZoom = Math.max(...ZOOM_LEVEL);
13
+ const minZoom = Math.min(...ZOOM_LEVEL);
14
+ const zoomIndex = ZOOM_LEVEL.slice(0, ZOOM_LEVEL.length).findIndex((i, index) => zoom >= i && (zoom < ZOOM_LEVEL[index + 1] || i === maxZoom));
15
+ let newZoom;
16
+ if (zoomIndex === -1) {
17
+ if (zoom >= minZoom && zoom <= maxZoom) {
18
+ newZoom = isZoomIn ? maxZoom : minZoom;
19
+ } else {
20
+ newZoom = isZoomIn ? minZoom : zoom;
21
+ }
22
+ } else {
23
+ const newZoomIndex = isZoomIn ? zoomIndex + 1 : zoomIndex - (ZOOM_LEVEL.includes(zoom) ? 1 : 0);
24
+ newZoom = ZOOM_LEVEL[MathUtils["default"].withinRange(newZoomIndex, [0, ZOOM_LEVEL.length - 1])];
25
+ }
26
+ return newZoom;
27
+ }
28
+ default: {
29
+ const ratio = isZoomIn ? 2 : 1 / 2;
30
+ return zoom * ratio;
31
+ }
32
+ }
33
+ };
34
+ ZoomUtils.wheelChangePos = (imgNode, coord, operator, oldCurrentPos, options = {}) => {
35
+ const {zoom = 1, innerZoom = 1, basicZoom = 1, zoomMax = 1e3, rotate = 0} = options;
36
+ const {x, y} = oldCurrentPos;
37
+ const ratio = parseFloat((zoom + 1 / 10).toFixed(1)) / 5;
38
+ if (imgNode && coord) {
39
+ let {width, height} = imgNode;
40
+ if ([90, 270].includes(rotate)) {
41
+ width = imgNode.height;
42
+ height = imgNode.width;
43
+ }
44
+ const imgWidth = width * innerZoom;
45
+ const imgHeight = height * innerZoom;
46
+ const offsetLeft = coord.x - x;
47
+ const offsetTop = coord.y - y;
48
+ const ratioX = offsetLeft / imgWidth;
49
+ const ratioY = offsetTop / imgHeight;
50
+ let currentZoom = zoom + operator * ratio;
51
+ currentZoom = MathUtils["default"].withinRange(currentZoom, [basicZoom, zoomMax]);
52
+ const changeX = width * currentZoom * ratioX;
53
+ const changeY = height * currentZoom * ratioY;
54
+ const currentX = x + (offsetLeft - changeX);
55
+ const currentY = y + (offsetTop - changeY);
56
+ return {
57
+ zoom: currentZoom,
58
+ currentPos: {
59
+ x: currentX,
60
+ y: currentY
61
+ },
62
+ imgInfo: {
63
+ width: width * currentZoom,
64
+ height: height * currentZoom
65
+ },
66
+ ratio
67
+ };
68
+ }
69
+ return null;
70
+ };
71
+
72
+ module.exports = ZoomUtils;
@@ -1 +1,133 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var tool=require("../../constant/tool.js"),__defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(e,t,l)=>t in e?__defProp(e,t,{enumerable:!0,configurable:!0,writable:!0,value:l}):e[t]=l,__spreadValues=(e,t)=>{for(var l in t||(t={}))__hasOwnProp.call(t,l)&&__defNormalProp(e,l,t[l]);if(__getOwnPropSymbols)for(var l of __getOwnPropSymbols(t))__propIsEnum.call(t,l)&&__defNormalProp(e,l,t[l]);return e},__spreadProps=(e,t)=>__defProps(e,__getOwnPropDescs(t));function createSmoothCurvePoints(e,t=.5,l=!1,s=16){if(e.length<4)return e;const f=[],r=e.slice(0);let a,o,x,y,p,m,_,v,w,P,h,c,u;for(l?(r.unshift(e[e.length-1]),r.unshift(e[e.length-2]),r.unshift(e[e.length-1]),r.unshift(e[e.length-2]),r.push(e[0]),r.push(e[1])):(r.unshift(e[1]),r.unshift(e[0]),r.push(e[e.length-2]),r.push(e[e.length-1])),u=2;u<r.length-4;u+=2)for(x=(r[u+2]-r[u-2])*t,y=(r[u+4]-r[u-0])*t,p=(r[u+3]-r[u-1])*t,m=(r[u+5]-r[u+1])*t,c=0;c<=s;c++)h=c/s,_=2*Math.pow(h,3)-3*Math.pow(h,2)+1,v=-(2*Math.pow(h,3))+3*Math.pow(h,2),w=Math.pow(h,3)-2*Math.pow(h,2)+h,P=Math.pow(h,3)-Math.pow(h,2),a=_*r[u]+v*r[u+2]+w*x+P*y,o=_*r[u+1]+v*r[u+3]+w*p+P*m,f.push(a),f.push(o);const i=[];for(let n=0;n<f.length-1;n+=2)i.push({x:f[n],y:f[n+1]});if(l)for(let n=0;n<s+1;n++){const M=i.shift();i.push(M)}return i}const createSmoothCurvePointsFromPointList=(e,t=16)=>createSmoothCurvePoints(e.reduce((l,s)=>[...l,s.x,s.y],[]),.5,!1,t);function isInPolygon(e,t,l=tool.ELineTypes.Line){let s=0,f,r,a,o;t=[...t],l===tool.ELineTypes.Curve&&(t=createSmoothCurvePoints(t.reduce((y,p)=>[...y,p.x,p.y],[]),.5,!0,tool.SEGMENT_NUMBER)),[a]=t;const x=t.length;for(f=1;f<=x;f++)o=t[f%x],e.x>Math.min(a.x,o.x)&&e.x<=Math.max(a.x,o.x)&&e.y<=Math.max(a.y,o.y)&&a.x!==o.x&&(r=(e.x-a.x)*(o.y-a.y)/(o.x-a.x)+a.y,(a.y===o.y||e.y<=r)&&s++),a=o;return s%2!=0}function getPolygonPointUnderZoom(e,t=1){return e.map(l=>__spreadProps(__spreadValues({},l),{x:l.x*t,y:l.y*t}))}exports.createSmoothCurvePoints=createSmoothCurvePoints,exports.createSmoothCurvePointsFromPointList=createSmoothCurvePointsFromPointList,exports.getPolygonPointUnderZoom=getPolygonPointUnderZoom,exports.isInPolygon=isInPolygon;
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var tool = require('../../constant/tool.js');
6
+
7
+ var __defProp = Object.defineProperty;
8
+ var __defProps = Object.defineProperties;
9
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
10
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
11
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
12
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
13
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {enumerable: true, configurable: true, writable: true, value}) : obj[key] = value;
14
+ var __spreadValues = (a, b) => {
15
+ for (var prop in b || (b = {}))
16
+ if (__hasOwnProp.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ if (__getOwnPropSymbols)
19
+ for (var prop of __getOwnPropSymbols(b)) {
20
+ if (__propIsEnum.call(b, prop))
21
+ __defNormalProp(a, prop, b[prop]);
22
+ }
23
+ return a;
24
+ };
25
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
26
+ function createSmoothCurvePoints(points, tension = 0.5, closed = false, numberOfSegments = 16) {
27
+ if (points.length < 4) {
28
+ return points;
29
+ }
30
+ const result = [];
31
+ const ps = points.slice(0);
32
+ let x;
33
+ let y;
34
+ let t1x;
35
+ let t2x;
36
+ let t1y;
37
+ let t2y;
38
+ let c1;
39
+ let c2;
40
+ let c3;
41
+ let c4;
42
+ let st;
43
+ let t;
44
+ let i;
45
+ if (closed) {
46
+ ps.unshift(points[points.length - 1]);
47
+ ps.unshift(points[points.length - 2]);
48
+ ps.unshift(points[points.length - 1]);
49
+ ps.unshift(points[points.length - 2]);
50
+ ps.push(points[0]);
51
+ ps.push(points[1]);
52
+ } else {
53
+ ps.unshift(points[1]);
54
+ ps.unshift(points[0]);
55
+ ps.push(points[points.length - 2]);
56
+ ps.push(points[points.length - 1]);
57
+ }
58
+ for (i = 2; i < ps.length - 4; i += 2) {
59
+ t1x = (ps[i + 2] - ps[i - 2]) * tension;
60
+ t2x = (ps[i + 4] - ps[i - 0]) * tension;
61
+ t1y = (ps[i + 3] - ps[i - 1]) * tension;
62
+ t2y = (ps[i + 5] - ps[i + 1]) * tension;
63
+ for (t = 0; t <= numberOfSegments; t++) {
64
+ st = t / numberOfSegments;
65
+ c1 = 2 * Math.pow(st, 3) - 3 * Math.pow(st, 2) + 1;
66
+ c2 = -(2 * Math.pow(st, 3)) + 3 * Math.pow(st, 2);
67
+ c3 = Math.pow(st, 3) - 2 * Math.pow(st, 2) + st;
68
+ c4 = Math.pow(st, 3) - Math.pow(st, 2);
69
+ x = c1 * ps[i] + c2 * ps[i + 2] + c3 * t1x + c4 * t2x;
70
+ y = c1 * ps[i + 1] + c2 * ps[i + 3] + c3 * t1y + c4 * t2y;
71
+ result.push(x);
72
+ result.push(y);
73
+ }
74
+ }
75
+ const formatResult = [];
76
+ for (let j = 0; j < result.length - 1; j += 2) {
77
+ formatResult.push({
78
+ x: result[j],
79
+ y: result[j + 1]
80
+ });
81
+ }
82
+ if (closed) {
83
+ for (let j = 0; j < numberOfSegments + 1; j++) {
84
+ const d = formatResult.shift();
85
+ formatResult.push(d);
86
+ }
87
+ }
88
+ return formatResult;
89
+ }
90
+ const createSmoothCurvePointsFromPointList = (pointList, numberOfSegments = 16) => createSmoothCurvePoints(pointList.reduce((acc, cur) => {
91
+ return [...acc, cur.x, cur.y];
92
+ }, []), 0.5, false, numberOfSegments);
93
+ function isInPolygon(checkPoint, polygonPoints, lineType = tool.ELineTypes.Line) {
94
+ let counter = 0;
95
+ let i;
96
+ let xinters;
97
+ let p1;
98
+ let p2;
99
+ polygonPoints = [...polygonPoints];
100
+ if (lineType === tool.ELineTypes.Curve) {
101
+ polygonPoints = createSmoothCurvePoints(polygonPoints.reduce((acc, cur) => {
102
+ return [...acc, cur.x, cur.y];
103
+ }, []), 0.5, true, tool.SEGMENT_NUMBER);
104
+ }
105
+ [p1] = polygonPoints;
106
+ const pointCount = polygonPoints.length;
107
+ for (i = 1; i <= pointCount; i++) {
108
+ p2 = polygonPoints[i % pointCount];
109
+ if (checkPoint.x > Math.min(p1.x, p2.x) && checkPoint.x <= Math.max(p1.x, p2.x)) {
110
+ if (checkPoint.y <= Math.max(p1.y, p2.y)) {
111
+ if (p1.x !== p2.x) {
112
+ xinters = (checkPoint.x - p1.x) * (p2.y - p1.y) / (p2.x - p1.x) + p1.y;
113
+ if (p1.y === p2.y || checkPoint.y <= xinters) {
114
+ counter++;
115
+ }
116
+ }
117
+ }
118
+ }
119
+ p1 = p2;
120
+ }
121
+ if (counter % 2 === 0) {
122
+ return false;
123
+ }
124
+ return true;
125
+ }
126
+ function getPolygonPointUnderZoom(pointList, zoom = 1) {
127
+ return pointList.map((v) => __spreadProps(__spreadValues({}, v), {x: v.x * zoom, y: v.y * zoom}));
128
+ }
129
+
130
+ exports.createSmoothCurvePoints = createSmoothCurvePoints;
131
+ exports.createSmoothCurvePointsFromPointList = createSmoothCurvePointsFromPointList;
132
+ exports.getPolygonPointUnderZoom = getPolygonPointUnderZoom;
133
+ exports.isInPolygon = isInPolygon;
@@ -1 +1,26 @@
1
- "use strict";function uuid(s=8,e=62){const n="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""),o=[];let t;if(e=e||n.length,s)for(t=0;t<s;t++)o[t]=n[0|Math.random()*e];else{let r;for(o[8]=o[13]=o[18]=o[23]="-",o[14]="4",t=0;t<36;t++)o[t]||(r=0|Math.random()*16,o[t]=n[t===19?r&3|8:r])}return o.join("")}module.exports=uuid;
1
+ 'use strict';
2
+
3
+ function uuid(len = 8, radix = 62) {
4
+ const chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split("");
5
+ const id = [];
6
+ let i;
7
+ radix = radix || chars.length;
8
+ if (len) {
9
+ for (i = 0; i < len; i++) {
10
+ id[i] = chars[0 | Math.random() * radix];
11
+ }
12
+ } else {
13
+ let r;
14
+ id[8] = id[13] = id[18] = id[23] = "-";
15
+ id[14] = "4";
16
+ for (i = 0; i < 36; i++) {
17
+ if (!id[i]) {
18
+ r = 0 | Math.random() * 16;
19
+ id[i] = chars[i === 19 ? r & 3 | 8 : r];
20
+ }
21
+ }
22
+ }
23
+ return id.join("");
24
+ }
25
+
26
+ module.exports = uuid;
@@ -1 +1,6 @@
1
- import{createBase64WorkerFactory as b}from"./_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js";var l=b("Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwooZnVuY3Rpb24oKXsidXNlIHN0cmljdCI7dmFyIEM9T2JqZWN0LmRlZmluZVByb3BlcnR5LEw9T2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyxJPU9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHksXz1PYmplY3QucHJvdG90eXBlLnByb3BlcnR5SXNFbnVtZXJhYmxlLE09KGMsdCxvKT0+dCBpbiBjP0MoYyx0LHtlbnVtZXJhYmxlOiEwLGNvbmZpZ3VyYWJsZTohMCx3cml0YWJsZTohMCx2YWx1ZTpvfSk6Y1t0XT1vLEU9KGMsdCk9Pntmb3IodmFyIG8gaW4gdHx8KHQ9e30pKUkuY2FsbCh0LG8pJiZNKGMsbyx0W29dKTtpZihMKWZvcih2YXIgbyBvZiBMKHQpKV8uY2FsbCh0LG8pJiZNKGMsbyx0W29dKTtyZXR1cm4gY307Y2xhc3MgUntzdGF0aWMgZmluZEFsbExpbmUodCxvPSEwKXtjb25zdCBuPVtdLHI9Wy4uLnRdO3IubGVuZ3RoPj0zJiZvPT09ITAmJnIucHVzaChFKHt9LHJbMF0pKTtmb3IobGV0IHM9MDtzPHIubGVuZ3RoO3MrKylyW3MrMV0mJm4ucHVzaCh7cG9pbnQxOnJbc10scG9pbnQyOnJbcysxXSxwb2ludEluZGV4OnN9KTtyZXR1cm4gbn19Y2xhc3MgZ3tzdGF0aWMgaXNJblJhbmdlKHQsbyl7Y29uc3Qgbj1NYXRoLm1pbiguLi5vKSxyPU1hdGgubWF4KC4uLm8pLHM9ZT0+ZTw9ciYmZT49bjtyZXR1cm4oQXJyYXkuaXNBcnJheSh0KT90Olt0XSkuZXZlcnkoZT0+cyhlKSl9c3RhdGljIGdldExpbmVMZW5ndGgodCxvKXtyZXR1cm4gTWF0aC5zcXJ0KE1hdGgucG93KG8ueS10LnksMikrTWF0aC5wb3coby54LXQueCwyKSl9c3RhdGljIGlzT3V0T2ZSYW5nZSh0LG8sbixyKXtjb25zdCBzPW8ueC10LngsYT1uLngtdC54LGU9by55LXQueSxmPW4ueS10LnksbD1zPj0wJiZhPj0wfHxzPD0wJiZhPD0wLHU9ZT49MCYmZj49MHx8ZTw9MCYmZjw9MDtyZXR1cm4gcz5yJiZhPnImJmx8fGU+ciYmZj5yJiZ1fXN0YXRpYyBjcm9zcyh0LG8pe3JldHVybiB0Lngqby55LW8ueCp0Lnl9c3RhdGljIGdldEZvb3RPZlBlcnBlbmRpY3VsYXIodCxvLG4scj0hMSl7bGV0IHM9e3g6MCx5OjB9O2NvbnN0IGE9by54LW4ueCxlPW8ueS1uLnk7aWYoTWF0aC5hYnMoYSk8MWUtOCYmTWF0aC5hYnMoZSk8MWUtOClyZXR1cm4gcz1vLHM7bGV0IGY9KHQueC1vLngpKihvLngtbi54KSsodC55LW8ueSkqKG8ueS1uLnkpO2YvPWEqYStlKmUscy54PW8ueCtmKmEscy55PW8ueStmKmU7Y29uc3QgbD10aGlzLmdldExpbmVMZW5ndGgodCxzKSx1PTI7aWYobD4yKXJldHVybntmb290UG9pbnQ6cyxsZW5ndGg6SW5maW5pdHl9O2NvbnN0IHA9TWF0aC5taW4oby54LG4ueCkseD1NYXRoLm1heChvLngsbi54KSxoPU1hdGgubWluKG8ueSxuLnkpLG09TWF0aC5tYXgoby55LG4ueSksaT0hKHRoaXMuaXNJblJhbmdlKHQueCxbcCx4XSl8fHRoaXMuaXNJblJhbmdlKHQueSxbaCxtXSkpLHk9dC54PngrdXx8dC54PHAtdXx8dC55Pm0rdXx8dC55PGgtdTtyZXR1cm4ocj9pOnkpP3tmb290UG9pbnQ6cyxsZW5ndGg6SW5maW5pdHl9Ontmb290UG9pbnQ6cyxsZW5ndGg6bH19fWZ1bmN0aW9uIFMoYyx0LG89MCxuPTMscil7bGV0IHM9ITE7Y29uc3QgYT1yP3IuaXNDbG9zZXx8ITA6ITE7bGV0IGU9IiIsZj0tMSxsPUluZmluaXR5LHU9Yztjb25zdCBwPTIwO2xldCB4PSExO3JldHVybiB0LmZvckVhY2goaD0+e2lmKCF4JiYhIWgucG9pbnRMaXN0KXN3aXRjaChvKXtjYXNlIDA6Ui5maW5kQWxsTGluZShoLnBvaW50TGlzdCxhKS5mb3JFYWNoKChpLHkpPT57aWYoeClyZXR1cm47Y29uc3QgUD1nLmdldExpbmVMZW5ndGgoaS5wb2ludDEsYyksdz1nLmdldExpbmVMZW5ndGgoaS5wb2ludDIsYyk7aWYoZy5pc091dE9mUmFuZ2UoYyxpLnBvaW50MSxpLnBvaW50MixuKSlyZXR1cm47bGV0e2xlbmd0aDpPLGZvb3RQb2ludDpkfT1nLmdldEZvb3RPZlBlcnBlbmRpY3VsYXIoYyxpLnBvaW50MSxpLnBvaW50Mik7UDxuKjImJihkPWkucG9pbnQxLE89UCx4PSEwKSx3PG4qMiYmKGQ9aS5wb2ludDIsTz13LHg9ITApLE88bCYmTzxuJiYoZT1oLmlkLGY9eSxsPU8sdT1kLHM9ITApfSk7YnJlYWs7Y2FzZSAxOntjb25zdCBtPXRoaXMuY3JlYXRlU21vb3RoQ3VydmVQb2ludHMoaC5wb2ludExpc3QucmVkdWNlKChpLHkpPT5bLi4uaSx5LngseS55XSxbXSksLjUsYSxwKTtmb3IobGV0IGk9MDtpPG0ubGVuZ3RoLTE7aSsrKXtjb25zdHtsZW5ndGg6eSxmb290UG9pbnQ6UH09Zy5nZXRGb290T2ZQZXJwZW5kaWN1bGFyKGMsbVtpXSxtW2krMV0pO3k8bCYmeTxuJiYoZT1oLmlkLGY9TWF0aC5mbG9vcihpLyhwKzEpKSxsPXksdT1QLHM9ITApfX1icmVha319KSx7ZHJvcEZvb3Q6dSxjbG9zZXN0RWRnZUluZGV4OmYsY2xvc2VzdFBvbHlnb25JRDplLGhhc0Nsb3NlZDpzfX1vbm1lc3NhZ2U9ZnVuY3Rpb24odCl7Y29uc3R7cG9pbnRzOm8sYmFja2dyb3VuZExpc3Q6bn09dC5kYXRhLHI9W10scz1uZXcgU2V0O3RyeXtjb25zdCBhPShlLGYpPT57Y29uc3R7ZHJvcEZvb3Q6bH09UyhlLGYsMCwxLHtpc0Nsb3NlOiExfSk7aWYobCE9PWUpe2NvbnN0IHU9YCR7bC54fSArICR7bC55fWA7cy5oYXModSl8fHIucHVzaChlKSxzLmFkZCh1KX19O28uZm9yRWFjaChmdW5jdGlvbihmKXthKGYsbil9KSxuLmZvckVhY2goZnVuY3Rpb24oZil7bGV0IGw9IiI7bD1mLmlkLG4uZm9yRWFjaChmdW5jdGlvbihwLHgpe2lmKHAuaWQ9PT1sKXJldHVybjtjb25zdCBoPVsuLi5uXTtoLnNwbGljZSh4LDEpLHAucG9pbnRMaXN0LmZvckVhY2goZnVuY3Rpb24oaSl7YShpLGgpfSl9KX0pLHBvc3RNZXNzYWdlKHtjb25uZWN0aW9uUG9pbnRzOnJ9KX1jYXRjaChhKXtjb25zb2xlLmVycm9yKGEpLHBvc3RNZXNzYWdlKHtjb25uZWN0aW9uUG9pbnRzOltdfSl9fX0pKCk7Cgo=",null,!1);export{l as default};
1
+ import { createBase64WorkerFactory } from './_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js';
2
+
3
+ var WorkerFactory = createBase64WorkerFactory('/* rollup-plugin-web-worker-loader */
(function () {
  'use strict';

  var __defProp = Object.defineProperty;
  var __getOwnPropSymbols = Object.getOwnPropertySymbols;
  var __hasOwnProp = Object.prototype.hasOwnProperty;
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {enumerable: true, configurable: true, writable: true, value}) : obj[key] = value;
  var __spreadValues = (a, b) => {
    for (var prop in b || (b = {}))
      if (__hasOwnProp.call(b, prop))
        __defNormalProp(a, prop, b[prop]);
    if (__getOwnPropSymbols)
      for (var prop of __getOwnPropSymbols(b)) {
        if (__propIsEnum.call(b, prop))
          __defNormalProp(a, prop, b[prop]);
      }
    return a;
  };
  class CommonToolUtils {
    static findAllLine(pointList, isClose = true) {
      const arr = [];
      const newPoint = [...pointList];
      if (newPoint.length >= 3 && isClose === true) {
        newPoint.push(__spreadValues({}, newPoint[0]));
      }
      for (let i = 0; i < newPoint.length; i++) {
        if (newPoint[i + 1]) {
          arr.push({
            point1: newPoint[i],
            point2: newPoint[i + 1],
            pointIndex: i
          });
        }
      }
      return arr;
    }
  }
  class MathUtils {
    static isInRange(value, range) {
      const min = Math.min(...range);
      const max = Math.max(...range);
      const inRange = (v) => v <= max && v >= min;
      const values = Array.isArray(value) ? value : [value];
      return values.every((v) => inRange(v));
    }
    static getLineLength(point1, point2) {
      return Math.sqrt(Math.pow(point2.y - point1.y, 2) + Math.pow(point2.x - point1.x, 2));
    }
    static isOutOfRange(coordinate, point1, point2, range) {
      const x1 = point1.x - coordinate.x;
      const x2 = point2.x - coordinate.x;
      const y1 = point1.y - coordinate.y;
      const y2 = point2.y - coordinate.y;
      const sameSideX = x1 >= 0 && x2 >= 0 || x1 <= 0 && x2 <= 0;
      const sameSideY = y1 >= 0 && y2 >= 0 || y1 <= 0 && y2 <= 0;
      return x1 > range && x2 > range && sameSideX || y1 > range && y2 > range && sameSideY;
    }
    static cross(vector1, vector2) {
      return vector1.x * vector2.y - vector2.x * vector1.y;
    }
    static getFootOfPerpendicular(pt, begin, end, useAxisRange = false) {
      let retVal = {x: 0, y: 0};
      const dx = begin.x - end.x;
      const dy = begin.y - end.y;
      if (Math.abs(dx) < 1e-8 && Math.abs(dy) < 1e-8) {
        retVal = begin;
        return retVal;
      }
      let u = (pt.x - begin.x) * (begin.x - end.x) + (pt.y - begin.y) * (begin.y - end.y);
      u /= dx * dx + dy * dy;
      retVal.x = begin.x + u * dx;
      retVal.y = begin.y + u * dy;
      const length = this.getLineLength(pt, retVal);
      const ratio = 2;
      if (length > 2) {
        return {
          footPoint: retVal,
          length: Infinity
        };
      }
      const fromX = Math.min(begin.x, end.x);
      const toX = Math.max(begin.x, end.x);
      const fromY = Math.min(begin.y, end.y);
      const toY = Math.max(begin.y, end.y);
      const allAxisOverRange = !(this.isInRange(pt.x, [fromX, toX]) || this.isInRange(pt.y, [fromY, toY]));
      const someAxisOverRange = pt.x > toX + ratio || pt.x < fromX - ratio || pt.y > toY + ratio || pt.y < fromY - ratio;
      const isOverRange = useAxisRange ? allAxisOverRange : someAxisOverRange;
      if (isOverRange) {
        return {
          footPoint: retVal,
          length: Infinity
        };
      }
      return {
        footPoint: retVal,
        length
      };
    }
  }
  function getClosestPoint(coordinate, polygonList, lineType = 0, range = 3, option) {
    let hasClosed = false;
    const isClose = option ? option.isClose || true : false;
    let closestPolygonID = "";
    let closestEdgeIndex = -1;
    let min = Infinity;
    let dropFoot = coordinate;
    const numberOfSegments = 20;
    let isCloseNode = false;
    polygonList.forEach((v) => {
      if (isCloseNode) {
        return;
      }
      if (!v.pointList) {
        return;
      }
      switch (lineType) {
        case 0:
          {
            const allLine = CommonToolUtils.findAllLine(v.pointList, isClose);
            allLine.forEach((line, lineIndex) => {
              if (isCloseNode) {
                return;
              }
              const twoPointDistance1 = MathUtils.getLineLength(line.point1, coordinate);
              const twoPointDistance2 = MathUtils.getLineLength(line.point2, coordinate);
              if (MathUtils.isOutOfRange(coordinate, line.point1, line.point2, range)) {
                return;
              }
              let {length, footPoint} = MathUtils.getFootOfPerpendicular(coordinate, line.point1, line.point2);
              if (twoPointDistance1 < range * 2) {
                footPoint = line.point1;
                length = twoPointDistance1;
                isCloseNode = true;
              }
              if (twoPointDistance2 < range * 2) {
                footPoint = line.point2;
                length = twoPointDistance2;
                isCloseNode = true;
              }
              if (length < min && length < range) {
                closestPolygonID = v.id;
                closestEdgeIndex = lineIndex;
                min = length;
                dropFoot = footPoint;
                hasClosed = true;
              }
            });
          }
          break;
        case 1:
          {
            const points = this.createSmoothCurvePoints(v.pointList.reduce((acc, cur) => {
              return [...acc, cur.x, cur.y];
            }, []), 0.5, isClose, numberOfSegments);
            for (let i = 0; i < points.length - 1; i++) {
              const {length, footPoint} = MathUtils.getFootOfPerpendicular(coordinate, points[i], points[i + 1]);
              if (length < min && length < range) {
                closestPolygonID = v.id;
                closestEdgeIndex = Math.floor(i / (numberOfSegments + 1));
                min = length;
                dropFoot = footPoint;
                hasClosed = true;
              }
            }
          }
          break;
      }
    });
    return {dropFoot, closestEdgeIndex, closestPolygonID, hasClosed};
  }
  onmessage = function onmessage2(e) {
    const {points, backgroundList} = e.data;
    const connectionPoints = [];
    const cacheSet = new Set();
    try {
      const judgeIsConnectPoint = (point, polygonList) => {
        const {dropFoot} = getClosestPoint(point, polygonList, 0, 1, {isClose: false});
        if (dropFoot !== point) {
          const s = `${dropFoot.x} + ${dropFoot.y}`;
          if (!cacheSet.has(s)) {
            connectionPoints.push(point);
          }
          cacheSet.add(s);
        }
      };
      points.forEach(function pointsCalc(point) {
        judgeIsConnectPoint(point, backgroundList);
      });
      backgroundList.forEach(function backgroundsCalc(v) {
        let traverseID = "";
        traverseID = v.id;
        backgroundList.forEach(function background2Calc(annotation, i) {
          if (annotation.id === traverseID) {
            return;
          }
          const newPolygonList = [...backgroundList];
          newPolygonList.splice(i, 1);
          annotation.pointList.forEach(function backgroundPointsCalc(point) {
            judgeIsConnectPoint(point, newPolygonList);
          });
        });
      });
      postMessage({connectionPoints});
    } catch (E) {
      console.error(E);
      postMessage({connectionPoints: []});
    }
  };

})();

', null, false);
4
+ /* eslint-enable */
5
+
6
+ export { WorkerFactory as default };
@@ -0,0 +1,12 @@
1
+ import { createBase64WorkerFactory as createBase64WorkerFactory$1 } from './_rollup-plugin-web-worker-loader__helper__node__createBase64WorkerFactory.js';
2
+ import { createBase64WorkerFactory as createBase64WorkerFactory$2 } from './_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js';
3
+ import { isNodeJS } from './_rollup-plugin-web-worker-loader__helper__auto__isNodeJS.js';
4
+
5
+ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
6
+ if (isNodeJS()) {
7
+ return createBase64WorkerFactory$1(base64, sourcemapArg, enableUnicodeArg);
8
+ }
9
+ return createBase64WorkerFactory$2(base64, sourcemapArg, enableUnicodeArg);
10
+ }
11
+
12
+ export { createBase64WorkerFactory };
@@ -0,0 +1,7 @@
1
+ var kIsNodeJS = Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]';
2
+
3
+ function isNodeJS() {
4
+ return kIsNodeJS;
5
+ }
6
+
7
+ export { isNodeJS };
@@ -1,2 +1,31 @@
1
- function i(o,a){var r=atob(o);if(a){for(var e=new Uint8Array(r.length),n=0,t=r.length;n<t;++n)e[n]=r.charCodeAt(n);return String.fromCharCode.apply(null,new Uint16Array(e.buffer))}return r}function l(o,a,r){var e=a===void 0?null:a,n=r===void 0?!1:r,t=i(o,n),u=t.indexOf(`
2
- `,10)+1,c=t.substring(u)+(e?"//# sourceMappingURL="+e:""),f=new Blob([c],{type:"application/javascript"});return URL.createObjectURL(f)}function v(o,a,r){var e;return function(t){return e=e||l(o,a,r),new Worker(e,t)}}export{v as createBase64WorkerFactory};
1
+ function decodeBase64(base64, enableUnicode) {
2
+ var binaryString = atob(base64);
3
+ if (enableUnicode) {
4
+ var binaryView = new Uint8Array(binaryString.length);
5
+ for (var i = 0, n = binaryString.length; i < n; ++i) {
6
+ binaryView[i] = binaryString.charCodeAt(i);
7
+ }
8
+ return String.fromCharCode.apply(null, new Uint16Array(binaryView.buffer));
9
+ }
10
+ return binaryString;
11
+ }
12
+
13
+ function createURL(base64, sourcemapArg, enableUnicodeArg) {
14
+ var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;
15
+ var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;
16
+ var source = decodeBase64(base64, enableUnicode);
17
+ var start = source.indexOf('\n', 10) + 1;
18
+ var body = source.substring(start) + (sourcemap ? '\/\/# sourceMappingURL=' + sourcemap : '');
19
+ var blob = new Blob([body], { type: 'application/javascript' });
20
+ return URL.createObjectURL(blob);
21
+ }
22
+
23
+ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
24
+ var url;
25
+ return function WorkerFactory(options) {
26
+ url = url || createURL(base64, sourcemapArg, enableUnicodeArg);
27
+ return new Worker(url, options);
28
+ };
29
+ }
30
+
31
+ export { createBase64WorkerFactory };
@@ -0,0 +1,11 @@
1
+ var WorkerClass = null;
2
+
3
+ try {
4
+ var WorkerThreads =
5
+ typeof module !== 'undefined' && typeof module.require === 'function' && module.require('worker_threads') ||
6
+ typeof __non_webpack_require__ === 'function' && __non_webpack_require__('worker_threads') ||
7
+ typeof require === 'function' && require('worker_threads');
8
+ WorkerClass = WorkerThreads.Worker;
9
+ } catch(e) {} // eslint-disable-line
10
+
11
+ export { WorkerClass };
@@ -0,0 +1,18 @@
1
+ import { WorkerClass } from './_rollup-plugin-web-worker-loader__helper__node__WorkerClass.js';
2
+
3
+ function decodeBase64(base64, enableUnicode) {
4
+ return Buffer.from(base64, 'base64').toString(enableUnicode ? 'utf16' : 'utf8');
5
+ }
6
+
7
+ function createBase64WorkerFactory(base64, sourcemapArg, enableUnicodeArg) {
8
+ var sourcemap = sourcemapArg === undefined ? null : sourcemapArg;
9
+ var enableUnicode = enableUnicodeArg === undefined ? false : enableUnicodeArg;
10
+ var source = decodeBase64(base64, enableUnicode);
11
+ var start = source.indexOf('\n', 10) + 1;
12
+ var body = source.substring(start) + (sourcemap ? '\/\/# sourceMappingURL=' + sourcemap : '');
13
+ return function WorkerFactory(options) {
14
+ return new WorkerClass(body, Object.assign({}, options, { eval: true }));
15
+ };
16
+ }
17
+
18
+ export { createBase64WorkerFactory };