@labelbee/lb-annotation 1.9.0-alpha.1 → 1.9.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +11 -11
- package/dist/types/core/pointCloud/annotation.d.ts +6 -4
- package/dist/types/core/pointCloud/index.d.ts +8 -1
- package/dist/types/core/toolOperation/basicToolOperation.d.ts +5 -0
- package/dist/types/core/toolOperation/pointCloud2dOperation.d.ts +11 -2
- package/dist/types/core/toolOperation/polygonOperation.d.ts +2 -1
- package/es/core/index.js +8 -1
- package/es/core/pointCloud/annotation.js +24 -13
- package/es/core/pointCloud/cache.js +9 -0
- package/es/core/pointCloud/index.js +110 -110
- package/es/core/scheduler.js +12 -1
- package/es/core/toolOperation/basicToolOperation.js +20 -11
- package/es/core/toolOperation/pointCloud2dOperation.js +83 -23
- package/es/core/toolOperation/polygonOperation.js +95 -54
- package/es/core/toolOperation/rectOperation.js +5 -1
- package/es/core/toolOperation/segmentByRect.js +8 -5
- package/es/index.js +11 -11
- package/es/utils/MathUtils.js +12 -0
- package/es/utils/tool/AttributeUtils.js +1 -1
- package/es/utils/tool/CommonToolUtils.js +0 -14
- package/es/utils/tool/EnhanceCommonToolUtils.js +39 -0
- package/es/utils/tool/PolygonUtils.js +5 -0
- package/package.json +5 -7
- package/dist/types/types/toolExport/index.d.ts +0 -5
package/dist/index.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";/*!
|
|
2
|
-
* sense-annotation v1.9.0-alpha.
|
|
2
|
+
* sense-annotation v1.9.0-alpha.2
|
|
3
3
|
* (c) 2020-2022
|
|
4
4
|
* Released under the Apache-2.0 License.
|
|
5
|
-
*/Object.defineProperty(exports,"__esModule",{value:!0});var turf=require("@turf/turf"),_=require("lodash"),lbUtils=require("@labelbee/lb-utils"),rgba=require("color-rgba"),THREE=require("three");function _interopDefaultLegacy(r){return r&&typeof r=="object"&&"default"in r?r:{default:r}}function _interopNamespace(r){if(r&&r.__esModule)return r;var t=Object.create(null);return r&&Object.keys(r).forEach(function(e){if(e!=="default"){var i=Object.getOwnPropertyDescriptor(r,e);Object.defineProperty(t,e,i.get?i:{enumerable:!0,get:function(){return r[e]}})}}),t.default=r,Object.freeze(t)}var ___default=_interopDefaultLegacy(_),rgba__default=_interopDefaultLegacy(rgba),THREE__namespace=_interopNamespace(THREE);const editStepWidth=320;var EPointCloudName;(function(r){r.PointCloud="pointCloudTool"})(EPointCloudName||(EPointCloudName={}));var EVideoToolName;(function(r){r.VideoTextTool="videoTextTool",r.VideoTagTool="videoTagTool",r.VideoClipTool="videoClipTool"})(EVideoToolName||(EVideoToolName={}));var EToolType;(function(r){r[r.Rect=0]="Rect",r[r.Tag=1]="Tag"})(EToolType||(EToolType={}));var EToolName;(function(r){r.Rect="rectTool",r.Tag="tagTool",r.Point="pointTool",r.PointMarker="pointMarkerTool",r.Segmentation="segmentationTool",r.Filter="filterTool",r.Text="textTool",r.Polygon="polygonTool",r.Line="lineTool",r.LineMarker="lineMarkerTool",r.Empty="emptyTool",r.FolderTag="folderTagTool",r.RectTrack="rectTrackTool",r.Face="faceTool",r.ClientAttribute="clientAttributeTool",r.OCRRelation="OCRRelationTool",r.SegmentByRect="segmentByRectTool"})(EToolName||(EToolName={}));var ECheckModel;(function(r){r.Check="check"})(ECheckModel||(ECheckModel={}));var ERectPattern;(function(r){r[r.nothing=0]="nothing",r[r.RectBG=1]="RectBG",r[r.showOrder=2]="showOrder"})(ERectPattern||(ERectPattern={}));const TOOL_NAME={[EToolName.Rect]:"\u62C9\u6846",[EToolName.Tag]:"\u6807\u7B7E",[EToolName.Point]:"\u6807\u70B9",[EToolName.PointMarker]:"\u5217\u8868\u6807\u70B9",[EToolName.Segmentation]:"\u524D\u666F\u5206\u5272",[EToolName.Filter]:"\u7B5B\u9009",[EToolName.Text]:"\u6587\u672C",[EToolName.Polygon]:"\u591A\u8FB9\u5F62",[EToolName.Line]:"\u7EBF\u6761",[EToolName.LineMarker]:"\u5217\u8868\u7EBF\u6761",[EToolName.FolderTag]:"\u6587\u4EF6\u5939\u6807\u7B7E",[EToolName.RectTrack]:"\u62C9\u6846\u8DDF\u8E2A",[EToolName.Face]:"\u4EBA\u8138106\u5DE5\u5177",[EToolName.ClientAttribute]:"\u5BA2\u6237\u7AEF\u5C5E\u6027\u5DE5\u5177",[EToolName.OCRRelation]:"OCR\u5173\u8054\u5173\u7CFB\u5DE5\u5177",[EToolName.SegmentByRect]:"\u7B97\u6CD5\u5206\u5272\u8F85\u52A9\u5DE5\u5177",[EVideoToolName.VideoTextTool]:"\u89C6\u9891\u6587\u672C",[EVideoToolName.VideoTagTool]:"\u89C6\u9891\u6807\u7B7E",[EVideoToolName.VideoClipTool]:"\u89C6\u9891\u622A\u53D6",[EPointCloudName.PointCloud]:"\u70B9\u4E91"};var EDependPattern;(function(r){r[r.noDepend=1]="noDepend",r[r.dependOrigin=2]="dependOrigin",r[r.dependShape=3]="dependShape",r[r.dependLine=4]="dependLine",r[r.dependPolygon=5]="dependPolygon",r[r.dependPreShape=101]="dependPreShape",r[r.dependPreLine=102]="dependPreLine",r[r.dependPrePolygon=103]="dependPrePolygon"})(EDependPattern||(EDependPattern={}));var EFilterToolOperation;(function(r){r.lc="leftClick",r.rc="rightClick",r.clc="ctrlLeftClick",r.crc="ctrlRightClick"})(EFilterToolOperation||(EFilterToolOperation={}));const OPERATION_LIST={leftClick:"\u9F20\u6807\u5DE6\u952E",rightClick:"\u9F20\u6807\u53F3\u952E",ctrlLeftClick:"ctrl + \u9F20\u6807\u5DE6\u952E",ctrlRightClick:"ctrl + \u9F20\u6807\u53F3\u952E"};var EAnnotationMode;(function(r){r[r.Normal=1]="Normal",r[r.Modify=2]="Modify"})(EAnnotationMode||(EAnnotationMode={}));var ELineTypes;(function(r){r[r.Line=0]="Line",r[r.Curve=1]="Curve"})(ELineTypes||(ELineTypes={}));var ELineColor;(function(r){r[r.SingleColor=0]="SingleColor",r[r.MultiColor=1]="MultiColor"})(ELineColor||(ELineColor={}));var ESelectedType;(function(r){r[r.Form=1]="Form",r[r.Json=2]="Json"})(ESelectedType||(ESelectedType={}));var EDragTarget$1;(function(r){r[r.Point=0]="Point",r[r.Line=1]="Line",r[r.Plane=2]="Plane"})(EDragTarget$1||(EDragTarget$1={}));var EDrawPointPattern;(function(r){r[r.None=0]="None",r[r.Drawing=1]="Drawing",r[r.Edit=2]="Edit"})(EDrawPointPattern||(EDrawPointPattern={}));var EPageOperator$1;(function(r){r[r.Backward=0]="Backward",r[r.Forward=1]="Forward",r[r.JumpSkip=2]="JumpSkip",r[r.None=3]="None"})(EPageOperator$1||(EPageOperator$1={}));var EAuditStatus;(function(r){r[r.Wait=0]="Wait",r[r.Pass=1]="Pass",r[r.Fail=2]="Fail",r[r.Loading=3]="Loading"})(EAuditStatus||(EAuditStatus={}));var ETextType;(function(r){r[r.AnyString=0]="AnyString",r[r.Order=1]="Order",r[r.EnglishOnly=2]="EnglishOnly",r[r.NumberOnly=3]="NumberOnly",r[r.CustomFormat=4]="CustomFormat"})(ETextType||(ETextType={}));const TEXT_TYPE={0:"\u4EFB\u610F\u5B57\u7B26",1:"\u5E8F\u53F7",2:"\u4EC5\u82F1\u6587",3:"\u4EC5\u6570\u5B57"},TEXT_ATTRIBUTE_MAX_LENGTH=1e3,TEXT_ATTRIBUTE_LINE_HEIGHT=16,DEFAULT_TEXT_MAX_WIDTH=300,DEFAULT_FONT="normal normal 500 14px Arial";var EThumbnailOption;(function(r){r[r.ImgList=1e3]="ImgList",r[r.TrackPrediction=1001]="TrackPrediction",r[r.ImgSearch=1002]="ImgSearch"})(EThumbnailOption||(EThumbnailOption={}));const CLIENT_TOOL_HEAD_TYPE={[EPointCloudName.PointCloud]:"sensebeepc",[EToolName.ClientAttribute]:"sensebeepc-EnumAttributeTool",[EToolName.Face]:"sensebeepc-FacePointsLabellingTool",[EToolName.OCRRelation]:"sensebeepc-OCRRelationTool"},CLIENT_TOOL_NAME={[EPointCloudName.PointCloud]:"\u70B9\u4E91\u5BA2\u6237\u7AEF",[EToolName.ClientAttribute]:"\u5BA2\u6237\u7AEF\u5C5E\u6027\u5DE5\u5177",[EToolName.Face]:"\u4EBA\u8138106\u70B9\u5DE5\u5177",[EToolName.OCRRelation]:"OCR\u5173\u8054\u5173\u7CFB\u5DE5\u5177"},SEGMENT_NUMBER$2=16,edgeAdsorptionScope=10;var EPolygonPattern;(function(r){r[r.Normal=0]="Normal",r[r.Rect=1]="Rect"})(EPolygonPattern||(EPolygonPattern={}));var tool=Object.freeze({__proto__:null,editStepWidth,get EPointCloudName(){return EPointCloudName},get EVideoToolName(){return EVideoToolName},get EToolType(){return EToolType},get EToolName(){return EToolName},get ECheckModel(){return ECheckModel},get ERectPattern(){return ERectPattern},TOOL_NAME,get EDependPattern(){return EDependPattern},get EFilterToolOperation(){return EFilterToolOperation},OPERATION_LIST,get EAnnotationMode(){return EAnnotationMode},get ELineTypes(){return ELineTypes},get ELineColor(){return ELineColor},get ESelectedType(){return ESelectedType},get EDragTarget(){return EDragTarget$1},get EDrawPointPattern(){return EDrawPointPattern},get EPageOperator(){return EPageOperator$1},get EAuditStatus(){return EAuditStatus},get ETextType(){return ETextType},TEXT_TYPE,TEXT_ATTRIBUTE_MAX_LENGTH,TEXT_ATTRIBUTE_LINE_HEIGHT,DEFAULT_TEXT_MAX_WIDTH,DEFAULT_FONT,get EThumbnailOption(){return EThumbnailOption},CLIENT_TOOL_HEAD_TYPE,CLIENT_TOOL_NAME,SEGMENT_NUMBER:SEGMENT_NUMBER$2,edgeAdsorptionScope,get EPolygonPattern(){return EPolygonPattern}}),__defProp$j=Object.defineProperty,__defProps$f=Object.defineProperties,__getOwnPropDescs$f=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$i=Object.getOwnPropertySymbols,__hasOwnProp$i=Object.prototype.hasOwnProperty,__propIsEnum$i=Object.prototype.propertyIsEnumerable,__defNormalProp$j=(r,t,e)=>t in r?__defProp$j(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$i=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$i.call(t,e)&&__defNormalProp$j(r,e,t[e]);if(__getOwnPropSymbols$i)for(var e of __getOwnPropSymbols$i(t))__propIsEnum$i.call(t,e)&&__defNormalProp$j(r,e,t[e]);return r},__spreadProps$f=(r,t)=>__defProps$f(r,__getOwnPropDescs$f(t));function createSmoothCurvePoints(r,t=.5,e=!1,i=16){if(r.length<4)return r;const s=[],n=r.slice(0);let o,a,l,h,d,u,c,g,p,f,v,m,x;for(e?(n.unshift(r[r.length-1]),n.unshift(r[r.length-2]),n.unshift(r[r.length-1]),n.unshift(r[r.length-2]),n.push(r[0]),n.push(r[1])):(n.unshift(r[1]),n.unshift(r[0]),n.push(r[r.length-2]),n.push(r[r.length-1])),x=2;x<n.length-4;x+=2)for(l=(n[x+2]-n[x-2])*t,h=(n[x+4]-n[x-0])*t,d=(n[x+3]-n[x-1])*t,u=(n[x+5]-n[x+1])*t,m=0;m<=i;m++)v=m/i,c=2*Math.pow(v,3)-3*Math.pow(v,2)+1,g=-(2*Math.pow(v,3))+3*Math.pow(v,2),p=Math.pow(v,3)-2*Math.pow(v,2)+v,f=Math.pow(v,3)-Math.pow(v,2),o=c*n[x]+g*n[x+2]+p*l+f*h,a=c*n[x+1]+g*n[x+3]+p*d+f*u,s.push(o),s.push(a);const b=[];for(let P=0;P<s.length-1;P+=2)b.push({x:s[P],y:s[P+1]});if(e)for(let P=0;P<i+1;P++){const w=b.shift();b.push(w)}return b}const createSmoothCurvePointsFromPointList=(r,t=16)=>createSmoothCurvePoints(r.reduce((e,i)=>[...e,i.x,i.y],[]),.5,!1,t);function isInPolygon(r,t,e=ELineTypes.Line){let i=0,s,n,o,a;t=[...t],e===ELineTypes.Curve&&(t=createSmoothCurvePoints(t.reduce((h,d)=>[...h,d.x,d.y],[]),.5,!0,SEGMENT_NUMBER$2)),[o]=t;const l=t.length;for(s=1;s<=l;s++)a=t[s%l],r.x>Math.min(o.x,a.x)&&r.x<=Math.max(o.x,a.x)&&r.y<=Math.max(o.y,a.y)&&o.x!==a.x&&(n=(r.x-o.x)*(a.y-o.y)/(a.x-o.x)+o.y,(o.y===a.y||r.y<=n)&&i++),o=a;return i%2!=0}function getPolygonPointUnderZoom(r,t=1){return r.map(e=>__spreadProps$f(__spreadValues$i({},e),{x:e.x*t,y:e.y*t}))}var __pow$1=Math.pow;class Vector{static add(t,e){return{x:t.x+e.x,y:t.y+e.y}}static getVector(t,e){return{x:e.x-t.x,y:e.y-t.y}}static len(t){return Math.sqrt(__pow$1(t.x,2)+__pow$1(t.y,2))}static dotProduct(t,e){return t.x*e.x+t.y+e.y}}class Trigonometric{static tanAPlusB(t,e){return(t+e)/(1-t*e)}static sinAPlusB(t,e,i,s){return s*t+e*i}static cosAPlusB(t,e,i,s){return e*s-t*i}}const _MathUtils=class{static getRotate(r){return r+90>=360?r+90-360:r+90}static getLineLength(r,t){return Math.sqrt(Math.pow(t.y-r.y,2)+Math.pow(t.x-r.x,2))}static getTextArea(r,t,e=DEFAULT_TEXT_MAX_WIDTH,i=DEFAULT_FONT,s){if(typeof t!="string")return{width:0,height:0};const n=r.getContext("2d");n.font=i;let o=0;typeof s=="undefined"&&(s=r&&parseInt(window.getComputedStyle(r).lineHeight,10)||parseInt(window.getComputedStyle(document.body).lineHeight,10));const a=r&&parseInt(window.getComputedStyle(r).fontSize,10)||parseInt(window.getComputedStyle(document.body).fontSize,10)||0,l=t.split(`
|
|
6
|
-
`);let h=0;for(let d=0;d<l.length;d++){const u=l[d].split("");let c="";for(let g=0;g<u.length;g++){const p=c+u[g],v=n.measureText(p).width;v>e&&g>0?(c=u[g],o+=s,h=e):(c=p,v>h&&(h=v))}d!==l.length-1&&(o+=s)}return{width:h,height:o+a,lineHeight:s,fontHeight:a}}static getLineCenterPoint(r){const[t,e]=r,i=Vector.getVector(t,e);return{x:t.x+i.x/2,y:t.y+i.y/2}}static getPerpendicularLine(r){if(r.length!==2)return;const[t,e]=r,i={x:e.x+e.y-t.y,y:e.y-(e.x-t.x)};return[e,i]}static getPerpendicularFootOfLine(r,t){if(r.length!==2)return r;const e=this.getPerpendicularLine(r);if(!e)return r;const[i,s]=e;return this.getFootOfPerpendicular(t,i,s).footPoint}static getQuadrangleFromTriangle(r){if(r.length!==3)return r;const[t,e,i]=r,s={x:i.x+t.x-e.x,y:i.y+t.y-e.y};return[t,e,i,s]}static getRectPerpendicularOffset(r,t,e){const[i,s]=e,n=this.getFootOfPerpendicular(r,i,s).footPoint,o=this.getFootOfPerpendicular(t,i,s).footPoint,a={x:n.x-o.x,y:n.y-o.y},l=Vector.add(t,a);return Vector.getVector(r,l)}static getArrayIndex(r,t){return r<0?t+r:r>=t?r-t:r}static getPointListFromPointOffset(r,t,e){const i=this.getArrayIndex(t-1,r.length),s=this.getArrayIndex(t+1,r.length),n=this.getArrayIndex(t-2,r.length),o=[...r];o[t]=Vector.add(o[t],e);const a=this.getFootOfPerpendicular(o[t],o[n],o[i]).footPoint,l=this.getFootOfPerpendicular(o[t],o[s],o[n]).footPoint;return o[i]=a,o[s]=l,o}static getRectCenterPoint(r){const[t,,e]=r;return{x:(t.x+e.x)/2,y:(t.y+e.y)/2}}static rotateRectPointList(r=5,t){const e=this.getRectCenterPoint(t),{PI:i}=Math,s=Math.sin(r*i/180),n=Math.cos(r*i/180);return t.map(o=>{const a=Vector.getVector(e,o),l=Vector.len(a),h=a.y/l,d=a.x/l;return{x:l*Trigonometric.cosAPlusB(h,d,s,n)+e.x,y:l*Trigonometric.sinAPlusB(h,d,s,n)+e.y}})}static getRectangleByRightAngle(r,t){if(t.length!==2)return t;const e=_MathUtils.getPerpendicularFootOfLine(t,r);return _MathUtils.getQuadrangleFromTriangle([...t,e])}static getRadiusFromQuadrangle(r){const[,t,e]=r,i=e.y-t.y,s=t.x-e.x,n=this.getLineLength(t,e),o=i/n,a=Math.acos(o);return s>0?-a:a}};let MathUtils=_MathUtils;MathUtils.isInRange=(r,t)=>{const e=Math.min(...t),i=Math.max(...t),s=o=>o<=i&&o>=e;return(Array.isArray(r)?r:[r]).every(o=>s(o))},MathUtils.withinRange=(r,t)=>{const e=Math.min(...t),i=Math.max(...t);return r>i?i:r<e?e:r},MathUtils.calcViewportBoundaries=(r,t=!1,e=SEGMENT_NUMBER$2,i=1)=>{if(!r)return{top:0,bottom:0,left:0,right:0};const s=20/i,n=[],o=[];let a=r;t&&(a=createSmoothCurvePointsFromPointList(r,e)),a.forEach(({x:p,y:f})=>{n.push(p),o.push(f)});let l=Math.min(...n),h=Math.max(...n),d=Math.min(...o),u=Math.max(...o);const c=h-l,g=u-d;if(c<s){const p=(s-c)/2;l-=p,h+=p}if(g<s){const p=(s-g)/2;d-=p,u+=p}return{top:d,bottom:u,left:l,right:h}},MathUtils.getFootOfPerpendicular=(r,t,e,i=!1)=>{let s={x:0,y:0};const n=t.x-e.x,o=t.y-e.y;if(Math.abs(n)<1e-8&&Math.abs(o)<1e-8)return s=t,s;let a=(r.x-t.x)*(t.x-e.x)+(r.y-t.y)*(t.y-e.y);a/=n*n+o*o,s.x=t.x+a*n,s.y=t.y+a*o;const l=_MathUtils.getLineLength(r,s),h=2,d=Math.min(t.x,e.x),u=Math.max(t.x,e.x),c=Math.min(t.y,e.y),g=Math.max(t.y,e.y),p=!(_MathUtils.isInRange(r.x,[d,u])||_MathUtils.isInRange(r.y,[c,g])),f=r.x>u+h||r.x<d-h||r.y>g+h||r.y<c-h;return(i?p:f)?{footPoint:s,length:Infinity}:{footPoint:s,length:l}};const headerHeight=61,tipsHeight=40,footerHeight=40,sidebarWidth=240;var EStepType;(function(r){r[r.ANNOTATION=1]="ANNOTATION",r[r.QUALITY_INSPECTION=2]="QUALITY_INSPECTION",r[r.PRE_ANNOTATION=3]="PRE_ANNOTATION",r[r.MANUAL_CORRECTION=4]="MANUAL_CORRECTION"})(EStepType||(EStepType={}));const ANNOTATION_MAX_SIZE=1e3;var EPageOperator;(function(r){r[r.Backward=0]="Backward",r[r.Forward=1]="Forward",r[r.JumpSkip=2]="JumpSkip",r[r.None=3]="None"})(EPageOperator||(EPageOperator={}));var EDragStatus;(function(r){r[r.Start=0]="Start",r[r.Stop=1]="Stop",r[r.Wait=2]="Wait",r[r.Move=3]="Move"})(EDragStatus||(EDragStatus={}));var EDragTarget;(function(r){r[r.Point=0]="Point",r[r.Line=1]="Line",r[r.Plane=2]="Plane"})(EDragTarget||(EDragTarget={}));var ESortDirection;(function(r){r[r.ascend=0]="ascend",r[r.descend=1]="descend"})(ESortDirection||(ESortDirection={}));var EGrowthMode;(function(r){r[r.Intelligence=0]="Intelligence",r[r.Linear=1]="Linear"})(EGrowthMode||(EGrowthMode={}));var ELang;(function(r){r.Zh="zh_CN",r.US="en_US"})(ELang||(ELang={}));var ERotateDirection;(function(r){r[r.Clockwise=0]="Clockwise",r[r.Anticlockwise=1]="Anticlockwise"})(ERotateDirection||(ERotateDirection={}));const DEFAULT_TEXT_OFFSET={offsetX:-10,offsetY:-10},DEFAULT_TEXT_SHADOW={shadowColor:"rgba(0,0,0,0.6)",shadowOffsetX:0,shadowOffsetY:2,shadowBlur:4},TEXT_ATTRIBUTE_OFFSET$1={x:8,y:26};var annotation=Object.freeze({__proto__:null,headerHeight,tipsHeight,footerHeight,sidebarWidth,get EStepType(){return EStepType},ANNOTATION_MAX_SIZE,get EPageOperator(){return EPageOperator},get EDragStatus(){return EDragStatus},get EDragTarget(){return EDragTarget},get ESortDirection(){return ESortDirection},get EGrowthMode(){return EGrowthMode},get ELang(){return ELang},get ERotateDirection(){return ERotateDirection},DEFAULT_TEXT_OFFSET,DEFAULT_TEXT_SHADOW,TEXT_ATTRIBUTE_OFFSET:TEXT_ATTRIBUTE_OFFSET$1}),__defProp$i=Object.defineProperty,__defProps$e=Object.defineProperties,__getOwnPropDescs$e=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$h=Object.getOwnPropertySymbols,__hasOwnProp$h=Object.prototype.hasOwnProperty,__propIsEnum$h=Object.prototype.propertyIsEnumerable,__defNormalProp$i=(r,t,e)=>t in r?__defProp$i(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$h=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$h.call(t,e)&&__defNormalProp$i(r,e,t[e]);if(__getOwnPropSymbols$h)for(var e of __getOwnPropSymbols$h(t))__propIsEnum$h.call(t,e)&&__defNormalProp$i(r,e,t[e]);return r},__spreadProps$e=(r,t)=>__defProps$e(r,__getOwnPropDescs$e(t));class CommonToolUtils$1{static getStepInfo(t,e){return e==null?void 0:e.filter(i=>i.step===t)[0]}static getCurrentStepInfo(t,e){const i=this.getStepInfo(t,e);return i&&(i.type===EStepType.QUALITY_INSPECTION||i.type===EStepType.MANUAL_CORRECTION)?this.getCurrentStepInfo(i.dataSourceStep,e):i}static getMaxOrder(t){let e=0;return t.forEach(i=>{i.order&&i.order>e&&(e=i.order)}),e}static hotkeyFilter(t){const e=t.target||t.srcElement;if(!e)return!0;const{tagName:i,type:s}=e;if(!i||!s)return!0;let n=!0;return(e.isContentEditable||i==="TEXTAREA"||(i==="INPUT"&&s!=="radio"||i==="TEXTAREA")&&!e.readOnly)&&(n=!1),n}static getNextSelectedRectID(t,e=ESortDirection.ascend,i){let s=1;e===ESortDirection.descend&&(s=-1);const n=t.sort((l,h)=>l.x-h.x==0?l.y-h.y:s*(l.x-h.x)),o=n.findIndex(l=>l.id===i),a=n.length;return n[(o+1)%a]}static getNextSelectedRectIDByEvent(t,e,i){const s=e.shiftKey?ESortDirection.descend:ESortDirection.ascend;return this.getNextSelectedRectID(t,s,i)}static getRenderResultList(t,e,i=[],s){let n;return[t.filter(a=>s&&s===(a==null?void 0:a.id)?(n=a,!1):!(i.length>0&&!i.includes(a==null?void 0:a.attribute)||this.isDifferSourceID(a==null?void 0:a.sourceID,e))),n]}static getSourceID(t){var e;const i="";return t&&(e=t==null?void 0:t.id)!=null?e:i}static findAllLine(t,e=!0){const i=[],s=[...t];s.length>=3&&e===!0&&s.push(__spreadValues$h({},s[0]));for(let n=0;n<s.length;n++)s[n+1]&&i.push({point1:s[n],point2:s[n+1],pointIndex:n});return i}static translateSourceID(t){return(t===void 0||t===0||t==="0")&&(t=""),t}static isDifferSourceID(t,e){return t=this.translateSourceID(t),e=this.translateSourceID(e),`${t}`!=`${e}`}static isSameSourceID(t,e){return t=this.translateSourceID(t),e=this.translateSourceID(e),`${t}`==`${e}`}static getNextMarker(t,e=[],i){if((e==null?void 0:e.length)===0)return;let s=e.map((n,o)=>__spreadProps$e(__spreadValues$h({},n),{index:o}));if(typeof i=="number"&&i>0){const n=e[i];if(n&&t.every(o=>o.label!==n.value))return{label:n.value,index:i};s=[...s.slice(i,e.length),...s.slice(0,i)]}for(let n=0;n<s.length;n++)if(!t.some(o=>o.label===s[n].value))return{label:s[n].value,index:s[n].index}}static getCurrentMarkerIndex(t,e=[]){return e.findIndex(i=>t===i.value)}}CommonToolUtils$1.jsonParser=(r,t={})=>{try{return typeof r=="string"?JSON.parse(r):_.isObject(r)?r:t}catch(e){return t}};var __defProp$h=Object.defineProperty,__defProps$d=Object.defineProperties,__getOwnPropDescs$d=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$g=Object.getOwnPropertySymbols,__hasOwnProp$g=Object.prototype.hasOwnProperty,__propIsEnum$g=Object.prototype.propertyIsEnumerable,__defNormalProp$h=(r,t,e)=>t in r?__defProp$h(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$g=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$g.call(t,e)&&__defNormalProp$h(r,e,t[e]);if(__getOwnPropSymbols$g)for(var e of __getOwnPropSymbols$g(t))__propIsEnum$g.call(t,e)&&__defNormalProp$h(r,e,t[e]);return r},__spreadProps$d=(r,t)=>__defProps$d(r,__getOwnPropDescs$d(t)),EStatus$1;(function(r){r[r.Create=0]="Create",r[r.Active=1]="Active",r[r.Edit=1]="Edit",r[r.None=2]="None"})(EStatus$1||(EStatus$1={}));var EColor;(function(r){r.ActiveArea="#B3B8FF"})(EColor||(EColor={}));const SEGMENT_NUMBER$1=16,POINT_RADIUS$1=3,_LineToolUtils=class{static isInLine(r,t,e,i=3){const{length:s}=MathUtils.getFootOfPerpendicular(r,t,e);return s<i}};let LineToolUtils=_LineToolUtils;LineToolUtils.setSpecialEdgeStyle=r=>{r.lineCap="butt",r.setLineDash([10,10])},LineToolUtils.setReferenceCtx=r=>{r.lineCap="butt",r.setLineDash([6])},LineToolUtils.calcOptimalIntersection=(r,t,e,i,s)=>{let n,o=Infinity,a;if(r.find((h,d)=>{if(d===0)return;const u=_LineToolUtils.isInLine(t.pointA,h,r[d-1]),c=_LineToolUtils.isInLine(t.pointB,h,r[d-1]);return u&&c}))return{point:e};if(r.forEach((h,d)=>{if(d===0)return;const u={pointA:r[d-1],pointB:h},c=_LineToolUtils.lineIntersection(t,u);if(c&&t){const{onLine2:g,onLine1:p,x:f,y:v}=c,m=_LineToolUtils.calcDistance(e,c);if(_LineToolUtils.isOnLine(t.pointB.x,t.pointB.y,h.x,h.y,r[d-1].x,r[d-1].y)){if(_LineToolUtils.calcDistance(e,c)<i/s){const P=t.pointB,{footPoint:w,length:L}=MathUtils.getFootOfPerpendicular(P,u.pointA,u.pointB,!0);if(L!==void 0){const R=_LineToolUtils.calcDistance(u.pointA,w),C=_LineToolUtils.calcDistance(u.pointB,w);a={point:w,minDistance:L},L===Infinity&&(a.point=R>C?u.pointB:u.pointA)}}return}m<o&&g&&p&&(o=m,n={x:f,y:v})}}),n)return{point:n,minDistance:o};if(a)return a},LineToolUtils.lineIntersection=(r,t)=>{let e=!1,i=!1;const s=_LineToolUtils.getAxisDiff(r),n=_LineToolUtils.getAxisDiff(t),o=n.y*s.x-n.x*s.y;if(o===0)return!1;let a=r.pointA.y-t.pointA.y,l=r.pointA.x-t.pointA.x;const h=(t.pointB.x-t.pointA.x)*a-(t.pointB.y-t.pointA.y)*l,d=(r.pointB.x-r.pointA.x)*a-(r.pointB.y-r.pointA.y)*l;a=h/o,l=d/o,a>0&&a<1&&(e=!0),l>0&&l<1&&(i=!0);const u=r.pointA.x+a*(r.pointB.x-r.pointA.x),c=r.pointA.y+a*(r.pointB.y-r.pointA.y);return{x:u,y:c,onLine1:e,onLine2:i}},LineToolUtils.getAxisDiff=r=>({x:r.pointB.x-r.pointA.x,y:r.pointB.y-r.pointA.y}),LineToolUtils.calcDistance=(r,t)=>Math.sqrt(Math.pow(Math.abs(r.x-t.x),2)+Math.pow(Math.abs(r.y-t.y),2)),LineToolUtils.drawCurveLine=(r,t,e,i=!0,s=!1,n)=>{const o=createSmoothCurvePointsFromPointList(t,SEGMENT_NUMBER$1);r.save(),r.lineCap="round",r.lineJoin="round",r.strokeStyle=e.color,i&&(r.lineWidth=e.lineWidth),s&&_LineToolUtils.setReferenceCtx(r),t.forEach((a,l)=>{const h=a==null?void 0:a.specialEdge,d=o.splice(0,SEGMENT_NUMBER$1+1);r.save(),r.beginPath(),n===l&&(r.lineWidth=4),d.forEach(({x:u,y:c},g)=>{const p=g>0?"lineTo":"moveTo";h&&_LineToolUtils.setSpecialEdgeStyle(r),r[p](u,c)}),r.stroke(),r.restore()}),r.restore()},LineToolUtils.calcTwoPointDistance=(r,t)=>Math.sqrt(Math.pow(r.x-t.x,2)+Math.pow(r.y-t.y,2)),LineToolUtils.pointOverTarget=(r,t,e,i,s,n,o,a,l,h)=>{const d=r;if(!t)return r;if(e===EToolName.Polygon){const u=_LineToolUtils.getPolygonPointList(i,s);if(u.length===0||PolygonUtils.isInPolygon(r,u))return d;const g=u.concat(u[0]).map(x=>l(x)),p=l(t),f=l(r),v={pointA:p,pointB:f},m=_LineToolUtils.calcOptimalIntersection(g,v,p,o,a);if(m){const x=h(m==null?void 0:m.point);d.x=x.x,d.y=x.y}else return t;return d}if(e===EToolName.Rect){const{x:u,y:c,width:g,height:p}=i;return d.x=MathUtils.withinRange(d.x,[u,u+g]),d.y=MathUtils.withinRange(d.y,[c,c+p]),d}return d.x=MathUtils.withinRange(d.x,[0,n.width]),d.y=MathUtils.withinRange(d.y,[0,n.height]),d},LineToolUtils.getPolygonPointList=(r,t)=>{const{pointList:e}=r,{lineType:i}=t;return i===ELineTypes.Line?e:PolygonUtils.createSmoothCurvePoints(e.reduce((s,n)=>[...s,n.x,n.y],[]),.5,!0,20)},LineToolUtils.isOnLine=(r,t,e,i,s,n)=>Math.abs((a=>(i-t)/(e-r)*(a-r)+t)(s)-n)<1e-6&&s>=r&&s<=e,LineToolUtils.inArea=({top:r,left:t,right:e,bottom:i},{x:s,y:n})=>n>=r&&n<=i&&s>=t&&s<=e,LineToolUtils.getVHPoint=(r,t,e,i)=>{const s=_LineToolUtils.getAngle(r,e);return Math.abs(s)<45?__spreadProps$d(__spreadValues$g({},t),{y:i.y}):__spreadProps$d(__spreadValues$g({},t),{x:i.x})},LineToolUtils.getAngle=(r,t)=>{const e=t.x-r.x,i=t.y-r.y;return 360*Math.atan(i/e)/(2*Math.PI)};var __defProp$g=Object.defineProperty,__getOwnPropSymbols$f=Object.getOwnPropertySymbols,__hasOwnProp$f=Object.prototype.hasOwnProperty,__propIsEnum$f=Object.prototype.propertyIsEnumerable,__defNormalProp$g=(r,t,e)=>t in r?__defProp$g(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$f=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$f.call(t,e)&&__defNormalProp$g(r,e,t[e]);if(__getOwnPropSymbols$f)for(var e of __getOwnPropSymbols$f(t))__propIsEnum$f.call(t,e)&&__defNormalProp$g(r,e,t[e]);return r};class PolygonUtils{static getHoverPolygonID(t,e,i=3,s=ELineTypes.Line){let n="",o=Infinity;const a=AxisUtils.axisArea(t,i);return e.forEach(l=>{l.pointList&&a.forEach(h=>{const d=this.calcPolygonSize(l.pointList);this.isInPolygon(h,l.pointList,s)&&d<o&&(n=l.id,o=d)})}),n}static calcPolygonSize(t=[]){if((t==null?void 0:t.length)<=2)return 0;const e=t.length,i=t.reduce((s,n,o,a)=>{const l=a[(o+1)%e];return s+n.x*l.y-l.x*n.y},0);return Math.abs(i)/2}static isInPolygon(t,e,i=ELineTypes.Line){let s=0,n,o,a,l;e=[...e],i===ELineTypes.Curve&&(e=this.createSmoothCurvePoints(e.reduce((d,u)=>[...d,u.x,u.y],[]),.5,!0,20)),[a]=e;const h=e.length;for(n=1;n<=h;n++)l=e[n%h],t.x>Math.min(a.x,l.x)&&t.x<=Math.max(a.x,l.x)&&t.y<=Math.max(a.y,l.y)&&a.x!==l.x&&(o=(t.x-a.x)*(l.y-a.y)/(l.x-a.x)+a.y,(a.y===l.y||t.y<=o)&&s++),a=l;return s%2!=0}static createSmoothCurvePointsFromPointList(t,e=SEGMENT_NUMBER$2){return this.createSmoothCurvePoints(t.reduce((s,n)=>[...s,n.x,n.y],[]),.5,!1,e).map((s,n)=>{var o;const a=n/(SEGMENT_NUMBER$2+1),l=Math.floor(a),h=(o=t[l])!=null?o:{};return __spreadValues$f(l===a?__spreadValues$f({},h):{specialEdge:h.specialEdge},s)})}static createSmoothCurvePoints(t,e=.5,i=!1,s=SEGMENT_NUMBER$2){if(t.length<4)return t;const n=[],o=t.slice(0);let a,l,h,d,u,c,g,p,f,v,m,x,b;for(i?(o.unshift(t[t.length-1]),o.unshift(t[t.length-2]),o.unshift(t[t.length-1]),o.unshift(t[t.length-2]),o.push(t[0]),o.push(t[1])):(o.unshift(t[1]),o.unshift(t[0]),o.push(t[t.length-2]),o.push(t[t.length-1])),b=2;b<o.length-4;b+=2)for(h=(o[b+2]-o[b-2])*e,d=(o[b+4]-o[b-0])*e,u=(o[b+3]-o[b-1])*e,c=(o[b+5]-o[b+1])*e,x=0;x<=s;x++)m=x/s,g=2*Math.pow(m,3)-3*Math.pow(m,2)+1,p=-(2*Math.pow(m,3))+3*Math.pow(m,2),f=Math.pow(m,3)-2*Math.pow(m,2)+m,v=Math.pow(m,3)-Math.pow(m,2),a=g*o[b]+p*o[b+2]+f*h+v*d,l=g*o[b+1]+p*o[b+3]+f*u+v*c,n.push(a),n.push(l);const P=[];for(let w=0;w<n.length-1;w+=2)P.push({x:n[w],y:n[w+1]});if(i)for(let w=0;w<s+1;w++){const L=P.shift();P.push(L)}return P}static getPolygonByID(t,e){return t.find(i=>i.id===e)}static getPolygonByIDs(t,e){if(e&&(e==null?void 0:e.length)>0)return t.filter(i=>e.includes(i.id))}static getHoverEdgeIndex(t,e,i=ELineTypes.Line,s=3){let n=[...e];i===ELineTypes.Curve?n=this.createSmoothCurvePoints(e.reduce((l,h)=>[...l,h.x,h.y],[]),.5,!0,SEGMENT_NUMBER$2):i===ELineTypes.Line&&n.push(n[0]);let o=-1,a=s;for(let l=0;l<n.length-1;l++){const{length:h}=MathUtils.getFootOfPerpendicular(t,n[l],n[l+1]);h<a&&(o=l,a=h)}return o===-1?-1:i===ELineTypes.Curve?Math.floor(o/SEGMENT_NUMBER$2):o}static getClosestPoint(t,e,i=ELineTypes.Line,s=3,n){var o;let a=!1;const l=(o=n==null?void 0:n.isClose)!=null?o:!0;let h="",d=-1,u=Infinity,c=t;const g=20;let p=!1;return e.forEach(f=>{if(!p&&!!f.pointList)switch(i){case ELineTypes.Line:CommonToolUtils$1.findAllLine(f.pointList,l).forEach((m,x)=>{if(p)return;let{length:b,footPoint:P}=MathUtils.getFootOfPerpendicular(t,m.point1,m.point2);const w=MathUtils.getLineLength(m.point1,t),L=MathUtils.getLineLength(m.point2,t);w<s*2&&(P=m.point1,b=w,p=!0),L<s*2&&(P=m.point2,b=L,p=!0),b<u&&b<s&&(h=f.id,d=x,u=b,c=P,a=!0)});break;case ELineTypes.Curve:{const v=this.createSmoothCurvePoints(f.pointList.reduce((m,x)=>[...m,x.x,x.y],[]),.5,l,g);for(let m=0;m<v.length-1;m++){const{length:x,footPoint:b}=MathUtils.getFootOfPerpendicular(t,v[m],v[m+1]);x<u&&x<s&&(h=f.id,d=Math.floor(m/(g+1)),u=x,c=b,a=!0)}}break}}),{dropFoot:c,closestEdgeIndex:d,closestPolygonID:h,hasClosed:a}}static isPointListInPolygon(t,e,i=ELineTypes.Line){return t.every(s=>this.isInPolygon(s,e,i))}static isPointListOutSidePolygon(t,e,i=ELineTypes.Line){return t.some(s=>!this.isInPolygon(s,e,i))}static getPolygonArea(t){let e=0;for(let i=0,s=t.length;i<s;i++){const n=t[i].x,o=t[i===t.length-1?0:i+1].y,a=t[i===t.length-1?0:i+1].x,l=t[i].y;e+=n*o*.5,e-=a*l*.5}return Math.abs(e)}static updatePolygonByRotate(t,e=1,i){let s=1;return t===ERotateDirection.Anticlockwise&&(s=-1),s*=e,MathUtils.rotateRectPointList(s,i)}static deletePolygonLastPoint(t,e,i,s){return i===s.length-1?t:[...t,{x:e[0],y:e[1]}]}static concatBeginAndEnd(t){return t.length<1?t:[...t,t[0]]}static segmentPolygonByPolygon(t,e){var i,s;try{let n=turf.polygon([[...PolygonUtils.concatBeginAndEnd(t.map(a=>[a.x,a.y]))]]);return e.forEach(a=>{const l=turf.polygon([[...PolygonUtils.concatBeginAndEnd(a.pointList.map(d=>[d.x,d.y]))]]),h=turf.difference(n,l);h&&(n=h)}),((s=(i=n==null?void 0:n.geometry)==null?void 0:i.coordinates.map(a=>{var l;return((l=n==null?void 0:n.geometry)==null?void 0:l.type)==="MultiPolygon"?a[0].reduce(PolygonUtils.deletePolygonLastPoint,[]):a.reduce(PolygonUtils.deletePolygonLastPoint,[])}))!=null?s:[]).reduce((a,l)=>{const h=l.length,d=l.filter((u,c)=>{const g=(c+1)%h;return!AxisUtils.getIsInScope(u,l[g],1)});return d.length<3?a:[...a,d]},[])}catch(n){console.error(n)}}static getPolygonPointList(t,e){const i=e.find(s=>s.id===t);return i&&i.pointList&&i.pointList.length>0?i.pointList:[]}static getWrapPolygonIndex(t,e){return e.findIndex(i=>PolygonUtils.isPointListInPolygon(t,i.pointList))}static clipPolygonFromWrapPolygon(t,e){const i=PolygonUtils.isPolygonClosewise(e),s=PolygonUtils.isPolygonClosewise(t),n=PolygonUtils.getClosePointDistanceFromPolygon(t[0],e),o=e[n];let a=[...e.slice(0,n),o,...t,t[0],...e.slice(n,e.length)];return i===s&&(a=[...e.slice(0,n),o,t[0],...t.reverse(),...e.slice(n,e.length)]),a}static isPolygonClosewise(t){const e=t.length;let i,s,n,o=0,a;if(e<3)return 0;for(i=0;i<e;i++)s=(i+1)%e,n=(i+2)%e,a=(t[s].x-t[i].x)*(t[n].y-t[s].y),a-=(t[s].y-t[i].y)*(t[n].x-t[s].x),a<0?o--:a>0&&o++;return o>0?1:o<0?-1:0}static getClosePointDistanceFromPolygon(t,e){let i=Number.MAX_SAFE_INTEGER,s=-1;return e.forEach((n,o)=>{const a=LineToolUtils.calcDistance(t,n);a<i&&(i=a,s=o)}),s}static combinePolygonWithPolygon(t,e){var i,s;try{const n=turf.polygon([[...PolygonUtils.concatBeginAndEnd(t.pointList.map(d=>[d.x,d.y]))]]),o=turf.polygon([[...PolygonUtils.concatBeginAndEnd(e.pointList.map(d=>[d.x,d.y]))]]),a=turf.union(n,o),l=[],h=t;if(((s=(i=a==null?void 0:a.geometry)==null?void 0:i.coordinates)==null?void 0:s.length)===1){l.push(e.id);const d=a==null?void 0:a.geometry.coordinates.map(u=>{var c;return((c=a==null?void 0:a.geometry)==null?void 0:c.type)==="MultiPolygon"?u[0].reduce(PolygonUtils.deletePolygonLastPoint,[]):u.reduce(PolygonUtils.deletePolygonLastPoint,[])})[0];h.pointList=d}return{newPolygon:h,unionList:l}}catch(n){console.error(n)}}}var __defProp$f=Object.defineProperty,__defProps$c=Object.defineProperties,__getOwnPropDescs$c=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$e=Object.getOwnPropertySymbols,__hasOwnProp$e=Object.prototype.hasOwnProperty,__propIsEnum$e=Object.prototype.propertyIsEnumerable,__defNormalProp$f=(r,t,e)=>t in r?__defProp$f(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$e=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$e.call(t,e)&&__defNormalProp$f(r,e,t[e]);if(__getOwnPropSymbols$e)for(var e of __getOwnPropSymbols$e(t))__propIsEnum$e.call(t,e)&&__defNormalProp$f(r,e,t[e]);return r},__spreadProps$c=(r,t)=>__defProps$c(r,__getOwnPropDescs$c(t));class AxisUtils{static getOffsetCoordinate(t,e,i){return{x:t.x*i+e.x,y:t.y*i+e.y}}static changeDrawOutsideTarget(t,e,i,s,n,o){return typeof s=="boolean"&&!s&&(n&&o?(t.x-e.x>(n.x+n.width)*o&&(t.x=(n.x+n.width)*o+e.x),t.x-e.x<n.x*o&&(t.x=n.x*o+e.x),t.y-e.y>(n.y+n.height)*o&&(t.y=(n.y+n.height)*o+e.y),t.y-e.y<n.y*o&&(t.y=n.y*o+e.y)):(t.x-e.x>i.width&&(t.x=i.width+e.x),t.x-e.x<0&&(t.x=e.x),t.y-e.y>i.height&&(t.y=i.height+e.y),t.y-e.y<0&&(t.y=e.y))),t}static changeCoordinateByRotate(t,e,i){const{width:s,height:n}=i,{x:o,y:a}=t;switch(e%360){case 90:return{x:n-a,y:o};case 180:return{x:s-o,y:n-a};case 270:return{x:a,y:s-o};default:return t}}static changeRectByZoom(t,e,i={x:0,y:0}){return __spreadProps$c(__spreadValues$e({},t),{x:t.x*e+i.x,y:t.y*e+i.y,width:t.width*e,height:t.height*e})}static changePointByZoom(t,e,i={x:0,y:0}){return __spreadProps$c(__spreadValues$e({},t),{x:t.x*e+i.x,y:t.y*e+i.y})}static changePointListByZoom(t,e,i={x:0,y:0}){return t.map(s=>this.changePointByZoom(s,e,i))}static axisArea(t,e=3){const{x:i,y:s}=t,n=[];for(let o=i-e;o<i+e;o+=e/3)for(let a=s-e;a<s+e;a+=e/3)n.push({x:o,y:a});return n}static getOriginCoordinateWithOffsetCoordinate(t,e=1,i={x:0,y:0}){return{x:(t.x-i.x)/e,y:(t.y-i.y)/e}}static returnClosePointIndex(t,e,i=3){let s=-1;for(let n=0;n<e.length;n++){const o=e[n];this.getIsInScope(t,o,i)&&(s=n)}return s}static getIsInScope(t,e,i){return Math.abs(t.x-e.x)<i&&Math.abs(t.y-e.y)<i}}class CoordinateUtils{constructor(t){this.currentPos=t.currentPos,this.zoom=t.zoom,this.basicImgInfo=t.basicImgInfo,this.dependToolName=""}get isDependPolygon(){return this.dependToolName===EToolName.Polygon}get isDependRect(){return this.dependToolName===EToolName.Rect}get isDependOriginalImage(){return this.dependToolName===""}getAbsCoord(t){return{x:(t.x-this.currentPos.x)/this.zoom,y:(t.y-this.currentPos.y)/this.zoom}}getRenderCoord(t){return{x:t.x*this.zoom+this.currentPos.x,y:t.y*this.zoom+this.currentPos.y}}coordInsideRect(t,e){const{x:i,y:s,width:n,height:o}=e;return{x:MathUtils.withinRange(t.x,[i,i+n]),y:MathUtils.withinRange(t.y,[s,s+o])}}getPolygonPointList(t,e){return t===ELineTypes.Curve?PolygonUtils.createSmoothCurvePointsFromPointList(e):e}getIntersection(t,e,i){const s=this.getRenderCoord(e),n=this.getRenderCoord(t),o={pointA:s,pointB:n};return LineToolUtils.calcOptimalIntersection(i,o,s,POINT_RADIUS$1,this.zoom)}coordInsidePolygon(t,e,i,s){const{pointList:n}=i,o=s==null?void 0:s.lineType;if(n.length===0)return t;const a=this.getPolygonPointList(o,n);if(PolygonUtils.isInPolygon(t,a))return t;const h=a.concat(a[0]).map(u=>this.getRenderCoord(u)),d=this.getIntersection(t,e,h);return d?this.getAbsCoord(d==null?void 0:d.point):t}coordInsideImage(t){return this.coordInsideRect(t,__spreadProps$c(__spreadValues$e({},this.basicImgInfo),{x:0,y:0}))}getNextCoordByDependTool(t,e){if(this.isDependRect)return this.coordInsideRect(t,this.basicResult);if(this.isDependPolygon)return this.coordInsidePolygon(t,e,this.basicResult,this.dependToolConfig);if(this.isDependOriginalImage)return this.coordInsideImage(t)}setDependInfo(t,e){this.dependToolName=t!=null?t:"",this.dependToolConfig=t?e:void 0}setBasicImgInfo(t){this.basicImgInfo=t}setBasicResult(t){this.basicResult=t}setZoomAndCurrentPos(t,e){this.zoom=t,this.currentPos=e}isCoordInsideTarget(t){if(this.isDependPolygon)return this.isInBasicPolygon(t);if(this.isDependRect){const{x:e,y:i,width:s,height:n}=this.basicResult,o=[e,e+s],a=[i,i+n];return MathUtils.isInRange(t.x,o)&&MathUtils.isInRange(t.y,a)}return MathUtils.isInRange(t.x,[0,this.basicImgInfo.width])&&MathUtils.isInRange(t.y,[0,this.basicImgInfo.height])}isInBasicPolygon(t){var e,i;return PolygonUtils.isInPolygon(t,((e=this.basicResult)==null?void 0:e.pointList)||[],(i=this.dependToolConfig)==null?void 0:i.lineType)}}var __defProp$e=Object.defineProperty,__defProps$b=Object.defineProperties,__getOwnPropDescs$b=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$d=Object.getOwnPropertySymbols,__hasOwnProp$d=Object.prototype.hasOwnProperty,__propIsEnum$d=Object.prototype.propertyIsEnumerable,__defNormalProp$e=(r,t,e)=>t in r?__defProp$e(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$d=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$d.call(t,e)&&__defNormalProp$e(r,e,t[e]);if(__getOwnPropSymbols$d)for(var e of __getOwnPropSymbols$d(t))__propIsEnum$d.call(t,e)&&__defNormalProp$e(r,e,t[e]);return r},__spreadProps$b=(r,t)=>__defProps$b(r,__getOwnPropDescs$b(t));class RectUtils{static composeResult(t,e,i,s,n){try{const o=JSON.parse(t),a=CommonToolUtils$1.getCurrentStepInfo(e,s),{dataSourceStep:l}=a,h=`step_${a.step}`;if(Object.assign(o,n),o[h]){const d=o[h];return d.result?(d.result=i,JSON.stringify(o)):JSON.stringify(__spreadProps$b(__spreadValues$d({},o),{[h]:__spreadProps$b(__spreadValues$d({},o[h]),{result:i})}))}return JSON.stringify(__spreadProps$b(__spreadValues$d({},o),{[h]:{dataSourceStep:l,toolName:a.tool,result:i}}))}catch(o){return t}}static changeCoordinateByRotate(t,e,i){const{x:s,y:n,width:o,height:a}=t,l=AxisUtils.changeCoordinateByRotate({x:s,y:n},e,i);switch(e%360){case 90:return __spreadProps$b(__spreadValues$d({},t),{x:l.x-a,y:l.y,width:a,height:o});case 180:return __spreadProps$b(__spreadValues$d({},t),{x:l.x-o,y:l.y-a});case 270:return __spreadProps$b(__spreadValues$d({},t),{x:l.x,y:l.y-o,width:a,height:o});default:return t}}static translateRect2Points(t){const{x:e,y:i,width:s,height:n}=t;return[{x:e,y:i},{x:e+s,y:i},{x:e+s,y:i+n},{x:e,y:i+n}]}static translatePoints2Rect(t,e){if(t.length!==4)return;const{x:i,y:s}=t[0],n=t[1].x-t[0].x,o=t[2].y-t[1].y;return __spreadProps$b(__spreadValues$d({},e),{x:i,y:s,width:n,height:o})}static getRectPointList(t,e=1){return[{x:t.x*e,y:t.y*e},{x:(t.x+t.width)*e,y:t.y*e},{x:(t.x+t.width)*e,y:(t.y+t.height)*e},{x:t.x*e,y:(t.y+t.height)*e}]}static getRectEdgeList(t,e=1){const i=this.getRectPointList(t,e),s=i.length;return i.map((n,o)=>({begin:n,end:i[(o+1)%s]}))}static isInRect(t,e,i=0,s=1){return t.x>=e.x*s-i&&t.x<=(e.x+e.width)*s+i&&t.y>=e.y*s-i&&t.y<=(e.y+e.height)*s+i}static getRectUnderZoom(t,e=1){const{x:i,y:s,width:n,height:o}=t;return __spreadProps$b(__spreadValues$d({},t),{x:i*e,y:s*e,width:n*e,height:o*e})}static isRectNotInPolygon(t,e){return this.getRectPointList(t).some(s=>!isInPolygon(s,e))}}var EKeyCode;(function(r){r[r.A=65]="A",r[r.B=66]="B",r[r.C=67]="C",r[r.D=68]="D",r[r.E=69]="E",r[r.F=70]="F",r[r.G=71]="G",r[r.H=72]="H",r[r.L=76]="L",r[r.R=82]="R",r[r.Z=90]="Z",r[r.W=87]="W",r[r.X=88]="X",r[r.Y=89]="Y",r[r.S=83]="S",r[r.Q=81]="Q",r[r.Delete=46]="Delete",r[r.F11=122]="F11",r[r.Space=32]="Space",r[r.Esc=27]="Esc",r[r.Left=37]="Left",r[r.Up=38]="Up",r[r.Right=39]="Right",r[r.Down=40]="Down",r[r.Enter=13]="Enter",r[r.Ctrl=17]="Ctrl",r[r.Alt=18]="Alt",r[r.Shift=16]="Shift",r[r.Tab=9]="Tab",r[r.BackSpace=8]="BackSpace"})(EKeyCode||(EKeyCode={}));var EKeyCode$1=EKeyCode,keyCode=Object.freeze({__proto__:null,default:EKeyCode$1}),EMessage;(function(r){r.NoRotateNotice="noRotateNotice",r.RectErrorSizeNotice="rectErrorSizeNotice",r.TextCheckNumberErrorNotice="textCheckNumberErrorNotice",r.TextCheckEnglishErrorNotice="textCheckEnglishErrorNotice",r.TextCheckCustomErrorNotice="textCheckCustomErrorNotice",r.UpperLimitErrorNotice="UpperLimitErrorNotice",r.LowerLimitErrorNotice="LowerLimitErrorNotice",r.InvalidImage="InvalidImage",r.DisableDelete="DisableDelete",r.ClearPartialData="ClearPartialData",r.MarkerFinish="MarkerFinish",r.LowerLimitPoint="LowerLimitPoint",r.NoRotateInDependence="noRotateInDependence",r.UnableToReannotation="unableToReannotation",r.ForbiddenCreationOutsideBoundary="ForbiddenCreationOutsideBoundary",r.SuccessfulEdgeAdsorption="SuccessfulEdgeAdsorption"})(EMessage||(EMessage={}));const message$1={[EMessage.NoRotateNotice]:"This Image contains data and cannot be rotated",[EMessage.RectErrorSizeNotice]:"The drawing frame size is smaller than the minimum drawing size",[EMessage.TextCheckNumberErrorNotice]:"Please enter in number-only format",[EMessage.TextCheckEnglishErrorNotice]:"Please enter in English only format",[EMessage.TextCheckCustomErrorNotice]:"Please enter in the required format",[EMessage.UpperLimitErrorNotice]:"The number of vertices is not more than",[EMessage.LowerLimitErrorNotice]:"The number of vertices is not less than",[EMessage.InvalidImage]:"Invalid image, please skip this image",[EMessage.DisableDelete]:"Disable delete",[EMessage.ClearPartialData]:"Clear partial data",[EMessage.MarkerFinish]:"ListAnnotation is finished",[EMessage.LowerLimitPoint]:"The maximum number of points has been reached",[EMessage.NoRotateInDependence]:"Disallow rotation in dependent cases",[EMessage.UnableToReannotation]:"Unabled to reannotation",[EMessage.ForbiddenCreationOutsideBoundary]:"Fobid creation outside boundary",[EMessage.SuccessfulEdgeAdsorption]:"Successful edge adsorption"},message={[EMessage.NoRotateNotice]:"\u672C\u56FE\u542B\u6709\u6570\u636E\uFF0C\u65E0\u6CD5\u8FDB\u884C\u65CB\u8F6C",[EMessage.RectErrorSizeNotice]:"\u7ED8\u5236\u6846\u5C3A\u5BF8\u5C0F\u4E8E\u6700\u5C0F\u7ED8\u5236\u5C3A\u5BF8",[EMessage.TextCheckNumberErrorNotice]:"\u8BF7\u6309\u4EC5\u6570\u5B57\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.TextCheckEnglishErrorNotice]:"\u8BF7\u6309\u4EC5\u82F1\u6587\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.TextCheckCustomErrorNotice]:"\u8BF7\u6309\u8981\u6C42\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.UpperLimitErrorNotice]:"\u9876\u70B9\u6570\u4E0D\u591A\u4E8E",[EMessage.LowerLimitErrorNotice]:"\u9876\u70B9\u6570\u4E0D\u5C11\u4E8E",[EMessage.InvalidImage]:"\u65E0\u6548\u56FE\u7247\uFF0C\u8BF7\u8DF3\u8FC7\u6B64\u56FE",[EMessage.DisableDelete]:"\u8BE5\u6570\u636E\u7981\u6B62\u5220\u9664",[EMessage.ClearPartialData]:"\u5B58\u5728\u90E8\u5206\u6570\u636E\u65E0\u6CD5\u6E05\u9664",[EMessage.MarkerFinish]:"\u5217\u8868\u6807\u6CE8\u5DF2\u5B8C\u6210",[EMessage.LowerLimitPoint]:"\u5DF2\u5230\u8FBE\u6807\u70B9\u6570\u91CF\u4E0A\u9650",[EMessage.NoRotateInDependence]:"\u4F9D\u8D56\u60C5\u51B5\u4E0B\u65E0\u6CD5\u8FDB\u884C\u65CB\u8F6C",[EMessage.UnableToReannotation]:"\u65E0\u6CD5\u8FDB\u884C\u7EED\u6807\u64CD\u4F5C",[EMessage.ForbiddenCreationOutsideBoundary]:"\u8FB9\u754C\u5916\u7981\u6B62\u521B\u5EFA",[EMessage.SuccessfulEdgeAdsorption]:"\u8FB9\u7F18\u5438\u9644\u6210\u529F"};class Locale{}Locale.getMessagesByLocale=(r,t)=>{switch(t){case ELang.US:return message$1[r];case ELang.Zh:default:return message[r]}};var canvasEdit0='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ccc"/></g></g></svg>',canvasEdit1='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ff2323"/></g></g></svg>',canvasEdit2='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ffe232"/></g></g></svg>',canvasEdit3='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#01ff30"/></g></g></svg>',canvasEdit4='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#00ffea"/></g></g></svg>',canvasEdit5='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#0282fa"/></g></g></svg>',canvasEdit6='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#800cf9"/></g></g></svg>',canvasEdit7='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ff88f7"/></g></g></svg>',canvasEdit8='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#994217"/></g></g></svg>',baseEditLan='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#1f0bf9"/></g></g></svg>',baseEditQing='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#3fe"/></g></g></svg>',baseEditLv='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#33fe33"/></g></g></svg>',baseEditHuang='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#fdff37"/></g></g></svg>',baseEditFen='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#f70efa"/></g></g></svg>',INVALID_ICON='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#f33"/></g></g></svg>';const NULL_ICON=canvasEdit0,HEADER_HEIGHT=61,TAB_HEIGHT=80,SEARCH_HEIGHT=62,PADDING=20,TABLE_ROW_HEIGHT=55,PAGINATION_HEIGHT=55,TIPS_HEIGHT=40,FOOTER_HEIGHT=80,SIDERBAR_WIDTH=240,EDIT_STEP_WIDTH=320,THEME_COLOR="rgba(102, 111, 255, 1)",COLORS_ARRAY=["rgba(128, 12, 249, 1)","rgba(0, 255, 48, 1)","rgba(255, 136, 247, 1)","rgba(255, 226, 50, 1)","rgba(153, 66, 23, 1)","rgba(2, 130, 250, 1)","rgba(255, 35, 35, 1)","rgba(0, 255, 234, 1)"],ICON_ARRAY=[canvasEdit0,canvasEdit6,canvasEdit3,canvasEdit7,canvasEdit2,canvasEdit8,canvasEdit5,canvasEdit1,canvasEdit4],BASE_ICON={1:baseEditLan,3:baseEditQing,5:baseEditLv,7:baseEditHuang,9:baseEditFen},INVALID_COLOR="rgba(255, 51, 51, 1)",NULL_COLOR="rgba(204, 204, 204, 1)",FILTER_TOOL_COLOR={[EFilterToolOperation.lc]:"rgba(153, 51, 255, 1)",[EFilterToolOperation.rc]:"rgba(51, 153, 255, 1)",[EFilterToolOperation.clc]:"rgba(46, 230, 46, 1)",[EFilterToolOperation.crc]:"rgba(255, 51, 51, 1)"};var style=Object.freeze({__proto__:null,HEADER_HEIGHT,TAB_HEIGHT,SEARCH_HEIGHT,PADDING,TABLE_ROW_HEIGHT,PAGINATION_HEIGHT,TIPS_HEIGHT,FOOTER_HEIGHT,SIDERBAR_WIDTH,EDIT_STEP_WIDTH,THEME_COLOR,COLORS_ARRAY,ICON_ARRAY,BASE_ICON,INVALID_COLOR,NULL_COLOR,NULL_ICON,INVALID_ICON,FILTER_TOOL_COLOR}),__defProp$d=Object.defineProperty,__defProps$a=Object.defineProperties,__getOwnPropDescs$a=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$c=Object.getOwnPropertySymbols,__hasOwnProp$c=Object.prototype.hasOwnProperty,__propIsEnum$c=Object.prototype.propertyIsEnumerable,__defNormalProp$d=(r,t,e)=>t in r?__defProp$d(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$c=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$c.call(t,e)&&__defNormalProp$d(r,e,t[e]);if(__getOwnPropSymbols$c)for(var e of __getOwnPropSymbols$c(t))__propIsEnum$c.call(t,e)&&__defNormalProp$d(r,e,t[e]);return r},__spreadProps$a=(r,t)=>__defProps$a(r,__getOwnPropDescs$a(t));const REGEXP_NUMBER="^[0-9]+$",REGEXP_ENGLISH="^[A-Za-z]+$";class AttributeUtils{static getAttributeIcon(t,e,i=!0){var s;const n=e.findIndex(l=>l.value===t);let o=(s=ICON_ARRAY[n%ICON_ARRAY.length])!=null?s:NULL_ICON;i||(o=INVALID_ICON),o="";const a=new Image;return a.src=o,a}static checkString(t,e){let i="";switch(t){case ETextType.Order:case ETextType.NumberOnly:i=REGEXP_NUMBER;break;case ETextType.EnglishOnly:i=REGEXP_ENGLISH;break;case ETextType.CustomFormat:i=e;break}return i}static checkTextAttibute(t,e){if(t===void 0||t==="")return!0;try{return new RegExp(e).test(t)}catch(i){return!1}}static getAttributeShowText(t,e=[]){var i,s;try{const n=e.findIndex(o=>o.value===t);return(s=(i=e[n])==null?void 0:i.key)!=null?s:t}catch(n){return t}}static getAttributeIndex(t,e){try{const i=e.findIndex(s=>s.value===t);return i>=8?i%8:i}catch(i){return-1}}static getAttributeColor(t,e){try{const i=this.getAttributeIndex(t,e);return i===-1?NULL_COLOR:COLORS_ARRAY[i%COLORS_ARRAY.length]}catch(i){return NULL_COLOR}}static getTextAttribute(t,e){try{if(e===ETextType.Order){const i=t.map(n=>parseInt(n.textAttribute,10)).filter(n=>_.isNumber(n)&&n<Number.MAX_SAFE_INTEGER&&n>=0);return i.sort((n,o)=>n-o),`${(i.pop()||0)+1}`}return""}catch(i){return""}}static textChange(t,e,i){return i.map(s=>s.id===e?__spreadProps$a(__spreadValues$c({},s),{textAttribute:t}):s)}static getErrorNotice(t,e){switch(t){case ETextType.Order:case ETextType.NumberOnly:return Locale.getMessagesByLocale(EMessage.TextCheckNumberErrorNotice,e);case ETextType.EnglishOnly:return Locale.getMessagesByLocale(EMessage.TextCheckEnglishErrorNotice,e);case ETextType.CustomFormat:return Locale.getMessagesByLocale(EMessage.TextCheckCustomErrorNotice,e);default:return""}}static textAttributeValidate(t,e,i){try{return new RegExp(this.checkString(t,e)).test(i)}catch(s){}}static checkTextAttribute(t,e,i,s){let n=!1;return i.forEach(o=>{(o==null?void 0:o.textAttribute)===void 0||(o==null?void 0:o.textAttribute)===""||(s?o.id===s:!0)&&!this.textAttributeValidate(t,e,o.textAttribute)&&(n=!0)}),!!n}static changeTextAttributeInLog(t,e){return t==null?void 0:t.map(i=>i==null?void 0:i.map(s=>{if((e==null?void 0:e.findIndex(n=>(n==null?void 0:n.id)===(s==null?void 0:s.id)))>-1){const n=e==null?void 0:e.find(o=>(o==null?void 0:o.id)===(s==null?void 0:s.id));return __spreadProps$a(__spreadValues$c({},s),{textAttribute:n==null?void 0:n.textAttribute})}return s}))}static getTextIconSvg(t="",e,i=!1,s){if(i===!0){const n=(e==null?void 0:e.findIndex(o=>(o==null?void 0:o.value)===t))%COLORS_ARRAY.length+1;return ICON_ARRAY[n]}return s}static getAttributeByKeycode(t,e){var i;let s;return MathUtils.isInRange(t,[48,57])&&(s=t-48),MathUtils.isInRange(t,[96,105])&&(s=t-96),s===0?"":s?(i=e[s-1])==null?void 0:i.value:void 0}}class CanvasUtils{static getMousePositionOnCanvasFromEvent(t,e){if(e&&t){const i=e.getBoundingClientRect();return{x:t.clientX-i.left,y:t.clientY-i.top}}return null}static getClientRect(t){if(t){const e=t.getBoundingClientRect();return{x:e.left,y:e.top,width:e.width,height:e.height}}return null}static getSize(t){if(t){const e=t.getBoundingClientRect();return{width:e.width,height:e.height}}return null}static inViewPort(t,e){return t?MathUtils.isInRange(t.x,[e.left,e.right])&&MathUtils.isInRange(t.y,[e.top,e.bottom]):!1}}CanvasUtils.getViewPort=(r,t,e)=>{const{width:i,height:s}=r,{x:n,y:o}=t,a=(0-o)/e,l=(0-n)/e,h=a+s/e,d=l+i/e;return{top:a,bottom:h,left:l,right:d}},CanvasUtils.getPixelRatio=r=>{if(!r||!window)return 1;const t=r.backingStorePixelRatio||r.webkitBackingStorePixelRatio||r.mozBackingStorePixelRatio||r.msBackingStorePixelRatio||r.oBackingStorePixelRatio||r.backingStorePixelRatio||1;return(window.devicePixelRatio||1)/t};class UnitUtils{static deg2rad(t){return t*Math.PI/180}static rad2deg(t){return t*180/Math.PI}}var __defProp$c=Object.defineProperty,__defProps$9=Object.defineProperties,__getOwnPropDescs$9=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$b=Object.getOwnPropertySymbols,__hasOwnProp$b=Object.prototype.hasOwnProperty,__propIsEnum$b=Object.prototype.propertyIsEnumerable,__defNormalProp$c=(r,t,e)=>t in r?__defProp$c(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$b=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$b.call(t,e)&&__defNormalProp$c(r,e,t[e]);if(__getOwnPropSymbols$b)for(var e of __getOwnPropSymbols$b(t))__propIsEnum$b.call(t,e)&&__defNormalProp$c(r,e,t[e]);return r},__spreadProps$9=(r,t)=>__defProps$9(r,__getOwnPropDescs$9(t));const DEFAULT_ZOOM=1,DEFAULT_CURRENT_POS={x:0,y:0},DEFAULT_ROTATE=0,DEFAULT_COLOR="";class DrawUtils{static drawLine(t,e,i,s={}){const n=t.getContext("2d"),{color:o=DEFAULT_COLOR,thickness:a=1,lineCap:l="round"}=s;n.save(),n.strokeStyle=o,n.lineWidth=a,n.lineCap=l,n.beginPath(),n.moveTo(e.x,e.y),n.lineTo(i.x+1,i.y+1),n.stroke(),n.restore()}static drawRect(t,e,i={}){const s=t.getContext("2d"),{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",hiddenText:l=!1,lineDash:h}=i;if(s.save(),s.strokeStyle=n,s.lineWidth=o,s.lineCap=a,Array.isArray(h)&&s.setLineDash(h),s.fillStyle=n,s.strokeRect(e.x,e.y,e.width,e.height),l===!1){let d="";if(e.attribute&&(d=`${d} ${e.attribute}`),this.drawText(t,{x:e.x,y:e.y-5},d),e.textAttribute){const c=`${~~e.width} * ${~~e.height}`.length*7,g=0,p=Math.max(20,e.width-c);this.drawText(t,{x:e.x,y:e.y+e.height+20+g},e.textAttribute,{textMaxWidth:p})}}s.restore()}static drawRectWithFill(t,e,i={}){const s=t.getContext("2d"),{color:n=DEFAULT_COLOR}=i;s.save(),s.fillStyle=n,s.fillRect(e.x,e.y,e.width,e.height),s.restore()}static drawTagByDom(t,e,i){const s=t;if(!((e==null?void 0:e.length)>0))return;const n=document.createElement("div");return n.innerHTML=e,n.setAttribute("id",i),s==null||s.appendChild(n),n}static drawTag(t,e){var i;const s=t==null?void 0:t.parentNode,n=window.self.document.getElementById("tagToolTag");if(n&&s&&s.contains(n)&&(s==null||s.removeChild(n)),!((e==null?void 0:e.length)>0))return;const o=document.createElement("div");return o.innerHTML=(i=e.reduce((a,l)=>`${a}${l.keyName}: ${l.value.join(" \u3001 ")}
|
|
7
|
-
`,""))!=null?i:"",o.setAttribute("id","tagToolTag"),s==null||s.appendChild(o),o}static drawLineWithPointList(t,e,i={}){if(e.length<2)return;const s=t.getContext("2d"),{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",lineType:l=ELineTypes.Line,lineDash:h,hoverEdgeIndex:
|
|
8
|
-
`);for(let h=0;h<l.length;h++){const d=l[h].split("");let u="";for(let c=0;c<d.length;c++){const g=u+d[c],f=a.measureText(g).width;n||(n=300),f>n&&c>0?(a.fillText(u,i,s),u=d[c],s+=o):u=g}a.fillText(u,i,s),s+=o}}static drawArrow(t,e,i,s={}){const{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",theta:l=30,headLen:h=10}=s,d=Math.atan2(e.y-i.y,e.x-i.x)*180/Math.PI,u=(d+l)*Math.PI/180,c=(d-l)*Math.PI/180,g=h*Math.cos(u),p=h*Math.sin(u),f=h*Math.cos(c),v=h*Math.sin(c);t.save(),t.strokeStyle=n,t.lineWidth=o,t.lineCap=a,t.beginPath(),t.moveTo(i.x+g,i.y+p),t.lineTo(i.x,i.y),t.lineTo(i.x+f,i.y+v),t.stroke(),t.restore()}static drawArrowByCanvas(t,e,i,s={}){const n=t.getContext("2d");this.drawArrow(n,e,i,s)}}DrawUtils.drawImg=(r,t,e={})=>{const i=r.getContext("2d"),{zoom:s=DEFAULT_ZOOM,currentPos:n=DEFAULT_CURRENT_POS,rotate:o=DEFAULT_ROTATE,imgAttribute:a}=e;switch(i.save(),o){case 0:i.translate(n.x,n.y);break;case 90:i.translate(n.x+t.height*s,n.y),i.rotate(90*Math.PI/180);break;case 180:i.translate(n.x+t.width*s,n.y+t.height*s),i.rotate(Math.PI);break;case 270:i.translate(n.x,n.y+t.width*s),i.rotate(270*Math.PI/180);break;default:i.translate(n.x,n.y);break}if(a){const{contrast:l,saturation:h,brightness:d}=a;i.filter=`saturate(${h+100}%) contrast(${l+100}%) brightness(${d+100}%)`}i.drawImage(t,0,0,t.width*s,t.height*s),i.restore()};class MarkerUtils{static getMarkerShowText(t,e=[]){return AttributeUtils.getAttributeShowText(t,e)}}function uuid(r=8,t=62){const e="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""),i=[];let s;if(t=t||e.length,r)for(s=0;s<r;s++)i[s]=e[0|Math.random()*t];else{let n;for(i[8]=i[13]=i[18]=i[23]="-",i[14]="4",s=0;s<36;s++)i[s]||(n=0|Math.random()*16,i[s]=e[s===19?n&3|8:n])}return i.join("")}const rectToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,drawOutsideTarget:!1,copyBackwardResult:!1,minWidth:1,minHeight:1,isShowOrder:!1,filterData:["valid","invalid"],attributeConfigurable:!1,attributeList:[],textConfigurable:!1,textCheckType:0,customFormat:""},tagToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,inputList:[{key:"\u7C7B\u522B1",value:"class1",isMulti:!1,subSelected:[{key:"\u9009\u98791",value:"option1",isDefault:!1},{key:"\u9009\u98792",value:"option1-2",isDefault:!1}]},{key:"\u7C7B\u522B2",value:"class-AH",isMulti:!0,subSelected:[{key:"\u9009\u98792-1",value:"option2-1",isDefault:!1},{key:"\u9009\u98792-2",value:"option2-2",isDefault:!1},{key:"\u9009\u98792-3",value:"option2-3",isDefault:!1}]},{key:"\u7C7B\u522B3",value:"class-0P",isMulti:!1,subSelected:[{key:"\u9009\u98793-1",value:"option3-1",isMulti:!1},{key:"\u9009\u98793-2",value:"option3-2",isDefault:!1},{key:"\u9009\u98793-3",value:"option3-3",isDefault:!1}]}]},lineToolConfig={lineType:0,lineColor:0,edgeAdsorption:!1,outOfTarget:!0,copyBackwardResult:!1,isShowOrder:!1,attributeConfigurable:!1,attributeList:[{key:"\u7C7B\u522B1",value:"\u7C7B\u522B1"},{key:"\u7C7B\u522Bao",value:"class-ao"},{key:"\u7C7B\u522BM1",value:"class-M1"},{key:"\u7C7B\u522BCm",value:"class-Cm"},{key:"\u7C7B\u522Bc3",value:"class-c3"},{key:"\u7C7B\u522Ba0",value:"class-a0"},{key:"\u7C7B\u522Bu7",value:"class-u7"},{key:"\u7C7B\u522BZb",value:"class-Zb"},{key:"\u7C7B\u522Bzi",value:"class-zi"}],textConfigurable:!1,textCheckType:2,customFormat:"",showConfirm:!1,lowerLimitPointNum:2,upperLimitPointNum:"",preReferenceStep:0,skipWhileNoDependencies:!1,filterData:["valid","invalid"]},textToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,enableTextRecognition:!1,recognitionMode:"general",configList:[{label:"\u6587\u672C",key:"text",required:!1,default:"",maxLength:1e3}],filterData:["valid","invalid"]},polygonConfig={lineType:0,lineColor:0,lowerLimitPointNum:3,edgeAdsorption:!1,drawOutsideTarget:!1,copyBackwardResult:!1,isShowOrder:!1,attributeConfigurable:!1,attributeList:[],textConfigurable:!0,textCheckType:0,customFormat:""},getConfig=r=>r==="lineTool"?lineToolConfig:r==="rectTool"?rectToolConfig:r==="tagTool"?tagToolConfig:r==="textTool"?textToolConfig:r==="polygonTool"?polygonConfig:rectToolConfig,styleDefaultConfig={toolColor:{1:{valid:{stroke:"rgba(0,0,255,0.50)",fill:"rgba(0,0,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(0,15,255,1.00)",fill:"rgba(0,15,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(0,15,255,0.80)",fill:"rgba(0,15,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},3:{valid:{stroke:"rgba(0,255,255,0.50)",fill:"rgba(0,255,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(0,212,255,1.00)",fill:"rgba(0,212,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(0,212,255,0.80)",fill:"rgba(0,212,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},5:{valid:{stroke:"rgba(0,255,0,0.50)",fill:"rgba(0,255,0,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(149,255,1.00)",fill:"rgba(149,255,0,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(149,255,0,0.80)",fill:"rgba(149,255,0,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},7:{valid:{stroke:"rgba(255,255,0,0.50)",fill:"rgba(255,255,0,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(255,230,102,1.00)",fill:"rgba(255,213,0,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(255,230,102,0.80)",fill:"rgba(255,230,102,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},9:{valid:{stroke:"rgba(255,0,255,0.50)",fill:"rgba(255,0,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(230,102,255,1.00)",fill:"rgba(213,0,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(230,102,255,0.80)",fill:"rgba(230,102,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}}},attributeColor:[{valid:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}}],lineColor:{1:"rgba(102, 111, 255, 1 )",3:"rgba(102, 230, 255, 1)",5:"rgba(191, 255, 102, 1)",7:"rgba(255, 230, 102, 1)",9:"rgba(230, 102, 255, 1)"},attributeLineColor:["rgba(204, 204, 204, 1)","rgba(153, 51, 255, 1)","rgba(51, 254, 51, 1)","rgba(255, 51, 255, 1)","rgba(204, 255, 51, 1)","rgba(51, 153, 255, 1)","rgba(255, 153, 51, 1)","rgba(51, 255, 238, 1)","rgba(255, 221, 51, 1)"],color:1,width:2,opacity:9};class ActionsHistory{constructor(t){this.record=[],this.recordIndex=-1,this.minRecordIndex=-1,this.emitHistoryChanged=()=>{this.historyChanged&&(this.constructor.name==="ActionsHistory"?!0:this.record.length>0)&&this.historyChanged(this.undoEnabled,this.redoEnabled)},this.historyChanged=t}get undoEnabled(){return this.recordIndex>this.minRecordIndex}get redoEnabled(){return this.recordIndex<this.record.length-1}pushHistory(t){if(this.recordIndex!==this.record.length-1){const e=this.record.slice(0,Math.min(this.recordIndex+1,this.record.length));this.record=e}this.record.push(___default.default.cloneDeepWith(t)),this.recordIndex+=1,this.emitHistoryChanged()}updateHistory(t){this.record[this.recordIndex]=___default.default.cloneDeep(t)}applyAttribute(t,e,i){t&&this.record.forEach(s=>{const n=s.find(o=>o.id===t);n&&(n[e]=i)})}undo(){if(this.undoEnabled)return this.recordIndex-=1,this.emitHistoryChanged(),___default.default.cloneDeep(this.record[this.recordIndex])||[]}redo(){if(this.redoEnabled)return this.recordIndex+=1,this.emitHistoryChanged(),___default.default.cloneDeep(this.record[this.recordIndex])}init(){this.record=[[]],this.recordIndex=0,this.emitHistoryChanged()}empty(){this.record=[],this.recordIndex=-1,this.emitHistoryChanged()}initRecord(t,e=!1){const i=t.length>0||e;this.record=i?[___default.default.cloneDeep(t)]:[],this.minRecordIndex=i?0:-1,this.recordIndex=0}}class DblClickEventListener{constructor(t,e){this.rcTime=0,this.mouseDownTime=0,this.onMouseDown=()=>{this.mouseDownTime=new Date().getTime()},this.dom=t,this.isDoubleClick=!1,this.delay=e}getRcTime(){return this.rcTime}getCoord(t){return{x:t.clientX,y:t.clientY}}removeEvent(){!this.dom||(this.dom.removeEventListener("mouseup",this.mouseUp),this.dom.removeEventListener("mousemove",this.mouseMove),this.dom.removeEventListener("dblclick",this.dblclick),this.dom.removeEventListener("mousedown",this.onMouseDown))}addEvent(t,e,i,s){!this.dom||(this.removeEvent(),this.mouseUp=n=>{const o=new Date().getTime(),a=s?s(n):!0;if(o-this.mouseDownTime>this.delay||a!==!0){t(n);return}if(n.button===2)if(this.rcTime===0)setTimeout(()=>{this.rcTime=0},this.delay),this.rcTime=o;else{o-this.rcTime<this.delay&&(i(n),clearTimeout(this.setTimeFun),this.cacheFunction=void 0),this.rcTime=0;return}this.setTimeFun&&clearTimeout(this.setTimeFun),this.clickCoord=this.getCoord(n),this.cacheFunction=()=>t(n),this.setTimeFun=setTimeout(()=>{if(this.isDoubleClick){this.isDoubleClick=!1;return}this.cacheFunction(),this.clickCoord=void 0},this.delay)},this.mouseMove=n=>{const o=this.getCoord(n);this.clickCoord&&!AxisUtils.getIsInScope(o,this.clickCoord,10)&&(this.cacheFunction&&this.cacheFunction(),this.clickCoord=void 0,this.cacheFunction=null,clearTimeout(this.setTimeFun))},this.dblclick=n=>{this.isDoubleClick=!0,this.clickCoord=void 0,e(n)},this.dom.addEventListener("mouseup",this.mouseUp),this.dom.addEventListener("mousemove",this.mouseMove),this.dom.addEventListener("dblclick",this.dblclick),this.dom.addEventListener("mousedown",this.onMouseDown))}clearRightDblClick(){this.rcTime=0}}class ImgPosUtils{static getInitImgPos(t,e,i=0,s=1,n=!1){(i===90||i===270)&&(e={width:e.height,height:e.width});const o=t.width*s/e.width,a=t.height*s/e.height;let l=n?1:Math.min(o,a);const h={x:(t.width-e.width*l)/2,y:(t.height-e.height*l)/2},d=e.width*l,u=e.height*l;return n&&(l=1),{zoom:l,currentPos:h,imgInfo:{width:d,height:u}}}static getBasicRecPos(t,e,i,s=.9,n=1,o=!1){if(e&&t){const{x:a,y:l,height:h,width:d}=e;let u=i.height/h;d/h>i.width/i.height&&(u=i.width/d);const c=o?1:u*s*n,g={x:i.width/2,y:i.height/2},p={x:(a+d/2)*c,y:(l+h/2)*c};return{currentPos:{x:g.x-p.x,y:g.y-p.y},innerZoom:c}}return!1}}class RenderDomUtils{static renderInvalidPage(t,e,i){const s=document.createElement("div");return s.setAttribute("style",`
|
|
5
|
+
*/Object.defineProperty(exports,"__esModule",{value:!0});var turf=require("@turf/turf"),_=require("lodash"),lbUtils=require("@labelbee/lb-utils"),rgba=require("color-rgba"),THREE=require("three");function _interopDefaultLegacy(r){return r&&typeof r=="object"&&"default"in r?r:{default:r}}function _interopNamespace(r){if(r&&r.__esModule)return r;var t=Object.create(null);return r&&Object.keys(r).forEach(function(e){if(e!=="default"){var i=Object.getOwnPropertyDescriptor(r,e);Object.defineProperty(t,e,i.get?i:{enumerable:!0,get:function(){return r[e]}})}}),t.default=r,Object.freeze(t)}var ___default=_interopDefaultLegacy(_),rgba__default=_interopDefaultLegacy(rgba),THREE__namespace=_interopNamespace(THREE);const editStepWidth=320;var EPointCloudName;(function(r){r.PointCloud="pointCloudTool"})(EPointCloudName||(EPointCloudName={}));var EVideoToolName;(function(r){r.VideoTextTool="videoTextTool",r.VideoTagTool="videoTagTool",r.VideoClipTool="videoClipTool"})(EVideoToolName||(EVideoToolName={}));var EToolType;(function(r){r[r.Rect=0]="Rect",r[r.Tag=1]="Tag"})(EToolType||(EToolType={}));var EToolName;(function(r){r.Rect="rectTool",r.Tag="tagTool",r.Point="pointTool",r.PointMarker="pointMarkerTool",r.Segmentation="segmentationTool",r.Filter="filterTool",r.Text="textTool",r.Polygon="polygonTool",r.Line="lineTool",r.LineMarker="lineMarkerTool",r.Empty="emptyTool",r.FolderTag="folderTagTool",r.RectTrack="rectTrackTool",r.Face="faceTool",r.ClientAttribute="clientAttributeTool",r.OCRRelation="OCRRelationTool",r.SegmentByRect="segmentByRectTool"})(EToolName||(EToolName={}));var ECheckModel;(function(r){r.Check="check"})(ECheckModel||(ECheckModel={}));var ERectPattern;(function(r){r[r.nothing=0]="nothing",r[r.RectBG=1]="RectBG",r[r.showOrder=2]="showOrder"})(ERectPattern||(ERectPattern={}));const TOOL_NAME={[EToolName.Rect]:"\u62C9\u6846",[EToolName.Tag]:"\u6807\u7B7E",[EToolName.Point]:"\u6807\u70B9",[EToolName.PointMarker]:"\u5217\u8868\u6807\u70B9",[EToolName.Segmentation]:"\u524D\u666F\u5206\u5272",[EToolName.Filter]:"\u7B5B\u9009",[EToolName.Text]:"\u6587\u672C",[EToolName.Polygon]:"\u591A\u8FB9\u5F62",[EToolName.Line]:"\u7EBF\u6761",[EToolName.LineMarker]:"\u5217\u8868\u7EBF\u6761",[EToolName.FolderTag]:"\u6587\u4EF6\u5939\u6807\u7B7E",[EToolName.RectTrack]:"\u62C9\u6846\u8DDF\u8E2A",[EToolName.Face]:"\u4EBA\u8138106\u5DE5\u5177",[EToolName.ClientAttribute]:"\u5BA2\u6237\u7AEF\u5C5E\u6027\u5DE5\u5177",[EToolName.OCRRelation]:"OCR\u5173\u8054\u5173\u7CFB\u5DE5\u5177",[EToolName.SegmentByRect]:"\u7B97\u6CD5\u5206\u5272\u8F85\u52A9\u5DE5\u5177",[EVideoToolName.VideoTextTool]:"\u89C6\u9891\u6587\u672C",[EVideoToolName.VideoTagTool]:"\u89C6\u9891\u6807\u7B7E",[EVideoToolName.VideoClipTool]:"\u89C6\u9891\u622A\u53D6",[EPointCloudName.PointCloud]:"\u70B9\u4E91"};var EDependPattern;(function(r){r[r.noDepend=1]="noDepend",r[r.dependOrigin=2]="dependOrigin",r[r.dependShape=3]="dependShape",r[r.dependLine=4]="dependLine",r[r.dependPolygon=5]="dependPolygon",r[r.dependPreShape=101]="dependPreShape",r[r.dependPreLine=102]="dependPreLine",r[r.dependPrePolygon=103]="dependPrePolygon"})(EDependPattern||(EDependPattern={}));var EFilterToolOperation;(function(r){r.lc="leftClick",r.rc="rightClick",r.clc="ctrlLeftClick",r.crc="ctrlRightClick"})(EFilterToolOperation||(EFilterToolOperation={}));const OPERATION_LIST={leftClick:"\u9F20\u6807\u5DE6\u952E",rightClick:"\u9F20\u6807\u53F3\u952E",ctrlLeftClick:"ctrl + \u9F20\u6807\u5DE6\u952E",ctrlRightClick:"ctrl + \u9F20\u6807\u53F3\u952E"};var EAnnotationMode;(function(r){r[r.Normal=1]="Normal",r[r.Modify=2]="Modify"})(EAnnotationMode||(EAnnotationMode={}));var ELineTypes;(function(r){r[r.Line=0]="Line",r[r.Curve=1]="Curve"})(ELineTypes||(ELineTypes={}));var ELineColor;(function(r){r[r.SingleColor=0]="SingleColor",r[r.MultiColor=1]="MultiColor"})(ELineColor||(ELineColor={}));var ESelectedType;(function(r){r[r.Form=1]="Form",r[r.Json=2]="Json"})(ESelectedType||(ESelectedType={}));var EDragTarget$1;(function(r){r[r.Point=0]="Point",r[r.Line=1]="Line",r[r.Plane=2]="Plane"})(EDragTarget$1||(EDragTarget$1={}));var EDrawPointPattern;(function(r){r[r.None=0]="None",r[r.Drawing=1]="Drawing",r[r.Edit=2]="Edit"})(EDrawPointPattern||(EDrawPointPattern={}));var EPageOperator$1;(function(r){r[r.Backward=0]="Backward",r[r.Forward=1]="Forward",r[r.JumpSkip=2]="JumpSkip",r[r.None=3]="None"})(EPageOperator$1||(EPageOperator$1={}));var EAuditStatus;(function(r){r[r.Wait=0]="Wait",r[r.Pass=1]="Pass",r[r.Fail=2]="Fail",r[r.Loading=3]="Loading"})(EAuditStatus||(EAuditStatus={}));var ETextType;(function(r){r[r.AnyString=0]="AnyString",r[r.Order=1]="Order",r[r.EnglishOnly=2]="EnglishOnly",r[r.NumberOnly=3]="NumberOnly",r[r.CustomFormat=4]="CustomFormat"})(ETextType||(ETextType={}));const TEXT_TYPE={0:"\u4EFB\u610F\u5B57\u7B26",1:"\u5E8F\u53F7",2:"\u4EC5\u82F1\u6587",3:"\u4EC5\u6570\u5B57"},TEXT_ATTRIBUTE_MAX_LENGTH=1e3,TEXT_ATTRIBUTE_LINE_HEIGHT=16,DEFAULT_TEXT_MAX_WIDTH=300,DEFAULT_FONT="normal normal 500 14px Arial";var EThumbnailOption;(function(r){r[r.ImgList=1e3]="ImgList",r[r.TrackPrediction=1001]="TrackPrediction",r[r.ImgSearch=1002]="ImgSearch"})(EThumbnailOption||(EThumbnailOption={}));const CLIENT_TOOL_HEAD_TYPE={[EPointCloudName.PointCloud]:"sensebeepc",[EToolName.ClientAttribute]:"sensebeepc-EnumAttributeTool",[EToolName.Face]:"sensebeepc-FacePointsLabellingTool",[EToolName.OCRRelation]:"sensebeepc-OCRRelationTool"},CLIENT_TOOL_NAME={[EPointCloudName.PointCloud]:"\u70B9\u4E91\u5BA2\u6237\u7AEF",[EToolName.ClientAttribute]:"\u5BA2\u6237\u7AEF\u5C5E\u6027\u5DE5\u5177",[EToolName.Face]:"\u4EBA\u8138106\u70B9\u5DE5\u5177",[EToolName.OCRRelation]:"OCR\u5173\u8054\u5173\u7CFB\u5DE5\u5177"},SEGMENT_NUMBER$2=16,edgeAdsorptionScope=10;var EPolygonPattern;(function(r){r[r.Normal=0]="Normal",r[r.Rect=1]="Rect"})(EPolygonPattern||(EPolygonPattern={}));var tool=Object.freeze({__proto__:null,editStepWidth,get EPointCloudName(){return EPointCloudName},get EVideoToolName(){return EVideoToolName},get EToolType(){return EToolType},get EToolName(){return EToolName},get ECheckModel(){return ECheckModel},get ERectPattern(){return ERectPattern},TOOL_NAME,get EDependPattern(){return EDependPattern},get EFilterToolOperation(){return EFilterToolOperation},OPERATION_LIST,get EAnnotationMode(){return EAnnotationMode},get ELineTypes(){return ELineTypes},get ELineColor(){return ELineColor},get ESelectedType(){return ESelectedType},get EDragTarget(){return EDragTarget$1},get EDrawPointPattern(){return EDrawPointPattern},get EPageOperator(){return EPageOperator$1},get EAuditStatus(){return EAuditStatus},get ETextType(){return ETextType},TEXT_TYPE,TEXT_ATTRIBUTE_MAX_LENGTH,TEXT_ATTRIBUTE_LINE_HEIGHT,DEFAULT_TEXT_MAX_WIDTH,DEFAULT_FONT,get EThumbnailOption(){return EThumbnailOption},CLIENT_TOOL_HEAD_TYPE,CLIENT_TOOL_NAME,SEGMENT_NUMBER:SEGMENT_NUMBER$2,edgeAdsorptionScope,get EPolygonPattern(){return EPolygonPattern}}),__defProp$j=Object.defineProperty,__defProps$f=Object.defineProperties,__getOwnPropDescs$f=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$i=Object.getOwnPropertySymbols,__hasOwnProp$i=Object.prototype.hasOwnProperty,__propIsEnum$i=Object.prototype.propertyIsEnumerable,__defNormalProp$j=(r,t,e)=>t in r?__defProp$j(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$i=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$i.call(t,e)&&__defNormalProp$j(r,e,t[e]);if(__getOwnPropSymbols$i)for(var e of __getOwnPropSymbols$i(t))__propIsEnum$i.call(t,e)&&__defNormalProp$j(r,e,t[e]);return r},__spreadProps$f=(r,t)=>__defProps$f(r,__getOwnPropDescs$f(t));function createSmoothCurvePoints(r,t=.5,e=!1,i=16){if(r.length<4)return r;const s=[],n=r.slice(0);let o,a,l,h,c,u,d,g,p,f,v,m,b;for(e?(n.unshift(r[r.length-1]),n.unshift(r[r.length-2]),n.unshift(r[r.length-1]),n.unshift(r[r.length-2]),n.push(r[0]),n.push(r[1])):(n.unshift(r[1]),n.unshift(r[0]),n.push(r[r.length-2]),n.push(r[r.length-1])),b=2;b<n.length-4;b+=2)for(l=(n[b+2]-n[b-2])*t,h=(n[b+4]-n[b-0])*t,c=(n[b+3]-n[b-1])*t,u=(n[b+5]-n[b+1])*t,m=0;m<=i;m++)v=m/i,d=2*Math.pow(v,3)-3*Math.pow(v,2)+1,g=-(2*Math.pow(v,3))+3*Math.pow(v,2),p=Math.pow(v,3)-2*Math.pow(v,2)+v,f=Math.pow(v,3)-Math.pow(v,2),o=d*n[b]+g*n[b+2]+p*l+f*h,a=d*n[b+1]+g*n[b+3]+p*c+f*u,s.push(o),s.push(a);const x=[];for(let P=0;P<s.length-1;P+=2)x.push({x:s[P],y:s[P+1]});if(e)for(let P=0;P<i+1;P++){const w=x.shift();x.push(w)}return x}const createSmoothCurvePointsFromPointList=(r,t=16)=>createSmoothCurvePoints(r.reduce((e,i)=>[...e,i.x,i.y],[]),.5,!1,t);function isInPolygon(r,t,e=ELineTypes.Line){let i=0,s,n,o,a;t=[...t],e===ELineTypes.Curve&&(t=createSmoothCurvePoints(t.reduce((h,c)=>[...h,c.x,c.y],[]),.5,!0,SEGMENT_NUMBER$2)),[o]=t;const l=t.length;for(s=1;s<=l;s++)a=t[s%l],r.x>Math.min(o.x,a.x)&&r.x<=Math.max(o.x,a.x)&&r.y<=Math.max(o.y,a.y)&&o.x!==a.x&&(n=(r.x-o.x)*(a.y-o.y)/(a.x-o.x)+o.y,(o.y===a.y||r.y<=n)&&i++),o=a;return i%2!=0}function getPolygonPointUnderZoom(r,t=1){return r.map(e=>__spreadProps$f(__spreadValues$i({},e),{x:e.x*t,y:e.y*t}))}var __pow$1=Math.pow;class Vector{static add(t,e){return{x:t.x+e.x,y:t.y+e.y}}static getVector(t,e){return{x:e.x-t.x,y:e.y-t.y}}static len(t){return Math.sqrt(__pow$1(t.x,2)+__pow$1(t.y,2))}static dotProduct(t,e){return t.x*e.x+t.y+e.y}}class Trigonometric{static tanAPlusB(t,e){return(t+e)/(1-t*e)}static sinAPlusB(t,e,i,s){return s*t+e*i}static cosAPlusB(t,e,i,s){return e*s-t*i}}const _MathUtils=class{static getRotate(r){return r+90>=360?r+90-360:r+90}static getLineLength(r,t){return Math.sqrt(Math.pow(t.y-r.y,2)+Math.pow(t.x-r.x,2))}static getTextArea(r,t,e=DEFAULT_TEXT_MAX_WIDTH,i=DEFAULT_FONT,s){if(typeof t!="string")return{width:0,height:0};const n=r.getContext("2d");n.font=i;let o=0;typeof s=="undefined"&&(s=r&&parseInt(window.getComputedStyle(r).lineHeight,10)||parseInt(window.getComputedStyle(document.body).lineHeight,10));const a=r&&parseInt(window.getComputedStyle(r).fontSize,10)||parseInt(window.getComputedStyle(document.body).fontSize,10)||0,l=t.split(`
|
|
6
|
+
`);let h=0;for(let c=0;c<l.length;c++){const u=l[c].split("");let d="";for(let g=0;g<u.length;g++){const p=d+u[g],v=n.measureText(p).width;v>e&&g>0?(d=u[g],o+=s,h=e):(d=p,v>h&&(h=v))}c!==l.length-1&&(o+=s)}return{width:h,height:o+a,lineHeight:s,fontHeight:a}}static getLineCenterPoint(r){const[t,e]=r,i=Vector.getVector(t,e);return{x:t.x+i.x/2,y:t.y+i.y/2}}static getPerpendicularLine(r){if(r.length!==2)return;const[t,e]=r,i={x:e.x+e.y-t.y,y:e.y-(e.x-t.x)};return[e,i]}static getPerpendicularFootOfLine(r,t){if(r.length!==2)return r;const e=this.getPerpendicularLine(r);if(!e)return r;const[i,s]=e;return this.getFootOfPerpendicular(t,i,s).footPoint}static getQuadrangleFromTriangle(r){if(r.length!==3)return r;const[t,e,i]=r,s={x:i.x+t.x-e.x,y:i.y+t.y-e.y};return[t,e,i,s]}static getRectPerpendicularOffset(r,t,e){const[i,s]=e,n=this.getFootOfPerpendicular(r,i,s).footPoint,o=this.getFootOfPerpendicular(t,i,s).footPoint,a={x:n.x-o.x,y:n.y-o.y},l=Vector.add(t,a);return Vector.getVector(r,l)}static getArrayIndex(r,t){return r<0?t+r:r>=t?r-t:r}static getPointListFromPointOffset(r,t,e){const i=this.getArrayIndex(t-1,r.length),s=this.getArrayIndex(t+1,r.length),n=this.getArrayIndex(t-2,r.length),o=[...r];o[t]=Vector.add(o[t],e);const a=this.getFootOfPerpendicular(o[t],o[n],o[i]).footPoint,l=this.getFootOfPerpendicular(o[t],o[s],o[n]).footPoint;return o[i]=a,o[s]=l,o}static getRectCenterPoint(r){const[t,,e]=r;return{x:(t.x+e.x)/2,y:(t.y+e.y)/2}}static rotateRectPointList(r=5,t){const e=this.getRectCenterPoint(t),{PI:i}=Math,s=Math.sin(r*i/180),n=Math.cos(r*i/180);return t.map(o=>{const a=Vector.getVector(e,o),l=Vector.len(a),h=a.y/l,c=a.x/l;return{x:l*Trigonometric.cosAPlusB(h,c,s,n)+e.x,y:l*Trigonometric.sinAPlusB(h,c,s,n)+e.y}})}static getRectangleByRightAngle(r,t){if(t.length!==2)return t;const e=_MathUtils.getPerpendicularFootOfLine(t,r);return _MathUtils.getQuadrangleFromTriangle([...t,e])}static getRadiusFromQuadrangle(r){const[,t,e]=r,i=e.y-t.y,s=t.x-e.x,n=this.getLineLength(t,e),o=i/n,a=Math.acos(o);return s>0?-a:a}};let MathUtils=_MathUtils;MathUtils.isInRange=(r,t)=>{const e=Math.min(...t),i=Math.max(...t),s=o=>o<=i&&o>=e;return(Array.isArray(r)?r:[r]).every(o=>s(o))},MathUtils.withinRange=(r,t)=>{const e=Math.min(...t),i=Math.max(...t);return r>i?i:r<e?e:r},MathUtils.calcViewportBoundaries=(r,t=!1,e=SEGMENT_NUMBER$2,i=1)=>{if(!r)return{top:0,bottom:0,left:0,right:0};const s=20/i,n=[],o=[];let a=r;t&&(a=createSmoothCurvePointsFromPointList(r,e)),a.forEach(({x:p,y:f})=>{n.push(p),o.push(f)});let l=Math.min(...n),h=Math.max(...n),c=Math.min(...o),u=Math.max(...o);const d=h-l,g=u-c;if(d<s){const p=(s-d)/2;l-=p,h+=p}if(g<s){const p=(s-g)/2;c-=p,u+=p}return{top:c,bottom:u,left:l,right:h}},MathUtils.getFootOfPerpendicular=(r,t,e,i=!1)=>{let s={x:0,y:0};const n=t.x-e.x,o=t.y-e.y;if(Math.abs(n)<1e-8&&Math.abs(o)<1e-8)return s=t,s;let a=(r.x-t.x)*(t.x-e.x)+(r.y-t.y)*(t.y-e.y);a/=n*n+o*o,s.x=t.x+a*n,s.y=t.y+a*o;const l=_MathUtils.getLineLength(r,s),h=2,c=Math.min(t.x,e.x),u=Math.max(t.x,e.x),d=Math.min(t.y,e.y),g=Math.max(t.y,e.y),p=!(_MathUtils.isInRange(r.x,[c,u])||_MathUtils.isInRange(r.y,[d,g])),f=r.x>u+h||r.x<c-h||r.y>g+h||r.y<d-h;return(i?p:f)?{footPoint:s,length:Infinity}:{footPoint:s,length:l}};const headerHeight=61,tipsHeight=40,footerHeight=40,sidebarWidth=240;var EStepType;(function(r){r[r.ANNOTATION=1]="ANNOTATION",r[r.QUALITY_INSPECTION=2]="QUALITY_INSPECTION",r[r.PRE_ANNOTATION=3]="PRE_ANNOTATION",r[r.MANUAL_CORRECTION=4]="MANUAL_CORRECTION"})(EStepType||(EStepType={}));const ANNOTATION_MAX_SIZE=1e3;var EPageOperator;(function(r){r[r.Backward=0]="Backward",r[r.Forward=1]="Forward",r[r.JumpSkip=2]="JumpSkip",r[r.None=3]="None"})(EPageOperator||(EPageOperator={}));var EDragStatus;(function(r){r[r.Start=0]="Start",r[r.Stop=1]="Stop",r[r.Wait=2]="Wait",r[r.Move=3]="Move"})(EDragStatus||(EDragStatus={}));var EDragTarget;(function(r){r[r.Point=0]="Point",r[r.Line=1]="Line",r[r.Plane=2]="Plane"})(EDragTarget||(EDragTarget={}));var ESortDirection;(function(r){r[r.ascend=0]="ascend",r[r.descend=1]="descend"})(ESortDirection||(ESortDirection={}));var EGrowthMode;(function(r){r[r.Intelligence=0]="Intelligence",r[r.Linear=1]="Linear"})(EGrowthMode||(EGrowthMode={}));var ELang;(function(r){r.Zh="zh_CN",r.US="en_US"})(ELang||(ELang={}));var ERotateDirection;(function(r){r[r.Clockwise=0]="Clockwise",r[r.Anticlockwise=1]="Anticlockwise"})(ERotateDirection||(ERotateDirection={}));const DEFAULT_TEXT_OFFSET={offsetX:-10,offsetY:-10},DEFAULT_TEXT_SHADOW={shadowColor:"rgba(0,0,0,0.6)",shadowOffsetX:0,shadowOffsetY:2,shadowBlur:4},TEXT_ATTRIBUTE_OFFSET$1={x:8,y:26};var annotation=Object.freeze({__proto__:null,headerHeight,tipsHeight,footerHeight,sidebarWidth,get EStepType(){return EStepType},ANNOTATION_MAX_SIZE,get EPageOperator(){return EPageOperator},get EDragStatus(){return EDragStatus},get EDragTarget(){return EDragTarget},get ESortDirection(){return ESortDirection},get EGrowthMode(){return EGrowthMode},get ELang(){return ELang},get ERotateDirection(){return ERotateDirection},DEFAULT_TEXT_OFFSET,DEFAULT_TEXT_SHADOW,TEXT_ATTRIBUTE_OFFSET:TEXT_ATTRIBUTE_OFFSET$1}),__defProp$i=Object.defineProperty,__defProps$e=Object.defineProperties,__getOwnPropDescs$e=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$h=Object.getOwnPropertySymbols,__hasOwnProp$h=Object.prototype.hasOwnProperty,__propIsEnum$h=Object.prototype.propertyIsEnumerable,__defNormalProp$i=(r,t,e)=>t in r?__defProp$i(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$h=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$h.call(t,e)&&__defNormalProp$i(r,e,t[e]);if(__getOwnPropSymbols$h)for(var e of __getOwnPropSymbols$h(t))__propIsEnum$h.call(t,e)&&__defNormalProp$i(r,e,t[e]);return r},__spreadProps$e=(r,t)=>__defProps$e(r,__getOwnPropDescs$e(t));class CommonToolUtils$1{static getStepInfo(t,e){return e==null?void 0:e.filter(i=>i.step===t)[0]}static getCurrentStepInfo(t,e){const i=this.getStepInfo(t,e);return i&&(i.type===EStepType.QUALITY_INSPECTION||i.type===EStepType.MANUAL_CORRECTION)?this.getCurrentStepInfo(i.dataSourceStep,e):i}static getMaxOrder(t){let e=0;return t.forEach(i=>{i.order&&i.order>e&&(e=i.order)}),e}static hotkeyFilter(t){const e=t.target||t.srcElement;if(!e)return!0;const{tagName:i,type:s}=e;if(!i||!s)return!0;let n=!0;return(e.isContentEditable||i==="TEXTAREA"||(i==="INPUT"&&s!=="radio"||i==="TEXTAREA")&&!e.readOnly)&&(n=!1),n}static getNextSelectedRectID(t,e=ESortDirection.ascend,i){let s=1;e===ESortDirection.descend&&(s=-1);const n=t.sort((l,h)=>l.x-h.x==0?l.y-h.y:s*(l.x-h.x)),o=n.findIndex(l=>l.id===i),a=n.length;return n[(o+1)%a]}static getNextSelectedRectIDByEvent(t,e,i){const s=e.shiftKey?ESortDirection.descend:ESortDirection.ascend;return this.getNextSelectedRectID(t,s,i)}static getRenderResultList(t,e,i=[],s){let n;return[t.filter(a=>s&&s===(a==null?void 0:a.id)?(n=a,!1):!(i.length>0&&!i.includes(a==null?void 0:a.attribute)||this.isDifferSourceID(a==null?void 0:a.sourceID,e))),n]}static getSourceID(t){var e;const i="";return t&&(e=t==null?void 0:t.id)!=null?e:i}static findAllLine(t,e=!0){const i=[],s=[...t];s.length>=3&&e===!0&&s.push(__spreadValues$h({},s[0]));for(let n=0;n<s.length;n++)s[n+1]&&i.push({point1:s[n],point2:s[n+1],pointIndex:n});return i}static translateSourceID(t){return(t===void 0||t===0||t==="0")&&(t=""),t}static isDifferSourceID(t,e){return t=this.translateSourceID(t),e=this.translateSourceID(e),`${t}`!=`${e}`}static isSameSourceID(t,e){return t=this.translateSourceID(t),e=this.translateSourceID(e),`${t}`==`${e}`}static getNextMarker(t,e=[],i){if((e==null?void 0:e.length)===0)return;let s=e.map((n,o)=>__spreadProps$e(__spreadValues$h({},n),{index:o}));if(typeof i=="number"&&i>0){const n=e[i];if(n&&t.every(o=>o.label!==n.value))return{label:n.value,index:i};s=[...s.slice(i,e.length),...s.slice(0,i)]}for(let n=0;n<s.length;n++)if(!t.some(o=>o.label===s[n].value))return{label:s[n].value,index:s[n].index}}static getCurrentMarkerIndex(t,e=[]){return e.findIndex(i=>t===i.value)}}CommonToolUtils$1.jsonParser=(r,t={})=>{try{return typeof r=="string"?JSON.parse(r):_.isObject(r)?r:t}catch(e){return t}};var __defProp$h=Object.defineProperty,__defProps$d=Object.defineProperties,__getOwnPropDescs$d=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$g=Object.getOwnPropertySymbols,__hasOwnProp$g=Object.prototype.hasOwnProperty,__propIsEnum$g=Object.prototype.propertyIsEnumerable,__defNormalProp$h=(r,t,e)=>t in r?__defProp$h(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$g=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$g.call(t,e)&&__defNormalProp$h(r,e,t[e]);if(__getOwnPropSymbols$g)for(var e of __getOwnPropSymbols$g(t))__propIsEnum$g.call(t,e)&&__defNormalProp$h(r,e,t[e]);return r},__spreadProps$d=(r,t)=>__defProps$d(r,__getOwnPropDescs$d(t)),EStatus$1;(function(r){r[r.Create=0]="Create",r[r.Active=1]="Active",r[r.Edit=1]="Edit",r[r.None=2]="None"})(EStatus$1||(EStatus$1={}));var EColor;(function(r){r.ActiveArea="#B3B8FF"})(EColor||(EColor={}));const SEGMENT_NUMBER$1=16,POINT_RADIUS$1=3,_LineToolUtils=class{static isInLine(r,t,e,i=3){const{length:s}=MathUtils.getFootOfPerpendicular(r,t,e);return s<i}};let LineToolUtils=_LineToolUtils;LineToolUtils.setSpecialEdgeStyle=r=>{r.lineCap="butt",r.setLineDash([10,10])},LineToolUtils.setReferenceCtx=r=>{r.lineCap="butt",r.setLineDash([6])},LineToolUtils.calcOptimalIntersection=(r,t,e,i,s)=>{let n,o=Infinity,a;if(r.find((h,c)=>{if(c===0)return;const u=_LineToolUtils.isInLine(t.pointA,h,r[c-1]),d=_LineToolUtils.isInLine(t.pointB,h,r[c-1]);return u&&d}))return{point:e};if(r.forEach((h,c)=>{if(c===0)return;const u={pointA:r[c-1],pointB:h},d=_LineToolUtils.lineIntersection(t,u);if(d&&t){const{onLine2:g,onLine1:p,x:f,y:v}=d,m=_LineToolUtils.calcDistance(e,d);if(_LineToolUtils.isOnLine(t.pointB.x,t.pointB.y,h.x,h.y,r[c-1].x,r[c-1].y)){if(_LineToolUtils.calcDistance(e,d)<i/s){const P=t.pointB,{footPoint:w,length:L}=MathUtils.getFootOfPerpendicular(P,u.pointA,u.pointB,!0);if(L!==void 0){const R=_LineToolUtils.calcDistance(u.pointA,w),C=_LineToolUtils.calcDistance(u.pointB,w);a={point:w,minDistance:L},L===Infinity&&(a.point=R>C?u.pointB:u.pointA)}}return}m<o&&g&&p&&(o=m,n={x:f,y:v})}}),n)return{point:n,minDistance:o};if(a)return a},LineToolUtils.lineIntersection=(r,t)=>{let e=!1,i=!1;const s=_LineToolUtils.getAxisDiff(r),n=_LineToolUtils.getAxisDiff(t),o=n.y*s.x-n.x*s.y;if(o===0)return!1;let a=r.pointA.y-t.pointA.y,l=r.pointA.x-t.pointA.x;const h=(t.pointB.x-t.pointA.x)*a-(t.pointB.y-t.pointA.y)*l,c=(r.pointB.x-r.pointA.x)*a-(r.pointB.y-r.pointA.y)*l;a=h/o,l=c/o,a>0&&a<1&&(e=!0),l>0&&l<1&&(i=!0);const u=r.pointA.x+a*(r.pointB.x-r.pointA.x),d=r.pointA.y+a*(r.pointB.y-r.pointA.y);return{x:u,y:d,onLine1:e,onLine2:i}},LineToolUtils.getAxisDiff=r=>({x:r.pointB.x-r.pointA.x,y:r.pointB.y-r.pointA.y}),LineToolUtils.calcDistance=(r,t)=>Math.sqrt(Math.pow(Math.abs(r.x-t.x),2)+Math.pow(Math.abs(r.y-t.y),2)),LineToolUtils.drawCurveLine=(r,t,e,i=!0,s=!1,n)=>{const o=createSmoothCurvePointsFromPointList(t,SEGMENT_NUMBER$1);r.save(),r.lineCap="round",r.lineJoin="round",r.strokeStyle=e.color,i&&(r.lineWidth=e.lineWidth),s&&_LineToolUtils.setReferenceCtx(r),t.forEach((a,l)=>{const h=a==null?void 0:a.specialEdge,c=o.splice(0,SEGMENT_NUMBER$1+1);r.save(),r.beginPath(),n===l&&(r.lineWidth=4),c.forEach(({x:u,y:d},g)=>{const p=g>0?"lineTo":"moveTo";h&&_LineToolUtils.setSpecialEdgeStyle(r),r[p](u,d)}),r.stroke(),r.restore()}),r.restore()},LineToolUtils.calcTwoPointDistance=(r,t)=>Math.sqrt(Math.pow(r.x-t.x,2)+Math.pow(r.y-t.y,2)),LineToolUtils.pointOverTarget=(r,t,e,i,s,n,o,a,l,h)=>{const c=r;if(!t)return r;if(e===EToolName.Polygon){const u=_LineToolUtils.getPolygonPointList(i,s);if(u.length===0||PolygonUtils.isInPolygon(r,u))return c;const g=u.concat(u[0]).map(b=>l(b)),p=l(t),f=l(r),v={pointA:p,pointB:f},m=_LineToolUtils.calcOptimalIntersection(g,v,p,o,a);if(m){const b=h(m==null?void 0:m.point);c.x=b.x,c.y=b.y}else return t;return c}if(e===EToolName.Rect){const{x:u,y:d,width:g,height:p}=i;return c.x=MathUtils.withinRange(c.x,[u,u+g]),c.y=MathUtils.withinRange(c.y,[d,d+p]),c}return c.x=MathUtils.withinRange(c.x,[0,n.width]),c.y=MathUtils.withinRange(c.y,[0,n.height]),c},LineToolUtils.getPolygonPointList=(r,t)=>{const{pointList:e}=r,{lineType:i}=t;return i===ELineTypes.Line?e:PolygonUtils.createSmoothCurvePoints(e.reduce((s,n)=>[...s,n.x,n.y],[]),.5,!0,20)},LineToolUtils.isOnLine=(r,t,e,i,s,n)=>Math.abs((a=>(i-t)/(e-r)*(a-r)+t)(s)-n)<1e-6&&s>=r&&s<=e,LineToolUtils.inArea=({top:r,left:t,right:e,bottom:i},{x:s,y:n})=>n>=r&&n<=i&&s>=t&&s<=e,LineToolUtils.getVHPoint=(r,t,e,i)=>{const s=_LineToolUtils.getAngle(r,e);return Math.abs(s)<45?__spreadProps$d(__spreadValues$g({},t),{y:i.y}):__spreadProps$d(__spreadValues$g({},t),{x:i.x})},LineToolUtils.getAngle=(r,t)=>{const e=t.x-r.x,i=t.y-r.y;return 360*Math.atan(i/e)/(2*Math.PI)};var __defProp$g=Object.defineProperty,__getOwnPropSymbols$f=Object.getOwnPropertySymbols,__hasOwnProp$f=Object.prototype.hasOwnProperty,__propIsEnum$f=Object.prototype.propertyIsEnumerable,__defNormalProp$g=(r,t,e)=>t in r?__defProp$g(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$f=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$f.call(t,e)&&__defNormalProp$g(r,e,t[e]);if(__getOwnPropSymbols$f)for(var e of __getOwnPropSymbols$f(t))__propIsEnum$f.call(t,e)&&__defNormalProp$g(r,e,t[e]);return r};class PolygonUtils{static getHoverPolygonID(t,e,i=3,s=ELineTypes.Line){let n="",o=Infinity;const a=AxisUtils.axisArea(t,i);return e.forEach(l=>{l.pointList&&a.forEach(h=>{const c=this.calcPolygonSize(l.pointList);this.isInPolygon(h,l.pointList,s)&&c<o&&(n=l.id,o=c)})}),n}static calcPolygonSize(t=[]){if((t==null?void 0:t.length)<=2)return 0;const e=t.length,i=t.reduce((s,n,o,a)=>{const l=a[(o+1)%e];return s+n.x*l.y-l.x*n.y},0);return Math.abs(i)/2}static isInPolygon(t,e,i=ELineTypes.Line){let s=0,n,o,a,l;e=[...e],i===ELineTypes.Curve&&(e=this.createSmoothCurvePoints(e.reduce((c,u)=>[...c,u.x,u.y],[]),.5,!0,20)),[a]=e;const h=e.length;for(n=1;n<=h;n++)l=e[n%h],t.x>Math.min(a.x,l.x)&&t.x<=Math.max(a.x,l.x)&&t.y<=Math.max(a.y,l.y)&&a.x!==l.x&&(o=(t.x-a.x)*(l.y-a.y)/(l.x-a.x)+a.y,(a.y===l.y||t.y<=o)&&s++),a=l;return s%2!=0}static createSmoothCurvePointsFromPointList(t,e=SEGMENT_NUMBER$2){return this.createSmoothCurvePoints(t.reduce((s,n)=>[...s,n.x,n.y],[]),.5,!1,e).map((s,n)=>{var o;const a=n/(SEGMENT_NUMBER$2+1),l=Math.floor(a),h=(o=t[l])!=null?o:{};return __spreadValues$f(l===a?__spreadValues$f({},h):{specialEdge:h.specialEdge},s)})}static createSmoothCurvePoints(t,e=.5,i=!1,s=SEGMENT_NUMBER$2){if(t.length<4)return t;const n=[],o=t.slice(0);let a,l,h,c,u,d,g,p,f,v,m,b,x;for(i?(o.unshift(t[t.length-1]),o.unshift(t[t.length-2]),o.unshift(t[t.length-1]),o.unshift(t[t.length-2]),o.push(t[0]),o.push(t[1])):(o.unshift(t[1]),o.unshift(t[0]),o.push(t[t.length-2]),o.push(t[t.length-1])),x=2;x<o.length-4;x+=2)for(h=(o[x+2]-o[x-2])*e,c=(o[x+4]-o[x-0])*e,u=(o[x+3]-o[x-1])*e,d=(o[x+5]-o[x+1])*e,b=0;b<=s;b++)m=b/s,g=2*Math.pow(m,3)-3*Math.pow(m,2)+1,p=-(2*Math.pow(m,3))+3*Math.pow(m,2),f=Math.pow(m,3)-2*Math.pow(m,2)+m,v=Math.pow(m,3)-Math.pow(m,2),a=g*o[x]+p*o[x+2]+f*h+v*c,l=g*o[x+1]+p*o[x+3]+f*u+v*d,n.push(a),n.push(l);const P=[];for(let w=0;w<n.length-1;w+=2)P.push({x:n[w],y:n[w+1]});if(i)for(let w=0;w<s+1;w++){const L=P.shift();P.push(L)}return P}static getPolygonByID(t,e){return t.find(i=>i.id===e)}static getPolygonByIDs(t,e){if(e&&(e==null?void 0:e.length)>0)return t.filter(i=>e.includes(i.id))}static getHoverEdgeIndex(t,e,i=ELineTypes.Line,s=3){let n=[...e];i===ELineTypes.Curve?n=this.createSmoothCurvePoints(e.reduce((l,h)=>[...l,h.x,h.y],[]),.5,!0,SEGMENT_NUMBER$2):i===ELineTypes.Line&&n.push(n[0]);let o=-1,a=s;for(let l=0;l<n.length-1;l++){const{length:h}=MathUtils.getFootOfPerpendicular(t,n[l],n[l+1]);h<a&&(o=l,a=h)}return o===-1?-1:i===ELineTypes.Curve?Math.floor(o/SEGMENT_NUMBER$2):o}static getClosestPoint(t,e,i=ELineTypes.Line,s=3,n){var o;let a=!1;const l=(o=n==null?void 0:n.isClose)!=null?o:!0;let h="",c=-1,u=Infinity,d=t;const g=20;let p=!1;return e.forEach(f=>{if(!p&&!!f.pointList)switch(i){case ELineTypes.Line:CommonToolUtils$1.findAllLine(f.pointList,l).forEach((m,b)=>{if(p)return;let{length:x,footPoint:P}=MathUtils.getFootOfPerpendicular(t,m.point1,m.point2);const w=MathUtils.getLineLength(m.point1,t),L=MathUtils.getLineLength(m.point2,t);w<s*2&&(P=m.point1,x=w,p=!0),L<s*2&&(P=m.point2,x=L,p=!0),x<u&&x<s&&(h=f.id,c=b,u=x,d=P,a=!0)});break;case ELineTypes.Curve:{const v=this.createSmoothCurvePoints(f.pointList.reduce((m,b)=>[...m,b.x,b.y],[]),.5,l,g);for(let m=0;m<v.length-1;m++){const{length:b,footPoint:x}=MathUtils.getFootOfPerpendicular(t,v[m],v[m+1]);b<u&&b<s&&(h=f.id,c=Math.floor(m/(g+1)),u=b,d=x,a=!0)}}break}}),{dropFoot:d,closestEdgeIndex:c,closestPolygonID:h,hasClosed:a}}static isPointListInPolygon(t,e,i=ELineTypes.Line){return t.every(s=>this.isInPolygon(s,e,i))}static isPointListOutSidePolygon(t,e,i=ELineTypes.Line){return t.some(s=>!this.isInPolygon(s,e,i))}static getPolygonArea(t){let e=0;for(let i=0,s=t.length;i<s;i++){const n=t[i].x,o=t[i===t.length-1?0:i+1].y,a=t[i===t.length-1?0:i+1].x,l=t[i].y;e+=n*o*.5,e-=a*l*.5}return Math.abs(e)}static updatePolygonByRotate(t,e=1,i){let s=1;return t===ERotateDirection.Anticlockwise&&(s=-1),s*=e,MathUtils.rotateRectPointList(s,i)}static deletePolygonLastPoint(t,e,i,s){return i===s.length-1?t:[...t,{x:e[0],y:e[1]}]}static concatBeginAndEnd(t){return t.length<1?t:[...t,t[0]]}static segmentPolygonByPolygon(t,e){var i,s;try{let n=turf.polygon([[...PolygonUtils.concatBeginAndEnd(t.map(a=>[a.x,a.y]))]]);return e.forEach(a=>{const l=turf.polygon([[...PolygonUtils.concatBeginAndEnd(a.pointList.map(c=>[c.x,c.y]))]]),h=turf.difference(n,l);h&&(n=h)}),((s=(i=n==null?void 0:n.geometry)==null?void 0:i.coordinates.map(a=>{var l;return((l=n==null?void 0:n.geometry)==null?void 0:l.type)==="MultiPolygon"?a[0].reduce(PolygonUtils.deletePolygonLastPoint,[]):a.reduce(PolygonUtils.deletePolygonLastPoint,[])}))!=null?s:[]).reduce((a,l)=>{const h=l.length,c=l.filter((u,d)=>{const g=(d+1)%h;return!AxisUtils.getIsInScope(u,l[g],1)});return c.length<3?a:[...a,c]},[])}catch(n){console.error(n)}}static getPolygonPointList(t,e){const i=e.find(s=>s.id===t);return i&&i.pointList&&i.pointList.length>0?i.pointList:[]}static getWrapPolygonIndex(t,e){return e.findIndex(i=>PolygonUtils.isPointListInPolygon(t,i.pointList))}static clipPolygonFromWrapPolygon(t,e){const i=PolygonUtils.isPolygonClosewise(e),s=PolygonUtils.isPolygonClosewise(t),n=PolygonUtils.getClosePointDistanceFromPolygon(t[0],e),o=e[n];let a=[...e.slice(0,n),o,...t,t[0],...e.slice(n,e.length)];return i===s&&(a=[...e.slice(0,n),o,t[0],...t.reverse(),...e.slice(n,e.length)]),a}static isPolygonClosewise(t){const e=t.length;let i,s,n,o=0,a;if(e<3)return 0;for(i=0;i<e;i++)s=(i+1)%e,n=(i+2)%e,a=(t[s].x-t[i].x)*(t[n].y-t[s].y),a-=(t[s].y-t[i].y)*(t[n].x-t[s].x),a<0?o--:a>0&&o++;return o>0?1:o<0?-1:0}static getClosePointDistanceFromPolygon(t,e){let i=Number.MAX_SAFE_INTEGER,s=-1;return e.forEach((n,o)=>{const a=LineToolUtils.calcDistance(t,n);a<i&&(i=a,s=o)}),s}static combinePolygonWithPolygon(t,e){var i,s;try{const n=turf.polygon([[...PolygonUtils.concatBeginAndEnd(t.pointList.map(c=>[c.x,c.y]))]]),o=turf.polygon([[...PolygonUtils.concatBeginAndEnd(e.pointList.map(c=>[c.x,c.y]))]]),a=turf.union(n,o),l=[],h=t;if(((s=(i=a==null?void 0:a.geometry)==null?void 0:i.coordinates)==null?void 0:s.length)===1){l.push(e.id);const c=a==null?void 0:a.geometry.coordinates.map(u=>{var d;return((d=a==null?void 0:a.geometry)==null?void 0:d.type)==="MultiPolygon"?u[0].reduce(PolygonUtils.deletePolygonLastPoint,[]):u.reduce(PolygonUtils.deletePolygonLastPoint,[])})[0];h.pointList=c}return{newPolygon:h,unionList:l}}catch(n){console.error(n)}}}var __defProp$f=Object.defineProperty,__defProps$c=Object.defineProperties,__getOwnPropDescs$c=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$e=Object.getOwnPropertySymbols,__hasOwnProp$e=Object.prototype.hasOwnProperty,__propIsEnum$e=Object.prototype.propertyIsEnumerable,__defNormalProp$f=(r,t,e)=>t in r?__defProp$f(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$e=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$e.call(t,e)&&__defNormalProp$f(r,e,t[e]);if(__getOwnPropSymbols$e)for(var e of __getOwnPropSymbols$e(t))__propIsEnum$e.call(t,e)&&__defNormalProp$f(r,e,t[e]);return r},__spreadProps$c=(r,t)=>__defProps$c(r,__getOwnPropDescs$c(t));class AxisUtils{static getOffsetCoordinate(t,e,i){return{x:t.x*i+e.x,y:t.y*i+e.y}}static changeDrawOutsideTarget(t,e,i,s,n,o){return typeof s=="boolean"&&!s&&(n&&o?(t.x-e.x>(n.x+n.width)*o&&(t.x=(n.x+n.width)*o+e.x),t.x-e.x<n.x*o&&(t.x=n.x*o+e.x),t.y-e.y>(n.y+n.height)*o&&(t.y=(n.y+n.height)*o+e.y),t.y-e.y<n.y*o&&(t.y=n.y*o+e.y)):(t.x-e.x>i.width&&(t.x=i.width+e.x),t.x-e.x<0&&(t.x=e.x),t.y-e.y>i.height&&(t.y=i.height+e.y),t.y-e.y<0&&(t.y=e.y))),t}static changeCoordinateByRotate(t,e,i){const{width:s,height:n}=i,{x:o,y:a}=t;switch(e%360){case 90:return{x:n-a,y:o};case 180:return{x:s-o,y:n-a};case 270:return{x:a,y:s-o};default:return t}}static changeRectByZoom(t,e,i={x:0,y:0}){return __spreadProps$c(__spreadValues$e({},t),{x:t.x*e+i.x,y:t.y*e+i.y,width:t.width*e,height:t.height*e})}static changePointByZoom(t,e,i={x:0,y:0}){return __spreadProps$c(__spreadValues$e({},t),{x:t.x*e+i.x,y:t.y*e+i.y})}static changePointListByZoom(t,e,i={x:0,y:0}){return t.map(s=>this.changePointByZoom(s,e,i))}static axisArea(t,e=3){const{x:i,y:s}=t,n=[];for(let o=i-e;o<i+e;o+=e/3)for(let a=s-e;a<s+e;a+=e/3)n.push({x:o,y:a});return n}static getOriginCoordinateWithOffsetCoordinate(t,e=1,i={x:0,y:0}){return{x:(t.x-i.x)/e,y:(t.y-i.y)/e}}static returnClosePointIndex(t,e,i=3){let s=-1;for(let n=0;n<e.length;n++){const o=e[n];this.getIsInScope(t,o,i)&&(s=n)}return s}static getIsInScope(t,e,i){return Math.abs(t.x-e.x)<i&&Math.abs(t.y-e.y)<i}}class CoordinateUtils{constructor(t){this.currentPos=t.currentPos,this.zoom=t.zoom,this.basicImgInfo=t.basicImgInfo,this.dependToolName=""}get isDependPolygon(){return this.dependToolName===EToolName.Polygon}get isDependRect(){return this.dependToolName===EToolName.Rect}get isDependOriginalImage(){return this.dependToolName===""}getAbsCoord(t){return{x:(t.x-this.currentPos.x)/this.zoom,y:(t.y-this.currentPos.y)/this.zoom}}getRenderCoord(t){return{x:t.x*this.zoom+this.currentPos.x,y:t.y*this.zoom+this.currentPos.y}}coordInsideRect(t,e){const{x:i,y:s,width:n,height:o}=e;return{x:MathUtils.withinRange(t.x,[i,i+n]),y:MathUtils.withinRange(t.y,[s,s+o])}}getPolygonPointList(t,e){return t===ELineTypes.Curve?PolygonUtils.createSmoothCurvePointsFromPointList(e):e}getIntersection(t,e,i){const s=this.getRenderCoord(e),n=this.getRenderCoord(t),o={pointA:s,pointB:n};return LineToolUtils.calcOptimalIntersection(i,o,s,POINT_RADIUS$1,this.zoom)}coordInsidePolygon(t,e,i,s){const{pointList:n}=i,o=s==null?void 0:s.lineType;if(n.length===0)return t;const a=this.getPolygonPointList(o,n);if(PolygonUtils.isInPolygon(t,a))return t;const h=a.concat(a[0]).map(u=>this.getRenderCoord(u)),c=this.getIntersection(t,e,h);return c?this.getAbsCoord(c==null?void 0:c.point):t}coordInsideImage(t){return this.coordInsideRect(t,__spreadProps$c(__spreadValues$e({},this.basicImgInfo),{x:0,y:0}))}getNextCoordByDependTool(t,e){if(this.isDependRect)return this.coordInsideRect(t,this.basicResult);if(this.isDependPolygon)return this.coordInsidePolygon(t,e,this.basicResult,this.dependToolConfig);if(this.isDependOriginalImage)return this.coordInsideImage(t)}setDependInfo(t,e){this.dependToolName=t!=null?t:"",this.dependToolConfig=t?e:void 0}setBasicImgInfo(t){this.basicImgInfo=t}setBasicResult(t){this.basicResult=t}setZoomAndCurrentPos(t,e){this.zoom=t,this.currentPos=e}isCoordInsideTarget(t){if(this.isDependPolygon)return this.isInBasicPolygon(t);if(this.isDependRect){const{x:e,y:i,width:s,height:n}=this.basicResult,o=[e,e+s],a=[i,i+n];return MathUtils.isInRange(t.x,o)&&MathUtils.isInRange(t.y,a)}return MathUtils.isInRange(t.x,[0,this.basicImgInfo.width])&&MathUtils.isInRange(t.y,[0,this.basicImgInfo.height])}isInBasicPolygon(t){var e,i;return PolygonUtils.isInPolygon(t,((e=this.basicResult)==null?void 0:e.pointList)||[],(i=this.dependToolConfig)==null?void 0:i.lineType)}}var __defProp$e=Object.defineProperty,__defProps$b=Object.defineProperties,__getOwnPropDescs$b=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$d=Object.getOwnPropertySymbols,__hasOwnProp$d=Object.prototype.hasOwnProperty,__propIsEnum$d=Object.prototype.propertyIsEnumerable,__defNormalProp$e=(r,t,e)=>t in r?__defProp$e(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$d=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$d.call(t,e)&&__defNormalProp$e(r,e,t[e]);if(__getOwnPropSymbols$d)for(var e of __getOwnPropSymbols$d(t))__propIsEnum$d.call(t,e)&&__defNormalProp$e(r,e,t[e]);return r},__spreadProps$b=(r,t)=>__defProps$b(r,__getOwnPropDescs$b(t));class RectUtils{static composeResult(t,e,i,s,n){try{const o=JSON.parse(t),a=CommonToolUtils$1.getCurrentStepInfo(e,s),{dataSourceStep:l}=a,h=`step_${a.step}`;if(Object.assign(o,n),o[h]){const c=o[h];return c.result?(c.result=i,JSON.stringify(o)):JSON.stringify(__spreadProps$b(__spreadValues$d({},o),{[h]:__spreadProps$b(__spreadValues$d({},o[h]),{result:i})}))}return JSON.stringify(__spreadProps$b(__spreadValues$d({},o),{[h]:{dataSourceStep:l,toolName:a.tool,result:i}}))}catch(o){return t}}static changeCoordinateByRotate(t,e,i){const{x:s,y:n,width:o,height:a}=t,l=AxisUtils.changeCoordinateByRotate({x:s,y:n},e,i);switch(e%360){case 90:return __spreadProps$b(__spreadValues$d({},t),{x:l.x-a,y:l.y,width:a,height:o});case 180:return __spreadProps$b(__spreadValues$d({},t),{x:l.x-o,y:l.y-a});case 270:return __spreadProps$b(__spreadValues$d({},t),{x:l.x,y:l.y-o,width:a,height:o});default:return t}}static translateRect2Points(t){const{x:e,y:i,width:s,height:n}=t;return[{x:e,y:i},{x:e+s,y:i},{x:e+s,y:i+n},{x:e,y:i+n}]}static translatePoints2Rect(t,e){if(t.length!==4)return;const{x:i,y:s}=t[0],n=t[1].x-t[0].x,o=t[2].y-t[1].y;return __spreadProps$b(__spreadValues$d({},e),{x:i,y:s,width:n,height:o})}static getRectPointList(t,e=1){return[{x:t.x*e,y:t.y*e},{x:(t.x+t.width)*e,y:t.y*e},{x:(t.x+t.width)*e,y:(t.y+t.height)*e},{x:t.x*e,y:(t.y+t.height)*e}]}static getRectEdgeList(t,e=1){const i=this.getRectPointList(t,e),s=i.length;return i.map((n,o)=>({begin:n,end:i[(o+1)%s]}))}static isInRect(t,e,i=0,s=1){return t.x>=e.x*s-i&&t.x<=(e.x+e.width)*s+i&&t.y>=e.y*s-i&&t.y<=(e.y+e.height)*s+i}static getRectUnderZoom(t,e=1){const{x:i,y:s,width:n,height:o}=t;return __spreadProps$b(__spreadValues$d({},t),{x:i*e,y:s*e,width:n*e,height:o*e})}static isRectNotInPolygon(t,e){return this.getRectPointList(t).some(s=>!isInPolygon(s,e))}}var EKeyCode;(function(r){r[r.A=65]="A",r[r.B=66]="B",r[r.C=67]="C",r[r.D=68]="D",r[r.E=69]="E",r[r.F=70]="F",r[r.G=71]="G",r[r.H=72]="H",r[r.L=76]="L",r[r.R=82]="R",r[r.Z=90]="Z",r[r.W=87]="W",r[r.X=88]="X",r[r.Y=89]="Y",r[r.S=83]="S",r[r.Q=81]="Q",r[r.Delete=46]="Delete",r[r.F11=122]="F11",r[r.Space=32]="Space",r[r.Esc=27]="Esc",r[r.Left=37]="Left",r[r.Up=38]="Up",r[r.Right=39]="Right",r[r.Down=40]="Down",r[r.Enter=13]="Enter",r[r.Ctrl=17]="Ctrl",r[r.Alt=18]="Alt",r[r.Shift=16]="Shift",r[r.Tab=9]="Tab",r[r.BackSpace=8]="BackSpace"})(EKeyCode||(EKeyCode={}));var EKeyCode$1=EKeyCode,keyCode=Object.freeze({__proto__:null,default:EKeyCode$1}),EMessage;(function(r){r.NoRotateNotice="noRotateNotice",r.RectErrorSizeNotice="rectErrorSizeNotice",r.TextCheckNumberErrorNotice="textCheckNumberErrorNotice",r.TextCheckEnglishErrorNotice="textCheckEnglishErrorNotice",r.TextCheckCustomErrorNotice="textCheckCustomErrorNotice",r.UpperLimitErrorNotice="UpperLimitErrorNotice",r.LowerLimitErrorNotice="LowerLimitErrorNotice",r.InvalidImage="InvalidImage",r.DisableDelete="DisableDelete",r.ClearPartialData="ClearPartialData",r.MarkerFinish="MarkerFinish",r.LowerLimitPoint="LowerLimitPoint",r.NoRotateInDependence="noRotateInDependence",r.UnableToReannotation="unableToReannotation",r.ForbiddenCreationOutsideBoundary="ForbiddenCreationOutsideBoundary",r.SuccessfulEdgeAdsorption="SuccessfulEdgeAdsorption"})(EMessage||(EMessage={}));const message$1={[EMessage.NoRotateNotice]:"This Image contains data and cannot be rotated",[EMessage.RectErrorSizeNotice]:"The drawing frame size is smaller than the minimum drawing size",[EMessage.TextCheckNumberErrorNotice]:"Please enter in number-only format",[EMessage.TextCheckEnglishErrorNotice]:"Please enter in English only format",[EMessage.TextCheckCustomErrorNotice]:"Please enter in the required format",[EMessage.UpperLimitErrorNotice]:"The number of vertices is not more than",[EMessage.LowerLimitErrorNotice]:"The number of vertices is not less than",[EMessage.InvalidImage]:"Invalid image, please skip this image",[EMessage.DisableDelete]:"Disable delete",[EMessage.ClearPartialData]:"Clear partial data",[EMessage.MarkerFinish]:"ListAnnotation is finished",[EMessage.LowerLimitPoint]:"The maximum number of points has been reached",[EMessage.NoRotateInDependence]:"Disallow rotation in dependent cases",[EMessage.UnableToReannotation]:"Unabled to reannotation",[EMessage.ForbiddenCreationOutsideBoundary]:"Fobid creation outside boundary",[EMessage.SuccessfulEdgeAdsorption]:"Successful edge adsorption"},message={[EMessage.NoRotateNotice]:"\u672C\u56FE\u542B\u6709\u6570\u636E\uFF0C\u65E0\u6CD5\u8FDB\u884C\u65CB\u8F6C",[EMessage.RectErrorSizeNotice]:"\u7ED8\u5236\u6846\u5C3A\u5BF8\u5C0F\u4E8E\u6700\u5C0F\u7ED8\u5236\u5C3A\u5BF8",[EMessage.TextCheckNumberErrorNotice]:"\u8BF7\u6309\u4EC5\u6570\u5B57\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.TextCheckEnglishErrorNotice]:"\u8BF7\u6309\u4EC5\u82F1\u6587\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.TextCheckCustomErrorNotice]:"\u8BF7\u6309\u8981\u6C42\u7684\u683C\u5F0F\u8F93\u5165",[EMessage.UpperLimitErrorNotice]:"\u9876\u70B9\u6570\u4E0D\u591A\u4E8E",[EMessage.LowerLimitErrorNotice]:"\u9876\u70B9\u6570\u4E0D\u5C11\u4E8E",[EMessage.InvalidImage]:"\u65E0\u6548\u56FE\u7247\uFF0C\u8BF7\u8DF3\u8FC7\u6B64\u56FE",[EMessage.DisableDelete]:"\u8BE5\u6570\u636E\u7981\u6B62\u5220\u9664",[EMessage.ClearPartialData]:"\u5B58\u5728\u90E8\u5206\u6570\u636E\u65E0\u6CD5\u6E05\u9664",[EMessage.MarkerFinish]:"\u5217\u8868\u6807\u6CE8\u5DF2\u5B8C\u6210",[EMessage.LowerLimitPoint]:"\u5DF2\u5230\u8FBE\u6807\u70B9\u6570\u91CF\u4E0A\u9650",[EMessage.NoRotateInDependence]:"\u4F9D\u8D56\u60C5\u51B5\u4E0B\u65E0\u6CD5\u8FDB\u884C\u65CB\u8F6C",[EMessage.UnableToReannotation]:"\u65E0\u6CD5\u8FDB\u884C\u7EED\u6807\u64CD\u4F5C",[EMessage.ForbiddenCreationOutsideBoundary]:"\u8FB9\u754C\u5916\u7981\u6B62\u521B\u5EFA",[EMessage.SuccessfulEdgeAdsorption]:"\u8FB9\u7F18\u5438\u9644\u6210\u529F"};class Locale{}Locale.getMessagesByLocale=(r,t)=>{switch(t){case ELang.US:return message$1[r];case ELang.Zh:default:return message[r]}};var canvasEdit0='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ccc"/></g></g></svg>',canvasEdit1='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ff2323"/></g></g></svg>',canvasEdit2='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ffe232"/></g></g></svg>',canvasEdit3='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#01ff30"/></g></g></svg>',canvasEdit4='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#00ffea"/></g></g></svg>',canvasEdit5='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#0282fa"/></g></g></svg>',canvasEdit6='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#800cf9"/></g></g></svg>',canvasEdit7='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#ff88f7"/></g></g></svg>',canvasEdit8='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#994217"/></g></g></svg>',baseEditLan='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#1f0bf9"/></g></g></svg>',baseEditQing='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#3fe"/></g></g></svg>',baseEditLv='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#33fe33"/></g></g></svg>',baseEditHuang='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#fdff37"/></g></g></svg>',baseEditFen='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#f70efa"/></g></g></svg>',INVALID_ICON='<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16" viewBox="0 0 16 16"><defs><clipPath id="a"><path d="M0,0H16V-16H0Z" fill="none"/></clipPath><clipPath id="b"><path d="M13.75-2.937H2.25a.5.5,0,0,0-.5.5v.563a.125.125,0,0,0,.125.125h12.25a.125.125,0,0,0,.125-.125v-.562A.5.5,0,0,0,13.75-2.937ZM4.027-4.25a.632.632,0,0,0,.094-.008l2.628-.461a.153.153,0,0,0,.083-.044l6.623-6.623a.156.156,0,0,0,0-.22l-2.6-2.6a.155.155,0,0,0-.111-.045.155.155,0,0,0-.111.045L4.012-7.581a.159.159,0,0,0-.044.083L3.508-4.87a.524.524,0,0,0,.147.466.529.529,0,0,0,.372.155Z" fill="none"/></clipPath></defs><g transform="translate(0 16)"><g clip-path="url(#a)"><path d="M-5-21H21V5H-5Z" fill="rgba(0,0,0,0)"/></g><g clip-path="url(#b)"><path d="M-3.25-19.25h22.5V3.25H-3.25Z" fill="#f33"/></g></g></svg>';const NULL_ICON=canvasEdit0,HEADER_HEIGHT=61,TAB_HEIGHT=80,SEARCH_HEIGHT=62,PADDING=20,TABLE_ROW_HEIGHT=55,PAGINATION_HEIGHT=55,TIPS_HEIGHT=40,FOOTER_HEIGHT=80,SIDERBAR_WIDTH=240,EDIT_STEP_WIDTH=320,THEME_COLOR="rgba(102, 111, 255, 1)",COLORS_ARRAY=["rgba(128, 12, 249, 1)","rgba(0, 255, 48, 1)","rgba(255, 136, 247, 1)","rgba(255, 226, 50, 1)","rgba(153, 66, 23, 1)","rgba(2, 130, 250, 1)","rgba(255, 35, 35, 1)","rgba(0, 255, 234, 1)"],ICON_ARRAY=[canvasEdit0,canvasEdit6,canvasEdit3,canvasEdit7,canvasEdit2,canvasEdit8,canvasEdit5,canvasEdit1,canvasEdit4],BASE_ICON={1:baseEditLan,3:baseEditQing,5:baseEditLv,7:baseEditHuang,9:baseEditFen},INVALID_COLOR="rgba(255, 51, 51, 1)",NULL_COLOR="rgba(204, 204, 204, 1)",FILTER_TOOL_COLOR={[EFilterToolOperation.lc]:"rgba(153, 51, 255, 1)",[EFilterToolOperation.rc]:"rgba(51, 153, 255, 1)",[EFilterToolOperation.clc]:"rgba(46, 230, 46, 1)",[EFilterToolOperation.crc]:"rgba(255, 51, 51, 1)"};var style=Object.freeze({__proto__:null,HEADER_HEIGHT,TAB_HEIGHT,SEARCH_HEIGHT,PADDING,TABLE_ROW_HEIGHT,PAGINATION_HEIGHT,TIPS_HEIGHT,FOOTER_HEIGHT,SIDERBAR_WIDTH,EDIT_STEP_WIDTH,THEME_COLOR,COLORS_ARRAY,ICON_ARRAY,BASE_ICON,INVALID_COLOR,NULL_COLOR,NULL_ICON,INVALID_ICON,FILTER_TOOL_COLOR}),__defProp$d=Object.defineProperty,__defProps$a=Object.defineProperties,__getOwnPropDescs$a=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$c=Object.getOwnPropertySymbols,__hasOwnProp$c=Object.prototype.hasOwnProperty,__propIsEnum$c=Object.prototype.propertyIsEnumerable,__defNormalProp$d=(r,t,e)=>t in r?__defProp$d(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$c=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$c.call(t,e)&&__defNormalProp$d(r,e,t[e]);if(__getOwnPropSymbols$c)for(var e of __getOwnPropSymbols$c(t))__propIsEnum$c.call(t,e)&&__defNormalProp$d(r,e,t[e]);return r},__spreadProps$a=(r,t)=>__defProps$a(r,__getOwnPropDescs$a(t));const REGEXP_NUMBER="^[0-9]+$",REGEXP_ENGLISH="^[A-Za-z]+$";class AttributeUtils{static getAttributeIcon(t,e,i=!0){var s;const n=e.findIndex(l=>l.value===t);let o=(s=ICON_ARRAY[n%ICON_ARRAY.length])!=null?s:NULL_ICON;i||(o=INVALID_ICON),o="";const a=new Image;return a.src=o,a}static checkString(t,e){let i="";switch(t){case ETextType.Order:case ETextType.NumberOnly:i=REGEXP_NUMBER;break;case ETextType.EnglishOnly:i=REGEXP_ENGLISH;break;case ETextType.CustomFormat:i=e;break}return i}static checkTextAttibute(t,e){if(t===void 0||t==="")return!0;try{return new RegExp(e).test(t)}catch(i){return!1}}static getAttributeShowText(t,e=[]){var i,s;try{const n=e.findIndex(o=>o.value===t);return(s=(i=e[n])==null?void 0:i.key)!=null?s:t}catch(n){return t}}static getAttributeIndex(t,e){try{const i=e.findIndex(s=>s.value===t);return i>=8?i%8:i}catch(i){return-1}}static getAttributeColor(t,e){try{const i=this.getAttributeIndex(t,e);return i===-1?NULL_COLOR:COLORS_ARRAY[i%COLORS_ARRAY.length]}catch(i){return NULL_COLOR}}static getTextAttribute(t,e){try{if(e===ETextType.Order){const i=t.map(n=>parseInt(n.textAttribute,10)).filter(n=>_.isNumber(n)&&n<Number.MAX_SAFE_INTEGER&&n>=0);return i.sort((n,o)=>n-o),`${(i.pop()||0)+1}`}return""}catch(i){return""}}static textChange(t,e,i){return i.map(s=>s.id===e?__spreadProps$a(__spreadValues$c({},s),{textAttribute:t}):s)}static getErrorNotice(t,e){switch(t){case ETextType.Order:case ETextType.NumberOnly:return Locale.getMessagesByLocale(EMessage.TextCheckNumberErrorNotice,e);case ETextType.EnglishOnly:return Locale.getMessagesByLocale(EMessage.TextCheckEnglishErrorNotice,e);case ETextType.CustomFormat:return Locale.getMessagesByLocale(EMessage.TextCheckCustomErrorNotice,e);default:return""}}static textAttributeValidate(t,e,i){try{return new RegExp(this.checkString(t,e)).test(i)}catch(s){}}static checkTextAttribute(t,e,i,s){let n=!1;return i.forEach(o=>{(o==null?void 0:o.textAttribute)===void 0||(o==null?void 0:o.textAttribute)===""||(s?o.id===s:!0)&&!this.textAttributeValidate(t,e,o.textAttribute)&&(n=!0)}),!!n}static changeTextAttributeInLog(t,e){return t==null?void 0:t.map(i=>i==null?void 0:i.map(s=>{if((e==null?void 0:e.findIndex(n=>(n==null?void 0:n.id)===(s==null?void 0:s.id)))>-1){const n=e==null?void 0:e.find(o=>(o==null?void 0:o.id)===(s==null?void 0:s.id));return __spreadProps$a(__spreadValues$c({},s),{textAttribute:n==null?void 0:n.textAttribute})}return s}))}static getTextIconSvg(t="",e,i=!1,s){if(i===!0){const n=(e==null?void 0:e.findIndex(o=>(o==null?void 0:o.value)===t))%COLORS_ARRAY.length+1;return ICON_ARRAY[n]}return s}static getAttributeByKeycode(t,e){var i;let s;return MathUtils.isInRange(t,[48,57])&&(s=t-48),MathUtils.isInRange(t,[96,105])&&(s=t-96),s===0?"":s?(i=e[s-1])==null?void 0:i.value:void 0}}class CanvasUtils{static getMousePositionOnCanvasFromEvent(t,e){if(e&&t){const i=e.getBoundingClientRect();return{x:t.clientX-i.left,y:t.clientY-i.top}}return null}static getClientRect(t){if(t){const e=t.getBoundingClientRect();return{x:e.left,y:e.top,width:e.width,height:e.height}}return null}static getSize(t){if(t){const e=t.getBoundingClientRect();return{width:e.width,height:e.height}}return null}static inViewPort(t,e){return t?MathUtils.isInRange(t.x,[e.left,e.right])&&MathUtils.isInRange(t.y,[e.top,e.bottom]):!1}}CanvasUtils.getViewPort=(r,t,e)=>{const{width:i,height:s}=r,{x:n,y:o}=t,a=(0-o)/e,l=(0-n)/e,h=a+s/e,c=l+i/e;return{top:a,bottom:h,left:l,right:c}},CanvasUtils.getPixelRatio=r=>{if(!r||!window)return 1;const t=r.backingStorePixelRatio||r.webkitBackingStorePixelRatio||r.mozBackingStorePixelRatio||r.msBackingStorePixelRatio||r.oBackingStorePixelRatio||r.backingStorePixelRatio||1;return(window.devicePixelRatio||1)/t};class UnitUtils{static deg2rad(t){return t*Math.PI/180}static rad2deg(t){return t*180/Math.PI}}var __defProp$c=Object.defineProperty,__defProps$9=Object.defineProperties,__getOwnPropDescs$9=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$b=Object.getOwnPropertySymbols,__hasOwnProp$b=Object.prototype.hasOwnProperty,__propIsEnum$b=Object.prototype.propertyIsEnumerable,__defNormalProp$c=(r,t,e)=>t in r?__defProp$c(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$b=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$b.call(t,e)&&__defNormalProp$c(r,e,t[e]);if(__getOwnPropSymbols$b)for(var e of __getOwnPropSymbols$b(t))__propIsEnum$b.call(t,e)&&__defNormalProp$c(r,e,t[e]);return r},__spreadProps$9=(r,t)=>__defProps$9(r,__getOwnPropDescs$9(t));const DEFAULT_ZOOM=1,DEFAULT_CURRENT_POS={x:0,y:0},DEFAULT_ROTATE=0,DEFAULT_COLOR="";class DrawUtils{static drawLine(t,e,i,s={}){const n=t.getContext("2d"),{color:o=DEFAULT_COLOR,thickness:a=1,lineCap:l="round"}=s;n.save(),n.strokeStyle=o,n.lineWidth=a,n.lineCap=l,n.beginPath(),n.moveTo(e.x,e.y),n.lineTo(i.x+1,i.y+1),n.stroke(),n.restore()}static drawRect(t,e,i={}){const s=t.getContext("2d"),{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",hiddenText:l=!1,lineDash:h}=i;if(s.save(),s.strokeStyle=n,s.lineWidth=o,s.lineCap=a,Array.isArray(h)&&s.setLineDash(h),s.fillStyle=n,s.strokeRect(e.x,e.y,e.width,e.height),l===!1){let c="";if(e.attribute&&(c=`${c} ${e.attribute}`),this.drawText(t,{x:e.x,y:e.y-5},c),e.textAttribute){const d=`${~~e.width} * ${~~e.height}`.length*7,g=0,p=Math.max(20,e.width-d);this.drawText(t,{x:e.x,y:e.y+e.height+20+g},e.textAttribute,{textMaxWidth:p})}}s.restore()}static drawRectWithFill(t,e,i={}){const s=t.getContext("2d"),{color:n=DEFAULT_COLOR}=i;s.save(),s.fillStyle=n,s.fillRect(e.x,e.y,e.width,e.height),s.restore()}static drawTagByDom(t,e,i){const s=t;if(!((e==null?void 0:e.length)>0))return;const n=document.createElement("div");return n.innerHTML=e,n.setAttribute("id",i),s==null||s.appendChild(n),n}static drawTag(t,e){var i;const s=t==null?void 0:t.parentNode,n=window.self.document.getElementById("tagToolTag");if(n&&s&&s.contains(n)&&(s==null||s.removeChild(n)),!((e==null?void 0:e.length)>0))return;const o=document.createElement("div");return o.innerHTML=(i=e.reduce((a,l)=>`${a}${l.keyName}: ${l.value.join(" \u3001 ")}
|
|
7
|
+
`,""))!=null?i:"",o.setAttribute("id","tagToolTag"),s==null||s.appendChild(o),o}static drawLineWithPointList(t,e,i={}){if(e.length<2)return;const s=t.getContext("2d"),{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",lineType:l=ELineTypes.Line,lineDash:h,hoverEdgeIndex:c}=i;s.save(),(()=>{s.strokeStyle=n,s.lineWidth=o,s.lineCap=a,Array.isArray(h)?s.setLineDash(h):s.setLineDash([])})(),l===ELineTypes.Curve?(c!==void 0&&c>-1&&e.push(e[0]),e=PolygonUtils.createSmoothCurvePointsFromPointList([...e],SEGMENT_NUMBER$2),c!==void 0&&c>-1&&(e=e.slice((SEGMENT_NUMBER$2+1)*c,(SEGMENT_NUMBER$2+1)*(c+1)))):c!==void 0&&c>-1&&(e=[...e,e[0]],e=e.slice(c,c+2));const d=[];s.beginPath(),s.moveTo(e[0].x,e[0].y);for(let f=0;f<e.length-1;f++)e[f].specialEdge&&d.push({i1:f,i2:f+1}),s.lineTo(e[f+1].x,e[f+1].y);s.stroke(),s.save(),s.lineWidth=o*.8,s.lineCap="butt",s.strokeStyle="white",s.setLineDash([3,3]),d.forEach(f=>{const v=e[f.i1],m=e[f.i2];s.beginPath(),s.moveTo(v.x,v.y),s.lineTo(m.x,m.y),s.stroke()}),s.restore();const g=4,p=2;return e.forEach(f=>{f.specialPoint&&(this.drawSpecialPoint(t,f,g+p,n),this.drawSpecialPoint(t,f,g,"white"))}),s.restore(),e}static drawCircle(t,e,i,s={}){const n=t.getContext("2d"),{startAngleDeg:o=0,endAngleDeg:a=360,thickness:l=1,color:h=DEFAULT_COLOR,fill:c=DEFAULT_COLOR}=s,u=UnitUtils.deg2rad(o),d=UnitUtils.deg2rad(a);n.save(),n.beginPath(),n.strokeStyle=h,n.fillStyle=c,n.lineWidth=l,n.arc(e.x,e.y,i,u,d,!1),n.stroke(),c&&n.fill(),n.closePath(),n.restore()}static drawCircleWithFill(t,e,i=3,s={}){const n=t.getContext("2d"),{color:o=DEFAULT_COLOR}=s;n.save();const a=UnitUtils.deg2rad(0),l=UnitUtils.deg2rad(360);n.fillStyle=o,n.beginPath(),n.arc(e.x,e.y,i,a,l,!1),n.fill(),n.restore()}static drawSpecialPoint(t,e,i=6,s){const n=t.getContext("2d"),{x:o,y:a}=e;n.save(),n.beginPath(),n.fillStyle=s;const l=i*1.5,h=l*Math.sqrt(3)/2,c=l/2;n.moveTo(o,a-l),n.lineTo(o-h,a+c),n.lineTo(o+h,a+c),n.closePath(),n.fill(),n.restore()}static drawPolygon(t,e,i={}){const{isClose:s=!1,lineType:n=ELineTypes.Line}=i;return s===!0&&(e=[...e,e[0]]),n===ELineTypes.Curve&&(e=PolygonUtils.createSmoothCurvePointsFromPointList([...e])),this.drawLineWithPointList(t,e,__spreadProps$9(__spreadValues$b({},i),{lineType:ELineTypes.Line})),e}static drawPolygonWithFill(t,e,i={}){if(e.length<2)return;const s=t.getContext("2d"),{color:n=DEFAULT_COLOR,lineType:o=ELineTypes.Line}=i;s.save(),s.fillStyle=n,s.beginPath(),o===ELineTypes.Curve&&(e=PolygonUtils.createSmoothCurvePointsFromPointList([...e,e[0]]));const[a,...l]=e;return s.moveTo(a.x,a.y),l.forEach(h=>{s.lineTo(h.x,h.y)}),s.fill(),s.restore(),e}static drawPolygonWithFillAndLine(t,e,i={}){const{strokeColor:s,fillColor:n,thickness:o,lineCap:a,isClose:l,lineType:h}=i,c=this.drawPolygon(t,e,{color:s,thickness:o,lineCap:a,isClose:l,lineType:h});return this.drawPolygonWithFill(t,e,{color:n,lineType:h}),c}static drawPolygonWithKeyPoint(t,e,i={}){const{pointColor:s="white",strokeColor:n}=i,o=this.drawPolygon(t,e,i);return o.forEach(a=>{this.drawCircleWithFill(t,a,4,{color:n}),this.drawCircleWithFill(t,a,3,{color:s})}),o}static drawSelectedPolygonWithFillAndLine(t,e,i={}){const{pointColor:s="white",strokeColor:n}=i,o=this.drawPolygonWithFillAndLine(t,e,i);return o.forEach(a=>{this.drawCircleWithFill(t,a,4,{color:n}),this.drawCircleWithFill(t,a,3,{color:s})}),o}static drawText(t,e,i,s={}){if(!i)return;const n=t.getContext("2d"),{color:o=DEFAULT_COLOR,font:a=DEFAULT_FONT,shadowColor:l="",shadowBlur:h=0,shadowOffsetX:c=0,shadowOffsetY:u=0,textMaxWidth:d=164,offsetX:g=0,offsetY:p=0,textAlign:f="start",lineHeight:v}=s;n.save(),n.textAlign=f,n.fillStyle=o!=null?o:"white",n.font=a,n.shadowColor=l,n.shadowOffsetX=c,n.shadowOffsetY=u,n.shadowBlur=h,this.wrapText(t,`${i}`,e.x+g,e.y+p,d,v),n.restore()}static wrapText(t,e,i,s,n,o){if(typeof e!="string"||typeof i!="number"||typeof s!="number")return;const a=t.getContext("2d");typeof n=="undefined"&&(n=t&&t.width||300),typeof o=="undefined"&&(o=t&&parseInt(window.getComputedStyle(t).lineHeight,10)||parseInt(window.getComputedStyle(document.body).lineHeight,10));const l=e.split(`
|
|
8
|
+
`);for(let h=0;h<l.length;h++){const c=l[h].split("");let u="";for(let d=0;d<c.length;d++){const g=u+c[d],f=a.measureText(g).width;n||(n=300),f>n&&d>0?(a.fillText(u,i,s),u=c[d],s+=o):u=g}a.fillText(u,i,s),s+=o}}static drawArrow(t,e,i,s={}){const{color:n=DEFAULT_COLOR,thickness:o=1,lineCap:a="round",theta:l=30,headLen:h=10}=s,c=Math.atan2(e.y-i.y,e.x-i.x)*180/Math.PI,u=(c+l)*Math.PI/180,d=(c-l)*Math.PI/180,g=h*Math.cos(u),p=h*Math.sin(u),f=h*Math.cos(d),v=h*Math.sin(d);t.save(),t.strokeStyle=n,t.lineWidth=o,t.lineCap=a,t.beginPath(),t.moveTo(i.x+g,i.y+p),t.lineTo(i.x,i.y),t.lineTo(i.x+f,i.y+v),t.stroke(),t.restore()}static drawArrowByCanvas(t,e,i,s={}){const n=t.getContext("2d");this.drawArrow(n,e,i,s)}}DrawUtils.drawImg=(r,t,e={})=>{const i=r.getContext("2d"),{zoom:s=DEFAULT_ZOOM,currentPos:n=DEFAULT_CURRENT_POS,rotate:o=DEFAULT_ROTATE,imgAttribute:a}=e;switch(i.save(),o){case 0:i.translate(n.x,n.y);break;case 90:i.translate(n.x+t.height*s,n.y),i.rotate(90*Math.PI/180);break;case 180:i.translate(n.x+t.width*s,n.y+t.height*s),i.rotate(Math.PI);break;case 270:i.translate(n.x,n.y+t.width*s),i.rotate(270*Math.PI/180);break;default:i.translate(n.x,n.y);break}if(a){const{contrast:l,saturation:h,brightness:c}=a;i.filter=`saturate(${h+100}%) contrast(${l+100}%) brightness(${c+100}%)`}i.drawImage(t,0,0,t.width*s,t.height*s),i.restore()};class MarkerUtils{static getMarkerShowText(t,e=[]){return AttributeUtils.getAttributeShowText(t,e)}}function uuid(r=8,t=62){const e="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""),i=[];let s;if(t=t||e.length,r)for(s=0;s<r;s++)i[s]=e[0|Math.random()*t];else{let n;for(i[8]=i[13]=i[18]=i[23]="-",i[14]="4",s=0;s<36;s++)i[s]||(n=0|Math.random()*16,i[s]=e[s===19?n&3|8:n])}return i.join("")}const rectToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,drawOutsideTarget:!1,copyBackwardResult:!1,minWidth:1,minHeight:1,isShowOrder:!1,filterData:["valid","invalid"],attributeConfigurable:!1,attributeList:[],textConfigurable:!1,textCheckType:0,customFormat:""},tagToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,inputList:[{key:"\u7C7B\u522B1",value:"class1",isMulti:!1,subSelected:[{key:"\u9009\u98791",value:"option1",isDefault:!1},{key:"\u9009\u98792",value:"option1-2",isDefault:!1}]},{key:"\u7C7B\u522B2",value:"class-AH",isMulti:!0,subSelected:[{key:"\u9009\u98792-1",value:"option2-1",isDefault:!1},{key:"\u9009\u98792-2",value:"option2-2",isDefault:!1},{key:"\u9009\u98792-3",value:"option2-3",isDefault:!1}]},{key:"\u7C7B\u522B3",value:"class-0P",isMulti:!1,subSelected:[{key:"\u9009\u98793-1",value:"option3-1",isMulti:!1},{key:"\u9009\u98793-2",value:"option3-2",isDefault:!1},{key:"\u9009\u98793-3",value:"option3-3",isDefault:!1}]}]},lineToolConfig={lineType:0,lineColor:0,edgeAdsorption:!1,outOfTarget:!0,copyBackwardResult:!1,isShowOrder:!1,attributeConfigurable:!1,attributeList:[{key:"\u7C7B\u522B1",value:"\u7C7B\u522B1"},{key:"\u7C7B\u522Bao",value:"class-ao"},{key:"\u7C7B\u522BM1",value:"class-M1"},{key:"\u7C7B\u522BCm",value:"class-Cm"},{key:"\u7C7B\u522Bc3",value:"class-c3"},{key:"\u7C7B\u522Ba0",value:"class-a0"},{key:"\u7C7B\u522Bu7",value:"class-u7"},{key:"\u7C7B\u522BZb",value:"class-Zb"},{key:"\u7C7B\u522Bzi",value:"class-zi"}],textConfigurable:!1,textCheckType:2,customFormat:"",showConfirm:!1,lowerLimitPointNum:2,upperLimitPointNum:"",preReferenceStep:0,skipWhileNoDependencies:!1,filterData:["valid","invalid"]},textToolConfig={showConfirm:!1,skipWhileNoDependencies:!1,enableTextRecognition:!1,recognitionMode:"general",configList:[{label:"\u6587\u672C",key:"text",required:!1,default:"",maxLength:1e3}],filterData:["valid","invalid"]},polygonConfig={lineType:0,lineColor:0,lowerLimitPointNum:3,edgeAdsorption:!1,drawOutsideTarget:!1,copyBackwardResult:!1,isShowOrder:!1,attributeConfigurable:!1,attributeList:[],textConfigurable:!0,textCheckType:0,customFormat:""},getConfig=r=>r==="lineTool"?lineToolConfig:r==="rectTool"?rectToolConfig:r==="tagTool"?tagToolConfig:r==="textTool"?textToolConfig:r==="polygonTool"?polygonConfig:rectToolConfig,styleDefaultConfig={toolColor:{1:{valid:{stroke:"rgba(0,0,255,0.50)",fill:"rgba(0,0,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(0,15,255,1.00)",fill:"rgba(0,15,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(0,15,255,0.80)",fill:"rgba(0,15,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},3:{valid:{stroke:"rgba(0,255,255,0.50)",fill:"rgba(0,255,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(0,212,255,1.00)",fill:"rgba(0,212,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(0,212,255,0.80)",fill:"rgba(0,212,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},5:{valid:{stroke:"rgba(0,255,0,0.50)",fill:"rgba(0,255,0,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(149,255,1.00)",fill:"rgba(149,255,0,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(149,255,0,0.80)",fill:"rgba(149,255,0,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},7:{valid:{stroke:"rgba(255,255,0,0.50)",fill:"rgba(255,255,0,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(255,230,102,1.00)",fill:"rgba(255,213,0,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(255,230,102,0.80)",fill:"rgba(255,230,102,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}},9:{valid:{stroke:"rgba(255,0,255,0.50)",fill:"rgba(255,0,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.80)"},validSelected:{stroke:"rgba(230,102,255,1.00)",fill:"rgba(213,0,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,0.60)",fill:"rgba(255,0,0,0.24)"},validHover:{stroke:"rgba(230,102,255,0.80)",fill:"rgba(230,102,255,0.64)"},invalidHover:{stroke:"rgba(255,0,0,0.50)",fill:"rgba(255,0,0,0.40)"}}},attributeColor:[{valid:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(204,204,204,1.00)",fill:"rgba(204,204,204,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(153,51,255,1.00)",fill:"rgba(153,51,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,254,51,1.00)",fill:"rgba(51,254,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,51,255,1.00)",fill:"rgba(255,51,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(204,255,51,1.00)",fill:"rgba(204,255,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,153,255,1.00)",fill:"rgba(51,153,255,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,153,51,1.00)",fill:"rgba(255,153,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(51,255,238,1.00)",fill:"rgba(51,255,238,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}},{valid:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.40)"},invalid:{stroke:"rgba(255,153,102,1.00)",fill:"rgba(255,153,102,0.40)"},validSelected:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.80)"},invalidSelected:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"},validHover:{stroke:"rgba(255,221,51,1.00)",fill:"rgba(255,221,51,0.80)"},invalidHover:{stroke:"rgba(255,0,0,1.00)",fill:"rgba(255,0,0,0.80)"}}],lineColor:{1:"rgba(102, 111, 255, 1 )",3:"rgba(102, 230, 255, 1)",5:"rgba(191, 255, 102, 1)",7:"rgba(255, 230, 102, 1)",9:"rgba(230, 102, 255, 1)"},attributeLineColor:["rgba(204, 204, 204, 1)","rgba(153, 51, 255, 1)","rgba(51, 254, 51, 1)","rgba(255, 51, 255, 1)","rgba(204, 255, 51, 1)","rgba(51, 153, 255, 1)","rgba(255, 153, 51, 1)","rgba(51, 255, 238, 1)","rgba(255, 221, 51, 1)"],color:1,width:2,opacity:9};class ActionsHistory{constructor(t){this.record=[],this.recordIndex=-1,this.minRecordIndex=-1,this.emitHistoryChanged=()=>{this.historyChanged&&(this.constructor.name==="ActionsHistory"?!0:this.record.length>0)&&this.historyChanged(this.undoEnabled,this.redoEnabled)},this.historyChanged=t}get undoEnabled(){return this.recordIndex>this.minRecordIndex}get redoEnabled(){return this.recordIndex<this.record.length-1}pushHistory(t){if(this.recordIndex!==this.record.length-1){const e=this.record.slice(0,Math.min(this.recordIndex+1,this.record.length));this.record=e}this.record.push(___default.default.cloneDeepWith(t)),this.recordIndex+=1,this.emitHistoryChanged()}updateHistory(t){this.record[this.recordIndex]=___default.default.cloneDeep(t)}applyAttribute(t,e,i){t&&this.record.forEach(s=>{const n=s.find(o=>o.id===t);n&&(n[e]=i)})}undo(){if(this.undoEnabled)return this.recordIndex-=1,this.emitHistoryChanged(),___default.default.cloneDeep(this.record[this.recordIndex])||[]}redo(){if(this.redoEnabled)return this.recordIndex+=1,this.emitHistoryChanged(),___default.default.cloneDeep(this.record[this.recordIndex])}init(){this.record=[[]],this.recordIndex=0,this.emitHistoryChanged()}empty(){this.record=[],this.recordIndex=-1,this.emitHistoryChanged()}initRecord(t,e=!1){const i=t.length>0||e;this.record=i?[___default.default.cloneDeep(t)]:[],this.minRecordIndex=i?0:-1,this.recordIndex=0}}class DblClickEventListener{constructor(t,e){this.rcTime=0,this.mouseDownTime=0,this.onMouseDown=()=>{this.mouseDownTime=new Date().getTime()},this.dom=t,this.isDoubleClick=!1,this.delay=e}getRcTime(){return this.rcTime}getCoord(t){return{x:t.clientX,y:t.clientY}}removeEvent(){!this.dom||(this.dom.removeEventListener("mouseup",this.mouseUp),this.dom.removeEventListener("mousemove",this.mouseMove),this.dom.removeEventListener("dblclick",this.dblclick),this.dom.removeEventListener("mousedown",this.onMouseDown))}addEvent(t,e,i,s){!this.dom||(this.removeEvent(),this.mouseUp=n=>{const o=new Date().getTime(),a=s?s(n):!0;if(o-this.mouseDownTime>this.delay||a!==!0){t(n);return}if(n.button===2)if(this.rcTime===0)setTimeout(()=>{this.rcTime=0},this.delay),this.rcTime=o;else{o-this.rcTime<this.delay&&(i(n),clearTimeout(this.setTimeFun),this.cacheFunction=void 0),this.rcTime=0;return}this.setTimeFun&&clearTimeout(this.setTimeFun),this.clickCoord=this.getCoord(n),this.cacheFunction=()=>t(n),this.setTimeFun=setTimeout(()=>{if(this.isDoubleClick){this.isDoubleClick=!1;return}this.cacheFunction(),this.clickCoord=void 0},this.delay)},this.mouseMove=n=>{const o=this.getCoord(n);this.clickCoord&&!AxisUtils.getIsInScope(o,this.clickCoord,10)&&(this.cacheFunction&&this.cacheFunction(),this.clickCoord=void 0,this.cacheFunction=null,clearTimeout(this.setTimeFun))},this.dblclick=n=>{this.isDoubleClick=!0,this.clickCoord=void 0,e(n)},this.dom.addEventListener("mouseup",this.mouseUp),this.dom.addEventListener("mousemove",this.mouseMove),this.dom.addEventListener("dblclick",this.dblclick),this.dom.addEventListener("mousedown",this.onMouseDown))}clearRightDblClick(){this.rcTime=0}}class ImgPosUtils{static getInitImgPos(t,e,i=0,s=1,n=!1){(i===90||i===270)&&(e={width:e.height,height:e.width});const o=t.width*s/e.width,a=t.height*s/e.height;let l=n?1:Math.min(o,a);const h={x:(t.width-e.width*l)/2,y:(t.height-e.height*l)/2},c=e.width*l,u=e.height*l;return n&&(l=1),{zoom:l,currentPos:h,imgInfo:{width:c,height:u}}}static getBasicRecPos(t,e,i,s=.9,n=1,o=!1){if(e&&t){const{x:a,y:l,height:h,width:c}=e;let u=i.height/h;c/h>i.width/i.height&&(u=i.width/c);const d=o?1:u*s*n,g={x:i.width/2,y:i.height/2},p={x:(a+c/2)*d,y:(l+h/2)*d};return{currentPos:{x:g.x-p.x,y:g.y-p.y},innerZoom:d}}return!1}}class RenderDomUtils{static renderInvalidPage(t,e,i){const s=document.createElement("div");return s.setAttribute("style",`
|
|
9
9
|
position: absolute;
|
|
10
10
|
left: 0px;
|
|
11
11
|
top: 0px;
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
font-size: 30px;
|
|
21
21
|
opacity: 0.7;
|
|
22
22
|
z-index: 30;
|
|
23
|
-
`),s.innerHTML=Locale.getMessagesByLocale(EMessage.InvalidImage,i),t.appendChild(s),s}}const ZOOM_LEVEL=[1,5,10,20,30,50,80,100].concat(Array.from({length:9}).map((r,t)=>(t+2)*100));class ZoomUtils{}ZoomUtils.zoomChanged=(r,t,e=EGrowthMode.Linear)=>{switch(e){case EGrowthMode.Intelligence:{const i=Math.max(...ZOOM_LEVEL),s=Math.min(...ZOOM_LEVEL),n=ZOOM_LEVEL.slice(0,ZOOM_LEVEL.length).findIndex((a,l)=>r>=a&&(r<ZOOM_LEVEL[l+1]||a===i));let o;if(n===-1)r>=s&&r<=i?o=t?i:s:o=t?s:r;else{const a=t?n+1:n-(ZOOM_LEVEL.includes(r)?1:0);o=ZOOM_LEVEL[MathUtils.withinRange(a,[0,ZOOM_LEVEL.length-1])]}return o}default:{const i=t?2:1/2;return r*i}}},ZoomUtils.wheelChangePos=(r,t,e,i,s={})=>{const{zoom:n=1,innerZoom:o=1,basicZoom:a=1,zoomMax:l=1e3,rotate:h=0}=s,{x:d,y:u}=i,c=parseFloat((n+1/10).toFixed(1))/5;if(r&&t){let{width:g,height:p}=r;[90,270].includes(h)&&(g=r.height,p=r.width);const f=g*o,v=p*o,m=t.x-d,x=t.y-u,b=m/f,P=x/v;let w=n+e*c;w=MathUtils.withinRange(w,[a,l]);const L=g*w*b,R=p*w*P,C=d+(m-L),D=u+(x-R);return{zoom:w,currentPos:{x:C,y:D},imgInfo:{width:g*w,height:p*w},ratio:c}}return null};class EventListener{constructor(){this._events=new Map}on(t,e){const i=this._events.get(t)||[];i.some(s=>s===e)||this._events.set(t,i.concat(e))}singleOn(t,e){this._events.set(t,[e])}emit(t,...e){const i=this._events.get(t);i&&i.forEach(s=>{s&&s(...e)})}unbind(t,e){const i=this._events.get(t);i&&this._events.set(t,i.filter(s=>s!==e))}unbindAll(t){this._events.delete(t)}}var __defProp$b=Object.defineProperty,__defProps$8=Object.defineProperties,__getOwnPropDescs$8=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$a=Object.getOwnPropertySymbols,__hasOwnProp$a=Object.prototype.hasOwnProperty,__propIsEnum$a=Object.prototype.propertyIsEnumerable,__defNormalProp$b=(r,t,e)=>t in r?__defProp$b(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$a=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$a.call(t,e)&&__defNormalProp$b(r,e,t[e]);if(__getOwnPropSymbols$a)for(var e of __getOwnPropSymbols$a(t))__propIsEnum$a.call(t,e)&&__defNormalProp$b(r,e,t[e]);return r},__spreadProps$8=(r,t)=>__defProps$8(r,__getOwnPropDescs$8(t)),__async$3=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const zoomInfo={min:.2,max:1e3,ratio:.4};class BasicToolOperation extends EventListener{constructor(t){super();this.isDrag=!1,this.isSpaceKey=!1,this.innerZoom=1,this.basicZoom=.01,this.isSpaceClick=!1,this.isDragStart=!1,this.startTime=0,this.initImgPos=()=>__async$3(this,null,function*(){var u,c;if(!this.imgNode)return;const g=(u=this._imgAttribute)==null?void 0:u.zoomRatio,p=(c=this._imgAttribute)==null?void 0:c.isOriginalSize,{currentPos:f,imgInfo:v,zoom:m}=ImgPosUtils.getInitImgPos(this.size,{width:this.imgNode.width,height:this.imgNode.height},this.rotate,g,p);this.setCurrentPos(f),this.currentPosStorage=f,this.setImgInfo(v),this.setZoom(m),this.render(),this.renderBasicCanvas(),this.emit("dependRender"),this.emit("renderZoom",m,f,v)}),this.getCurrentPos=u=>{const{_firstClickCoordinate:c,currentPosStorage:g}=this;try{let p;return c&&g?p={y:g.y+u.y-c.y,x:g.x+u.x-c.x}:p={x:0,y:0},p}catch(p){return console.error(p),{x:0,y:0}}},this.wheelChangePos=(u,c,g)=>{const{currentPos:p,imgNode:f}=this;if(!f){console.error("unable to load image");return}if(this.zoom===this.basicZoom&&c===-1)return;const v=ZoomUtils.wheelChangePos(f,u,c,p,{zoom:g||this.zoom,innerZoom:this.innerZoom,basicZoom:this.basicZoom,zoomMax:zoomInfo.max,rotate:this.rotate});if(!v)return;const{currentPos:m,ratio:x,zoom:b,imgInfo:P}=v;this.setZoom(b),this.setCurrentPos(m),this.currentPosStorage=m,this.setImgInfo(P),zoomInfo.ratio=x,this.emit("renderZoom",b,m,P)},this.zoomChanged=(u,c=EGrowthMode.Linear)=>{const g=ZoomUtils.zoomChanged(this.zoom,u,c);this.wheelChangePos(this.getGetCenterCoordinate(),g>this.zoom?1:-1,g),this.render(),this.renderBasicCanvas()},this.zoomChangeOnCenter=u=>{this.wheelChangePos(this.getGetCenterCoordinate(),0,u),this.render(),this.renderBasicCanvas()},this.drawImg=()=>{!this.imgNode||this.hiddenImg===!0||DrawUtils.drawImg(this.basicCanvas,this.imgNode,{zoom:this.zoom,currentPos:this.currentPos,rotate:this.rotate,imgAttribute:this._imgAttribute})};var e,i,s,n,o,a,l,h,d;this.container=t.container,this.showDefaultCursor=t.showDefaultCursor||!1,this.destroyCanvas(),this.createCanvas(t.size,t.isAppend),this.imgNode=t.imgNode,this.isImgError=!t.imgNode,this.basicImgInfo={width:(i=(e=t.imgNode)==null?void 0:e.width)!=null?i:0,height:(n=(s=t.imgNode)==null?void 0:s.height)!=null?n:0,valid:!0,rotate:0},this.forbidOperation=(o=t.forbidOperation)!=null?o:!1,this.forbidBasicResultRender=(a=t.forbidBasicResultRender)!=null?a:!1,this.size=t.size,this.currentPos={x:0,y:0},this.zoom=1,this.coord={x:-1,y:-1},this.currentPosStorage={x:0,y:0},this.isShowCursor=!1,this.style={strokeColor:COLORS_ARRAY[4],fillColor:COLORS_ARRAY[4],strokeWidth:2,opacity:1},this.attributeLockList=[],this.history=new ActionsHistory,this.style=(l=t.style)!=null?l:{},this._imgAttribute=(h=t.imgAttribute)!=null?h:{},this.isHidden=!1,this.dragStatus=EDragStatus.Wait,this.defaultAttribute=(d=t==null?void 0:t.defaultAttribute)!=null?d:"",this.forbidCursorLine=!!t.forbidCursorLine,this.lang=ELang.Zh,this.onMouseDown=this.onMouseDown.bind(this),this.onMouseMove=this.onMouseMove.bind(this),this.onMouseLeave=this.onMouseLeave.bind(this),this.onMouseUp=this.onMouseUp.bind(this),this.onKeyDown=this.onKeyDown.bind(this),this.onKeyUp=this.onKeyUp.bind(this),this.onWheel=this.onWheel.bind(this),this.onLeftDblClick=this.onLeftDblClick.bind(this),this.onRightDblClick=this.onRightDblClick.bind(this),this.onClick=this.onClick.bind(this),this.clearImgDrag=this.clearImgDrag.bind(this),this.dblClickListener=new DblClickEventListener(this.container,200),this.coordUtils=new CoordinateUtils(this),this.coordUtils.setBasicImgInfo(this.basicImgInfo),this.hiddenImg=t.hiddenImg||!1}onContextmenu(t){t.preventDefault()}get ctx(){var t;return this._ctx||((t=this.canvas)==null?void 0:t.getContext("2d"))}get basicCtx(){var t;return(t=this.basicCanvas)==null?void 0:t.getContext("2d")}get rotate(){var t,e;return(e=(t=this.basicImgInfo)==null?void 0:t.rotate)!=null?e:0}get valid(){var t,e;return(e=(t=this.basicImgInfo)==null?void 0:t.valid)!=null?e:!0}get baseIcon(){return BASE_ICON[this.style.color]}get defaultCursor(){return this.showDefaultCursor?"default":"none"}get dataList(){return[]}get hasMarkerConfig(){return this.config.markerConfigurable===!0&&this.config.markerList&&this.config.markerList.length>0}setZoom(t){this.zoom=t,this.innerZoom=t,this.coordUtils.setZoomAndCurrentPos(this.zoom,this.currentPos)}setCurrentPos(t){this.currentPos=t,this.coordUtils.setZoomAndCurrentPos(this.zoom,this.currentPos)}setReferenceData(t){this.referenceData=t}setImgInfo(t){this.imgInfo=t}updatePosition(t){const{zoom:e,currentPos:i}=t;this.setZoom(e),this.setCurrentPos(i),this.currentPosStorage=i,this.renderBasicCanvas(),this.render()}setLang(t){this.lang=t}setShowDefaultCursor(t){this.showDefaultCursor=t,this.container.style.cursor=this.defaultCursor}get forbidMouseOperation(){return!1}get pixelRatio(){var t;return CanvasUtils.getPixelRatio((t=this.canvas)==null?void 0:t.getContext("2d"))}init(){this.eventUnbinding(),this.initPosition(),this.eventBinding(),this.render(),this.renderBasicCanvas()}destroy(){this.destroyCanvas(),this.eventUnbinding()}createCanvas(t,e=!0){var i,s;const n=document.createElement("canvas"),o=this.pixelRatio;n.width=t.width*o,n.height=t.height*o,n.style.width=`${t.width}px`,n.style.height=`${t.height}px`,n.style.left="0",n.style.top="0",n.style.zIndex="0",this.basicCanvas=n;const a=document.createElement("canvas");a.style.position="absolute",a.style.left="0",a.style.top="0",a.style.zIndex="10",a.style.width=`${t.width}px`,a.style.height=`${t.height}px`,a.width=t.width*o,a.height=t.height*o,this.container.style.position="relative",e&&(this.container.hasChildNodes()?(this.container.insertBefore(a,this.container.childNodes[0]),this.container.insertBefore(n,this.container.childNodes[0])):(this.container.appendChild(n),this.container.appendChild(a))),this.canvas=a,this.container.style.cursor=this.defaultCursor,(i=this.ctx)==null||i.scale(o,o),(s=this.basicCtx)==null||s.scale(o,o)}destroyCanvas(){this.canvas&&this.container.contains(this.canvas)&&this.container.removeChild(this.canvas),this.basicCanvas&&this.container.contains(this.basicCanvas)&&this.container.removeChild(this.basicCanvas),this.clearInvalidPage(),this.clearImgDrag()}setStyle(t){this.style=t,this.render()}setImgNode(t,e={}){this.imgNode=t,this.setBasicImgInfo(__spreadValues$a({width:t.width,height:t.height,valid:!0,rotate:0},e)),this.isImgError===!0&&(this.isImgError=!1,this.emit("changeAnnotationShow")),typeof e.valid=="boolean"&&this.setValid(e.valid),this.initImgPos(),this.render(),this.renderBasicCanvas()}setErrorImg(){const t=this.isImgError;this.isImgError=!0,this.imgNode=void 0,this.setBasicImgInfo({width:0,height:0,valid:!0,rotate:0}),t===!1&&this.emit("changeAnnotationShow")}setBasicImgInfo(t){this.basicImgInfo=t,this.coordUtils.setBasicImgInfo(t)}setForbidOperation(t){this.forbidOperation=t,this.setShowDefaultCursor(!0),this.render()}setForbidCursorLine(t){this.forbidCursorLine=t,this.render()}setIsHidden(t){this.isHidden=t,this.emit("hiddenChange")}setIsShowOrder(t){this.config.isShowOrder=t,this.render()}getCoordinate(t){const e=this.canvas.getBoundingClientRect();return{x:t.clientX-e.left,y:t.clientY-e.top}}getCoordinateUnderZoom(t){const e=this.canvas.getBoundingClientRect();return{x:t.clientX-e.left-this.currentPos.x,y:t.clientY-e.top-this.currentPos.y}}getGetCenterCoordinate(){return{x:this.size.width/2,y:this.size.height/2}}initPosition(){if(this.basicResult&&this.imgInfo){const{basicResult:t,size:e,imgNode:i,_imgAttribute:s,imgInfo:n,dependToolName:o}=this;if(t&&i&&o){let a=t;switch(o){case EToolName.Polygon:case EToolName.Line:{if(t.pointList){const h=MathUtils.calcViewportBoundaries(t.pointList);a={x:h.left,y:h.top,width:h.right-h.left,height:h.bottom-h.top}}break}}const l=ImgPosUtils.getBasicRecPos(i,a,e,void 0,s==null?void 0:s.zoomRatio,s==null?void 0:s.isOriginalSize);l&&(this.setCurrentPos(l.currentPos),this.currentPosStorage=this.currentPos,this.setImgInfo(__spreadProps$8(__spreadValues$a({},n),{width:n.width/this.innerZoom*l.innerZoom,height:n.height/this.innerZoom*l.innerZoom})),this.setZoom(l.innerZoom),this.render(),this.renderBasicCanvas())}}else this.initImgPos()}undo(){this.history.undo()}redo(){this.history.redo()}clearCanvas(){var t;(t=this.ctx)==null||t.clearRect(0,0,this.size.width,this.size.height)}clearBasicCanvas(){var t;(t=this.basicCtx)==null||t.clearRect(0,0,this.size.width,this.size.height)}eventBinding(){this.dblClickListener.addEvent(()=>{},this.onLeftDblClick,this.onRightDblClick),this.container.addEventListener("mousedown",this.onMouseDown),this.container.addEventListener("mousemove",this.onMouseMove),this.container.addEventListener("mouseup",this.onMouseUp),this.container.addEventListener("mouseleave",this.onMouseLeave),this.container.addEventListener("click",this.onClick),this.container.addEventListener("wheel",this.onWheel),document.addEventListener("keydown",this.onKeyDown),document.addEventListener("keyup",this.onKeyUp),window.parent.document.addEventListener("contextmenu",this.onContextmenu,!1)}eventUnbinding(){this.container.removeEventListener("mousedown",this.onMouseDown),this.container.removeEventListener("mousemove",this.onMouseMove),this.container.removeEventListener("mouseup",this.onMouseUp),this.container.removeEventListener("mouseleave",this.onMouseLeave),this.container.removeEventListener("wheel",this.onWheel),this.container.removeEventListener("click",this.onClick),document.removeEventListener("keydown",this.onKeyDown),document.removeEventListener("keyup",this.onKeyUp),window.parent.document.removeEventListener("contextmenu",this.onContextmenu,!1),this.dblClickListener.removeEvent()}clearImgDrag(){this.isDrag=!1,this.isDragStart=!1,this.isSpaceClick=!1,this.startTime=0,this.container.style.cursor=this.defaultCursor,this.forbidCursorLine=!1}clearCursorLine(){this.coord={x:-1,y:-1}}onMouseDown(t){if(!this.canvas||this.isImgError)return!0;const e=this.getCoordinate(t);(this.isSpaceKey&&t.button===0||t.button===2)&&(t.stopPropagation(),this._firstClickCoordinate=e,this.currentPosStorage=this.currentPos,this.isSpaceClick=!0,this.isDragStart=!0,this.startTime=new Date().getTime())}onMouseMove(t){if(!this.canvas||this.isImgError)return!0;const e=this.getCoordinate(t);this.isShowCursor&&(this.coord=e);try{if(!e||!_.isNumber(e==null?void 0:e.x)||!_.isNumber(e==null?void 0:e.y))throw new Error("coord error");if(this.coord=e,(this.isSpaceClick||this.isDragStart)&&this._firstClickCoordinate){const i=this.getCurrentPos(e);this.setCurrentPos(i),this.isDrag=!0,this.container.style.cursor="grabbing",this.forbidCursorLine=!0,this.renderBasicCanvas(),this.emit("dependRender"),this.emit("dragMove",{currentPos:i,zoom:this.zoom,imgInfo:this.imgInfo})}this.render()}catch(i){console.error(i)}}onMouseUp(t){if(!this.canvas||this.isImgError)return!0;if(this.container.style.cursor=this.defaultCursor,this.forbidCursorLine=!1,this.isDrag=!1,this.isDragStart=!1,this.isSpaceClick=!1,this.startTime!==0&&this._firstClickCoordinate){const e=new Date().getTime(),i=this.getCoordinate(t);if(e-this.startTime>1e3||this.isSpaceKey===!0||LineToolUtils.calcTwoPointDistance(i,this._firstClickCoordinate)>10)return t.stopPropagation(),this.startTime=0,this.render(),!0}this.startTime=0,this.render()}onMouseLeave(){this.clearImgDrag()}onClick(t){}onLeftDblClick(t){}onRightDblClick(t){this.clearImgDrag()}onKeyDown(t){switch(t.keyCode===EKeyCode$1.Alt&&t.preventDefault(),t.keyCode){case EKeyCode$1.Space:this.isSpaceKey=!0;break;case EKeyCode$1.Z:if(t.ctrlKey)return t.shiftKey?this.redo():this.undo(),!1;break}return!0}onKeyUp(t){switch(t.keyCode){case EKeyCode$1.Space:this.isSpaceKey=!1;break}}onWheel(t,e=!0){if(!this.imgNode||!this.coord)return;t.preventDefault(),t.stopPropagation();const i=this.getCoordinate(t),s=t.deltaY||t.wheelDelta;let n=0;s>0&&this.zoom>zoomInfo.min&&(n=-1),s<0&&this.zoom<zoomInfo.max&&(n=1),this.wheelChangePos(i,n),this.emit("dependRender"),e&&this.render(),this.renderBasicCanvas()}renderCursorLine(t=(e=>(e=this.style.lineColor[0])!=null?e:"")()){if(!this.ctx||this.forbidCursorLine||this.forbidOperation)return;const{x:e,y:i}=this.coord;DrawUtils.drawLine(this.canvas,{x:0,y:i},{x:1e4,y:i},{color:t}),DrawUtils.drawLine(this.canvas,{x:e,y:0},{x:e,y:1e4},{color:t}),DrawUtils.drawCircleWithFill(this.canvas,{x:e,y:i},1,{color:"white"})}setSize(t){var e;this.size=t,this.container.contains(this.canvas)&&(this.destroyCanvas(),this.createCanvas(t),this.eventUnbinding(),this.init(),((e=this.basicImgInfo)==null?void 0:e.valid)===!1&&this.renderInvalidPage())}setImgAttribute(t){const e=this._imgAttribute;if(this._imgAttribute=t,(e==null?void 0:e.zoomRatio)!==t.zoomRatio||e.isOriginalSize!==t.isOriginalSize){this.initImgPos();return}this.renderBasicCanvas(),this.render()}clearResult(t){}setValid(t){this.basicImgInfo.valid=t,t===!1?(this.renderInvalidPage(),this.clearResult(!1)):this.clearInvalidPage()}setRotate(t){this.basicImgInfo.rotate=t}setBasicResult(t){this.basicResult=t,this.coordUtils.setBasicResult(t),this.initPosition(),this.emit("dependRender")}setDependName(t,e){this.dependToolName=t,this.coordUtils.setDependInfo(t,e)}setAttributeLockList(t){this.attributeLockList=t,this.render()}setConfig(t){this.config=CommonToolUtils$1.jsonParser(t)}setDataInjectionAtCreation(t){this.dataInjectionAtCreation=t}setRenderEnhance(t){this.renderEnhance=t}setCustomRenderStyle(t){this.customRenderStyle=t}updateRotate(){if(this.dependToolName)return this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.NoRotateInDependence,this.lang)),!1;if(this.dataList.length>0)return this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.NoRotateNotice,this.lang)),!1;const t=MathUtils.getRotate(this.basicImgInfo.rotate);this.basicImgInfo.rotate=t,this.initImgPos(),this.emit("updateResult")}getColor(t="",e=this.config){var i;if((e==null?void 0:e.attributeConfigurable)===!0&&this.style.attributeColor){const o=AttributeUtils.getAttributeIndex(t,(i=e.attributeList)!=null?i:[])+1;return this.style.attributeColor[o]}const{color:s,toolColor:n}=this.style;return n?n[s]:styleDefaultConfig.toolColor["1"]}getLineColor(t=""){var e,i,s;if(((e=this.config)==null?void 0:e.attributeConfigurable)===!0){const a=AttributeUtils.getAttributeIndex(t,(s=(i=this.config)==null?void 0:i.attributeList)!=null?s:[])+1;return this.style.attributeLineColor?this.style.attributeLineColor[a]:""}const{color:n,lineColor:o}=this.style;return n&&o?o[n]:""}clearInvalidPage(){this._invalidDOM&&this.container&&this.container.contains(this._invalidDOM)&&(this.container.removeChild(this._invalidDOM),this._invalidDOM=void 0)}renderInvalidPage(){!this.container||this._invalidDOM||(this._invalidDOM=RenderDomUtils.renderInvalidPage(this.container,this.size,this.lang))}renderBasicCanvas(){if(!this.basicCanvas)return;this.clearBasicCanvas(),this.drawImg();const t=3;if(!this.forbidBasicResultRender&&this.basicResult&&this.dependToolName)switch(this.dependToolName){case EToolName.Rect:{DrawUtils.drawRect(this.basicCanvas,AxisUtils.changeRectByZoom(this.basicResult,this.zoom,this.currentPos),{color:"rgba(204,204,204,1.00)",thickness:t});break}case EToolName.Polygon:{DrawUtils.drawPolygonWithFillAndLine(this.basicCanvas,AxisUtils.changePointListByZoom(this.basicResult.pointList,this.zoom,this.currentPos),{fillColor:"transparent",strokeColor:"rgba(204,204,204,1.00)",isClose:!0,thickness:t});break}case EToolName.Line:{DrawUtils.drawLineWithPointList(this.basicCanvas,AxisUtils.changePointListByZoom(this.basicResult.pointList,this.zoom,this.currentPos),{color:"rgba(204,204,204,1.00)",thickness:t});break}}}render(){!this.canvas||!this.ctx||!this.imgNode||this.clearCanvas()}changeStyle(t=this.defaultAttribute){this.emit("changeStyle",{attribute:t})}}const defaultWidth=30,DEFAULT_TEXT_WIDTH=164;class TextAttributeClass{constructor(t){this.textKeyDown=l=>{switch(l.stopPropagation(),l.keyCode){case EKeyCode$1.Enter:this.submitTextarea(),this.appendToContainer();break}};const{container:e,icon:i,color:s,getCurrentSelectedData:n,updateSelectedTextAttribute:o}=t,a=t.width||DEFAULT_TEXT_WIDTH;this.container=e,this.getCurrentSelectedData=n,this.updateSelectedTextAttribute=o,this._textAttributeDOM=this.initTextAttributeDOM(),this._iconDOM=this.initIconDOM(i),this._textDOM=this.initTextDOM(a,TEXT_ATTRIBUTE_LINE_HEIGHT),this._textareaDOM=this.initTextareaDOM(a,s),this.appendToContainer()}get isExit(){return this._textAttributeDOM?this.container.contains(this._textAttributeDOM):!1}get isExitTextareaDOM(){return this._textareaDOM?this.container.contains(this._textareaDOM):!1}updateIcon(t){this._iconDOM&&(this._iconDOM.innerHTML=t)}appendToContainer(){!this._textAttributeDOM||!this._textDOM||!this._iconDOM||(this.container.appendChild(this._textAttributeDOM),this._textAttributeDOM.appendChild(this._textDOM),this._textAttributeDOM.appendChild(this._iconDOM))}initTextAttributeDOM(){const t=document.createElement("div");return t.setAttribute("id","textArea"),t}initTextDOM(t,e){const i=document.createElement("span");return i.setAttribute("style",`
|
|
23
|
+
`),s.innerHTML=Locale.getMessagesByLocale(EMessage.InvalidImage,i),t.appendChild(s),s}}const ZOOM_LEVEL=[1,5,10,20,30,50,80,100].concat(Array.from({length:9}).map((r,t)=>(t+2)*100));class ZoomUtils{}ZoomUtils.zoomChanged=(r,t,e=EGrowthMode.Linear)=>{switch(e){case EGrowthMode.Intelligence:{const i=Math.max(...ZOOM_LEVEL),s=Math.min(...ZOOM_LEVEL),n=ZOOM_LEVEL.slice(0,ZOOM_LEVEL.length).findIndex((a,l)=>r>=a&&(r<ZOOM_LEVEL[l+1]||a===i));let o;if(n===-1)r>=s&&r<=i?o=t?i:s:o=t?s:r;else{const a=t?n+1:n-(ZOOM_LEVEL.includes(r)?1:0);o=ZOOM_LEVEL[MathUtils.withinRange(a,[0,ZOOM_LEVEL.length-1])]}return o}default:{const i=t?2:1/2;return r*i}}},ZoomUtils.wheelChangePos=(r,t,e,i,s={})=>{const{zoom:n=1,innerZoom:o=1,basicZoom:a=1,zoomMax:l=1e3,rotate:h=0}=s,{x:c,y:u}=i,d=parseFloat((n+1/10).toFixed(1))/5;if(r&&t){let{width:g,height:p}=r;[90,270].includes(h)&&(g=r.height,p=r.width);const f=g*o,v=p*o,m=t.x-c,b=t.y-u,x=m/f,P=b/v;let w=n+e*d;w=MathUtils.withinRange(w,[a,l]);const L=g*w*x,R=p*w*P,C=c+(m-L),D=u+(b-R);return{zoom:w,currentPos:{x:C,y:D},imgInfo:{width:g*w,height:p*w},ratio:d}}return null};class EventListener{constructor(){this._events=new Map}on(t,e){const i=this._events.get(t)||[];i.some(s=>s===e)||this._events.set(t,i.concat(e))}singleOn(t,e){this._events.set(t,[e])}emit(t,...e){const i=this._events.get(t);i&&i.forEach(s=>{s&&s(...e)})}unbind(t,e){const i=this._events.get(t);i&&this._events.set(t,i.filter(s=>s!==e))}unbindAll(t){this._events.delete(t)}}var __defProp$b=Object.defineProperty,__defProps$8=Object.defineProperties,__getOwnPropDescs$8=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$a=Object.getOwnPropertySymbols,__hasOwnProp$a=Object.prototype.hasOwnProperty,__propIsEnum$a=Object.prototype.propertyIsEnumerable,__defNormalProp$b=(r,t,e)=>t in r?__defProp$b(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$a=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$a.call(t,e)&&__defNormalProp$b(r,e,t[e]);if(__getOwnPropSymbols$a)for(var e of __getOwnPropSymbols$a(t))__propIsEnum$a.call(t,e)&&__defNormalProp$b(r,e,t[e]);return r},__spreadProps$8=(r,t)=>__defProps$8(r,__getOwnPropDescs$8(t)),__async$3=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const zoomInfo={min:.2,max:1e3,ratio:.4};class BasicToolOperation extends EventListener{constructor(t){super();this.isDrag=!1,this.isSpaceKey=!1,this.innerZoom=1,this.basicZoom=.01,this.isSpaceClick=!1,this.isDragStart=!1,this.startTime=0,this.initImgPos=()=>__async$3(this,null,function*(){var u,d;if(!this.imgNode)return;const g=(u=this._imgAttribute)==null?void 0:u.zoomRatio,p=(d=this._imgAttribute)==null?void 0:d.isOriginalSize,{currentPos:f,imgInfo:v,zoom:m}=ImgPosUtils.getInitImgPos(this.size,{width:this.imgNode.width,height:this.imgNode.height},this.rotate,g,p);this.setCurrentPos(f),this.currentPosStorage=f,this.setImgInfo(v),this.setZoom(m),this.render(),this.renderBasicCanvas(),this.emit("dependRender"),this.emit("renderZoom",m,f,v)}),this.getCurrentPos=u=>{const{_firstClickCoordinate:d,currentPosStorage:g}=this;try{let p;return d&&g?p={y:g.y+u.y-d.y,x:g.x+u.x-d.x}:p={x:0,y:0},p}catch(p){return console.error(p),{x:0,y:0}}},this.wheelChangePos=(u,d,g)=>{const{currentPos:p,imgNode:f}=this;if(!f){console.error("unable to load image");return}if(this.zoom===this.basicZoom&&d===-1)return;const v=ZoomUtils.wheelChangePos(f,u,d,p,{zoom:g||this.zoom,innerZoom:this.innerZoom,basicZoom:this.basicZoom,zoomMax:zoomInfo.max,rotate:this.rotate});if(!v)return;const{currentPos:m,ratio:b,zoom:x,imgInfo:P}=v;this.setZoom(x),this.setCurrentPos(m),this.currentPosStorage=m,this.setImgInfo(P),zoomInfo.ratio=b,this.emit("renderZoom",x,m,P)},this.zoomChanged=(u,d=EGrowthMode.Linear)=>{const g=ZoomUtils.zoomChanged(this.zoom,u,d);this.wheelChangePos(this.getGetCenterCoordinate(),g>this.zoom?1:-1,g),this.render(),this.renderBasicCanvas()},this.zoomChangeOnCenter=u=>{this.wheelChangePos(this.getGetCenterCoordinate(),0,u),this.render(),this.renderBasicCanvas()},this.drawImg=()=>{!this.imgNode||this.hiddenImg===!0||DrawUtils.drawImg(this.basicCanvas,this.imgNode,{zoom:this.zoom,currentPos:this.currentPos,rotate:this.rotate,imgAttribute:this._imgAttribute})};var e,i,s,n,o,a,l,h,c;this.container=t.container,this.showDefaultCursor=t.showDefaultCursor||!1,this.destroyCanvas(),this.createCanvas(t.size,t.isAppend),this.imgNode=t.imgNode,this.isImgError=!t.imgNode,this.basicImgInfo={width:(i=(e=t.imgNode)==null?void 0:e.width)!=null?i:0,height:(n=(s=t.imgNode)==null?void 0:s.height)!=null?n:0,valid:!0,rotate:0},this.forbidOperation=(o=t.forbidOperation)!=null?o:!1,this.forbidBasicResultRender=(a=t.forbidBasicResultRender)!=null?a:!1,this.size=t.size,this.currentPos={x:0,y:0},this.zoom=1,this.coord={x:-1,y:-1},this.currentPosStorage={x:0,y:0},this.isShowCursor=!1,this.style={strokeColor:COLORS_ARRAY[4],fillColor:COLORS_ARRAY[4],strokeWidth:2,opacity:1},this.attributeLockList=[],this.history=new ActionsHistory,this.style=(l=t.style)!=null?l:{},this._imgAttribute=(h=t.imgAttribute)!=null?h:{},this.isHidden=!1,this.dragStatus=EDragStatus.Wait,this.defaultAttribute=(c=t==null?void 0:t.defaultAttribute)!=null?c:"",this.forbidCursorLine=!!t.forbidCursorLine,this.lang=ELang.Zh,this.onMouseDown=this.onMouseDown.bind(this),this.onMouseMove=this.onMouseMove.bind(this),this.onMouseLeave=this.onMouseLeave.bind(this),this.onMouseUp=this.onMouseUp.bind(this),this.onKeyDown=this.onKeyDown.bind(this),this.onKeyUp=this.onKeyUp.bind(this),this.onWheel=this.onWheel.bind(this),this.onLeftDblClick=this.onLeftDblClick.bind(this),this.onRightDblClick=this.onRightDblClick.bind(this),this.onClick=this.onClick.bind(this),this.clearImgDrag=this.clearImgDrag.bind(this),this.dblClickListener=new DblClickEventListener(this.container,200),this.coordUtils=new CoordinateUtils(this),this.coordUtils.setBasicImgInfo(this.basicImgInfo),this.hiddenImg=t.hiddenImg||!1}onContextmenu(t){t.preventDefault()}get ctx(){var t;return this._ctx||((t=this.canvas)==null?void 0:t.getContext("2d"))}get basicCtx(){var t;return(t=this.basicCanvas)==null?void 0:t.getContext("2d")}get rotate(){var t,e;return(e=(t=this.basicImgInfo)==null?void 0:t.rotate)!=null?e:0}get valid(){var t,e;return(e=(t=this.basicImgInfo)==null?void 0:t.valid)!=null?e:!0}get baseIcon(){return BASE_ICON[this.style.color]}get defaultCursor(){return this.showDefaultCursor?"default":"none"}get dataList(){return[]}get hasMarkerConfig(){return this.config.markerConfigurable===!0&&this.config.markerList&&this.config.markerList.length>0}setZoom(t){this.zoom=t,this.innerZoom=t,this.coordUtils.setZoomAndCurrentPos(this.zoom,this.currentPos)}setCurrentPos(t){this.currentPos=t,this.coordUtils.setZoomAndCurrentPos(this.zoom,this.currentPos)}setReferenceData(t){this.referenceData=t}setImgInfo(t){this.imgInfo=t}updatePosition(t){const{zoom:e,currentPos:i}=t;this.setZoom(e),this.setCurrentPos(i),this.currentPosStorage=i,this.renderBasicCanvas(),this.render()}setLang(t){this.lang=t}setShowDefaultCursor(t){this.showDefaultCursor=t,this.container.style.cursor=this.defaultCursor}get forbidMouseOperation(){return!1}get pixelRatio(){var t;return CanvasUtils.getPixelRatio((t=this.canvas)==null?void 0:t.getContext("2d"))}init(){this.eventUnbinding(),this.initPosition(),this.eventBinding(),this.render(),this.renderBasicCanvas()}destroy(){this.destroyCanvas(),this.eventUnbinding()}createCanvas(t,e=!0){var i,s;const n=document.createElement("canvas"),o=this.pixelRatio;n.width=t.width*o,n.height=t.height*o,n.style.width=`${t.width}px`,n.style.height=`${t.height}px`,n.style.left="0",n.style.top="0",n.style.zIndex="0",this.basicCanvas=n;const a=document.createElement("canvas");a.style.position="absolute",a.style.left="0",a.style.top="0",a.style.zIndex="10",a.style.width=`${t.width}px`,a.style.height=`${t.height}px`,a.width=t.width*o,a.height=t.height*o,e&&(this.container.hasChildNodes()?(this.container.insertBefore(a,this.container.childNodes[0]),this.container.insertBefore(n,this.container.childNodes[0])):(this.container.appendChild(n),this.container.appendChild(a))),this.canvas=a,this.container.style.cursor=this.defaultCursor,(i=this.ctx)==null||i.scale(o,o),(s=this.basicCtx)==null||s.scale(o,o)}destroyCanvas(){this.canvas&&this.container.contains(this.canvas)&&this.container.removeChild(this.canvas),this.basicCanvas&&this.container.contains(this.basicCanvas)&&this.container.removeChild(this.basicCanvas),this.clearInvalidPage(),this.clearImgDrag()}setStyle(t){this.style=t,this.render()}setImgNode(t,e={}){this.imgNode=t,this.setBasicImgInfo(__spreadValues$a({width:t.width,height:t.height,valid:!0,rotate:0},e)),this.isImgError===!0&&(this.isImgError=!1,this.emit("changeAnnotationShow")),typeof e.valid=="boolean"&&this.setValid(e.valid),this.initImgPos(),this.render(),this.renderBasicCanvas()}setErrorImg(){const t=this.isImgError;this.isImgError=!0,this.imgNode=void 0,this.setBasicImgInfo({width:0,height:0,valid:!0,rotate:0}),t===!1&&this.emit("changeAnnotationShow")}setBasicImgInfo(t){this.basicImgInfo=t,this.coordUtils.setBasicImgInfo(t)}setForbidOperation(t){this.forbidOperation=t,this.setShowDefaultCursor(!0),this.render()}setForbidCursorLine(t){this.forbidCursorLine=t,this.render()}setIsHidden(t){this.isHidden=t,this.emit("hiddenChange")}setIsShowOrder(t){this.config.isShowOrder=t,this.render()}getCoordinate(t){const e=this.canvas.getBoundingClientRect();return{x:t.clientX-e.left,y:t.clientY-e.top}}getCoordinateUnderZoom(t){const e=this.canvas.getBoundingClientRect();return{x:t.clientX-e.left-this.currentPos.x,y:t.clientY-e.top-this.currentPos.y}}getGetCenterCoordinate(){return{x:this.size.width/2,y:this.size.height/2}}initPosition(){if(this.basicResult&&this.imgInfo){const{basicResult:t,size:e,imgNode:i,_imgAttribute:s,imgInfo:n,dependToolName:o}=this;if(t&&i&&o){let a=t;switch(o){case EToolName.Polygon:case EToolName.Line:{if(t.pointList){const h=MathUtils.calcViewportBoundaries(t.pointList);a={x:h.left,y:h.top,width:h.right-h.left,height:h.bottom-h.top}}break}}const l=ImgPosUtils.getBasicRecPos(i,a,e,void 0,s==null?void 0:s.zoomRatio,s==null?void 0:s.isOriginalSize);l&&(this.setCurrentPos(l.currentPos),this.currentPosStorage=this.currentPos,this.setImgInfo(__spreadProps$8(__spreadValues$a({},n),{width:n.width/this.innerZoom*l.innerZoom,height:n.height/this.innerZoom*l.innerZoom})),this.setZoom(l.innerZoom),this.render(),this.renderBasicCanvas())}}else this.initImgPos()}undo(){this.history.undo()}redo(){this.history.redo()}clearCanvas(){var t;(t=this.ctx)==null||t.clearRect(0,0,this.size.width,this.size.height)}clearBasicCanvas(){var t;(t=this.basicCtx)==null||t.clearRect(0,0,this.size.width,this.size.height)}eventBinding(){this.dblClickListener.addEvent(()=>{},this.onLeftDblClick,this.onRightDblClick),this.container.addEventListener("mousedown",this.onMouseDown),this.container.addEventListener("mousemove",this.onMouseMove),this.container.addEventListener("mouseup",this.onMouseUp),this.container.addEventListener("mouseleave",this.onMouseLeave),this.container.addEventListener("click",this.onClick),this.container.addEventListener("wheel",this.onWheel),document.addEventListener("keydown",this.onKeyDown),document.addEventListener("keyup",this.onKeyUp),window.parent.document.addEventListener("contextmenu",this.onContextmenu,!1)}eventUnbinding(){this.container.removeEventListener("mousedown",this.onMouseDown),this.container.removeEventListener("mousemove",this.onMouseMove),this.container.removeEventListener("mouseup",this.onMouseUp),this.container.removeEventListener("mouseleave",this.onMouseLeave),this.container.removeEventListener("wheel",this.onWheel),this.container.removeEventListener("click",this.onClick),document.removeEventListener("keydown",this.onKeyDown),document.removeEventListener("keyup",this.onKeyUp),window.parent.document.removeEventListener("contextmenu",this.onContextmenu,!1),this.dblClickListener.removeEvent()}clearImgDrag(){this.isDrag=!1,this.isDragStart=!1,this.isSpaceClick=!1,this.startTime=0,this.container.style.cursor=this.defaultCursor,this.forbidCursorLine=!1}clearCursorLine(){this.coord={x:-1,y:-1}}onMouseDown(t){if(!this.canvas||this.isImgError)return!0;const e=this.getCoordinate(t);(this.isSpaceKey&&t.button===0||t.button===2)&&(t.stopPropagation(),this._firstClickCoordinate=e,this.currentPosStorage=this.currentPos,this.isSpaceClick=!0,this.isDragStart=!0,this.startTime=new Date().getTime())}onMouseMove(t){if(!this.canvas||this.isImgError)return!0;const e=this.getCoordinate(t);this.isShowCursor&&(this.coord=e);try{if(!e||!_.isNumber(e==null?void 0:e.x)||!_.isNumber(e==null?void 0:e.y))throw new Error("coord error");if(this.coord=e,(this.isSpaceClick||this.isDragStart)&&this._firstClickCoordinate){const i=this.getCurrentPos(e);this.setCurrentPos(i),this.isDrag=!0,this.container.style.cursor="grabbing",this.forbidCursorLine=!0,this.renderBasicCanvas(),this.emit("dependRender"),this.emit("dragMove",{currentPos:i,zoom:this.zoom,imgInfo:this.imgInfo})}this.render()}catch(i){console.error(i)}}onMouseUp(t){if(!this.canvas||this.isImgError)return!0;if(this.container.style.cursor=this.defaultCursor,this.forbidCursorLine=!1,this.isDrag=!1,this.isDragStart=!1,this.isSpaceClick=!1,this.startTime!==0&&this._firstClickCoordinate){const e=new Date().getTime(),i=this.getCoordinate(t);if(e-this.startTime>1e3||this.isSpaceKey===!0||LineToolUtils.calcTwoPointDistance(i,this._firstClickCoordinate)>10)return t.stopPropagation(),this.startTime=0,this.render(),!0}this.startTime=0,this.render()}onMouseLeave(){this.clearImgDrag()}onClick(t){}onLeftDblClick(t){}onRightDblClick(t){this.clearImgDrag()}onKeyDown(t){switch(t.keyCode===EKeyCode$1.Alt&&t.preventDefault(),t.keyCode){case EKeyCode$1.Space:this.isSpaceKey=!0;break;case EKeyCode$1.Z:if(t.ctrlKey)return t.shiftKey?this.redo():this.undo(),!1;break}return!0}onKeyUp(t){switch(t.keyCode){case EKeyCode$1.Space:this.isSpaceKey=!1;break}}exportCustomData(){return{}}onWheel(t,e=!0){if(!this.imgNode||!this.coord)return;t.preventDefault(),t.stopPropagation();const i=this.getCoordinate(t),s=t.deltaY||t.wheelDelta;let n=0;s>0&&this.zoom>zoomInfo.min&&(n=-1),s<0&&this.zoom<zoomInfo.max&&(n=1),this.wheelChangePos(i,n),this.emit("dependRender"),e&&this.render(),this.renderBasicCanvas()}renderCursorLine(t=(e=>(e=this.style.lineColor[0])!=null?e:"")()){if(!this.ctx||this.forbidCursorLine||this.forbidOperation)return;const{x:e,y:i}=this.coord;DrawUtils.drawLine(this.canvas,{x:0,y:i},{x:1e4,y:i},{color:t}),DrawUtils.drawLine(this.canvas,{x:e,y:0},{x:e,y:1e4},{color:t}),DrawUtils.drawCircleWithFill(this.canvas,{x:e,y:i},1,{color:"white"})}setSize(t){var e;this.size=t,this.container.contains(this.canvas)&&(this.destroyCanvas(),this.createCanvas(t),this.eventUnbinding(),this.init(),((e=this.basicImgInfo)==null?void 0:e.valid)===!1&&this.renderInvalidPage())}setImgAttribute(t){const e=this._imgAttribute;if(this._imgAttribute=t,(e==null?void 0:e.zoomRatio)!==t.zoomRatio||e.isOriginalSize!==t.isOriginalSize){this.initImgPos();return}this.renderBasicCanvas(),this.render()}clearResult(t){}setValid(t){this.basicImgInfo.valid=t,t===!1?(this.renderInvalidPage(),this.clearResult(!1)):this.clearInvalidPage()}setRotate(t){this.basicImgInfo.rotate=t}setBasicResult(t){this.basicResult=t,this.coordUtils.setBasicResult(t),this.initPosition(),this.emit("dependRender")}setDependName(t,e){this.dependToolName=t,this.coordUtils.setDependInfo(t,e)}setAttributeLockList(t){this.attributeLockList=t,this.render()}setConfig(t){this.config=CommonToolUtils$1.jsonParser(t)}setDataInjectionAtCreation(t){this.dataInjectionAtCreation=t}setRenderEnhance(t){this.renderEnhance=t}setCustomRenderStyle(t){this.customRenderStyle=t}updateRotate(){if(this.dependToolName)return this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.NoRotateInDependence,this.lang)),!1;if(this.dataList.length>0)return this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.NoRotateNotice,this.lang)),!1;const t=MathUtils.getRotate(this.basicImgInfo.rotate);this.basicImgInfo.rotate=t,this.initImgPos(),this.emit("updateResult")}getColor(t="",e=this.config){var i;if((e==null?void 0:e.attributeConfigurable)===!0&&this.style.attributeColor){const o=AttributeUtils.getAttributeIndex(t,(i=e.attributeList)!=null?i:[])+1;return this.style.attributeColor[o]}const{color:s,toolColor:n}=this.style;return n?n[s]:styleDefaultConfig.toolColor["1"]}getLineColor(t=""){var e,i,s;if(((e=this.config)==null?void 0:e.attributeConfigurable)===!0){const a=AttributeUtils.getAttributeIndex(t,(s=(i=this.config)==null?void 0:i.attributeList)!=null?s:[])+1;return this.style.attributeLineColor?this.style.attributeLineColor[a]:""}const{color:n,lineColor:o}=this.style;return n&&o?o[n]:""}clearInvalidPage(){this._invalidDOM&&this.container&&this.container.contains(this._invalidDOM)&&(this.container.removeChild(this._invalidDOM),this._invalidDOM=void 0)}renderInvalidPage(){!this.container||this._invalidDOM||(this._invalidDOM=RenderDomUtils.renderInvalidPage(this.container,this.size,this.lang))}renderBasicCanvas(){if(!this.basicCanvas)return;this.clearBasicCanvas(),this.drawImg();const t=3;if(!this.forbidBasicResultRender&&this.basicResult&&this.dependToolName)switch(this.dependToolName){case EToolName.Rect:{DrawUtils.drawRect(this.basicCanvas,AxisUtils.changeRectByZoom(this.basicResult,this.zoom,this.currentPos),{color:"rgba(204,204,204,1.00)",thickness:t});break}case EToolName.Polygon:{DrawUtils.drawPolygonWithFillAndLine(this.basicCanvas,AxisUtils.changePointListByZoom(this.basicResult.pointList,this.zoom,this.currentPos),{fillColor:"transparent",strokeColor:"rgba(204,204,204,1.00)",isClose:!0,thickness:t});break}case EToolName.Line:{DrawUtils.drawLineWithPointList(this.basicCanvas,AxisUtils.changePointListByZoom(this.basicResult.pointList,this.zoom,this.currentPos),{color:"rgba(204,204,204,1.00)",thickness:t});break}}}render(){!this.canvas||!this.ctx||!this.imgNode||this.clearCanvas()}changeStyle(t=this.defaultAttribute){this.emit("changeStyle",{attribute:t})}}const defaultWidth=30,DEFAULT_TEXT_WIDTH=164;class TextAttributeClass{constructor(t){this.textKeyDown=l=>{switch(l.stopPropagation(),l.keyCode){case EKeyCode$1.Enter:this.submitTextarea(),this.appendToContainer();break}};const{container:e,icon:i,color:s,getCurrentSelectedData:n,updateSelectedTextAttribute:o}=t,a=t.width||DEFAULT_TEXT_WIDTH;this.container=e,this.getCurrentSelectedData=n,this.updateSelectedTextAttribute=o,this._textAttributeDOM=this.initTextAttributeDOM(),this._iconDOM=this.initIconDOM(i),this._textDOM=this.initTextDOM(a,TEXT_ATTRIBUTE_LINE_HEIGHT),this._textareaDOM=this.initTextareaDOM(a,s),this.appendToContainer()}get isExit(){return this._textAttributeDOM?this.container.contains(this._textAttributeDOM):!1}get isExitTextareaDOM(){return this._textareaDOM?this.container.contains(this._textareaDOM):!1}updateIcon(t){this._iconDOM&&(this._iconDOM.innerHTML=t)}appendToContainer(){!this._textAttributeDOM||!this._textDOM||!this._iconDOM||(this.container.appendChild(this._textAttributeDOM),this._textAttributeDOM.appendChild(this._textDOM),this._textAttributeDOM.appendChild(this._iconDOM))}initTextAttributeDOM(){const t=document.createElement("div");return t.setAttribute("id","textArea"),t}initTextDOM(t,e){const i=document.createElement("span");return i.setAttribute("style",`
|
|
24
24
|
width: ${Math.max(t,defaultWidth)}px;
|
|
25
25
|
line-height: ${e}px;
|
|
26
26
|
word-break: break-all;
|
|
@@ -56,7 +56,7 @@
|
|
|
56
56
|
left:${s}px;
|
|
57
57
|
top: ${n}px;
|
|
58
58
|
color: ${o};
|
|
59
|
-
`),this._textDOM&&(this._textDOM.innerHTML=`${t}`),this._textareaDOM&&(this._textareaDOM.style.width=`${l}px`,this._textareaDOM.style.borderColor=`${o}`)}changeSelected(){this.isExitTextareaDOM&&this.submitTextarea()}}var __defProp$a=Object.defineProperty,__defProps$7=Object.defineProperties,__getOwnPropDescs$7=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$9=Object.getOwnPropertySymbols,__hasOwnProp$9=Object.prototype.hasOwnProperty,__propIsEnum$9=Object.prototype.propertyIsEnumerable,__defNormalProp$a=(r,t,e)=>t in r?__defProp$a(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$9=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$9.call(t,e)&&__defNormalProp$a(r,e,t[e]);if(__getOwnPropSymbols$9)for(var e of __getOwnPropSymbols$9(t))__propIsEnum$9.call(t,e)&&__defNormalProp$a(r,e,t[e]);return r},__spreadProps$7=(r,t)=>__defProps$7(r,__getOwnPropDescs$7(t));const scope=6;class RectOperation extends BasicToolOperation{constructor(t){super(t);this.setMarkerIndex=e=>{this.markerIndex=e},this.setMarkerIndexAndSelect=e=>{if(!this.config.markerList)return;this.markerIndex=e;const i=this.config.markerList[e].value,s=this.currentPageResult.find(n=>n.label===i);s&&(this.setSelectedID(s.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(s.attribute)),this.emit("markIndexChange")},this.getHoverRectID=e=>{const i=this.getCoordinateUnderZoom(e),s=scope,{currentShowList:n}=this;if(n.length>0){if(this.selectedRectID){const{selectedRect:a}=this;if(a&&RectUtils.isInRect(i,a,s,this.zoom))return a.id}const o=n.filter(a=>RectUtils.isInRect(i,a,s,this.zoom));if(o.length===0)return"";if(o.length===1)return o[0].id;if(o.length>1)return o.map(l=>({size:l.width*l.height,id:l.id})).sort((l,h)=>l.size-h.size)[0].id}return""},this.textChange=e=>{this.config.textConfigurable!==!0||!this.selectedRectID||(this.setRectList(AttributeUtils.textChange(e,this.selectedRectID,this.rectList),!0),this.emit("selectedChange"),this.render())},this.drawOutSideTarget=t.drawOutSideTarget||!1,this.rectList=[],this.isFlow=!0,this.config=CommonToolUtils$1.jsonParser(t.config),this.hoverRectEdgeIndex=-1,this.hoverRectPointIndex=-1,this.markerIndex=0,this.setStyle(t.style),this.createNewDrawingRect=this.createNewDrawingRect.bind(this),this.getDrawingRectWithRectList=this.getDrawingRectWithRectList.bind(this),this.setSelectedIdAfterAddingDrawingRect=this.setSelectedIdAfterAddingDrawingRect.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedRectTextAttribute=this.updateSelectedRectTextAttribute.bind(this),this.setSelectedID=this.setSelectedID.bind(this)}setResult(t){if(this.clearActiveStatus(),this.setRectList(t),this.hasMarkerConfig){const e=CommonToolUtils$1.getNextMarker(this.getCurrentPageResult(t),this.config.markerList);e&&this.setMarkerIndex(e.index)}this.render()}destroy(){super.destroy(),this._textAttributInstance&&this._textAttributInstance.clearTextAttribute()}setConfig(t,e=!1){this.config=CommonToolUtils$1.jsonParser(t),e===!0&&this.clearResult(!1)}setRectList(t,e=!1){const i=this.rectList.length;this.rectList=t,i!==t.length&&this.emit("updatePageNumber"),e&&this.emit("updateResult")}get selectedRect(){return this.rectList.find(t=>t.id===this.selectedRectID)}get selectedID(){return this.selectedRectID}get selectedText(){var t;return(t=this.selectedRect)==null?void 0:t.textAttribute}get dataList(){return this.rectList}get currentShowList(){let t=[];const[e,i]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);return t=e,this.isHidden&&(t=[]),i&&t.push(i),t}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}getCurrentPageResult(t){const[e]=CommonToolUtils$1.getRenderResultList(t,CommonToolUtils$1.getSourceID(this.basicResult),[]);return e}setSelectedID(t){this.setSelectedRectID(t)}setSelectedRectID(t){var e,i;const s=this.selectedRectID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedRectID=t,this.render(),this.emit("selectedChange")}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}updateSelectedRectTextAttribute(t){if(this._textAttributInstance&&t){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setRectList(this.rectList.map(i=>i.id===this.selectedRectID?__spreadProps$7(__spreadValues$9({},i),{textAttribute:e}):i),!0),this.emit("updateTextAttribute"),this.render()}}getHoverRectPointIndex(t){return this.selectedRect?AxisUtils.returnClosePointIndex(this.getCoordinateUnderZoom(t),RectUtils.getRectPointList(this.selectedRect,this.zoom),scope+2):-1}getHoverRectEdgeIndex(t){if(!this.selectedRect)return-1;let e=-1;const{selectedRect:i}=this,s=RectUtils.getRectEdgeList(i,this.zoom),n=this.getCoordinateUnderZoom(t);for(let o=0;o<s.length;o++){const a=s[o],{length:l}=MathUtils.getFootOfPerpendicular(n,a.begin,a.end);l<scope+10&&(e=o)}return e}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||t.ctrlKey===!0)return;const e=this.getCoordinateUnderZoom(t),i=this.getHoverRectID(t),s=this.currentShowList.find(n=>n.id===this.selectedRectID);if(!(!s||t.button===2||t.button===0&&this.isSpaceKey===!0)){if(this.selectedRectID){if(this.getHoverRectPointIndex(t)>-1){const n=EDragTarget$1.Point;this.dragInfo={dragStartCoord:e,dragTarget:n,startTime:+new Date,firstRect:s},this.dragStatus=EDragStatus.Start;return}if(this.getHoverRectEdgeIndex(t)>-1){const n=EDragTarget$1.Line;this.dragInfo={dragStartCoord:e,dragTarget:n,startTime:+new Date,firstRect:s},this.dragStatus=EDragStatus.Start;return}}if(i===this.selectedRectID&&!this.drawingRect){const n=EDragTarget$1.Plane;this.dragInfo={dragStartCoord:e,dragTarget:n,firstRect:s,startTime:+new Date},this.dragStatus=EDragStatus.Start}}}onDragMove(t){var e,i,s,n,o,a;if(!this.dragInfo)return;this.dragStatus=EDragStatus.Move;const l=RectUtils.getRectUnderZoom(this.dragInfo.firstRect,this.zoom),{x:h,y:d,width:u,height:c}=l,g={x:t.x-this.dragInfo.dragStartCoord.x,y:t.y-this.dragInfo.dragStartCoord.y};let p=this.rectList.filter(f=>f.id===this.selectedRectID)[0];switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p=__spreadProps$7(__spreadValues$9({},p),{x:h+g.x,y:d+g.y,width:u,height:c});break;case EDragTarget$1.Point:{let f=h,v=d,m=u,x=c;switch(this.hoverRectPointIndex){case 0:{f=u-g.x<0?h+u:h+g.x,v=c-g.y<0?d+c:d+g.y,m=Math.abs(g.x-u),x=Math.abs(g.y-c);break}case 1:{f=u+g.x>0?h:h+u+g.x,v=c-g.y<0?d+c:d+g.y,m=Math.abs(u+g.x),x=Math.abs(c-g.y);break}case 2:{f=u+g.x>0?h:h+u+g.x,v=c+g.y>0?d:d+c+g.y,m=Math.abs(u+g.x),x=c+g.y>0?c+g.y:Math.abs(c+g.y);break}case 3:{f=u-g.x<0?h+u:h+g.x,v=c+g.y>0?d:d+c+g.y,m=Math.abs(g.x-u),x=c+g.y>0?c+g.y:Math.abs(c+g.y);break}default:return}p=__spreadProps$7(__spreadValues$9({},p),{x:f,y:v,width:m,height:x})}break;case EDragTarget$1.Line:{let f=h,v=d,m=u,x=c;switch(this.hoverRectEdgeIndex){case 0:{v=c-g.y<0?d+c:d+g.y,x=Math.abs(g.y-c);break}case 1:{f=u+g.x>0?h:h+u+g.x,m=Math.abs(u+g.x);break}case 2:{v=c+g.y>0?d:d+c+g.y,x=c+g.y>0?c+g.y:Math.abs(c+g.y);break}case 3:{f=u-g.x<0?h+u:h+g.x,m=Math.abs(g.x-u);break}default:return}p=__spreadProps$7(__spreadValues$9({},p),{x:f,y:v,width:m,height:x});break}default:return}if(this.config.drawOutsideTarget===!1){if(this.basicResult){if(((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&RectUtils.isRectNotInPolygon(p,getPolygonPointUnderZoom(this.basicResult.pointList,this.zoom)))return;const f=this.basicResult.x*this.zoom,v=this.basicResult.y*this.zoom,m=this.basicResult.width*this.zoom,x=this.basicResult.height*this.zoom;if(this.dragInfo.dragTarget!==EDragTarget$1.Plane&&(p.x<f-.01||p.y<v-.01||p.width>f+m-p.x+.01||p.height>v+x-p.y+.01))return;if(p.x<f&&(p.x=f),p.y<v&&(p.y=v),p.width>f+m-p.x)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.x=f+m-u;break;case EDragTarget$1.Point:case EDragTarget$1.Line:g.x>0&&g.y>0&&(p.width=f+m-p.x);break;default:return}if(p.height>v+x-p.y)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.y=v+x-c;break}}else if(p.x<0&&(p.x=0),p.y<0&&(p.y=0),this.imgInfo)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.x+p.width>((s=this.imgInfo)==null?void 0:s.width)&&(p.x=this.imgInfo.width-u),p.y+p.height>((n=this.imgInfo)==null?void 0:n.height)&&(p.y=this.imgInfo.height-c);break;default:if(p.x+p.width>((o=this.imgInfo)==null?void 0:o.width)+.01||p.y+p.height>((a=this.imgInfo)==null?void 0:a.height)+.01)return}}this.setRectList(this.rectList.map(f=>f.id===p.id?RectUtils.getRectUnderZoom(p,1/this.zoom):f)),this.render()}onMouseMove(t){var e,i;if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(this.selectedRectID&&this.dragInfo){this.onDragMove(n);return}if(this.selectedRectID){const l=this.getHoverRectPointIndex(t);if(l!==this.hoverRectPointIndex){this.hoverRectPointIndex=l,this.hoverRectEdgeIndex=-1,this.render();return}if(this.hoverRectPointIndex===-1){const h=this.getHoverRectEdgeIndex(t);if(h!==this.hoverRectEdgeIndex){this.hoverRectEdgeIndex=h,this.render();return}}}const o=this.getHoverRectID(t),a=this.hoverRectID;if(this.hoverRectID=o,o!==a&&this.render(),this.drawingRect&&this.firstClickCoord){let{x:l,y:h}=this.firstClickCoord,{width:d,height:u}=this.drawingRect;if(d=Math.abs(l-n.x),u=Math.abs(h-n.y),n.x<l&&(l=n.x),n.y<h&&(h=n.y),this.config.drawOutsideTarget===!1){if(((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&RectUtils.isRectNotInPolygon(__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:l,y:h,width:d,height:u}),getPolygonPointUnderZoom(this.basicResult.pointList,this.zoom)))return;n.x<0&&(d=Math.abs(this.firstClickCoord.x),l=0),n.y<0&&(u=Math.abs(this.firstClickCoord.y),h=0),this.imgInfo&&(l+d>this.imgInfo.width&&(d=Math.abs(this.imgInfo.width-l)),h+u>this.imgInfo.height&&(u=Math.abs(this.imgInfo.height-h)))}this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:l,y:h,width:d,height:u}),this.render()}}setAttributeLockList(t){this.setSelectedRectID(void 0),super.setAttributeLockList(t)}setBasicResult(t){super.setBasicResult(t),this.clearActiveStatus()}setRectValidAndRender(t){!t||(this.setRectList(this.rectList.map(e=>e.id===t?__spreadProps$7(__spreadValues$9({},e),{valid:!e.valid}):e),!0),this.render(),this.emit("updateResult"))}createNewDrawingRect(t,e){if(!this.imgInfo)return;const i=this.getCoordinateUnderZoom(t),s=AxisUtils.changeDrawOutsideTarget(i,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(this.setSelectedRectID(""),this.hoverRectID="",this.drawOutSideTarget&&(s.x<0&&(s.x=0),s.y<0&&(s.y=0)),this.drawingRect=__spreadProps$7(__spreadValues$9({},s),{width:0,height:0,attribute:this.defaultAttribute,valid:!t.ctrlKey,id:uuid(8,62),sourceID:e,textAttribute:""}),this.hasMarkerConfig){const n=CommonToolUtils$1.getNextMarker(this.currentPageResult,this.config.markerList,this.markerIndex);if(n)this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{label:n.label})),this.markerIndex=n.index,this.emit("markIndexChange");else{this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.MarkerFinish,this.lang)),this.drawingRect=void 0;return}}if(this.config.textConfigurable){let n="";n=AttributeUtils.getTextAttribute(this.rectList.filter(o=>CommonToolUtils$1.isSameSourceID(o.sourceID,e)),this.config.textCheckType),this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{textAttribute:n}))}if(Object.assign(this.drawingRect,{order:CommonToolUtils$1.getMaxOrder(this.rectList.filter(n=>CommonToolUtils$1.isSameSourceID(n.sourceID,e)))+1}),this.firstClickCoord=__spreadValues$9({},s),this.firstCurrentPos=__spreadValues$9({},this.currentPos),this.dataInjectionAtCreation){const n=this.dataInjectionAtCreation(this.drawingRect);n&&Object.assign(this.drawingRect,n)}}addDrawingRectToRectList(){if(!this.drawingRect)return;let{width:t,height:e}=this.drawingRect;if(t/=this.zoom,e/=this.zoom,Math.round(t)<this.config.minWidth||Math.round(e)<this.config.minHeight){this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.RectErrorSizeNotice,this.lang)),this.drawingRect=void 0,this.firstClickCoord=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.render();return}const i=this.getDrawingRectWithRectList();this.setRectList(i,!0),this.history.pushHistory(this.rectList),this.setSelectedIdAfterAddingDrawingRect(),this.firstClickCoord=void 0,this.drawingRect=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait}setSelectedIdAfterAddingDrawingRect(){!this.drawingRect||(this.config.textConfigurable?this.setSelectedRectID(this.drawingRect.id):this.setSelectedRectID())}getDrawingRectWithRectList(){if(!this.drawingRect)return this.rectList;let{x:t,y:e,width:i,height:s}=this.drawingRect;return t/=this.zoom,e/=this.zoom,i/=this.zoom,s/=this.zoom,[...this.rectList,__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:t,y:e,width:i,height:s})]}rightMouseUp(t){const e=this.getHoverRectID(t),i=this.rectList.find(n=>n.id===e),{selectedRectID:s}=this;if(this.setSelectedRectID(void 0),i&&this.setDefaultAttribute(i.attribute),this.drawingRect)this.drawingRect=void 0,this.firstClickCoord=void 0;else if(s!==e&&this.dblClickListener.clearRightDblClick(),this.setSelectedRectID(e),this.hoverRectID="",(i==null?void 0:i.label)&&this.hasMarkerConfig){const n=CommonToolUtils$1.getCurrentMarkerIndex(i.label,this.config.markerList);n>=0&&(this.setMarkerIndex(n),this.emit("markIndexChange"))}this.render()}shiftRightMouseUp(t){const e=this.getHoverRectID(t);this.emit("shiftRightMouseUp",e)}onMouseUp(t){if(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)return!0;if(this.dragInfo&&this.dragStatus===EDragStatus.Move){this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.history.pushHistory(this.rectList),this.emit("updateResult");return}if(t.button===2&&t.shiftKey===!0){this.shiftRightMouseUp(t);return}if(t.button===2){this.rightMouseUp(t);return}const e=CommonToolUtils$1.getSourceID(this.basicResult);if(this.drawingRect){this.addDrawingRectToRectList();return}if(t.ctrlKey===!0&&t.button===0&&this.hoverRectID){this.setRectValidAndRender(this.hoverRectID);return}this.createNewDrawingRect(t,e),this.render()}onRightDblClick(t){super.onRightDblClick(t);const e=this.getHoverRectID(t);this.selectedRectID&&this.selectedRectID===e&&this.deleteRect(e)}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Ctrl:this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{valid:!t.ctrlKey}),this.render());break;case EKeyCode$1.F:this.selectedRectID&&this.setRectValidAndRender(this.selectedRectID);break;case EKeyCode$1.Z:this.setIsHidden(!this.isHidden),this.render();break;case EKeyCode$1.Delete:this.deleteRect(this.selectedRectID);break;case EKeyCode$1.Tab:{if(t.preventDefault(),this.drawingRect)return;let i=ESortDirection.ascend;t.shiftKey&&(i=ESortDirection.descend);const[s,n]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedRectID);let o=[...s];n&&(o=[...o,n]);const a=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom);o=o.filter(h=>CanvasUtils.inViewPort({x:h.x,y:h.y},a));const l=CommonToolUtils$1.getNextSelectedRectID(o,i,this.selectedRectID);l&&(this.setSelectedRectID(l.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(l.attribute));break}default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}return!0}onKeyUp(t){switch(super.onKeyUp(t),t.keyCode){case EKeyCode$1.Ctrl:this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{valid:!0}),this.render());break}}onWheel(t){const e=this.zoom;let i,s;this.drawingRect&&this.firstClickCoord&&(i=RectUtils.getRectUnderZoom(this.drawingRect,1/e),s=AxisUtils.changePointByZoom(this.firstClickCoord,1/e)),super.onWheel(t,!1),i&&s&&(this.drawingRect=RectUtils.getRectUnderZoom(i,this.zoom),this.firstClickCoord=AxisUtils.changePointByZoom(s,this.zoom)),this.render()}getCurrentSelectedData(){const{selectedRect:t}=this;if(!t)return;const e=this.getColor(t.attribute),i=t.valid?e==null?void 0:e.valid.stroke:e==null?void 0:e.invalid.stroke;return{width:t.width*this.zoom*.6,textAttribute:t.textAttribute,color:i}}getRenderStyle(t){const e=this.customRenderStyle&&this.customRenderStyle(t);if(e)return e;const i=this.getColor(t.attribute);let s,n;return t.valid===!1?(s=i==null?void 0:i.invalid.stroke,n=i==null?void 0:i.invalid.fill):(s=i==null?void 0:i.valid.stroke,n=i==null?void 0:i.valid.fill),{strokeColor:s,fillColor:n,textColor:s,toolColor:i}}renderTextAttribute(){var t;const{selectedRect:e}=this;if(!this.ctx||this.config.textConfigurable!==!0||!e)return;const{x:i,y:s,width:n,height:o,attribute:a,valid:l}=e,h=n*this.zoom*.6,d=AxisUtils.getOffsetCoordinate({x:i,y:s+o},this.currentPos,this.zoom),u=this.getColor(a),c=l?u==null?void 0:u.valid.stroke:u==null?void 0:u.invalid.stroke,g=4;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:h,container:this.container,icon:this.getTextIconSvg(a),color:c,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedRectTextAttribute})),this._textAttributInstance&&!((t=this._textAttributInstance)==null?void 0:t.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${e.textAttribute}`,{left:d.x,top:d.y+g,color:c,width:h})}renderSelectedRect(t){const{selectedRect:e}=this;if(!this.ctx||!t||!e)return;const{ctx:i}=this;let s=10;const n=RectUtils.getRectPointList(e),o=n.length,a=this.getColor(t.attribute);n.forEach((l,h)=>{var d,u;if(i.save(),i.moveTo(l.x,l.y),i.beginPath(),this.hoverRectPointIndex===h?s=scope+6:s=scope,t.valid===!1?(i.strokeStyle=a==null?void 0:a.invalid.stroke,i.fillStyle=a==null?void 0:a.invalid.stroke):(i.strokeStyle=a==null?void 0:a.valid.stroke,i.fillStyle=a==null?void 0:a.valid.stroke),i.arc(l.x*this.zoom+this.currentPos.x,l.y*this.zoom+this.currentPos.y,s,0,2*Math.PI),i.fill(),this.hoverRectEdgeIndex===h){i.beginPath(),i.lineWidth=10;const c=this.getColor(t.attribute),g=t.valid===!1?(d=c==null?void 0:c.invalid)==null?void 0:d.stroke:(u=c==null?void 0:c.valid)==null?void 0:u.stroke;i.strokeStyle=g,i.moveTo(n[h].x*this.zoom+this.currentPos.x,n[h].y*this.zoom+this.currentPos.y),i.lineTo(n[(h+1)%o].x*this.zoom+this.currentPos.x,n[(h+1)%o].y*this.zoom+this.currentPos.y),i.stroke()}i.restore()}),this.renderTextAttribute()}renderDrawingRect(t,e=this.zoom,i=!1){var s,n,o,a;if(this.ctx&&t){const{ctx:l,style:h}=this,{hiddenText:d=!1}=h;l.save();const{strokeColor:u,fillColor:c,textColor:g}=this.getRenderStyle(t);l.font="lighter 14px Arial";let p="";((s=this.config)==null?void 0:s.isShowOrder)&&t.order&&(t==null?void 0:t.order)>0&&(p=`${t.order}`),t.label&&this.hasMarkerConfig&&(p=`${CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList)+1}_${MarkerUtils.getMarkerShowText(t.label,this.config.markerList)}`),t.attribute&&(p=`${p} ${AttributeUtils.getAttributeShowText(t.attribute,(n=this.config)==null?void 0:n.attributeList)}`);const f=AxisUtils.changeRectByZoom(t,i?e:this.zoom,this.currentPos);d||DrawUtils.drawText(this.canvas,{x:f.x,y:f.y-6},p,__spreadProps$7(__spreadValues$9({color:u,font:"normal normal 900 14px SourceHanSansCN-Regular"},DEFAULT_TEXT_SHADOW),{textMaxWidth:300}));const v=(a=(o=this.style)==null?void 0:o.width)!=null?a:2;(t.id===this.hoverRectID||t.id===this.selectedRectID)&&DrawUtils.drawRectWithFill(this.canvas,f,{color:c}),DrawUtils.drawRect(this.canvas,f,{color:u,thickness:v,hiddenText:!0}),l.restore();let m=`${Math.round(t.width)} * ${Math.round(t.height)}`;i===!0&&(m=`${Math.round(t.width/this.zoom)} * ${Math.round(f.height/this.zoom)}`);const x=m.length*7;if(d||DrawUtils.drawText(this.canvas,{x:f.x+f.width-x,y:f.y+f.height+15},m,__spreadValues$9({color:g,font:"normal normal 600 14px Arial"},DEFAULT_TEXT_SHADOW)),!d&&t.textAttribute&&t.id!==this.selectedRectID){const b=0,P=Math.max(20,f.width-x);DrawUtils.drawText(this.canvas,{x:f.x,y:f.y+f.height+20+b},t.textAttribute,__spreadValues$9({color:g,font:"italic normal 900 14px Arial",textMaxWidth:P},DEFAULT_TEXT_SHADOW))}}}renderStaticRect(){var t;if(!(((t=this.rectList)==null?void 0:t.length)>0&&JSON.stringify(this.rectList)))return;const{renderEnhance:e={}}=this,[i,s]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedRectID);this.isHidden||i==null||i.forEach(n=>{this.renderDrawingRect(n),e.staticRender&&e.staticRender(this.canvas,AxisUtils.changeRectByZoom(n,this.zoom,this.currentPos),this.getRenderStyle(n))}),s&&(this.renderDrawingRect(s),this.renderSelectedRect(s),e.selectedRender&&e.selectedRender(this.canvas,AxisUtils.changeRectByZoom(s,this.zoom,this.currentPos),this.getRenderStyle(s)))}renderCreatingRect(){if(!this.drawingRect)return;const{renderEnhance:t={}}=this;this.renderDrawingRect(this.drawingRect,1,!0),t.creatingRender&&t.creatingRender(this.canvas,AxisUtils.changeRectByZoom(this.drawingRect,1,this.currentPos),this.getRenderStyle(this.drawingRect))}renderRect(){this.renderStaticRect(),this.renderCreatingRect()}render(){!this.ctx||(super.render(),this.renderRect(),this.renderCursorLine(this.getLineColor(this.defaultAttribute)))}setDefaultAttribute(t){const e=this.defaultAttribute;if(this.defaultAttribute=t!=null?t:"",e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedRect:i}=this;if(i&&(this.setRectList(this.rectList.map(s=>s.id===this.selectedID?__spreadProps$7(__spreadValues$9({},s),{attribute:this.defaultAttribute}):s),!0),this.history.pushHistory(this.rectList),this.render()),this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{attribute:this.defaultAttribute}),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(this.defaultAttribute)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}setValid(t){super.setValid(t),this.emit("updateResult")}clearActiveStatus(){this.drawingRect=void 0,this.firstClickCoord=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.setSelectedRectID(void 0)}clearResult(t=!0){const e=this.rectList.filter(i=>i.disableDelete===!0);e.length>0&&t&&this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.ClearPartialData,this.lang)),this.setRectList(e,!0),this.setSelectedRectID(void 0)}deleteRect(t){var e;if(!t)return;const i=this.rectList.find(s=>s.id===t);if((i==null?void 0:i.disableDelete)===!0){this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.DisableDelete,this.lang));return}this.setRectList(this.rectList.filter(s=>s.id!==t),!0),this.history.pushHistory(this.rectList),this.setSelectedRectID(void 0),(e=this._textAttributInstance)==null||e.clearTextAttribute(),this.render()}exportData(){const{rectList:t}=this;return[t,this.basicImgInfo]}undo(){const t=this.history.undo();t&&(t.length!==this.rectList.length&&this.setSelectedRectID(""),this.setRectList(t,!0),this.render())}redo(){const t=this.history.redo();t&&(t.length!==this.rectList.length&&this.setSelectedRectID(""),this.setRectList(t,!0),this.render())}}var __defProp$9=Object.defineProperty,__getOwnPropSymbols$8=Object.getOwnPropertySymbols,__hasOwnProp$8=Object.prototype.hasOwnProperty,__propIsEnum$8=Object.prototype.propertyIsEnumerable,__defNormalProp$9=(r,t,e)=>t in r?__defProp$9(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$8=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$8.call(t,e)&&__defNormalProp$9(r,e,t[e]);if(__getOwnPropSymbols$8)for(var e of __getOwnPropSymbols$8(t))__propIsEnum$8.call(t,e)&&__defNormalProp$9(r,e,t[e]);return r};class TagUtil{static getTagKeyName(t,e){var i,s;if(!!e)return(s=(i=e.find(n=>n.value===t))==null?void 0:i.key)!=null?s:""}static getTagName([t="",e=""],i){if(!!i){for(const s of i)if(s.value===t){if(!s.subSelected)return console.error("\u6807\u7B7E\u89E3\u6790\u9519\u8BEF",t,e),"";for(const n of s.subSelected)if(n.value===e)return n.key}}}static getTagNameList(t,e){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((i,s)=>{const[n,o]=s;if(o&&o.length>0){const a=o.split(";"),l={keyName:this.getTagKeyName(n,e),value:a.map(h=>this.getTagName([n,h],e))};return[...i,l]}return i},[]).filter(i=>i)}static getTagnameListWithoutConfig(t){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((e,i)=>{const[s,n]=i,o=n.split(";"),a={keyName:s,value:o};return[...e,a]},[]).filter(e=>e)}static judgeResultIsInInputList(t,e,i){return!t||!e||!i?!1:i.filter(n=>{if(n.value===t&&n.subSelected){const o=e==null?void 0:e.split(";");return(n==null?void 0:n.subSelected.filter(a=>o.indexOf(a.value)>-1).length)>0}return!1}).length>0}static getDefaultResultByConfig(t){return t.reduce((e,i)=>(i.subSelected&&i.subSelected.forEach(s=>{var n;if(s.isDefault){const o=(n=e[i.value])!=null?n:"";let a=[];o.length>0&&(a=o.split(";")),a.push(s.value),e[i.value]=a.join(";")}}),e),{})}static getDefaultTagResult(t,e){const i=this.getDefaultResultByConfig(t);return e.length>0?e.map(s=>({id:uuid(),sourceID:s.id,result:__spreadValues$8({},i)})):[{id:uuid(),sourceID:"",result:__spreadValues$8({},i)}]}}class TagOperation extends BasicToolOperation{constructor(t){super(t);this.getInitResultList=(e,i)=>!(e===0||e===void 0)&&i.length===0?[]:TagUtil.getDefaultTagResult(this.config.inputList,i),this.setLabel=(e,i)=>{var s,n;if(this.isImgError||!this.basicResult&&this.dependToolName)return;const o=this.config.inputList;if(!o[e])return;const{subSelected:a}=o[e];if(e<o.length&&o[e].subSelected&&a&&i<a.length){const l=o[e].value;let h=(s=a[i])==null?void 0:s.value;const d=(n=o[e])==null?void 0:n.isMulti,u=this.tagResult.filter(c=>{const g=`${c.sourceID}`;return CommonToolUtils$1.isSameSourceID(g,this.sourceID)})[0];if(u){let c=0;const{result:g}=u;u.sourceID===0&&(u.sourceID="0");for(const p in u.result)if(p===o[e].value){if(c++,d===!0){const f=g[p].split(";").filter(m=>m!==""),v=f.indexOf(h);v===-1?f.push(h):f.splice(v,1),h=f.join(";")}h===""?Object.keys(g).length===1?this.tagResult=this.tagResult.filter(f=>{const v=`${f.sourceID}`;return CommonToolUtils$1.isDifferSourceID(v,this.sourceID)}):Object.keys(g).length>1&&delete g[p]:g[p]=h}c===0&&Object.assign(u.result,{[l]:h})}else this.tagResult=[{sourceID:this.sourceID,id:uuid(8,62),result:{[l]:h}}];this.render()}},this.clearResult=(e=!0,i)=>{i?this.tagResult=this.tagResult.map(s=>((s==null?void 0:s.result[i])&&delete s.result[i],s)):this.tagResult=[],this.render()},this.config=CommonToolUtils$1.jsonParser(t.config),this.tagResult=[],this.labelSelectedList=[],this.setShowDefaultCursor(!0)}destroy(){this.clearTag(),super.destroy()}setResult(t){this.tagResult=t,this.render()}get currentPageResult(){return[this.currentTagResult]}get currentTagResult(){var t;return(t=this.tagResult.filter(e=>{const i=`${e.sourceID}`;return CommonToolUtils$1.isSameSourceID(i,this.sourceID)})[0])!=null?t:{}}get sourceID(){return CommonToolUtils$1.getSourceID(this.basicResult)}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t))return;let{keyCode:e}=t;if(e&&(e<=57&&e>=49||e<=105&&e>=97)){if(e>57?e-=97:e-=49,this.config.inputList.length===1){this.labelSelectedList=[0,e],this.setLabel(0,e),setTimeout(()=>{this.labelSelectedList=[],this.render()},500);return}this.labelSelectedList.length===1?(this.labelSelectedList=[this.labelSelectedList[0],e],this.setLabel(this.labelSelectedList[0],e),setTimeout(()=>{this.labelSelectedList=[],this.render()},500)):(this.labelSelectedList=[e],this.emit("expend"))}}clearTag(){var t;const e=(t=this.canvas)==null?void 0:t.parentNode,i=window.self.document.getElementById("tagToolTag");i&&e&&e.contains(i)&&(e==null||e.removeChild(i))}renderTag(){var t,e,i,s,n,o;if(this.clearTag(),!(((t=this.tagResult)==null?void 0:t.length)>0))return;const a=document.createElement("div"),l=TagUtil.getTagNameList((i=(e=this.currentTagResult)==null?void 0:e.result)!=null?i:{},this.config.inputList);a.innerHTML=(s=l.reduce((h,d)=>`${h}${d.keyName}: ${d.value.join(" \u3001 ")}
|
|
59
|
+
`),this._textDOM&&(this._textDOM.innerHTML=`${t}`),this._textareaDOM&&(this._textareaDOM.style.width=`${l}px`,this._textareaDOM.style.borderColor=`${o}`)}changeSelected(){this.isExitTextareaDOM&&this.submitTextarea()}}var __defProp$a=Object.defineProperty,__defProps$7=Object.defineProperties,__getOwnPropDescs$7=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$9=Object.getOwnPropertySymbols,__hasOwnProp$9=Object.prototype.hasOwnProperty,__propIsEnum$9=Object.prototype.propertyIsEnumerable,__defNormalProp$a=(r,t,e)=>t in r?__defProp$a(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$9=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$9.call(t,e)&&__defNormalProp$a(r,e,t[e]);if(__getOwnPropSymbols$9)for(var e of __getOwnPropSymbols$9(t))__propIsEnum$9.call(t,e)&&__defNormalProp$a(r,e,t[e]);return r},__spreadProps$7=(r,t)=>__defProps$7(r,__getOwnPropDescs$7(t));const scope=6;class RectOperation extends BasicToolOperation{constructor(t){super(t);this.setMarkerIndex=e=>{this.markerIndex=e},this.setMarkerIndexAndSelect=e=>{if(!this.config.markerList)return;this.markerIndex=e;const i=this.config.markerList[e].value,s=this.currentPageResult.find(n=>n.label===i);s&&(this.setSelectedID(s.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(s.attribute)),this.emit("markIndexChange")},this.getHoverRectID=e=>{const i=this.getCoordinateUnderZoom(e),s=scope,{currentShowList:n}=this;if(n.length>0){if(this.selectedRectID){const{selectedRect:a}=this;if(a&&RectUtils.isInRect(i,a,s,this.zoom))return a.id}const o=n.filter(a=>RectUtils.isInRect(i,a,s,this.zoom));if(o.length===0)return"";if(o.length===1)return o[0].id;if(o.length>1)return o.map(l=>({size:l.width*l.height,id:l.id})).sort((l,h)=>l.size-h.size)[0].id}return""},this.textChange=e=>{this.config.textConfigurable!==!0||!this.selectedRectID||(this.setRectList(AttributeUtils.textChange(e,this.selectedRectID,this.rectList),!0),this.emit("selectedChange"),this.render())},this.drawOutSideTarget=t.drawOutSideTarget||!1,this.rectList=[],this.isFlow=!0,this.config=CommonToolUtils$1.jsonParser(t.config),this.hoverRectEdgeIndex=-1,this.hoverRectPointIndex=-1,this.markerIndex=0,this.setStyle(t.style),this.createNewDrawingRect=this.createNewDrawingRect.bind(this),this.getDrawingRectWithRectList=this.getDrawingRectWithRectList.bind(this),this.setSelectedIdAfterAddingDrawingRect=this.setSelectedIdAfterAddingDrawingRect.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedRectTextAttribute=this.updateSelectedRectTextAttribute.bind(this),this.setSelectedID=this.setSelectedID.bind(this)}setResult(t){if(this.clearActiveStatus(),this.setRectList(t),this.hasMarkerConfig){const e=CommonToolUtils$1.getNextMarker(this.getCurrentPageResult(t),this.config.markerList);e&&this.setMarkerIndex(e.index)}this.render()}destroy(){super.destroy(),this._textAttributInstance&&this._textAttributInstance.clearTextAttribute()}setConfig(t,e=!1){this.config=CommonToolUtils$1.jsonParser(t),e===!0&&this.clearResult(!1)}setRectList(t,e=!1){const i=this.rectList.length;this.rectList=t,i!==t.length&&this.emit("updatePageNumber"),e&&this.emit("updateResult")}get selectedRect(){return this.rectList.find(t=>t.id===this.selectedRectID)}get selectedID(){return this.selectedRectID}get selectedText(){var t;return(t=this.selectedRect)==null?void 0:t.textAttribute}get dataList(){return this.rectList}get currentShowList(){let t=[];const[e,i]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);return t=e,this.isHidden&&(t=[]),i&&t.push(i),t}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}getCurrentPageResult(t){const[e]=CommonToolUtils$1.getRenderResultList(t,CommonToolUtils$1.getSourceID(this.basicResult),[]);return e}setSelectedID(t){this.setSelectedRectID(t)}setSelectedRectID(t){var e,i;const s=this.selectedRectID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedRectID=t,this.render(),this.emit("selectedChange")}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}updateSelectedRectTextAttribute(t){if(this._textAttributInstance&&t){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setRectList(this.rectList.map(i=>i.id===this.selectedRectID?__spreadProps$7(__spreadValues$9({},i),{textAttribute:e}):i),!0),this.emit("updateTextAttribute"),this.render()}}getHoverRectPointIndex(t){return this.selectedRect?AxisUtils.returnClosePointIndex(this.getCoordinateUnderZoom(t),RectUtils.getRectPointList(this.selectedRect,this.zoom),scope+2):-1}getHoverRectEdgeIndex(t){if(!this.selectedRect)return-1;let e=-1;const{selectedRect:i}=this,s=RectUtils.getRectEdgeList(i,this.zoom),n=this.getCoordinateUnderZoom(t);for(let o=0;o<s.length;o++){const a=s[o],{length:l}=MathUtils.getFootOfPerpendicular(n,a.begin,a.end);l<scope+10&&(e=o)}return e}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||t.ctrlKey===!0)return;const e=this.getCoordinateUnderZoom(t),i=this.getHoverRectID(t),s=this.currentShowList.find(n=>n.id===this.selectedRectID);if(!(!s||t.button===2||t.button===0&&this.isSpaceKey===!0)){if(this.selectedRectID){if(this.getHoverRectPointIndex(t)>-1){const n=EDragTarget$1.Point;this.dragInfo={dragStartCoord:e,dragTarget:n,startTime:+new Date,firstRect:s},this.dragStatus=EDragStatus.Start;return}if(this.getHoverRectEdgeIndex(t)>-1){const n=EDragTarget$1.Line;this.dragInfo={dragStartCoord:e,dragTarget:n,startTime:+new Date,firstRect:s},this.dragStatus=EDragStatus.Start;return}}if(i===this.selectedRectID&&!this.drawingRect){const n=EDragTarget$1.Plane;this.dragInfo={dragStartCoord:e,dragTarget:n,firstRect:s,startTime:+new Date},this.dragStatus=EDragStatus.Start}}}onDragMove(t){var e,i,s,n,o,a;if(!this.dragInfo)return;this.dragStatus=EDragStatus.Move;const l=RectUtils.getRectUnderZoom(this.dragInfo.firstRect,this.zoom),{x:h,y:c,width:u,height:d}=l,g={x:t.x-this.dragInfo.dragStartCoord.x,y:t.y-this.dragInfo.dragStartCoord.y};let p=this.rectList.filter(f=>f.id===this.selectedRectID)[0];switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p=__spreadProps$7(__spreadValues$9({},p),{x:h+g.x,y:c+g.y,width:u,height:d});break;case EDragTarget$1.Point:{let f=h,v=c,m=u,b=d;switch(this.hoverRectPointIndex){case 0:{f=u-g.x<0?h+u:h+g.x,v=d-g.y<0?c+d:c+g.y,m=Math.abs(g.x-u),b=Math.abs(g.y-d);break}case 1:{f=u+g.x>0?h:h+u+g.x,v=d-g.y<0?c+d:c+g.y,m=Math.abs(u+g.x),b=Math.abs(d-g.y);break}case 2:{f=u+g.x>0?h:h+u+g.x,v=d+g.y>0?c:c+d+g.y,m=Math.abs(u+g.x),b=d+g.y>0?d+g.y:Math.abs(d+g.y);break}case 3:{f=u-g.x<0?h+u:h+g.x,v=d+g.y>0?c:c+d+g.y,m=Math.abs(g.x-u),b=d+g.y>0?d+g.y:Math.abs(d+g.y);break}default:return}p=__spreadProps$7(__spreadValues$9({},p),{x:f,y:v,width:m,height:b})}break;case EDragTarget$1.Line:{let f=h,v=c,m=u,b=d;switch(this.hoverRectEdgeIndex){case 0:{v=d-g.y<0?c+d:c+g.y,b=Math.abs(g.y-d);break}case 1:{f=u+g.x>0?h:h+u+g.x,m=Math.abs(u+g.x);break}case 2:{v=d+g.y>0?c:c+d+g.y,b=d+g.y>0?d+g.y:Math.abs(d+g.y);break}case 3:{f=u-g.x<0?h+u:h+g.x,m=Math.abs(g.x-u);break}default:return}p=__spreadProps$7(__spreadValues$9({},p),{x:f,y:v,width:m,height:b});break}default:return}if(this.config.drawOutsideTarget===!1){if(this.basicResult){if(((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&RectUtils.isRectNotInPolygon(p,getPolygonPointUnderZoom(this.basicResult.pointList,this.zoom)))return;const f=this.basicResult.x*this.zoom,v=this.basicResult.y*this.zoom,m=this.basicResult.width*this.zoom,b=this.basicResult.height*this.zoom;if(this.dragInfo.dragTarget!==EDragTarget$1.Plane&&(p.x<f-.01||p.y<v-.01||p.width>f+m-p.x+.01||p.height>v+b-p.y+.01))return;if(p.x<f&&(p.x=f),p.y<v&&(p.y=v),p.width>f+m-p.x)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.x=f+m-u;break;case EDragTarget$1.Point:case EDragTarget$1.Line:g.x>0&&g.y>0&&(p.width=f+m-p.x);break;default:return}if(p.height>v+b-p.y)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.y=v+b-d;break}}else if(p.x<0&&(p.x=0),p.y<0&&(p.y=0),this.imgInfo)switch(this.dragInfo.dragTarget){case EDragTarget$1.Plane:p.x+p.width>((s=this.imgInfo)==null?void 0:s.width)&&(p.x=this.imgInfo.width-u),p.y+p.height>((n=this.imgInfo)==null?void 0:n.height)&&(p.y=this.imgInfo.height-d);break;default:if(p.x+p.width>((o=this.imgInfo)==null?void 0:o.width)+.01||p.y+p.height>((a=this.imgInfo)==null?void 0:a.height)+.01)return}}this.setRectList(this.rectList.map(f=>f.id===p.id?RectUtils.getRectUnderZoom(p,1/this.zoom):f)),this.render()}onMouseMove(t){var e,i;if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(this.selectedRectID&&this.dragInfo){this.onDragMove(n);return}if(this.selectedRectID){const l=this.getHoverRectPointIndex(t);if(l!==this.hoverRectPointIndex){this.hoverRectPointIndex=l,this.hoverRectEdgeIndex=-1,this.render();return}if(this.hoverRectPointIndex===-1){const h=this.getHoverRectEdgeIndex(t);if(h!==this.hoverRectEdgeIndex){this.hoverRectEdgeIndex=h,this.render();return}}}const o=this.getHoverRectID(t),a=this.hoverRectID;if(this.hoverRectID=o,o!==a&&this.render(),this.drawingRect&&this.firstClickCoord){let{x:l,y:h}=this.firstClickCoord,{width:c,height:u}=this.drawingRect;if(c=Math.abs(l-n.x),u=Math.abs(h-n.y),n.x<l&&(l=n.x),n.y<h&&(h=n.y),this.config.drawOutsideTarget===!1){if(((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&RectUtils.isRectNotInPolygon(__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:l,y:h,width:c,height:u}),getPolygonPointUnderZoom(this.basicResult.pointList,this.zoom)))return;n.x<0&&(c=Math.abs(this.firstClickCoord.x),l=0),n.y<0&&(u=Math.abs(this.firstClickCoord.y),h=0),this.imgInfo&&(l+c>this.imgInfo.width&&(c=Math.abs(this.imgInfo.width-l)),h+u>this.imgInfo.height&&(u=Math.abs(this.imgInfo.height-h)))}this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:l,y:h,width:c,height:u}),this.render()}}setAttributeLockList(t){this.setSelectedRectID(void 0),super.setAttributeLockList(t)}setBasicResult(t){super.setBasicResult(t),this.clearActiveStatus()}setRectValidAndRender(t){!t||(this.setRectList(this.rectList.map(e=>e.id===t?__spreadProps$7(__spreadValues$9({},e),{valid:!e.valid}):e),!0),this.render(),this.emit("updateResult"))}createNewDrawingRect(t,e){if(!this.imgInfo)return;const i=this.getCoordinateUnderZoom(t),s=AxisUtils.changeDrawOutsideTarget(i,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(this.setSelectedRectID(""),this.hoverRectID="",this.drawOutSideTarget&&(s.x<0&&(s.x=0),s.y<0&&(s.y=0)),this.drawingRect=__spreadProps$7(__spreadValues$9({},s),{width:0,height:0,attribute:this.defaultAttribute,valid:!t.ctrlKey,id:uuid(8,62),sourceID:e,textAttribute:""}),this.hasMarkerConfig){const n=CommonToolUtils$1.getNextMarker(this.currentPageResult,this.config.markerList,this.markerIndex);if(n)this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{label:n.label})),this.markerIndex=n.index,this.emit("markIndexChange");else{this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.MarkerFinish,this.lang)),this.drawingRect=void 0;return}}if(this.config.textConfigurable){let n="";n=AttributeUtils.getTextAttribute(this.rectList.filter(o=>CommonToolUtils$1.isSameSourceID(o.sourceID,e)),this.config.textCheckType),this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{textAttribute:n}))}if(Object.assign(this.drawingRect,{order:CommonToolUtils$1.getMaxOrder(this.rectList.filter(n=>CommonToolUtils$1.isSameSourceID(n.sourceID,e)))+1}),this.firstClickCoord=__spreadValues$9({},s),this.firstCurrentPos=__spreadValues$9({},this.currentPos),this.dataInjectionAtCreation){const n=this.dataInjectionAtCreation(this.drawingRect);n&&Object.assign(this.drawingRect,n)}}addDrawingRectToRectList(){if(!this.drawingRect)return;let{width:t,height:e}=this.drawingRect;if(t/=this.zoom,e/=this.zoom,Math.round(t)<this.config.minWidth||Math.round(e)<this.config.minHeight){this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.RectErrorSizeNotice,this.lang)),this.drawingRect=void 0,this.firstClickCoord=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.render();return}const i=this.getDrawingRectWithRectList();this.setRectList(i,!0),this.history.pushHistory(this.rectList),this.setSelectedIdAfterAddingDrawingRect(),this.firstClickCoord=void 0,this.drawingRect=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait}setSelectedIdAfterAddingDrawingRect(){!this.drawingRect||(this.config.textConfigurable?this.setSelectedRectID(this.drawingRect.id):this.setSelectedRectID())}getDrawingRectWithRectList(){if(!this.drawingRect)return this.rectList;let{x:t,y:e,width:i,height:s}=this.drawingRect;return t/=this.zoom,e/=this.zoom,i/=this.zoom,s/=this.zoom,[...this.rectList,__spreadProps$7(__spreadValues$9({},this.drawingRect),{x:t,y:e,width:i,height:s})]}rightMouseUp(t){const e=this.getHoverRectID(t),i=this.rectList.find(n=>n.id===e),{selectedRectID:s}=this;if(this.setSelectedRectID(void 0),i&&this.setDefaultAttribute(i.attribute),this.drawingRect)this.drawingRect=void 0,this.firstClickCoord=void 0;else if(s!==e&&this.dblClickListener.clearRightDblClick(),this.setSelectedRectID(e),this.hoverRectID="",(i==null?void 0:i.label)&&this.hasMarkerConfig){const n=CommonToolUtils$1.getCurrentMarkerIndex(i.label,this.config.markerList);n>=0&&(this.setMarkerIndex(n),this.emit("markIndexChange"))}this.render()}shiftRightMouseUp(t){const e=this.getHoverRectID(t);this.emit("shiftRightMouseUp",e)}onMouseUp(t){if(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)return!0;if(this.dragInfo&&this.dragStatus===EDragStatus.Move){this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.history.pushHistory(this.rectList),this.emit("updateResult");return}if(t.button===2&&t.shiftKey===!0){this.shiftRightMouseUp(t);return}if(t.button===2){this.rightMouseUp(t);return}const e=CommonToolUtils$1.getSourceID(this.basicResult);if(this.drawingRect){this.addDrawingRectToRectList();return}if(t.ctrlKey===!0&&t.button===0&&this.hoverRectID){this.setRectValidAndRender(this.hoverRectID);return}this.createNewDrawingRect(t,e),this.render()}onRightDblClick(t){super.onRightDblClick(t);const e=this.getHoverRectID(t);this.selectedRectID&&this.selectedRectID===e&&this.deleteRect(e)}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Ctrl:this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{valid:!t.ctrlKey}),this.render());break;case EKeyCode$1.F:this.selectedRectID&&this.setRectValidAndRender(this.selectedRectID);break;case EKeyCode$1.Z:this.setIsHidden(!this.isHidden),this.render();break;case EKeyCode$1.Delete:this.deleteRect(this.selectedRectID);break;case EKeyCode$1.Tab:{if(t.preventDefault(),this.drawingRect)return;let i=ESortDirection.ascend;t.shiftKey&&(i=ESortDirection.descend);const[s,n]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedRectID);let o=[...s];n&&(o=[...o,n]);const a=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom);o=o.filter(h=>CanvasUtils.inViewPort({x:h.x,y:h.y},a));const l=CommonToolUtils$1.getNextSelectedRectID(o,i,this.selectedRectID);l&&(this.setSelectedRectID(l.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(l.attribute));break}default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}return!0}onKeyUp(t){switch(super.onKeyUp(t),t.keyCode){case EKeyCode$1.Ctrl:this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{valid:!0}),this.render());break}}onWheel(t){const e=this.zoom;let i,s;this.drawingRect&&this.firstClickCoord&&(i=RectUtils.getRectUnderZoom(this.drawingRect,1/e),s=AxisUtils.changePointByZoom(this.firstClickCoord,1/e)),super.onWheel(t,!1),i&&s&&(this.drawingRect=RectUtils.getRectUnderZoom(i,this.zoom),this.firstClickCoord=AxisUtils.changePointByZoom(s,this.zoom)),this.render()}getCurrentSelectedData(){const{selectedRect:t}=this;if(!t)return;const e=this.getColor(t.attribute),i=t.valid?e==null?void 0:e.valid.stroke:e==null?void 0:e.invalid.stroke;return{width:t.width*this.zoom*.6,textAttribute:t.textAttribute,color:i}}getRenderStyle(t){const e=this.customRenderStyle&&this.customRenderStyle(t);if(e)return e;const i=this.getColor(t.attribute);let s,n;return t.valid===!1?(s=i==null?void 0:i.invalid.stroke,n=i==null?void 0:i.invalid.fill):(s=i==null?void 0:i.valid.stroke,n=i==null?void 0:i.valid.fill),{strokeColor:s,fillColor:n,textColor:s,toolColor:i}}renderTextAttribute(){var t;const{selectedRect:e}=this;if(!this.ctx||this.config.textConfigurable!==!0||!e)return;const{x:i,y:s,width:n,height:o,attribute:a,valid:l}=e,h=n*this.zoom*.6,c=AxisUtils.getOffsetCoordinate({x:i,y:s+o},this.currentPos,this.zoom),u=this.getColor(a),d=l?u==null?void 0:u.valid.stroke:u==null?void 0:u.invalid.stroke,g=4;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:h,container:this.container,icon:this.getTextIconSvg(a),color:d,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedRectTextAttribute})),this._textAttributInstance&&!((t=this._textAttributInstance)==null?void 0:t.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${e.textAttribute}`,{left:c.x,top:c.y+g,color:d,width:h})}renderSelectedRect(t){const{selectedRect:e}=this;if(!this.ctx||!t||!e)return;const{ctx:i}=this;let s=10;const n=RectUtils.getRectPointList(e),o=n.length,a=this.getColor(t.attribute);n.forEach((l,h)=>{var c,u;if(i.save(),i.moveTo(l.x,l.y),i.beginPath(),this.hoverRectPointIndex===h?s=scope+6:s=scope,t.valid===!1?(i.strokeStyle=a==null?void 0:a.invalid.stroke,i.fillStyle=a==null?void 0:a.invalid.stroke):(i.strokeStyle=a==null?void 0:a.valid.stroke,i.fillStyle=a==null?void 0:a.valid.stroke),i.arc(l.x*this.zoom+this.currentPos.x,l.y*this.zoom+this.currentPos.y,s,0,2*Math.PI),i.fill(),this.hoverRectEdgeIndex===h){i.beginPath(),i.lineWidth=10;const d=this.getColor(t.attribute),g=t.valid===!1?(c=d==null?void 0:d.invalid)==null?void 0:c.stroke:(u=d==null?void 0:d.valid)==null?void 0:u.stroke;i.strokeStyle=g,i.moveTo(n[h].x*this.zoom+this.currentPos.x,n[h].y*this.zoom+this.currentPos.y),i.lineTo(n[(h+1)%o].x*this.zoom+this.currentPos.x,n[(h+1)%o].y*this.zoom+this.currentPos.y),i.stroke()}i.restore()}),this.renderTextAttribute()}renderDrawingRect(t,e=this.zoom,i=!1){var s,n,o,a;if(this.ctx&&t){const{ctx:l,style:h}=this,{hiddenText:c=!1}=h;l.save();const{strokeColor:u,fillColor:d,textColor:g}=this.getRenderStyle(t);l.font="lighter 14px Arial";let p="";((s=this.config)==null?void 0:s.isShowOrder)&&t.order&&(t==null?void 0:t.order)>0&&(p=`${t.order}`),t.label&&this.hasMarkerConfig&&(p=`${CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList)+1}_${MarkerUtils.getMarkerShowText(t.label,this.config.markerList)}`),t.attribute&&(p=`${p} ${AttributeUtils.getAttributeShowText(t.attribute,(n=this.config)==null?void 0:n.attributeList)}`);const f=AxisUtils.changeRectByZoom(t,i?e:this.zoom,this.currentPos);c||DrawUtils.drawText(this.canvas,{x:f.x,y:f.y-6},p,__spreadProps$7(__spreadValues$9({color:u,font:"normal normal 900 14px SourceHanSansCN-Regular"},DEFAULT_TEXT_SHADOW),{textMaxWidth:300}));const v=(a=(o=this.style)==null?void 0:o.width)!=null?a:2;(t.id===this.hoverRectID||t.id===this.selectedRectID)&&DrawUtils.drawRectWithFill(this.canvas,f,{color:d}),DrawUtils.drawRect(this.canvas,f,{color:u,thickness:v,hiddenText:!0}),l.restore();let m=`${Math.round(t.width)} * ${Math.round(t.height)}`;i===!0&&(m=`${Math.round(t.width/this.zoom)} * ${Math.round(f.height/this.zoom)}`);const b=m.length*7;if(c||DrawUtils.drawText(this.canvas,{x:f.x+f.width-b,y:f.y+f.height+15},m,__spreadValues$9({color:g,font:"normal normal 600 14px Arial"},DEFAULT_TEXT_SHADOW)),!c&&t.textAttribute&&t.id!==this.selectedRectID){const x=0,P=Math.max(20,f.width-b);DrawUtils.drawText(this.canvas,{x:f.x,y:f.y+f.height+20+x},t.textAttribute,__spreadValues$9({color:g,font:"italic normal 900 14px Arial",textMaxWidth:P},DEFAULT_TEXT_SHADOW))}}}renderStaticRect(){var t;if(!(((t=this.rectList)==null?void 0:t.length)>0&&JSON.stringify(this.rectList)))return;const{renderEnhance:e={}}=this,[i,s]=CommonToolUtils$1.getRenderResultList(this.rectList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedRectID);this.isHidden||i==null||i.forEach(n=>{this.renderDrawingRect(n),e.staticRender&&e.staticRender(this.canvas,AxisUtils.changeRectByZoom(n,this.zoom,this.currentPos),this.getRenderStyle(n))}),s&&(this.renderDrawingRect(s),this.renderSelectedRect(s),e.selectedRender&&e.selectedRender(this.canvas,AxisUtils.changeRectByZoom(s,this.zoom,this.currentPos),this.getRenderStyle(s)))}renderCreatingRect(){if(!this.drawingRect)return;const{renderEnhance:t={}}=this;this.renderDrawingRect(this.drawingRect,1,!0),t.creatingRender&&t.creatingRender(this.canvas,AxisUtils.changeRectByZoom(this.drawingRect,1,this.currentPos),this.getRenderStyle(this.drawingRect))}renderRect(){this.renderStaticRect(),this.renderCreatingRect()}render(){!this.ctx||(super.render(),this.renderRect(),this.renderCursorLine(this.getLineColor(this.defaultAttribute)))}setDefaultAttribute(t){const e=this.defaultAttribute;if(this.defaultAttribute=t!=null?t:"",e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedRect:i}=this;if(i&&(this.setRectList(this.rectList.map(s=>s.id===this.selectedID?__spreadProps$7(__spreadValues$9({},s),{attribute:this.defaultAttribute}):s),!0),this.history.pushHistory(this.rectList),this.render()),this.drawingRect&&(this.drawingRect=__spreadProps$7(__spreadValues$9({},this.drawingRect),{attribute:this.defaultAttribute}),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(this.defaultAttribute)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}setValid(t){super.setValid(t),this.emit("updateResult")}clearActiveStatus(){this.drawingRect=void 0,this.firstClickCoord=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.setSelectedRectID(void 0)}clearResult(t=!0){const e=this.rectList.filter(i=>i.disableDelete===!0);e.length>0&&t&&this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.ClearPartialData,this.lang)),this.setRectList(e,!0),this.setSelectedRectID(void 0)}deleteRect(t){var e;if(!t)return;const i=this.rectList.find(s=>s.id===t);if((i==null?void 0:i.disableDelete)===!0){this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.DisableDelete,this.lang));return}this.setRectList(this.rectList.filter(s=>s.id!==t),!0),this.history.pushHistory(this.rectList),this.setSelectedRectID(void 0),(e=this._textAttributInstance)==null||e.clearTextAttribute(),this.render()}exportData(){const{rectList:t}=this;return[t,this.basicImgInfo]}undo(){const t=this.history.undo();t&&(t.length!==this.rectList.length&&this.setSelectedRectID(""),this.setRectList(t,!0),this.render())}redo(){const t=this.history.redo();t&&(t.length!==this.rectList.length&&this.setSelectedRectID(""),this.setRectList(t,!0),this.render())}}var __defProp$9=Object.defineProperty,__getOwnPropSymbols$8=Object.getOwnPropertySymbols,__hasOwnProp$8=Object.prototype.hasOwnProperty,__propIsEnum$8=Object.prototype.propertyIsEnumerable,__defNormalProp$9=(r,t,e)=>t in r?__defProp$9(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$8=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$8.call(t,e)&&__defNormalProp$9(r,e,t[e]);if(__getOwnPropSymbols$8)for(var e of __getOwnPropSymbols$8(t))__propIsEnum$8.call(t,e)&&__defNormalProp$9(r,e,t[e]);return r};class TagUtil{static getTagKeyName(t,e){var i,s;if(!!e)return(s=(i=e.find(n=>n.value===t))==null?void 0:i.key)!=null?s:""}static getTagName([t="",e=""],i){if(!!i){for(const s of i)if(s.value===t){if(!s.subSelected)return console.error("\u6807\u7B7E\u89E3\u6790\u9519\u8BEF",t,e),"";for(const n of s.subSelected)if(n.value===e)return n.key}}}static getTagNameList(t,e){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((i,s)=>{const[n,o]=s;if(o&&o.length>0){const a=o.split(";"),l={keyName:this.getTagKeyName(n,e),value:a.map(h=>this.getTagName([n,h],e))};return[...i,l]}return i},[]).filter(i=>i)}static getTagnameListWithoutConfig(t){return Object.keys(t).length<=0?[]:Object.entries(t).reduce((e,i)=>{const[s,n]=i,o=n.split(";"),a={keyName:s,value:o};return[...e,a]},[]).filter(e=>e)}static judgeResultIsInInputList(t,e,i){return!t||!e||!i?!1:i.filter(n=>{if(n.value===t&&n.subSelected){const o=e==null?void 0:e.split(";");return(n==null?void 0:n.subSelected.filter(a=>o.indexOf(a.value)>-1).length)>0}return!1}).length>0}static getDefaultResultByConfig(t){return t.reduce((e,i)=>(i.subSelected&&i.subSelected.forEach(s=>{var n;if(s.isDefault){const o=(n=e[i.value])!=null?n:"";let a=[];o.length>0&&(a=o.split(";")),a.push(s.value),e[i.value]=a.join(";")}}),e),{})}static getDefaultTagResult(t,e){const i=this.getDefaultResultByConfig(t);return e.length>0?e.map(s=>({id:uuid(),sourceID:s.id,result:__spreadValues$8({},i)})):[{id:uuid(),sourceID:"",result:__spreadValues$8({},i)}]}}class TagOperation extends BasicToolOperation{constructor(t){super(t);this.getInitResultList=(e,i)=>!(e===0||e===void 0)&&i.length===0?[]:TagUtil.getDefaultTagResult(this.config.inputList,i),this.setLabel=(e,i)=>{var s,n;if(this.isImgError||!this.basicResult&&this.dependToolName)return;const o=this.config.inputList;if(!o[e])return;const{subSelected:a}=o[e];if(e<o.length&&o[e].subSelected&&a&&i<a.length){const l=o[e].value;let h=(s=a[i])==null?void 0:s.value;const c=(n=o[e])==null?void 0:n.isMulti,u=this.tagResult.filter(d=>{const g=`${d.sourceID}`;return CommonToolUtils$1.isSameSourceID(g,this.sourceID)})[0];if(u){let d=0;const{result:g}=u;u.sourceID===0&&(u.sourceID="0");for(const p in u.result)if(p===o[e].value){if(d++,c===!0){const f=g[p].split(";").filter(m=>m!==""),v=f.indexOf(h);v===-1?f.push(h):f.splice(v,1),h=f.join(";")}h===""?Object.keys(g).length===1?this.tagResult=this.tagResult.filter(f=>{const v=`${f.sourceID}`;return CommonToolUtils$1.isDifferSourceID(v,this.sourceID)}):Object.keys(g).length>1&&delete g[p]:g[p]=h}d===0&&Object.assign(u.result,{[l]:h})}else this.tagResult=[{sourceID:this.sourceID,id:uuid(8,62),result:{[l]:h}}];this.render()}},this.clearResult=(e=!0,i)=>{i?this.tagResult=this.tagResult.map(s=>((s==null?void 0:s.result[i])&&delete s.result[i],s)):this.tagResult=[],this.render()},this.config=CommonToolUtils$1.jsonParser(t.config),this.tagResult=[],this.labelSelectedList=[],this.setShowDefaultCursor(!0)}destroy(){this.clearTag(),super.destroy()}setResult(t){this.tagResult=t,this.render()}get currentPageResult(){return[this.currentTagResult]}get currentTagResult(){var t;return(t=this.tagResult.filter(e=>{const i=`${e.sourceID}`;return CommonToolUtils$1.isSameSourceID(i,this.sourceID)})[0])!=null?t:{}}get sourceID(){return CommonToolUtils$1.getSourceID(this.basicResult)}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t))return;let{keyCode:e}=t;if(e&&(e<=57&&e>=49||e<=105&&e>=97)){if(e>57?e-=97:e-=49,this.config.inputList.length===1){this.labelSelectedList=[0,e],this.setLabel(0,e),setTimeout(()=>{this.labelSelectedList=[],this.render()},500);return}this.labelSelectedList.length===1?(this.labelSelectedList=[this.labelSelectedList[0],e],this.setLabel(this.labelSelectedList[0],e),setTimeout(()=>{this.labelSelectedList=[],this.render()},500)):(this.labelSelectedList=[e],this.emit("expend"))}}clearTag(){var t;const e=(t=this.canvas)==null?void 0:t.parentNode,i=window.self.document.getElementById("tagToolTag");i&&e&&e.contains(i)&&(e==null||e.removeChild(i))}renderTag(){var t,e,i,s,n,o;if(this.clearTag(),!(((t=this.tagResult)==null?void 0:t.length)>0))return;const a=document.createElement("div"),l=TagUtil.getTagNameList((i=(e=this.currentTagResult)==null?void 0:e.result)!=null?i:{},this.config.inputList);a.innerHTML=(s=l.reduce((h,c)=>`${h}${c.keyName}: ${c.value.join(" \u3001 ")}
|
|
60
60
|
`,""))!=null?s:"",a.setAttribute("id","tagToolTag"),a.setAttribute("style",`
|
|
61
61
|
position: absolute;
|
|
62
62
|
top: 0;
|
|
@@ -74,7 +74,7 @@
|
|
|
74
74
|
background: rgba(102, 111, 255, 1);
|
|
75
75
|
opacity: 0.6;
|
|
76
76
|
clear: both;
|
|
77
|
-
`),(o=(n=this.canvas)==null?void 0:n.parentNode)==null||o.appendChild(a)}render(){this.renderTag(),super.render(),this.emit("render")}exportData(){let{tagResult:t}=this;return this.isImgError&&(t=[]),[t,this.basicImgInfo]}}class StyleUtils{static getStrokeAndFill(t,e=!0,i={}){const{isSelected:s=!1,isHover:n=!1}=i;return s?{stroke:e?t.validSelected.stroke:t.invalidSelected.stroke,fill:e?t.validSelected.fill:t.invalidSelected.fill}:n?{stroke:e?t.validHover.stroke:t.invalidHover.stroke,fill:e?t.validHover.fill:t.invalidHover.fill}:{stroke:e?t.valid.stroke:t.invalid.stroke,fill:e?t.valid.fill:t.invalid.fill}}static getStyle2String(t){if(!!t)return Object.entries(t).reduce((e,i)=>`${e} ${i[0]}: ${i[1]};`,"")}}var __defProp$8=Object.defineProperty,__defProps$6=Object.defineProperties,__getOwnPropDescs$6=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$7=Object.getOwnPropertySymbols,__hasOwnProp$7=Object.prototype.hasOwnProperty,__propIsEnum$7=Object.prototype.propertyIsEnumerable,__pow=Math.pow,__defNormalProp$8=(r,t,e)=>t in r?__defProp$8(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$7=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$7.call(t,e)&&__defNormalProp$8(r,e,t[e]);if(__getOwnPropSymbols$7)for(var e of __getOwnPropSymbols$7(t))__propIsEnum$7.call(t,e)&&__defNormalProp$8(r,e,t[e]);return r},__spreadProps$6=(r,t)=>__defProps$6(r,__getOwnPropDescs$6(t));const TEXTAREA_WIDTH=200;class PointOperation extends BasicToolOperation{constructor(t){super(t);this.setMarkerIndex=e=>{this.markerIndex=e},this.setMarkerIndexAndSelect=e=>{if(!this.config.markerList)return;this.markerIndex=e;const i=this.config.markerList[e].value,s=this.currentPageResult.find(n=>n.label===i);s&&(this.setSelectedID(s.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(s.attribute)),this.emit("markIndexChange")},this.textChange=e=>{this.config.textConfigurable!==!0||!this.selectedID||(this.setPointList(AttributeUtils.textChange(e,this.selectedID,this.pointList)),this.emit("selectedChange"),this.render())},this.isMinDistance=e=>{const i=AxisUtils.changePointByZoom(e,this.zoom);return this.pointList.some(s=>{const n=AxisUtils.changePointByZoom(s,this.zoom);return MathUtils.getLineLength(n,i)<.2})},this.config=CommonToolUtils$1.jsonParser(t.config),this.pointList=[],this.markerIndex=0,this.setStyle(t.style),this.createPoint=this.createPoint.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this),this.setSelectedID=this.setSelectedID.bind(this)}get dataList(){return this.pointList}get drawOutsideTarget(){var t;return(t=this.config.drawOutsideTarget)!=null?t:this.config.drawPointOut}setNextMarker(t=this.pointList){if(this.hasMarkerConfig){const e=CommonToolUtils$1.getNextMarker(this.getCurrentPageResult(t),this.config.markerList);e&&this.setMarkerIndexAndSelect(e.index)}}setResult(t){this.clearActiveStatus(),this.setPointList(t),this.setNextMarker(t),this.render()}setPointList(t,e=!1){const i=this.pointList.length;this.pointList=t,i!==t.length&&this.emit("updatePageNumber"),e&&this.emit("updateResult")}setConfig(t,e=!1){this.config=CommonToolUtils$1.jsonParser(t),e===!0&&this.clearResult()}clearResult(){this.setPointList([]),this.setSelectedID(void 0),this.history.pushHistory([]),this.hoverID="",this.render()}setDefaultAttribute(t=""){const e=this.defaultAttribute;if(this.defaultAttribute=t,e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedID:i}=this;if(i&&(this.pointList.forEach(s=>{s.id===i&&(s.attribute=t)}),this.history.pushHistory(this.pointList),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(t)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}get selectedText(){var t;return(t=this.pointList.find(e=>e.id===this.selectedID))==null?void 0:t.textAttribute}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render(),this.emit("selectedChange")}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}clearActiveStatus(){this.hoverID=void 0,this.dragStatus=EDragStatus.Wait,this.setSelectedID(void 0)}setBasicResult(t){super.setBasicResult(t),this.setNextMarker(),this.clearActiveStatus()}onMouseDown(t){if(!(super.onMouseDown(t)||this.forbidMouseOperation)){if(t.button===0&&!this.hoverID){this.createPoint(t),this.render();return}return this.hoverID===this.selectedID&&t.button===0&&(this.dragStatus=EDragStatus.Start),this.render(),!0}}onMouseMove(t){super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo||(this.hoverID=this.getHoverId(),(this.dragStatus===EDragStatus.Start||this.dragStatus===EDragStatus.Move)&&this.onDragMove(t),this.hoverID&&this.render())}onMouseUp(t){if(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)return!0;t.button===2&&this.rightMouseUp(),this.dragStatus===EDragStatus.Move&&this.history.pushHistory(this.pointList),this.dragStatus=EDragStatus.Wait,this.render()}onDragMove(t){var e,i;if(!this.imgInfo)return;this.dragStatus=EDragStatus.Move;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.drawOutsideTarget,this.basicResult,this.zoom),o=this.drawOutsideTarget?AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos):AxisUtils.changePointByZoom(n,1/this.zoom);this.drawOutsideTarget===!1&&this.dependToolName===EToolName.Polygon&&((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&!PolygonUtils.isInPolygon(o,this.basicResult.pointList)||(this.pointList.forEach(a=>{a.id===this.selectedID&&(a.x=o.x,a.y=o.y)}),this.render())}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Delete:this.deletePoint();break;case EKeyCode$1.Tab:{this.onTabKeyDown(t);break}case EKeyCode$1.Z:this.setIsHidden(!this.isHidden),this.render();break;default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}}createPoint(t){var e,i,s,n;if(!this.imgInfo)return;const{upperLimit:o}=this.config;if(o&&this.currentPageResult.length>=o){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.LowerLimitPoint,this.lang)}`);return}const a=CommonToolUtils$1.getSourceID(this.basicResult),l=this.getCoordinateUnderZoom(t);let h=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);if(this.config.edgeAdsorption&&this.referenceData&&[EToolName.Polygon,EToolName.Line].includes((e=this.referenceData)==null?void 0:e.toolName)){const g=((i=this.referenceData)==null?void 0:i.toolName)===EToolName.Polygon,{dropFoot:p,hasClosed:f}=PolygonUtils.getClosestPoint(h,this.referenceData.result,(n=(s=this.referenceData.config)==null?void 0:s.lineType)!=null?n:ELineTypes.Line,edgeAdsorptionScope/this.zoom,{isClose:g});p&&(h=p),f&&this.emit("messageSuccess",`${Locale.getMessagesByLocale(EMessage.SuccessfulEdgeAdsorption,this.lang)}`)}if(this.drawOutsideTarget===!1){if(this.dependToolName&&this.basicCanvas){let c=!1;switch(this.dependToolName){case EToolName.Rect:{c=!RectUtils.isInRect(h,this.basicResult);break}case EToolName.Polygon:{c=!PolygonUtils.isInPolygon(h,this.basicResult.pointList);break}}if(c)return}if(l.x<0||l.y<0||l.x>this.imgInfo.width||l.y>this.imgInfo.height)return}if(this.isMinDistance(h))return;let d=__spreadProps$6(__spreadValues$7({},h),{attribute:this.defaultAttribute,valid:!t.ctrlKey,id:uuid(8,62),sourceID:a,textAttribute:"",order:CommonToolUtils$1.getMaxOrder(this.pointList.filter(c=>CommonToolUtils$1.isSameSourceID(c.sourceID,a)))+1});if(this.config.textConfigurable){let c="";c=AttributeUtils.getTextAttribute(this.pointList.filter(g=>CommonToolUtils$1.isSameSourceID(g.sourceID,a)),this.config.textCheckType),d=__spreadProps$6(__spreadValues$7({},d),{textAttribute:c})}if(this.hasMarkerConfig){const c=CommonToolUtils$1.getNextMarker(this.currentPageResult,this.config.markerList,this.markerIndex);if(c)d=__spreadProps$6(__spreadValues$7({},d),{label:c.label}),this.markerIndex=c.index,this.emit("markIndexChange");else{this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.MarkerFinish,this.lang));return}}this.hoverID=d.id;const u=[...this.pointList,d];this.setPointList(u),this.history.pushHistory(u),this.setSelectedID(d.id)}isInPoint(t,e,i=this.zoom){return(this.style.width+2)/i>=Math.sqrt(__pow(t.x-e.x,2)+__pow(t.y-e.y,2))}getHoverId(){var t;const e=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos),i=(t=this.pointList)==null?void 0:t.find(s=>this.isInPoint(e,s));return i==null?void 0:i.id}rightMouseUp(){if(this.selectedID===this.hoverID){const e=this.pointList.filter(i=>i.id!==this.selectedID);this.setPointList(e),this.history.pushHistory(e),this.setSelectedID(""),this.hoverID="";return}const t=this.pointList.find(e=>e.id===this.hoverID);if(this.setSelectedID(this.hoverID),this.setDefaultAttribute(t==null?void 0:t.attribute),(t==null?void 0:t.label)&&this.hasMarkerConfig){const e=CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList);e>=0&&(this.setMarkerIndex(e),this.emit("markIndexChange"))}}onTabKeyDown(t){if(t.preventDefault(),this.dragStatus===EDragStatus.Move||this.dragStatus===EDragStatus.Start)return;let e=ESortDirection.ascend;t.shiftKey&&(e=ESortDirection.descend);const[i,s]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);let n=[...i];s&&(n=[...n,s]);const o=CommonToolUtils$1.getNextSelectedRectID(n,e,this.selectedID);o&&this.setSelectedID(o.id)}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}getCurrentPageResult(t){const[e]=CommonToolUtils$1.getRenderResultList(t,CommonToolUtils$1.getSourceID(this.basicResult),[]);return e}exportData(){const{pointList:t}=this;return[t,this.basicImgInfo]}deletePoint(){var t;this.selectedID&&(this.setPointList(this.pointList.filter(e=>e.id!==this.selectedID)),this.history.pushHistory(this.pointList),(t=this._textAttributInstance)==null||t.clearTextAttribute(),this.emit("selectedChange"),this.render())}undoAndRedo(t){var e,i;if(this.dragStatus===EDragStatus.Move||this.dragStatus===EDragStatus.Start)return;const s=(i=(e=this.history)[t])==null?void 0:i.call(e);(s==null?void 0:s.some(n=>n.id===this.selectedID))||this.setSelectedID(""),s&&(this.setPointList(s,!0),this.render())}undo(){this.undoAndRedo("undo")}redo(){this.undoAndRedo("redo")}getCurrentSelectedData(){var t;if(!this.selectedID)return;const e=(t=this.pointList)==null?void 0:t.find(n=>n.id===this.selectedID),i=this.getColor(e==null?void 0:e.attribute),s=(e==null?void 0:e.valid)?i==null?void 0:i.valid.stroke:i==null?void 0:i.invalid.stroke;return this.dragStatus=EDragStatus.Wait,{width:TEXTAREA_WIDTH*this.zoom*.6,textAttribute:(e==null?void 0:e.textAttribute)||"",color:s}}updateSelectedTextAttribute(t){if(this._textAttributInstance&&t&&this.selectedID){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setPointList(AttributeUtils.textChange(e,this.selectedID,this.pointList)),this.emit("updateTextAttribute"),this.render()}}renderTextAttribute(){var t,e;const i=(t=this.pointList)==null?void 0:t.find(g=>g.id===this.selectedID);if(!this.ctx||this.config.textConfigurable!==!0||!i)return;const{x:s,y:n,attribute:o,valid:a}=i,l=TEXTAREA_WIDTH*this.zoom*.6,h=AxisUtils.getOffsetCoordinate({x:s,y:n},this.currentPos,this.zoom),d=this.getColor(o),u=a?d==null?void 0:d.valid.stroke:d==null?void 0:d.invalid.stroke,c=4;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:l,container:this.container,icon:this.getTextIconSvg(o),color:u,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributInstance&&!((e=this._textAttributInstance)==null?void 0:e.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${i.textAttribute}`,{left:h.x,top:h.y+c,color:u,width:l})}renderPoint(t){var e,i,s;const{textAttribute:n="",attribute:o}=t,a=t.id===this.selectedID,l=this.getColor(o),h=AxisUtils.changePointByZoom(t,this.zoom,this.currentPos),{width:d=2,hiddenText:u=!1}=this.style,c=StyleUtils.getStrokeAndFill(l,t.valid,{isSelected:a||t.id===this.hoverID});DrawUtils.drawCircle(this.canvas,h,d,{startAngleDeg:0,endAngleDeg:360,thickness:1,color:c.stroke,fill:c.fill});let g="";(((e=this.config)==null?void 0:e.isShowOrder)||((i=this.config)==null?void 0:i.showOrder))&&t.order&&(t==null?void 0:t.order)>0&&(g=`${t.order}`),t.label&&this.hasMarkerConfig&&(g=`${CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList)+1}_${MarkerUtils.getMarkerShowText(t.label,this.config.markerList)}`),t.attribute&&(g=`${g} ${AttributeUtils.getAttributeShowText(t.attribute,(s=this.config)==null?void 0:s.attributeList)}`),u||DrawUtils.drawText(this.canvas,{x:h.x+d/2,y:h.y-d-4},g,{textAlign:"center",color:c.stroke}),a?this.renderTextAttribute():u||DrawUtils.drawText(this.canvas,{x:h.x+d,y:h.y+d+24},n,__spreadValues$7({color:c.stroke},DEFAULT_TEXT_OFFSET))}renderPointList(){const[t,e]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);this.isHidden||t.forEach(i=>{this.renderPoint(i)}),e&&this.renderPoint(e)}renderTop(){var t,e,i;const s=this.getLineColor(this.defaultAttribute);if(this.renderCursorLine(s),this.config.edgeAdsorption&&this.referenceData){let n=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);const o=((t=this.referenceData)==null?void 0:t.toolName)===EToolName.Polygon,{dropFoot:a}=PolygonUtils.getClosestPoint(n,this.referenceData.result,(i=(e=this.referenceData.config)==null?void 0:e.lineType)!=null?i:ELineTypes.Line,edgeAdsorptionScope/this.zoom,{isClose:o});a&&n!==a&&n!==a&&(n=a,DrawUtils.drawCircle(this.canvas,AxisUtils.changePointByZoom(n,this.zoom,this.currentPos),5,{color:"white",fill:"white"}),DrawUtils.drawCircle(this.canvas,AxisUtils.changePointByZoom(n,this.zoom,this.currentPos),3,{fill:s,color:s}))}}render(){!this.ctx||(super.render(),this.renderPointList(),this.renderTop())}}var __defProp$7=Object.defineProperty,__defProps$5=Object.defineProperties,__getOwnPropDescs$5=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$6=Object.getOwnPropertySymbols,__hasOwnProp$6=Object.prototype.hasOwnProperty,__propIsEnum$6=Object.prototype.propertyIsEnumerable,__defNormalProp$7=(r,t,e)=>t in r?__defProp$7(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$6=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$6.call(t,e)&&__defNormalProp$7(r,e,t[e]);if(__getOwnPropSymbols$6)for(var e of __getOwnPropSymbols$6(t))__propIsEnum$6.call(t,e)&&__defNormalProp$7(r,e,t[e]);return r},__spreadProps$5=(r,t)=>__defProps$5(r,__getOwnPropDescs$5(t)),EStatus;(function(r){r[r.Create=0]="Create",r[r.Active=1]="Active",r[r.None=2]="None"})(EStatus||(EStatus={}));const SEGMENT_NUMBER=16,LINE_ORDER_OFFSET={x:0,y:20},POINT_RADIUS=3,POINT_ACTIVE_RADIUS=5,INNER_POINT_RADIUS=2;class LineToolOperation extends BasicToolOperation{constructor(t){super(t);this.drawActivatedLine=(e,i,s)=>{const n=___default.default.cloneDeep(this.activeLine);if(!n||n.length===0)return;const o=this.isActiveLineValid();let a;const l=this.selectedID?this.lineList.find(d=>d.id===this.selectedID):void 0;l?a=l.order:a=this.nextOrder();const h=this.getLineColorByAttribute({attribute:this.defaultAttribute,valid:!!o});n.map(d=>Object.assign(d,this.coordUtils.getRenderCoord(d))),this.updateActiveArea(),this.drawLine(n,e,h,!0,!0),this.drawLineNumber(n[0],a,h,"",this.defaultAttribute,o),e&&this.isCreate&&this.arc(e,POINT_RADIUS,h),this.cursor&&!this.selectedPoint&&!s&&!this.isShift&&this.arc(this.cursor,POINT_ACTIVE_RADIUS,h)},this.drawHoverPoint=e=>{if(!this.isMousedown&&e&&this.isLineSelected){const i=this.getPointList(this.activeLine),s=this.activeLine.find(o=>LineToolUtils.calcDistance(this.coordUtils.getRenderCoord(o),e)<=POINT_ACTIVE_RADIUS);let n;!s&&this.activeLine&&(n=this.findNearestPoint(i,e)),this.hoverPointID=s?s.id:void 0,this.cursor=s||n==null?void 0:n.point}},this.lineList=[],this.activeLine=[],this.coordsInsideActiveArea=!1,this.hoverLineSegmentIndex=-1,this.isShift=!1,this.isReference=!1,this.drawCurveLine=(e,i,s,n=!0,o=!1,a)=>{const l=createSmoothCurvePointsFromPointList(i,SEGMENT_NUMBER);e.save(),e.lineCap="round",e.lineJoin="round",e.strokeStyle=s.color,n&&(e.lineWidth=s.lineWidth),o&&LineToolUtils.setReferenceCtx(e),i.forEach(({specialEdge:h},d)=>{const u=l.splice(0,SEGMENT_NUMBER+1);e.save(),e.beginPath(),a===d&&(e.lineWidth=4),u.forEach(({x:c,y:g},p)=>{const f=p>0?"lineTo":"moveTo";h&&LineToolUtils.setSpecialEdgeStyle(e),e[f](c,g)}),e.stroke(),e.restore()}),e.restore()},this.drawLine=(e,i,s,n=!1,o=!1)=>{const a=i?e.concat(i):e,l={color:s,lineWidth:o?1:this.lineStyle.lineWidth};this.isCurve?LineToolUtils.drawCurveLine(this.ctx,a,l,!n,this.isReference,o?this.hoverLineSegmentIndex:-1):this.drawStraightLine(a,l,o),n&&e.forEach(h=>{var d,u;const c=h.id,g=c&&[this.hoverPointID,(d=this.selectedPoint)==null?void 0:d.id].includes(c)?POINT_ACTIVE_RADIUS:POINT_RADIUS;this.arc(h,g,s),[this.hoverPointID,(u=this.selectedPoint)==null?void 0:u.id].includes(c)||this.arc(h,INNER_POINT_RADIUS,"white")})},this.drawStraightLine=(e,i,s=!1)=>{const{ctx:n}=this;n&&(n.save(),n.lineCap="round",n.lineJoin="round",n.strokeStyle=i.color,n.lineWidth=i.lineWidth,this.isReference&&LineToolUtils.setReferenceCtx(n),e.forEach((o,a)=>{if(n.beginPath(),a>0){const l=e[a-1];n.save(),(l==null?void 0:l.specialEdge)&&LineToolUtils.setSpecialEdgeStyle(n),s&&this.hoverLineSegmentIndex+1===a&&(n.lineWidth=4),n.moveTo(l.x,l.y),n.lineTo(o.x,o.y),n.stroke(),n.restore()}}),n.restore())},this.drawLines=()=>{try{const e=___default.default.cloneDeep(this.attributeFilteredLines);if(this.isHidden)return;e.forEach(i=>{if(i.id!==this.selectedID&&i.pointList){i.pointList.map(l=>Object.assign(l,this.coordUtils.getRenderCoord(l)));const{order:s,label:n}=i,o=s,a=i&&this.getLineColorByAttribute(i);this.drawLine(i.pointList,void 0,a,!1),this.drawLineNumber(i.pointList[0],o,a,n,i.attribute,i.valid),i.id!==this.textEditingID&&this.drawLineTextAttribute(i.pointList[1],a,i==null?void 0:i.textAttribute)}})}catch(e){console.error(e,"\u7EBF\u6761\u5DE5\u5177\u6570\u636E\u89E3\u6790\u9519\u8BEF"),this.lineList=[],this.clearCanvas()}},this.render=e=>{super.render(),this.drawLines(),this.drawActivatedLine(e,void 0,!0),this.renderTextAttribute(),this.renderCursorLine(this.getLineColor(this.defaultAttribute))},this.moveLineInPolygon=(e,i)=>{var s;if(!Array.isArray(this.activeLine))return!1;((s=this.activeLine)==null?void 0:s.every(o=>this.isInBasicPolygon({x:o.x+e,y:o.y+i})))&&(this.lineDragging=!0,this.moveActiveArea(e,i))},this.moveLineInRectRange=(e,i,s,n)=>{if(this.activeArea===void 0)return;const{top:o,left:a,right:l,bottom:h}=this.activeArea,d=[a,l].map(v=>___default.default.isNumber(v)?v+e:0),u=[o,h].map(v=>___default.default.isNumber(v)?v+i:0),c=a>=0&&l&&MathUtils.isInRange(d,s),g=o>=0&&h&&MathUtils.isInRange(u,n),p=c?e:0,f=g?i:0;this.lineDragging=!0,this.moveActiveArea(p,f)},this.onRightClick=e=>{if(this.cursor=void 0,this.isCreate){if(this.isLinePointsNotEnough())return;this.stopLineCreating(!0);return}this.setActiveArea(this.getCoordinate(e),!0),this.emit("contextmenu")},this.updateSelectedAttributeAfterHistoryChanged=()=>{if(this.selectedID){const e=this.lineList.find(s=>s.id===this.selectedID),i=e==null?void 0:e.attribute;typeof i=="string"&&(this.defaultAttribute=i,this.updateAttribute(i),this.render())}},this.onLeftClick=e=>{const i=this.getCoordinate(e),{lineDragging:s}=this;if(this.lineDragging=!1,this.isSpaceKey)return;if(this.isNone&&e.ctrlKey){const o=this.findHoverLine(i);o&&this.setInvalidLine(o.id);return}if(this.isLinePointsExceed())return;const n=this.getNextPoint(e,i);if(this.isCreate||this.isNone){this.setCreatStatusAndAddPoint(n);return}if(this.isActive){if(s)return;if(this.isMouseCoordOutsideActiveArea()){this.setNoneStatus(!1),this.setCreatStatusAndAddPoint(n);return}if(e.shiftKey){this.updateLineSegmentSpecial(i);return}if(this.coordsInsideActiveArea&&e.ctrlKey){this.setInvalidLine(this.selectedID);return}this.addLinePointToActiveLine()}},this.onDblclick=()=>{},this.onKeyUp=e=>{if(super.onKeyUp(e),this.isShift=!1,this.hoverLineSegmentIndex=-1,e.keyCode===EKeyCode$1.Esc){this.stopLineCreating(!1);return}if(this.isActive){if(e.keyCode===EKeyCode$1.Delete){this.deleteLine();return}if(e.keyCode===EKeyCode$1.F){this.setInvalidLine(this.selectedID);return}if(e.keyCode===EKeyCode$1.Space){this.continueToEdit();return}}this.keyboardEventWhileLineCreating(e)},this.onRightDblClick=e=>{super.onRightDblClick(e);const i=this.getCoordinate(e);if(this.isActive){const s=this.findHoveredPoint(i);if(s){this.deleteSelectedLinePoint(s.id);return}this.deleteSelectedLine(i)}},this.setReference=e=>{this.isReference=e},this.pointsWithinRange=e=>!(this.lowerLimitPointNum&&e<this.lowerLimitPointNum||this.upperLimitPointNum&&e>this.upperLimitPointNum),this.setLineList=e=>{const i=e.length!==this.lineListLen;this.lineList=e,i&&this.emit("updatePageNumber")},this.textChange=e=>{this.config.textConfigurable===!1||!this.selectedID||(this.updateSelectedTextAttribute(e),this.emit("selectedChange"))},this.status=2,this.isMousedown=!1,this.lineDragging=!1,this.isLineValid=!0,this.setConfig(t.config),this.prevAxis={x:0,y:0},this.textEditingID="",this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.actionsHistory=new ActionsHistory,this.dependToolConfig={lineType:ELineTypes.Line}}get isLineSelected(){return this.selectedID&&this.activeLine}get selectedLinePoints(){return this.activeLine?this.getPointList(this.activeLine):[]}get isCreate(){return this.status===0}get isActive(){return this.status===1}get isNone(){return this.status===2}get isCurve(){return this.config.lineType===ELineTypes.Curve}get isMultipleColor(){return this.config.lineColor===ELineColor.MultiColor}get imageSize(){return this.rotate%180==0?this.basicImgInfo:{width:this.basicImgInfo.height,height:this.basicImgInfo.width}}get lineListLen(){return this.lineList.length}get edgeAdsorptionEnabled(){return this.edgeAdsorption&&!this.isCurve&&this.lineListLen>0}get attributeConfigurable(){return this.config.attributeConfigurable}get isTextConfigurable(){return this.config.textConfigurable}get isDependPolygon(){return this.dependToolName===EToolName.Polygon}get isDependRect(){return this.dependToolName===EToolName.Rect}get isCurrentAttributeLocked(){return this.attributeLockList.includes(this.defaultAttribute)}get attributeFilteredLines(){return this.attributeLockList.length>0?this.lineList.filter(t=>this.attributeLockList.includes((t==null?void 0:t.attribute)||"")):this.lineList}get enableOutOfTarget(){return this.config.enableOutOfTarget}get showOrder(){return this.config.showOrder}get edgeAdsorption(){return this.config.edgeAdsorption}get attributeList(){return this.config.attributeList}get lowerLimitPointNum(){return this.config.lowerLimitPointNum}get upperLimitPointNum(){return this.config.upperLimitPointNum}get textCheckType(){return this.config.textCheckType}get customFormat(){return this.config.customFormat}get dataList(){return this.lineList}get hasActiveLine(){return this.activeLine&&this.activeLine.length>0}get viewPortLines(){const t=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom);return this.isHidden?[]:this.attributeFilteredLines.filter(e=>{var i;return(i=e==null?void 0:e.pointList)==null?void 0:i.some(s=>CanvasUtils.inViewPort(s,t))})}get lineStyle(){return{lineWidth:this.style.width,color:this.getLineColor(this.defaultAttribute),opacity:this.style.opacity}}get selectedText(){var t,e;return(e=(t=this.lineList.find(i=>i.id===this.selectedID))==null?void 0:t.textAttribute)!=null?e:""}get currentPageResult(){return this.lineList}updateStatus(t,e=!1){if(t!==this.status){if(e){let i="";this.textCheckType===ETextType.Order&&this.isTextConfigurable&&(i=AttributeUtils.getTextAttribute(this.lineList,this.textCheckType)),this.emit("updateText",i)}this.status=t,this.lineStatusChanged()}}isInBasicPolygon(t){var e,i;return isInPolygon(t,((e=this.basicResult)==null?void 0:e.pointList)||[],(i=this.dependToolConfig)==null?void 0:i.lineType)}getPolygonPointList(){if(!this.basicResult)return[];const{pointList:t}=this.basicResult,{lineType:e}=this.dependToolConfig;return e===ELineTypes.Curve?createSmoothCurvePoints(t.reduce((i,s)=>[...i,s.x,s.y],[]),.5,!0,20):t}getNextCoordByRenderCoord(t){return this.getNextCoordByAbsCoord(this.coordUtils.getAbsCoord(t))}getNextCoordByAbsCoord(t){var e;const i=(e=this.activeLine)==null?void 0:e.slice(-1)[0];return i?this.coordUtils.getNextCoordByDependTool(t,i):t}pointInLine(t,e,i){return t.filter(s=>s).length<2?!1:t.some((s,n)=>{if(n===0)return!1;const o=this.coordUtils.getRenderCoord(t[n-1]),a=this.coordUtils.getRenderCoord(s);return LineToolUtils.isInLine(e,o,a,i)})}arc(t,e=POINT_RADIUS,i){var s,n,o,a,l,h;if(this.ctx){const{x:d,y:u}=t;(s=this.ctx)==null||s.save(),(n=this.ctx)==null||n.beginPath(),this.ctx.fillStyle=i||this.lineStyle.color,(o=this.ctx)==null||o.arc(d,u,e,0,360),(a=this.ctx)==null||a.closePath(),(l=this.ctx)==null||l.fill(),(h=this.ctx)==null||h.restore()}}renderActiveArea(){if(this.isActive&&this.activeArea&&this.ctx){const{top:t,left:e,right:i,bottom:s}=this.activeArea,{x:n,y:o}=this.coordUtils.getRenderCoord({x:e,y:t});this.ctx.save(),this.ctx.beginPath(),this.ctx.strokeStyle="#B3B8FF",this.ctx.rect(n,o,(i-e)*this.zoom,(s-t)*this.zoom),this.ctx.stroke(),this.ctx.restore()}}addLinePoint(t){var e,i,s,n;this.arc(t),(e=this.activeLine)==null||e.push(__spreadProps$5(__spreadValues$6({},t),{id:uuid()})),((i=this.activeLine)==null?void 0:i.length)===1?(s=this.actionsHistory)==null||s.initRecord(this.activeLine):(n=this.actionsHistory)==null||n.pushHistory(this.activeLine),this.render()}setCreatStatusAndAddPoint(t,e=!1){this.updateStatus(0,e),this.addLinePoint(t)}isActiveLineValid(){var t;return this.selectedID?(t=this.lineList.find(e=>e.id===this.selectedID))==null?void 0:t.valid:this.isLineValid}nextOrder(){return this.lineListLen===0?1:this.lineList.slice(-1)[0].order+1}getLineColorByAttribute(t,e=!1){return StyleUtils.getStrokeAndFill(this.getColor(t.attribute),t.valid,{isSelected:e}).stroke}updateActiveArea(){this.activeArea=this.getActiveArea(),this.renderActiveArea()}getActiveArea(){return this.hasActiveLine?MathUtils.calcViewportBoundaries(this.activeLine,this.isCurve,SEGMENT_NUMBER,this.zoom):void 0}drawLineNumber(t,e=1,i,s="",n,o=!0){var a,l,h;if((this.showOrder||this.attributeConfigurable)&&this.ctx){let d=this.showOrder?e.toString():`${s}`;if(this.attributeConfigurable){const u=n?(h=(l=(a=this.attributeList)==null?void 0:a.find(c=>c.value===n))==null?void 0:l.key)!=null?h:n:"";d=[d,`${!o&&u?"\u65E0\u6548":""}${u}`].filter(c=>c).join("_")}this.drawText(t,d,i)}}drawLineTextAttribute(t,e,i){if(t&&i)return this.drawText(t,i,e,200)}drawText(t,e,i,s){var n,o;this.ctx&&((n=this.ctx)==null||n.save(),this.ctx.font="italic bold 14px SourceHanSansCN-Regular",this.ctx.fillStyle=i,this.ctx.strokeStyle=i,this.ctx.shadowColor="rgba(0, 0, 0, 0.6)",this.ctx.shadowOffsetY=2,this.ctx.shadowBlur=4,s?DrawUtils.wrapText(this.canvas,e,t.x-LINE_ORDER_OFFSET.x,t.y-LINE_ORDER_OFFSET.y,s):this.ctx.fillText(e,t.x-LINE_ORDER_OFFSET.x,t.y-LINE_ORDER_OFFSET.y),(o=this.ctx)==null||o.restore())}moveActiveArea(t,e){this.activeArea&&(this.activeArea=Object.assign(this.activeArea,{top:this.activeArea.top+e,bottom:this.activeArea.bottom+e,right:this.activeArea.right+t,left:this.activeArea.left+t})),this.activeLine&&(this.activeLine.map(i=>Object.assign(i,{x:i.x+t,y:i.y+e})),this.updateLines())}findHoveredPoint(t){if(!!this.activeLine)return this.activeLine.find(e=>{const i=this.coordUtils.getRenderCoord(e);return LineToolUtils.calcDistance(i,t)<=POINT_ACTIVE_RADIUS})}findHoverLine(t){return ___default.default.cloneDeep(this.lineList).reverse().find(({pointList:i})=>{const s=i?this.getPointList(i):[],n=this.getLineWidthScope();return s.some((o,a)=>{if(a===0)return!1;const l=this.coordUtils.getRenderCoord(o),h=this.coordUtils.getRenderCoord(s[a-1]);return LineToolUtils.isInLine(t,l,h,n)})})}getAdsorptionPoint(t){let e,i,s;return ___default.default.cloneDeep(this.lineList).reverse().forEach(({pointList:n,id:o})=>{if(o===this.selectedID||!n||(n==null?void 0:n.length)<2)return;const a=this.findNearestPoint(n,t);if(a){if(a.minDistance===0){e=a.point;return}(i===void 0||a.minDistance<i)&&(e=a.point,i=a.minDistance)}}),s||e}findNearestPoint(t,e,i=7){let s;const n=i;for(let o=1;o<=t.length-1;o++){const a=this.coordUtils.getRenderCoord(t[o]),l=this.coordUtils.getRenderCoord(t[o-1]),{length:h,footPoint:d}=MathUtils.getFootOfPerpendicular(e,a,l),u=LineToolUtils.calcTwoPointDistance(a,e),c=LineToolUtils.calcTwoPointDistance(l,e);if(u<=i*2){s=a,i=0;break}if(c<=i*2){s=l,i=0;break}h<i&&(s=d,i=h)}return s?{point:s,minDistance:n}:void 0}getPointList(t){return this.isCurve?createSmoothCurvePointsFromPointList(t,SEGMENT_NUMBER):t}moveSelectedLine(t){const e=(t.x-this.prevAxis.x)/this.zoom,i=(t.y-this.prevAxis.y)/this.zoom;if(this.enableOutOfTarget){this.lineDragging=!0,this.moveActiveArea(e,i);return}if(this.isDependPolygon){this.moveLineInPolygon(e,i);return}let s=[0,this.imageSize.width],n=[0,this.imageSize.height];if(this.isDependRect){const{x:o,y:a,width:l,height:h}=this.basicResult;s=[o,o+l],n=[a,a+h]}this.moveLineInRectRange(e,i,s,n)}moveSelectPoint(t){if(!this.selectedPoint)return;const e=t.x-this.prevAxis.x,i=t.y-this.prevAxis.y,s=(this.selectedPoint?this.selectedPoint.x:0)+e/this.zoom,n=(this.selectedPoint?this.selectedPoint.y:0)+i/this.zoom,o={x:s,y:n};Object.assign(this.selectedPoint,this.getNextCoordByAbsCoord(o)),this.updateLines(),this.render()}getCoordByConfig(t,e){var i;const s=!!t.shiftKey,n=t.altKey;if(((i=this.activeLine)==null?void 0:i.length)>0&&s){const o=this.activeLine.slice(-1)[0];return LineToolUtils.getVHPoint(o,e,this.coordUtils.getAbsCoord(e),this.coordUtils.getRenderCoord(o))}return this.edgeAdsorptionEnabled&&!n?this.getAdsorptionPoint(e):e}getNextPoint(t,e){const i=this.getCoordByConfig(t,e)||e;return this.enableOutOfTarget?i:this.getNextCoordByRenderCoord(i)}lineHover(){this.render()}mouseMoveHandler(t){const e=this.getCoordinate(t),i=t.which===1;if(this.isCreate){this.hasActiveLine&&this.renderNextPoint(t,e);return}if(this.isNone&&(this.lineHover(),this.edgeAdsorptionEnabled&&!t.altKey)){const s=this.getAdsorptionPoint(e);s&&this.arc(s)}if(this.isActive){if(this.isMousedown&&i){if(this.selectedPoint){this.moveSelectPoint(e);return}if(this.coordsInsideActiveArea){this.moveSelectedLine(e),this.drawActivatedLine(void 0,void 0,!0);return}}this.drawHoverPoint(e),this.render()}}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.getCoordinate(t);this.mouseMoveHandler(t),this.prevAxis=e}setActiveArea(t,e=!1){const i=this.findHoverLine(t);if(i){const s=this.lineList.findIndex(a=>a.id===(i==null?void 0:i.id)),n=MathUtils.calcViewportBoundaries((i==null?void 0:i.pointList)||[],this.isCurve,SEGMENT_NUMBER,this.zoom),o=this.lineList[s];this.updateStatus(1),this.setActiveLine(o.pointList),this.setSelectedLineID(o.id),this.activeArea=n,this.updateLineAttributes(o)}else e&&this.setNoneStatus();this.render()}setActiveLineByID(t){const e=this.lineList.find(i=>i.id===t);if(e){const i=MathUtils.calcViewportBoundaries((e==null?void 0:e.pointList)||[],this.isCurve,SEGMENT_NUMBER,this.zoom);this.updateStatus(1),this.setActiveLine(e.pointList),this.setSelectedLineID(e.id),this.activeArea=i,this.updateLineAttributes(e)}this.render()}setActiveLine(t){this.activeLine=t?___default.default.cloneDeep(t):void 0}historyChanged(t){const e=`${t}Enabled`;if(this.isCreate){if(this.actionsHistory&&this.actionsHistory[e]){const i=this.actionsHistory&&this.actionsHistory[t]();this.setActiveLine(i),this.render()}return}if(this.history&&this.history[e]){const i=this.history[t](),s=i==null?void 0:i.find(n=>n.id===this.selectedID);this.lineList=i,this.selectedID&&s?this.setActiveLine(s==null?void 0:s.pointList):this.setNoneStatus(),this.render()}this.emit("dataUpdated",this.lineList)}undo(){this.historyChanged("undo"),this.updateSelectedAttributeAfterHistoryChanged()}redo(){this.historyChanged("redo"),this.updateSelectedAttributeAfterHistoryChanged()}isCoordInsideTarget(t){if(this.isDependPolygon)return this.isInBasicPolygon(t);if(this.isDependRect){const{x:e,y:i,width:s,height:n}=this.basicResult,o=[e,e+s],a=[i,i+n];return MathUtils.isInRange(t.x,o)&&MathUtils.isInRange(t.y,a)}return MathUtils.isInRange(t.x,[0,this.imageSize.width])&&MathUtils.isInRange(t.y,[0,this.imageSize.height])}getPointInsertIndex(t,e){if(t&&this.activeLine){const i=this.getPointList(this.activeLine);return this.activeLine.length===2?1:this.activeLine.findIndex((s,n)=>{if(n>0){const o=this.activeLine?this.activeLine[n-1]:void 0,a=this.isCurve?i.slice((n-1)*(SEGMENT_NUMBER+1),n*(SEGMENT_NUMBER+1)):[o,s];return this.pointInLine(a,t,e||this.getLineWidthScope())}return!1})}return-1}getLineWidthScope(){return this.lineStyle.lineWidth}isMouseCoordOutsideActiveArea(){return!this.coordsInsideActiveArea&&!this.selectedPoint}isLinePointsExceed(){return this.isCreate&&this.activeLine&&this.upperLimitPointNum&&~~this.upperLimitPointNum<=this.activeLine.length}isLinePointsNotEnough(){var t;return this.activeLine&&((t=this.activeLine)==null?void 0:t.length)<this.lowerLimitPointNum}updateLineSegmentSpecial(t){const e=this.getPointInsertIndex(t,2)-1;if(e>-1){const i=this.activeLine[e];i.specialEdge=!i.specialEdge,this.hoverLineSegmentIndex=-1,this.render()}}addLinePointToActiveLine(){var t;const e=this.getPointInsertIndex(this.cursor),i=this.pointsWithinRange(this.activeLine.length+1);this.cursor&&e>-1&&i&&(this.activeLine.splice(e,0,__spreadProps$5(__spreadValues$6({},this.coordUtils.getAbsCoord(this.cursor)),{id:uuid()})),this.updateLines(),(t=this.history)==null||t.pushHistory(this.lineList),this.render(),this.cursor=void 0)}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.getCoordinate(t);if(this.isMousedown=!0,this.prevAxis=e,t.which===3){this.cursor=void 0;return}this.selectedPoint=this.findHoveredPoint(e),this.coordsInsideActiveArea=this.isActive&&this.activeArea?LineToolUtils.inArea(this.activeArea,this.coordUtils.getAbsCoord(e)):!1,this.lineDragging=!1}lineHasChanged(){const t=this.lineList.find(e=>e.id===this.selectedID);return t?JSON.stringify(t.pointList)!==JSON.stringify(this.activeLine):!1}updateLines(){const t=this.lineList.find(e=>e.id===this.selectedID);t&&(t.pointList=___default.default.cloneDeep(this.activeLine),this.emit("dataUpdated",this.lineList))}onMouseUp(t){const e=()=>{this.isMousedown=!1,this.hoverPointID=void 0,this.cursor=void 0,this.selectedPoint=void 0};if(this.hoverPointID=void 0,super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo){e();return}t.which===1&&this.onLeftClick(t),t.which===3&&this.onRightClick(t),e()}isTextValid(t){return AttributeUtils.textAttributeValidate(this.textCheckType,this.customFormat,t)}createLineData(){const t=uuid(),e={pointList:___default.default.cloneDeep(this.activeLine),id:t,valid:this.isLineValid,order:this.nextOrder()};return e.attribute=this.defaultAttribute,e}stopLineCreating(t=!0){var e,i,s,n;const o=this.selectedID?!0:!!this.isTextConfigurable;let a;if(t){if(this.selectedID){const l=this.lineList.find(h=>h.id===this.selectedID);a=this.selectedID,l&&(l.pointList=___default.default.cloneWith(this.activeLine),___default.default.isEqual(l.pointList,(e=this.history)==null?void 0:e.pushHistory(this.lineList))||(i=this.history)==null||i.pushHistory(this.lineList))}else if(this.isCreate&&this.activeLine&&this.activeLine.length>1){const l=this.createLineData();a=l.id,this.setLineList([...this.lineList,l]),(s=this.history)==null||s.pushHistory(this.lineList)}}o?this.setActiveStatus(a):this.setNoneStatus(),(n=this.actionsHistory)==null||n.empty(),this.emit("dataUpdated",this.lineList),this.render()}setActiveStatus(t){const e=t?this.lineList.find(i=>i.id===t):void 0;if(e){const i=e==null?void 0:e.pointList;this.updateStatus(1),this.setActiveLine(i),this.setSelectedLineID(t)}else this.setNoneStatus()}setNoneStatus(t=!0){t&&this.updateStatus(2),this.activeLine=[],this.setSelectedLineID(void 0),this.activeArea=void 0,this.isLineValid=!0,this.cursor=void 0}setKeyDownStatus(t,e){this.isShift=e!=null?e:t.keyCode===EKeyCode$1.Shift}continueToEdit(){var t;this.updateStatus(0),this.cursor=void 0,(t=this.actionsHistory)==null||t.pushHistory(this.activeLine),this.render()}setInvalidLineOnCreating(t){if(this.selectedID&&t.keyCode!==EKeyCode$1.Ctrl||!this.isCreate)return;const e=!t.ctrlKey;this.selectedID?this.setInvalidLine(this.selectedID,e,!1):this.isLineValid=e}onKeyDown(t){if(super.onKeyDown(t),this.setKeyDownStatus(t),t.keyCode===EKeyCode$1.Z&&!t.ctrlKey&&this.toggleIsHide(),t.keyCode===EKeyCode$1.Shift&&this.render(),t.keyCode===EKeyCode$1.Tab){t.preventDefault(),this.selectToNextLine(t);return}if(this.isCreate&&this.keyboardEventWhileLineCreating(t),this.config.attributeConfigurable){const e=AttributeUtils.getAttributeByKeycode(t.keyCode,this.config.attributeList);e!==void 0&&this.setDefaultAttribute(e)}}selectToNextLine(t){const e=CommonToolUtils$1.getNextSelectedRectIDByEvent(this.viewPortLines.map(i=>{var s,n,o,a;return __spreadProps$5(__spreadValues$6({},i),{x:(n=(s=i.pointList[0])==null?void 0:s.x)!=null?n:0,y:(a=(o=i.pointList[0])==null?void 0:o.y)!=null?a:0})}),t,this.selectedID);e&&this.setActiveLineByID(e.id)}keyboardEventWhileLineCreating(t){!this.isCreate||(t.keyCode===EKeyCode$1.Ctrl&&this.setInvalidLineOnCreating(t),[EKeyCode$1.Shift,EKeyCode$1.Alt].includes(t.keyCode)&&this.renderNextPoint(t,this.prevAxis))}renderNextPoint(t,e){const i=this.coordUtils.getRenderCoord(this.getNextPoint(t,e));this.render(i)}deleteSelectedLine(t){const e=MathUtils.calcViewportBoundaries(this.activeLine,this.isCurve,SEGMENT_NUMBER,this.zoom);LineToolUtils.inArea(e,this.coordUtils.getAbsCoord(t))&&this.deleteLine()}deleteSelectedLinePoint(t){var e;this.pointsWithinRange(this.activeLine.length-1)&&t&&(this.setActiveLine(this.activeLine.filter(s=>s.id!==t)),this.updateLines(),(e=this.history)==null||e.pushHistory(this.lineList)),this.cursor=void 0,this.render()}deleteLine(){var t;this.lineList=this.lineList.filter(e=>e.id!==this.selectedID),(t=this.history)==null||t.pushHistory(this.lineList),this.setNoneStatus(),this.emit("dataUpdated",this.lineList),this.render()}setInvalidLine(t,e,i=!0){var s;const n=this.lineList.find(o=>o.id===t);n&&(n.valid=e!==void 0?e:!n.valid,(s=this.history)==null||s.pushHistory(this.lineList),i&&this.render())}empty(){var t,e;this.lineList=[],this.setNoneStatus(),this.selectedPoint=void 0,(t=this.actionsHistory)==null||t.empty(),(e=this.history)==null||e.init(),this.emit("dataUpdated",this.lineList),this.render()}setAttribute(t){var e;this.attributeConfigurable&&(this.defaultAttribute=t,this.setLineAttribute("attribute",t),this.selectedID&&((e=this.history)==null||e.pushHistory(this.lineList)))}setTextAttribute(t){var e;this.isTextConfigurable&&(this.setLineAttribute("textAttribute",t),(e=this.history)==null||e.applyAttribute(this.selectedID,"textAttribute",t))}setLineAttribute(t,e,i){const s=i||this.selectedID;if(s){const n=this.lineList.find(o=>o.id===s);n&&(n[t]=e)}this.render()}updateAttribute(t){this.emit("updateAttribute",t)}updateLineAttributes(t){var e;if(this.attributeConfigurable&&t){const i=(t==null?void 0:t.attribute)||"";this.defaultAttribute=i,this.updateAttribute(i)}if(this.isTextConfigurable&&t){const i=(t==null?void 0:t.textAttribute)||"";this.updateTextAttribute(i)}(e=this.history)==null||e.updateHistory(this.lineList)}lineStatusChanged(){this.emit("lineStatusChanged",{status:this.status,selectedLineID:this.selectedID})}updateTextAttribute(t){if(this.selectedID){const e=this.lineList.find(i=>i.id===this.selectedID);e&&(e.textAttribute=t)}this.emit("updateText",t)}saveData(){this.stopLineCreating(),this.setNoneStatus(),this.render()}setTextEditingID(t){this.textEditingID=t,this.render()}setSelectedLineID(t){var e,i;if(this.selectedID===t)return;const s=this.selectedID;t!==s&&s&&((e=this._textAttributeInstance)==null||e.changeSelected()),t||(i=this._textAttributeInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.emit("selectedChange")}attributeLockListChange(t){this.attributeLockList=t,this.render()}setResult(t){this.setNoneStatus(),this.setLineList(t),this.render()}setConfig(t){super.setConfig(t)}toggleIsHide(){this.setIsHidden(!this.isHidden),this.render()}clearCanvas(){super.clearCanvas()}clearResult(){this.setResult([]),this.setSelectedLineID(void 0),this.render()}exportData(){return[this.lineList,this.basicImgInfo]}setDefaultAttribute(t=""){var e;this.attributeConfigurable&&(this.defaultAttribute=t,this.setLineAttribute("attribute",t),this.selectedID&&((e=this.history)==null||e.pushHistory(this.lineList)),this.emit("changeAttributeSidebar"))}getCurrentSelectedData(){var t,e;const i=this.isActiveLineValid(),s=this.defaultAttribute,n=this.getColor(s),o=i?n==null?void 0:n.valid.stroke:n==null?void 0:n.invalid.stroke,a=(e=(t=this.lineList.find(l=>l.id===this.selectedID))==null?void 0:t.textAttribute)!=null?e:"";return{color:o,textAttribute:a}}renderTextAttribute(){var t,e,i,s;if(!this.ctx||!this.activeLine||((t=this.activeLine)==null?void 0:t.length)<2||this.isCreate)return;const n=this.isActiveLineValid(),o=this.defaultAttribute,{x:a,y:l}=this.activeLine[1],h=this.coordUtils.getRenderCoord({x:a,y:l}),d=this.getColor(o),u=n?d==null?void 0:d.valid.stroke:d==null?void 0:d.invalid.stroke,c=(i=(e=this.lineList.find(g=>g.id===this.selectedID))==null?void 0:e.textAttribute)!=null?i:"";this._textAttributeInstance||(this._textAttributeInstance=new TextAttributeClass({container:this.container,icon:this.getTextIconSvg(o),color:u,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributeInstance&&!((s=this._textAttributeInstance)==null?void 0:s.isExit)&&this._textAttributeInstance.appendToContainer(),this._textAttributeInstance.update(`${c}`,{left:h.x,top:h.y,color:u}),this._textAttributeInstance.updateIcon(this.getTextIconSvg(o))}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}updateSelectedTextAttribute(t){if(this._textAttributeInstance&&t&&this.selectedID){let e=t;!AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setTextAttribute(e),this.emit("updateTextAttribute"),this.render()}}}class TextToolOperation extends BasicToolOperation{constructor(t){super(t);this.getSingleResult=e=>{const i={};return this.config.configList.length>0&&this.config.configList.forEach(s=>{var n;i[s.key]=(n=s.default)!=null?n:""}),{value:i,id:uuid(),sourceID:e!=null?e:CommonToolUtils$1.getSourceID()}},this.getInitResultList=(e,i)=>e>0?i.map(s=>this.getSingleResult(s.id)):[this.getSingleResult()],this.textList=[],this.setShowDefaultCursor(!0),this.setConfig(t.config),this.initTextDisplayContainer()}get dataList(){return this.textList}get textValueContainerID(){return"textValueContainer"}get textValueContainer(){return document.getElementById(this.textValueContainerID)}get currentPageResult(){return this.textList}setResult(t){var e;this.textList=t,this.toggleTextContainerVisible(!0);const i=(e=this.textList[0])==null?void 0:e.value;i&&Object.keys(i).forEach(s=>{this.renderText(s,i[s])}),this.emit("valueUpdated"),this.toggleTextContainerVisible(!!i)}updateTextValue(t,e){this.textList[0].value[t]=e,this.renderText(t,e),this.emit("valueUpdated")}renderText(t,e){const i=document.getElementById(`textKey${t}`);i&&(i.innerText=e)}getTextDomID(t){return`textKey${t}`}initTextDisplayContainer(){const t=document.createElement("div"),e={position:"absolute",right:"0",top:"0","z-index":"20","max-width":"20%","font-family":"SourceHanSansCN-Regular",background:"rgb(102, 230, 255)",color:"white","word-break":"break-all","line-height":"24px","white-space":"pre-wrap","max-height":"80%","overflow-y":"auto",opacity:"0.6"};t.setAttribute("style",Object.keys(e).reduce((i,s)=>(i+=`${s}: ${e[s]};`,i),"")),t.setAttribute("id",this.textValueContainerID),this.config.configList.forEach(i=>{const s=document.createElement("div"),n=document.createElement("div"),o=document.createElement("div");s.setAttribute("style","padding: 8px 16px"),n.innerText=`${i.key}:`,o.innerText="",o.setAttribute("id",this.getTextDomID(i.key)),s.appendChild(n),s.appendChild(o),t.appendChild(s)}),this.container.appendChild(t)}exportData(){return[this.textList,this.basicImgInfo]}destroyCanvas(){super.destroyCanvas(),this.textValueContainer&&this.container.removeChild(this.textValueContainer)}onKeyDown(t){super.onKeyDown(t),t.keyCode===EKeyCode$1.Z&&this.toggleTextContainerVisible()}toggleTextContainerVisible(t){if(this.textValueContainer){const e=(t!==void 0?!t:this.textValueContainer.style.display==="block")?"none":"block";this.textValueContainer.style.display=e}}}var __defProp$6=Object.defineProperty,__defProps$4=Object.defineProperties,__getOwnPropDescs$4=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$5=Object.getOwnPropertySymbols,__hasOwnProp$5=Object.prototype.hasOwnProperty,__propIsEnum$5=Object.prototype.propertyIsEnumerable,__defNormalProp$6=(r,t,e)=>t in r?__defProp$6(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$5=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$5.call(t,e)&&__defNormalProp$6(r,e,t[e]);if(__getOwnPropSymbols$5)for(var e of __getOwnPropSymbols$5(t))__propIsEnum$5.call(t,e)&&__defNormalProp$6(r,e,t[e]);return r},__spreadProps$4=(r,t)=>__defProps$4(r,__getOwnPropDescs$4(t));const TEXT_MAX_WIDTH=164;class PolygonOperation extends BasicToolOperation{constructor(t){super(t);this.isAllowDouble=e=>{const{selectedID:i}=this,s=this.getHoverID(e);return!!(i&&i===s)},this.textChange=e=>{this.config.textConfigurable===!1||!this.selectedID||(this.setPolygonList(AttributeUtils.textChange(e,this.selectedID,this.polygonList)),this.emit("selectedChange"),this.render())},this.config=CommonToolUtils$1.jsonParser(t.config),this.drawingPointList=[],this.polygonList=[],this.hoverPointIndex=-1,this.hoverEdgeIndex=-1,this.drawingHistory=new ActionsHistory,this.isCtrl=!1,this.isAlt=!1,this.isCombined=!1,this.pattern=EPolygonPattern.Normal,this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this)}eventBinding(){super.eventBinding(),this.container.removeEventListener("mouseup",this.onMouseUp),this.container.addEventListener("mouseup",this.dragMouseUp),this.dblClickListener.addEvent(this.onMouseUp,this.onLeftDblClick,this.onRightDblClick,this.isAllowDouble)}eventUnbinding(){super.eventUnbinding(),this.container.removeEventListener("mouseup",this.dragMouseUp)}destroy(){super.destroy(),this._textAttributInstance&&this._textAttributInstance.clearTextAttribute()}get selectedPolygon(){return PolygonUtils.getPolygonByID(this.polygonList,this.selectedID)}get hoverPolygon(){return this.polygonList.find(t=>t.id===this.hoverID&&t.id!==this.selectedID)}get polygonListUnderZoom(){return this.polygonList.map(t=>__spreadProps$4(__spreadValues$5({},t),{pointList:AxisUtils.changePointListByZoom(t.pointList,this.zoom)}))}get selectedText(){var t;return(t=this.selectedPolygon)==null?void 0:t.textAttribute}get dataList(){return this.polygonList}setPattern(t,e=!1){var i;((i=this.drawingPointList)==null?void 0:i.length)>0&&e===!0||(this.pattern=t)}get currentShowList(){let t=[];const[e,i]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);return t=e,this.isHidden&&(t=[]),i&&t.push(i),t}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}setResultAndSelectedID(t,e){this.setPolygonList(t),e&&(this.selectedID=e),this.render()}setResult(t){this.clearActiveStatus(),this.setPolygonList(t),this.render()}setPolygonDataByID(t,e){return this.polygonList.map(i=>i.id===e?__spreadValues$5(__spreadValues$5({},i),t):i)}rotatePolygon(t=1,e=ERotateDirection.Clockwise,i=this.selectedID){if(!i)return;const s=PolygonUtils.getPolygonByID(this.polygonList,i);if(!s)return;const n=PolygonUtils.updatePolygonByRotate(e,t,s==null?void 0:s.pointList);this.setPolygonList(this.setPolygonDataByID({pointList:n},i)),this.render()}addPointInDrawing(t){if(!this.imgInfo)return;const{upperLimitPointNum:e,edgeAdsorption:i}=this.config;if(e&&this.drawingPointList.length>=e){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UpperLimitErrorNotice,this.lang)}${e}`);return}this.deleteSelectedID();const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(AxisUtils.returnClosePointIndex(n,AxisUtils.changePointListByZoom(this.drawingPointList,this.zoom))===0){this.addDrawingPointToPolygonList();return}const{dropFoot:a}=PolygonUtils.getClosestPoint(n,this.polygonListUnderZoom,this.config.lineType,edgeAdsorptionScope),l=AxisUtils.changePointByZoom(a&&t.altKey===!1&&i?a:n,1/this.zoom);if(this.pattern===EPolygonPattern.Rect&&this.drawingPointList.length===2){const h=MathUtils.getRectangleByRightAngle(l,this.drawingPointList);if(this.drawingPointList=h,this.config.drawOutsideTarget===!1&&this.imgInfo&&this.isPolygonOutSide(this.drawingPointList)){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.ForbiddenCreationOutsideBoundary,this.lang)}`),this.drawingPointList=[];return}this.addDrawingPointToPolygonList(!0);return}this.drawingPointList.push(l),this.drawingPointList.length===1?this.drawingHistory.initRecord(this.drawingPointList):this.drawingHistory.pushHistory(this.drawingPointList)}clearResult(){this.setPolygonList([]),this.deleteSelectedID(),this.render()}clearPolygonDrag(){this.drawingPointList=[],this.dragInfo=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.hoverEdgeIndex=-1,this.hoverPointIndex=-1,this.hoverID=""}clearActiveStatus(){this.clearPolygonDrag(),this.deleteSelectedID()}clearDrawingStatus(){this.drawingPointList=[]}setPolygonList(t){const e=this.polygonList.length;this.polygonList=t,e!==t.length&&this.emit("updatePageNumber")}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render(),this.emit("selectedChange")}setDefaultAttribute(t=""){const e=this.defaultAttribute;if(this.defaultAttribute=t,e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedID:i}=this;if(i&&(this.selectedPolygon&&(this.selectedPolygon.attribute=t),this.history.pushHistory(this.polygonList),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(t)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}setPolygonValidAndRender(t){if(!t)return;const e=this.polygonList.map(i=>i.id===t?__spreadProps$4(__spreadValues$5({},i),{valid:!i.valid}):i);this.setPolygonList(e),this.history.pushHistory(this.polygonList),this.render(),this.emit("updateResult")}addDrawingPointToPolygonList(t){let{lowerLimitPointNum:e=3}=this.config;if(e<3&&(e=3),this.drawingPointList.length<e){this.drawingPointList=[],this.editPolygonID="";return}const i=CommonToolUtils$1.getSourceID(this.basicResult),s=[...this.polygonList];if(this.editPolygonID){const n=s.find(o=>o.id===this.editPolygonID);if(!n)return;n.pointList=this.drawingPointList,this.editPolygonID=""}else{const n=uuid(8,62);let o={id:n,sourceID:i,valid:!this.isCtrl,textAttribute:"",pointList:this.drawingPointList,attribute:this.defaultAttribute,order:CommonToolUtils$1.getMaxOrder(s.filter(a=>CommonToolUtils$1.isSameSourceID(a.sourceID,i)))+1};if(this.config.textConfigurable){let a="";a=AttributeUtils.getTextAttribute(this.polygonList.filter(l=>CommonToolUtils$1.isSameSourceID(l.sourceID,i)),this.config.textCheckType),o=__spreadProps$4(__spreadValues$5({},o),{textAttribute:a})}this.pattern===EPolygonPattern.Rect&&t===!0&&(o=__spreadProps$4(__spreadValues$5({},o),{isRect:!0})),s.push(o),this.emit("polygonCreated",o,this.zoom,this.currentPos),this.setSelectedIdAfterAddingDrawing(n)}this.setPolygonList(s),this.isCtrl=!1,this.drawingPointList=[],this.history.pushHistory(s)}setSelectedIdAfterAddingDrawing(t){this.drawingPointList.length!==0&&(this.config.textConfigurable?this.setSelectedID(t):this.deleteSelectedID())}getHoverID(t){var e;const i=this.getCoordinateUnderZoom(t),s=this.currentShowList.map(n=>__spreadProps$4(__spreadValues$5({},n),{pointList:AxisUtils.changePointListByZoom(n.pointList,this.zoom)}));return PolygonUtils.getHoverPolygonID(i,s,10,(e=this.config)==null?void 0:e.lineType)}getHoverEdgeIndex(t){var e;if(!this.selectedID)return-1;const i=this.selectedPolygon;if(!i)return-1;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changePointListByZoom(i.pointList,this.zoom);return PolygonUtils.getHoverEdgeIndex(s,n,(e=this.config)==null?void 0:e.lineType)}getHoverPointIndex(t){if(!this.selectedID)return-1;const e=this.selectedPolygon;if(!e)return-1;const i=this.getCoordinateUnderZoom(t),s=AxisUtils.changePointListByZoom(e.pointList,this.zoom);return AxisUtils.returnClosePointIndex(i,s)}deletePolygon(t){var e;if(!t)return;const i=this.polygonList.find(s=>s.id===t);this.emit("deletedObject",{deletedObject:i,id:t}),this.setPolygonList(this.polygonList.filter(s=>s.id!==t)),this.history.pushHistory(this.polygonList),(e=this._textAttributInstance)==null||e.clearTextAttribute(),this.emit("selectedChange"),this.render()}deletePolygonPoint(t){if(!this.selectedID)return;const{selectedPolygon:e}=this;if(!e)return;let{lowerLimitPointNum:i}=this.config;if(i<3&&(i=3),e.pointList.length<=i){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.LowerLimitErrorNotice,this.lang)}${i}`);return}e==null||e.pointList.splice(t,1),this.history.pushHistory(this.polygonList),this.render()}spaceKeydown(){var t,e,i;if(this.selectedID){if(((t=this.selectedPolygon)==null?void 0:t.isRect)===!0){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UnableToReannotation,this.lang)}`);return}this.editPolygonID=this.selectedID,this.drawingPointList=(i=(e=this.selectedPolygon)==null?void 0:e.pointList)!=null?i:[],this.drawingHistory.empty(),this.drawingHistory.initRecord(this.drawingPointList),this.hoverID="",this.deleteSelectedID(),this.render()}}onTabKeyDown(t){t.preventDefault();let e=ESortDirection.ascend;t.shiftKey&&(e=ESortDirection.descend),this.switchToNextPolygon(e)}switchToNextPolygon(t){if(this.drawingPointList.length>0)return;const[e,i]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);let s=[...e];i&&(s=[...s,i]);const n=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom),o=s.map(l=>{var h,d,u,c;return __spreadProps$4(__spreadValues$5({},l),{x:(d=(h=l.pointList[0])==null?void 0:h.x)!=null?d:0,y:(c=(u=l.pointList[0])==null?void 0:u.y)!=null?c:0})}).filter(l=>CanvasUtils.inViewPort({x:l.x,y:l.y},n)),a=CommonToolUtils$1.getNextSelectedRectID(o,t,this.selectedID);if(a){this.setSelectedID(a.id);const{selectedPolygon:l}=this;l&&this.setDefaultAttribute(l.attribute)}this.render()}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Space:this.spaceKeydown();break;case EKeyCode$1.Esc:this.drawingPointList=[],this.editPolygonID="";break;case EKeyCode$1.F:this.selectedID&&this.setPolygonValidAndRender(this.selectedID);break;case EKeyCode$1.Z:if(t.altKey){this.onCombinedExecute();return}this.setIsHidden(!this.isHidden),this.render();break;case EKeyCode$1.Delete:this.deletePolygon(this.selectedID),this.render();break;case EKeyCode$1.Ctrl:this.isCtrl=!0;break;case EKeyCode$1.Alt:this.isAlt===!1&&(t.preventDefault(),this.isAlt=!0,this.render());break;case EKeyCode$1.Tab:{this.onTabKeyDown(t);break}case EKeyCode$1.X:t.altKey&&this.segment();break;default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}}onKeyUp(t){switch(super.onKeyUp(t),t.keyCode){case EKeyCode$1.Ctrl:this.isCtrl=!1;break;case EKeyCode$1.Alt:{const e=this.isAlt;this.isAlt=!1,e===!0&&this.render();break}}}rightMouseUp(t){if(this.drawingPointList.length>0){this.addDrawingPointToPolygonList();return}this.setSelectedID(this.hoverID);const{selectedPolygon:e}=this;e&&this.setDefaultAttribute(e.attribute)}onLeftDblClick(t){if(this.hoverEdgeIndex>-1){const e=this.getCoordinateUnderZoom(t),{selectedPolygon:i}=this;if(!i)return;const{dropFoot:s}=PolygonUtils.getClosestPoint(e,this.polygonListUnderZoom,this.config.lineType,edgeAdsorptionScope);if(!s)return;const{upperLimitPointNum:n}=this.config;if(n&&i.pointList.length>=n){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UpperLimitErrorNotice,this.lang)}${n}`),this.clearPolygonDrag();return}i==null||i.pointList.splice(this.hoverEdgeIndex+1,0,AxisUtils.changePointByZoom(s,1/this.zoom)),this.setPolygonDataByID(i,this.selectedID),this.history.pushHistory(this.polygonList),this.hoverPointIndex=-1,this.hoverEdgeIndex=-1,this.render()}this.dragInfo=void 0}onRightDblClick(t){this.dragInfo=void 0,this.clearImgDrag();const e=this.getHoverID(t),i=this.getHoverPointIndex(t);if(this.hoverPointIndex>-1&&this.hoverPointIndex===i){this.deletePolygonPoint(i),this.dragInfo=void 0,this.hoverPointIndex=-1,this.render();return}this.hoverID===this.selectedID&&this.deletePolygon(e),this.render()}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||t.ctrlKey===!0)return;const e=this.selectedPolygon;if(!e||t.button!==0||this.getHoverID(t)!==this.selectedID)return;const s=e.pointList,n=this.getCoordinateUnderZoom(t);let o=[0],a=EDragTarget.Plane;this.dragStatus=EDragStatus.Start;const l=this.getHoverPointIndex(t),h=this.getHoverEdgeIndex(t);return l>-1?(a=EDragTarget.Point,o=[l]):h>-1&&this.hoverEdgeIndex>-1&&(a=EDragTarget.Line,o=[h,(h+1)%s.length]),this.dragInfo={dragStartCoord:n,dragTarget:a,initPointList:s,changePointIndex:o,originPolygon:this.selectedPolygon},!0}segment(){var t;if(!this.selectedID||((t=this.config)==null?void 0:t.lineType)!==ELineTypes.Line)return;const e=PolygonUtils.getPolygonPointList(this.selectedID,this.currentShowList),i=this.currentShowList.filter(o=>o.id!==this.selectedID);if(i.length===0||e.length===0)return;const s=PolygonUtils.getWrapPolygonIndex(e,i);let n=[...this.polygonList];if(s===-1){const o=PolygonUtils.segmentPolygonByPolygon(e,i);if(!o)return;const a=o.shift();if(!a)return;let l="",h=!0;const d=CommonToolUtils$1.getSourceID(this.basicResult);let u="";n=this.polygonList.map(c=>{var g,p;return c.id===this.selectedID?(l=c.attribute,h=(g=c==null?void 0:c.valid)!=null?g:!0,u=(p=c==null?void 0:c.textAttribute)!=null?p:"",__spreadProps$4(__spreadValues$5({},c),{pointList:a})):c}),o.length>0&&o.forEach((c,g)=>{n.push({sourceID:d,id:uuid(8,62),pointList:c,valid:h,order:CommonToolUtils$1.getMaxOrder(this.currentShowList)+1+g,attribute:l,textAttribute:u})})}else n[s].pointList=PolygonUtils.clipPolygonFromWrapPolygon(e,n[s].pointList),n=n.filter(o=>o.id!==this.selectedID);this.setPolygonList(n),this.history.pushHistory(n),this.render()}onCombinedExecute(){if(!this.selectedID){this.emit("messageInfo",lbUtils.i18n.t("PolygonsToBeCombinedNeedToBeSelected"));return}this.isCombined=!this.isCombined}combine(t){var e;const i=this.getHoverID(t);if(!i||!this.selectedID||this.selectedID===i)return;if(((e=this.config)==null?void 0:e.lineType)!==ELineTypes.Line){this.emit("messageInfo",lbUtils.i18n.t("CurveModeDoesNotSupportCutting"));return}const s=this.polygonList.find(h=>h.id===this.selectedID),n=this.currentShowList.find(h=>h.id===i);if(!n||!s)return;const o=PolygonUtils.combinePolygonWithPolygon(s,n);if(!o)return;const{newPolygon:a,unionList:l}=o;if(l.length===1&&a){const h=this.polygonList.filter(d=>!l.includes(d.id)).map(d=>d.id===this.selectedID?a:d);this.setPolygonList(h),this.history.pushHistory(h),this.render(),this.emit("messageInfo",lbUtils.i18n.t("CombineSuccess"))}else this.emit("messageInfo",lbUtils.i18n.t("CombiningFailedNotify"));this.isCombined=!1}isPolygonOutSide(t){if(this.dependToolName&&this.basicCanvas&&this.basicResult){let a=!1;switch(this.dependToolName){case EToolName.Rect:{a=t.filter(l=>!RectUtils.isInRect(l,this.basicResult)).length>0;break}case EToolName.Polygon:{a=PolygonUtils.isPointListOutSidePolygon(t,this.basicResult.pointList,this.config.lineType);break}}return a}if(!this.imgInfo)return!1;const{left:e,top:i,right:s,bottom:n}=MathUtils.calcViewportBoundaries(AxisUtils.changePointListByZoom(t,this.zoom)),o=1e-5;return e<0||i<0||s>this.imgInfo.width+o||n>this.imgInfo.height+o}onDragMove(t){if(!this.dragInfo||!this.selectedID)return;const{selectedPolygon:e}=this;let i=e==null?void 0:e.pointList;if(!i)return;const{initPointList:s,dragStartCoord:n,dragTarget:o,changePointIndex:a}=this.dragInfo,l=this.getCoordinateUnderZoom(t);let h={x:(l.x-n.x)/this.zoom,y:(l.y-n.y)/this.zoom};if(this.pattern===EPolygonPattern.Rect&&(e==null?void 0:e.isRect)===!0&&a&&[EDragTarget.Line].includes(o)){const u=MathUtils.getArrayIndex(a[0]-2,4),c=MathUtils.getArrayIndex(a[0]-1,4),g=[s[u],s[c]];h=MathUtils.getRectPerpendicularOffset(n,l,g),h={x:h.x/this.zoom,y:h.y/this.zoom}}switch(this.dragStatus=EDragStatus.Move,o){case EDragTarget.Plane:i=i.map((u,c)=>__spreadProps$4(__spreadValues$5({},u),{x:s[c].x+h.x,y:s[c].y+h.y}));break;case EDragTarget.Point:case EDragTarget.Line:i=i.map((u,c)=>a&&a.includes(c)?__spreadProps$4(__spreadValues$5({},u),{x:s[c].x+h.x,y:s[c].y+h.y}):u);break}if(this.pattern===EPolygonPattern.Rect&&(e==null?void 0:e.isRect)===!0&&o===EDragTarget.Point&&a&&(i=MathUtils.getPointListFromPointOffset(s,a[0],h)),this.config.drawOutsideTarget===!1&&this.imgInfo&&this.isPolygonOutSide(i))return;const d=this.polygonList.map(u=>{if(u.id===this.selectedID){const c=__spreadProps$4(__spreadValues$5({},u),{pointList:i});return u.isRect===!0&&this.pattern===EPolygonPattern.Normal&&Object.assign(c,{isRect:!1}),c}return u});this.setPolygonList(d),this.render()}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;if(this.selectedID&&this.dragInfo){this.onDragMove(t);return}let e=-1,i=-1;const{selectedID:s}=this;if(s&&(this.hoverEdgeIndex=-1,this.hoverPointIndex=-1,e=this.getHoverPointIndex(t),e>-1?this.hoverPointIndex=e:(i=this.getHoverEdgeIndex(t),this.hoverEdgeIndex=i)),this.drawingPointList.length>0)return;const n=this.getHoverID(t);this.hoverID!==n&&(this.hoverID=n,this.render())}leftMouseUp(t){const e=this.getHoverID(t);if(this.drawingPointList.length===0&&t.ctrlKey===!0&&e){this.setPolygonValidAndRender(e);return}this.addPointInDrawing(t)}onMouseUp(t){if(this.isCombined){switch(t.button){case 0:this.combine(t);break;case 2:this.isCombined=!1;break;default:return}return}if(!(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)){if(this.dragInfo&&this.dragStatus===EDragStatus.Move){const{originPolygon:e}=this.dragInfo;this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.history.pushHistory(this.polygonList),this.emit("updateResult"),this.emit("updatePolygonByDrag",{newPolygon:this.selectedPolygon,originPolygon:e});return}switch(t.button){case 0:{this.leftMouseUp(t);break}case 2:{this.rightMouseUp(t);break}}this.render()}}dragMouseUp(){this.dragStatus===EDragStatus.Start&&(this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait)}exportData(){const{polygonList:t}=this;return[t,this.basicImgInfo]}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}getCurrentSelectedData(){const{selectedPolygon:t}=this;if(!t)return;const e=this.getColor(t.attribute),i=t.valid?e==null?void 0:e.valid.stroke:e==null?void 0:e.invalid.stroke;return{width:TEXT_MAX_WIDTH,textAttribute:t.textAttribute,color:i}}updateSelectedTextAttribute(t){if(this._textAttributInstance&&t&&this.selectedID){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setPolygonList(AttributeUtils.textChange(e,this.selectedID,this.polygonList)),this.emit("updateTextAttribute"),this.render()}}renderTextAttribute(){var t;const{selectedPolygon:e}=this;if(!this.ctx||this.config.textConfigurable===!1||!e)return;const{pointList:i,attribute:s,valid:n,textAttribute:o}=e,{x:a,y:l}=i[i.length-1],h=TEXT_MAX_WIDTH,d=AxisUtils.getOffsetCoordinate({x:a,y:l},this.currentPos,this.zoom),u=this.getColor(s),c=n?u==null?void 0:u.valid.stroke:u==null?void 0:u.invalid.stroke;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:h,container:this.container,icon:this.getTextIconSvg(s),color:c,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributInstance&&!((t=this._textAttributInstance)==null?void 0:t.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${o}`,{left:d.x,top:d.y,color:c,width:h})}renderStaticPolygon(){var t;this.isHidden===!1&&((t=this.polygonList)==null||t.forEach(e=>{var i,s,n,o,a;if([this.selectedID,this.editPolygonID].includes(e.id))return;const{textAttribute:l,attribute:h}=e,d=this.getColor(h),u=StyleUtils.getStrokeAndFill(d,e.valid),c=AxisUtils.changePointListByZoom(e.pointList||[],this.zoom,this.currentPos);DrawUtils.drawPolygonWithFillAndLine(this.canvas,c,{fillColor:u.fill,strokeColor:u.stroke,pointColor:"white",thickness:(s=(i=this.style)==null?void 0:i.width)!=null?s:2,lineCap:"round",isClose:!0,lineType:(n=this.config)==null?void 0:n.lineType});let g=`${(o=AttributeUtils.getAttributeShowText(h,this.config.attributeList))!=null?o:""}`;((a=this.config)==null?void 0:a.isShowOrder)&&(e==null?void 0:e.order)>0&&(g=`${e.order} ${g}`),DrawUtils.drawText(this.canvas,c[0],g,__spreadValues$5({color:u.stroke},DEFAULT_TEXT_OFFSET));const p=c[c.length-1];DrawUtils.drawText(this.canvas,{x:p.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:p.y+TEXT_ATTRIBUTE_OFFSET$1.y},l,__spreadValues$5({color:u.stroke},DEFAULT_TEXT_OFFSET))}))}renderSelectedPolygon(){var t,e,i;if(this.selectedID){const s=this.selectedPolygon;if(s){const n=this.getColor(s.attribute),o=StyleUtils.getStrokeAndFill(n,s.valid,{isSelected:!0});DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(s.pointList,this.zoom,this.currentPos),{fillColor:o.fill,strokeColor:o.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!0,lineType:(t=this.config)==null?void 0:t.lineType});let a=`${(e=AttributeUtils.getAttributeShowText(s.attribute,this.config.attributeList))!=null?e:""}`;((i=this.config)==null?void 0:i.isShowOrder)&&(s==null?void 0:s.order)>0&&(a=`${s.order} ${a}`),DrawUtils.drawText(this.canvas,AxisUtils.changePointByZoom(s.pointList[0],this.zoom,this.currentPos),a,__spreadValues$5({color:o.stroke},DEFAULT_TEXT_OFFSET)),this.renderTextAttribute()}}}renderHoverPolygon(){var t;if(this.hoverID&&this.hoverID!==this.editPolygonID){const{hoverPolygon:e}=this;if(e){let i="";const s=this.getColor(e.attribute);e.valid?i=s.validHover.fill:i=StyleUtils.getStrokeAndFill(s,!1,{isHover:!0}).fill,DrawUtils.drawPolygonWithFill(this.canvas,AxisUtils.changePointListByZoom(e.pointList,this.zoom,this.currentPos),{color:i,lineType:(t=this.config)==null?void 0:t.lineType})}}}renderPolygon(){var t,e,i,s;this.renderStaticPolygon(),this.renderHoverPolygon(),this.renderSelectedPolygon();const n=this.getColor(this.defaultAttribute),o=StyleUtils.getStrokeAndFill(n,!this.isCtrl);if(((t=this.drawingPointList)==null?void 0:t.length)>0){let a=[...this.drawingPointList],l=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);if(this.pattern===EPolygonPattern.Rect&&a.length===2)a=MathUtils.getRectangleByRightAngle(l,a);else{if(((e=this.config)==null?void 0:e.edgeAdsorption)&&this.isAlt===!1){const{dropFoot:h}=PolygonUtils.getClosestPoint(l,this.polygonList,(i=this.config)==null?void 0:i.lineType,edgeAdsorptionScope/this.zoom);h&&(l=h)}a.push(l)}DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(a,this.zoom,this.currentPos),{fillColor:o.fill,strokeColor:o.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!1,lineType:this.config.lineType})}if(this.hoverPointIndex>-1&&this.selectedID){const a=this.selectedPolygon;if(!a)return;const l=StyleUtils.getStrokeAndFill(n,a.valid,{isSelected:!0}),h=a==null?void 0:a.pointList[this.hoverPointIndex];if(h){const{x:d,y:u}=AxisUtils.changePointByZoom(h,this.zoom,this.currentPos);DrawUtils.drawCircleWithFill(this.canvas,{x:d,y:u},5,{color:l.fill})}}if(this.hoverEdgeIndex>-1&&this.selectedID){const a=this.selectedPolygon;if(!a)return;const l=StyleUtils.getStrokeAndFill(n,a.valid,{isSelected:!0});DrawUtils.drawLineWithPointList(this.canvas,AxisUtils.changePointListByZoom(a.pointList,this.zoom,this.currentPos),{color:l.stroke,thickness:10,hoverEdgeIndex:this.hoverEdgeIndex,lineType:(s=this.config)==null?void 0:s.lineType})}}render(){!this.ctx||(super.render(),this.renderPolygon(),this.renderCursorLine(this.getLineColor(this.defaultAttribute)))}renderCursorLine(t){if(super.renderCursorLine(t),this.isCombined){const{x:e,y:i}=this.coord,s=10,n=186,o=32;DrawUtils.drawRectWithFill(this.canvas,{x:e+s,y:i-s*4-1,width:n,height:o},{color:"black"}),DrawUtils.drawText(this.canvas,{x:e,y:i},lbUtils.i18n.t("ClickAnotherPolygon"),{textAlign:"center",color:"white",offsetX:n/2+s,offsetY:-(o/2+s/2)}),DrawUtils.drawRect(this.canvas,{x:e-s,y:i-s,width:s*2,height:s*2},{lineDash:[6],color:"white"})}}undo(){if(this.drawingPointList.length>0){const e=this.drawingHistory.undo();if(!e)return;this.drawingPointList=e,this.render();return}const t=this.history.undo();t&&(t.length!==this.polygonList.length&&this.deleteSelectedID(),this.setPolygonList(t),this.render())}redo(){if(this.drawingPointList.length>0){const e=this.drawingHistory.redo();if(!e)return;this.drawingPointList=e,this.render();return}const t=this.history.redo();t&&(t.length!==this.polygonList.length&&this.deleteSelectedID(),this.setPolygonList(t),this.render())}deleteSelectedID(){this.setSelectedID("")}}var __defProp$5=Object.defineProperty,__defProps$3=Object.defineProperties,__getOwnPropDescs$3=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$4=Object.getOwnPropertySymbols,__hasOwnProp$4=Object.prototype.hasOwnProperty,__propIsEnum$4=Object.prototype.propertyIsEnumerable,__defNormalProp$5=(r,t,e)=>t in r?__defProp$5(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$4=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$4.call(t,e)&&__defNormalProp$5(r,e,t[e]);if(__getOwnPropSymbols$4)for(var e of __getOwnPropSymbols$4(t))__propIsEnum$4.call(t,e)&&__defNormalProp$5(r,e,t[e]);return r},__spreadProps$3=(r,t)=>__defProps$3(r,__getOwnPropDescs$3(t));const config={textConfigurable:!1,attributeConfigurable:!0,attributeList:[]};class MeasureOperation extends RectOperation{constructor(t){super(__spreadProps$3(__spreadValues$4({},t),{config:JSON.stringify(config)}))}setSelectedIdAfterAddingDrawingRect(){!this.drawingRect||this.setSelectedRectID(this.drawingRect.id)}}class RenderDomClass{constructor(t){this._domMap=new Map,this._container=t.container,this._height=t.height}wheelChange(t){t.stopPropagation()}clearTag(t){const e=this._container,i=window.self.document.getElementById(t);i&&e&&e.contains(i)&&(i.removeEventListener("wheel",this.wheelChange),e==null||e.removeChild(i))}render(t){const e=Array.from(this._domMap.keys()),i=t.map(s=>s.id);t.forEach(s=>{const{text:n,textMaxWidth:o,color:a="white",background:l="rgba(0, 0, 0, 0.6)",style:h}=s;if(this._domMap.has(s.id)){const d=this._domMap.get(s.id);d&&(d.innerHTML=n)}else{const d=DrawUtils.drawTagByDom(this._container,n,s.id);d&&(d.setAttribute("style",`
|
|
77
|
+
`),(o=(n=this.canvas)==null?void 0:n.parentNode)==null||o.appendChild(a)}render(){this.renderTag(),super.render(),this.emit("render")}exportData(){let{tagResult:t}=this;return this.isImgError&&(t=[]),[t,this.basicImgInfo]}}class StyleUtils{static getStrokeAndFill(t,e=!0,i={}){const{isSelected:s=!1,isHover:n=!1}=i;return s?{stroke:e?t.validSelected.stroke:t.invalidSelected.stroke,fill:e?t.validSelected.fill:t.invalidSelected.fill}:n?{stroke:e?t.validHover.stroke:t.invalidHover.stroke,fill:e?t.validHover.fill:t.invalidHover.fill}:{stroke:e?t.valid.stroke:t.invalid.stroke,fill:e?t.valid.fill:t.invalid.fill}}static getStyle2String(t){if(!!t)return Object.entries(t).reduce((e,i)=>`${e} ${i[0]}: ${i[1]};`,"")}}var __defProp$8=Object.defineProperty,__defProps$6=Object.defineProperties,__getOwnPropDescs$6=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$7=Object.getOwnPropertySymbols,__hasOwnProp$7=Object.prototype.hasOwnProperty,__propIsEnum$7=Object.prototype.propertyIsEnumerable,__pow=Math.pow,__defNormalProp$8=(r,t,e)=>t in r?__defProp$8(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$7=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$7.call(t,e)&&__defNormalProp$8(r,e,t[e]);if(__getOwnPropSymbols$7)for(var e of __getOwnPropSymbols$7(t))__propIsEnum$7.call(t,e)&&__defNormalProp$8(r,e,t[e]);return r},__spreadProps$6=(r,t)=>__defProps$6(r,__getOwnPropDescs$6(t));const TEXTAREA_WIDTH=200;class PointOperation extends BasicToolOperation{constructor(t){super(t);this.setMarkerIndex=e=>{this.markerIndex=e},this.setMarkerIndexAndSelect=e=>{if(!this.config.markerList)return;this.markerIndex=e;const i=this.config.markerList[e].value,s=this.currentPageResult.find(n=>n.label===i);s&&(this.setSelectedID(s.id),this.config.attributeConfigurable===!0&&this.setDefaultAttribute(s.attribute)),this.emit("markIndexChange")},this.textChange=e=>{this.config.textConfigurable!==!0||!this.selectedID||(this.setPointList(AttributeUtils.textChange(e,this.selectedID,this.pointList)),this.emit("selectedChange"),this.render())},this.isMinDistance=e=>{const i=AxisUtils.changePointByZoom(e,this.zoom);return this.pointList.some(s=>{const n=AxisUtils.changePointByZoom(s,this.zoom);return MathUtils.getLineLength(n,i)<.2})},this.config=CommonToolUtils$1.jsonParser(t.config),this.pointList=[],this.markerIndex=0,this.setStyle(t.style),this.createPoint=this.createPoint.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this),this.setSelectedID=this.setSelectedID.bind(this)}get dataList(){return this.pointList}get drawOutsideTarget(){var t;return(t=this.config.drawOutsideTarget)!=null?t:this.config.drawPointOut}setNextMarker(t=this.pointList){if(this.hasMarkerConfig){const e=CommonToolUtils$1.getNextMarker(this.getCurrentPageResult(t),this.config.markerList);e&&this.setMarkerIndexAndSelect(e.index)}}setResult(t){this.clearActiveStatus(),this.setPointList(t),this.setNextMarker(t),this.render()}setPointList(t,e=!1){const i=this.pointList.length;this.pointList=t,i!==t.length&&this.emit("updatePageNumber"),e&&this.emit("updateResult")}setConfig(t,e=!1){this.config=CommonToolUtils$1.jsonParser(t),e===!0&&this.clearResult()}clearResult(){this.setPointList([]),this.setSelectedID(void 0),this.history.pushHistory([]),this.hoverID="",this.render()}setDefaultAttribute(t=""){const e=this.defaultAttribute;if(this.defaultAttribute=t,e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedID:i}=this;if(i&&(this.pointList.forEach(s=>{s.id===i&&(s.attribute=t)}),this.history.pushHistory(this.pointList),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(t)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}get selectedText(){var t;return(t=this.pointList.find(e=>e.id===this.selectedID))==null?void 0:t.textAttribute}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render(),this.emit("selectedChange")}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}clearActiveStatus(){this.hoverID=void 0,this.dragStatus=EDragStatus.Wait,this.setSelectedID(void 0)}setBasicResult(t){super.setBasicResult(t),this.setNextMarker(),this.clearActiveStatus()}onMouseDown(t){if(!(super.onMouseDown(t)||this.forbidMouseOperation)){if(t.button===0&&!this.hoverID){this.createPoint(t),this.render();return}return this.hoverID===this.selectedID&&t.button===0&&(this.dragStatus=EDragStatus.Start),this.render(),!0}}onMouseMove(t){super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo||(this.hoverID=this.getHoverId(),(this.dragStatus===EDragStatus.Start||this.dragStatus===EDragStatus.Move)&&this.onDragMove(t),this.hoverID&&this.render())}onMouseUp(t){if(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)return!0;t.button===2&&this.rightMouseUp(),this.dragStatus===EDragStatus.Move&&this.history.pushHistory(this.pointList),this.dragStatus=EDragStatus.Wait,this.render()}onDragMove(t){var e,i;if(!this.imgInfo)return;this.dragStatus=EDragStatus.Move;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.drawOutsideTarget,this.basicResult,this.zoom),o=this.drawOutsideTarget?AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos):AxisUtils.changePointByZoom(n,1/this.zoom);this.drawOutsideTarget===!1&&this.dependToolName===EToolName.Polygon&&((i=(e=this.basicResult)==null?void 0:e.pointList)==null?void 0:i.length)>0&&!PolygonUtils.isInPolygon(o,this.basicResult.pointList)||(this.pointList.forEach(a=>{a.id===this.selectedID&&(a.x=o.x,a.y=o.y)}),this.render())}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Delete:this.deletePoint();break;case EKeyCode$1.Tab:{this.onTabKeyDown(t);break}case EKeyCode$1.Z:this.setIsHidden(!this.isHidden),this.render();break;default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}}createPoint(t){var e,i,s,n;if(!this.imgInfo)return;const{upperLimit:o}=this.config;if(o&&this.currentPageResult.length>=o){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.LowerLimitPoint,this.lang)}`);return}const a=CommonToolUtils$1.getSourceID(this.basicResult),l=this.getCoordinateUnderZoom(t);let h=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);if(this.config.edgeAdsorption&&this.referenceData&&[EToolName.Polygon,EToolName.Line].includes((e=this.referenceData)==null?void 0:e.toolName)){const g=((i=this.referenceData)==null?void 0:i.toolName)===EToolName.Polygon,{dropFoot:p,hasClosed:f}=PolygonUtils.getClosestPoint(h,this.referenceData.result,(n=(s=this.referenceData.config)==null?void 0:s.lineType)!=null?n:ELineTypes.Line,edgeAdsorptionScope/this.zoom,{isClose:g});p&&(h=p),f&&this.emit("messageSuccess",`${Locale.getMessagesByLocale(EMessage.SuccessfulEdgeAdsorption,this.lang)}`)}if(this.drawOutsideTarget===!1){if(this.dependToolName&&this.basicCanvas){let d=!1;switch(this.dependToolName){case EToolName.Rect:{d=!RectUtils.isInRect(h,this.basicResult);break}case EToolName.Polygon:{d=!PolygonUtils.isInPolygon(h,this.basicResult.pointList);break}}if(d)return}if(l.x<0||l.y<0||l.x>this.imgInfo.width||l.y>this.imgInfo.height)return}if(this.isMinDistance(h))return;let c=__spreadProps$6(__spreadValues$7({},h),{attribute:this.defaultAttribute,valid:!t.ctrlKey,id:uuid(8,62),sourceID:a,textAttribute:"",order:CommonToolUtils$1.getMaxOrder(this.pointList.filter(d=>CommonToolUtils$1.isSameSourceID(d.sourceID,a)))+1});if(this.config.textConfigurable){let d="";d=AttributeUtils.getTextAttribute(this.pointList.filter(g=>CommonToolUtils$1.isSameSourceID(g.sourceID,a)),this.config.textCheckType),c=__spreadProps$6(__spreadValues$7({},c),{textAttribute:d})}if(this.hasMarkerConfig){const d=CommonToolUtils$1.getNextMarker(this.currentPageResult,this.config.markerList,this.markerIndex);if(d)c=__spreadProps$6(__spreadValues$7({},c),{label:d.label}),this.markerIndex=d.index,this.emit("markIndexChange");else{this.emit("messageInfo",Locale.getMessagesByLocale(EMessage.MarkerFinish,this.lang));return}}this.hoverID=c.id;const u=[...this.pointList,c];this.setPointList(u),this.history.pushHistory(u),this.setSelectedID(c.id)}isInPoint(t,e,i=this.zoom){return(this.style.width+2)/i>=Math.sqrt(__pow(t.x-e.x,2)+__pow(t.y-e.y,2))}getHoverId(){var t;const e=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos),i=(t=this.pointList)==null?void 0:t.find(s=>this.isInPoint(e,s));return i==null?void 0:i.id}rightMouseUp(){if(this.selectedID===this.hoverID){const e=this.pointList.filter(i=>i.id!==this.selectedID);this.setPointList(e),this.history.pushHistory(e),this.setSelectedID(""),this.hoverID="";return}const t=this.pointList.find(e=>e.id===this.hoverID);if(this.setSelectedID(this.hoverID),this.setDefaultAttribute(t==null?void 0:t.attribute),(t==null?void 0:t.label)&&this.hasMarkerConfig){const e=CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList);e>=0&&(this.setMarkerIndex(e),this.emit("markIndexChange"))}}onTabKeyDown(t){if(t.preventDefault(),this.dragStatus===EDragStatus.Move||this.dragStatus===EDragStatus.Start)return;let e=ESortDirection.ascend;t.shiftKey&&(e=ESortDirection.descend);const[i,s]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);let n=[...i];s&&(n=[...n,s]);const o=CommonToolUtils$1.getNextSelectedRectID(n,e,this.selectedID);o&&this.setSelectedID(o.id)}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}getCurrentPageResult(t){const[e]=CommonToolUtils$1.getRenderResultList(t,CommonToolUtils$1.getSourceID(this.basicResult),[]);return e}exportData(){const{pointList:t}=this;return[t,this.basicImgInfo]}deletePoint(){var t;this.selectedID&&(this.setPointList(this.pointList.filter(e=>e.id!==this.selectedID)),this.history.pushHistory(this.pointList),(t=this._textAttributInstance)==null||t.clearTextAttribute(),this.emit("selectedChange"),this.render())}undoAndRedo(t){var e,i;if(this.dragStatus===EDragStatus.Move||this.dragStatus===EDragStatus.Start)return;const s=(i=(e=this.history)[t])==null?void 0:i.call(e);(s==null?void 0:s.some(n=>n.id===this.selectedID))||this.setSelectedID(""),s&&(this.setPointList(s,!0),this.render())}undo(){this.undoAndRedo("undo")}redo(){this.undoAndRedo("redo")}getCurrentSelectedData(){var t;if(!this.selectedID)return;const e=(t=this.pointList)==null?void 0:t.find(n=>n.id===this.selectedID),i=this.getColor(e==null?void 0:e.attribute),s=(e==null?void 0:e.valid)?i==null?void 0:i.valid.stroke:i==null?void 0:i.invalid.stroke;return this.dragStatus=EDragStatus.Wait,{width:TEXTAREA_WIDTH*this.zoom*.6,textAttribute:(e==null?void 0:e.textAttribute)||"",color:s}}updateSelectedTextAttribute(t){if(this._textAttributInstance&&t&&this.selectedID){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setPointList(AttributeUtils.textChange(e,this.selectedID,this.pointList)),this.emit("updateTextAttribute"),this.render()}}renderTextAttribute(){var t,e;const i=(t=this.pointList)==null?void 0:t.find(g=>g.id===this.selectedID);if(!this.ctx||this.config.textConfigurable!==!0||!i)return;const{x:s,y:n,attribute:o,valid:a}=i,l=TEXTAREA_WIDTH*this.zoom*.6,h=AxisUtils.getOffsetCoordinate({x:s,y:n},this.currentPos,this.zoom),c=this.getColor(o),u=a?c==null?void 0:c.valid.stroke:c==null?void 0:c.invalid.stroke,d=4;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:l,container:this.container,icon:this.getTextIconSvg(o),color:u,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributInstance&&!((e=this._textAttributInstance)==null?void 0:e.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${i.textAttribute}`,{left:h.x,top:h.y+d,color:u,width:l})}renderPoint(t){var e,i,s;const{textAttribute:n="",attribute:o}=t,a=t.id===this.selectedID,l=this.getColor(o),h=AxisUtils.changePointByZoom(t,this.zoom,this.currentPos),{width:c=2,hiddenText:u=!1}=this.style,d=StyleUtils.getStrokeAndFill(l,t.valid,{isSelected:a||t.id===this.hoverID});DrawUtils.drawCircle(this.canvas,h,c,{startAngleDeg:0,endAngleDeg:360,thickness:1,color:d.stroke,fill:d.fill});let g="";(((e=this.config)==null?void 0:e.isShowOrder)||((i=this.config)==null?void 0:i.showOrder))&&t.order&&(t==null?void 0:t.order)>0&&(g=`${t.order}`),t.label&&this.hasMarkerConfig&&(g=`${CommonToolUtils$1.getCurrentMarkerIndex(t.label,this.config.markerList)+1}_${MarkerUtils.getMarkerShowText(t.label,this.config.markerList)}`),t.attribute&&(g=`${g} ${AttributeUtils.getAttributeShowText(t.attribute,(s=this.config)==null?void 0:s.attributeList)}`),u||DrawUtils.drawText(this.canvas,{x:h.x+c/2,y:h.y-c-4},g,{textAlign:"center",color:d.stroke}),a?this.renderTextAttribute():u||DrawUtils.drawText(this.canvas,{x:h.x+c,y:h.y+c+24},n,__spreadValues$7({color:d.stroke},DEFAULT_TEXT_OFFSET))}renderPointList(){const[t,e]=CommonToolUtils$1.getRenderResultList(this.pointList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);this.isHidden||t.forEach(i=>{this.renderPoint(i)}),e&&this.renderPoint(e)}renderTop(){var t,e,i;const s=this.getLineColor(this.defaultAttribute);if(this.renderCursorLine(s),this.config.edgeAdsorption&&this.referenceData){let n=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);const o=((t=this.referenceData)==null?void 0:t.toolName)===EToolName.Polygon,{dropFoot:a}=PolygonUtils.getClosestPoint(n,this.referenceData.result,(i=(e=this.referenceData.config)==null?void 0:e.lineType)!=null?i:ELineTypes.Line,edgeAdsorptionScope/this.zoom,{isClose:o});a&&n!==a&&n!==a&&(n=a,DrawUtils.drawCircle(this.canvas,AxisUtils.changePointByZoom(n,this.zoom,this.currentPos),5,{color:"white",fill:"white"}),DrawUtils.drawCircle(this.canvas,AxisUtils.changePointByZoom(n,this.zoom,this.currentPos),3,{fill:s,color:s}))}}render(){!this.ctx||(super.render(),this.renderPointList(),this.renderTop())}}var __defProp$7=Object.defineProperty,__defProps$5=Object.defineProperties,__getOwnPropDescs$5=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$6=Object.getOwnPropertySymbols,__hasOwnProp$6=Object.prototype.hasOwnProperty,__propIsEnum$6=Object.prototype.propertyIsEnumerable,__defNormalProp$7=(r,t,e)=>t in r?__defProp$7(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$6=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$6.call(t,e)&&__defNormalProp$7(r,e,t[e]);if(__getOwnPropSymbols$6)for(var e of __getOwnPropSymbols$6(t))__propIsEnum$6.call(t,e)&&__defNormalProp$7(r,e,t[e]);return r},__spreadProps$5=(r,t)=>__defProps$5(r,__getOwnPropDescs$5(t)),EStatus;(function(r){r[r.Create=0]="Create",r[r.Active=1]="Active",r[r.None=2]="None"})(EStatus||(EStatus={}));const SEGMENT_NUMBER=16,LINE_ORDER_OFFSET={x:0,y:20},POINT_RADIUS=3,POINT_ACTIVE_RADIUS=5,INNER_POINT_RADIUS=2;class LineToolOperation extends BasicToolOperation{constructor(t){super(t);this.drawActivatedLine=(e,i,s)=>{const n=___default.default.cloneDeep(this.activeLine);if(!n||n.length===0)return;const o=this.isActiveLineValid();let a;const l=this.selectedID?this.lineList.find(c=>c.id===this.selectedID):void 0;l?a=l.order:a=this.nextOrder();const h=this.getLineColorByAttribute({attribute:this.defaultAttribute,valid:!!o});n.map(c=>Object.assign(c,this.coordUtils.getRenderCoord(c))),this.updateActiveArea(),this.drawLine(n,e,h,!0,!0),this.drawLineNumber(n[0],a,h,"",this.defaultAttribute,o),e&&this.isCreate&&this.arc(e,POINT_RADIUS,h),this.cursor&&!this.selectedPoint&&!s&&!this.isShift&&this.arc(this.cursor,POINT_ACTIVE_RADIUS,h)},this.drawHoverPoint=e=>{if(!this.isMousedown&&e&&this.isLineSelected){const i=this.getPointList(this.activeLine),s=this.activeLine.find(o=>LineToolUtils.calcDistance(this.coordUtils.getRenderCoord(o),e)<=POINT_ACTIVE_RADIUS);let n;!s&&this.activeLine&&(n=this.findNearestPoint(i,e)),this.hoverPointID=s?s.id:void 0,this.cursor=s||n==null?void 0:n.point}},this.lineList=[],this.activeLine=[],this.coordsInsideActiveArea=!1,this.hoverLineSegmentIndex=-1,this.isShift=!1,this.isReference=!1,this.drawCurveLine=(e,i,s,n=!0,o=!1,a)=>{const l=createSmoothCurvePointsFromPointList(i,SEGMENT_NUMBER);e.save(),e.lineCap="round",e.lineJoin="round",e.strokeStyle=s.color,n&&(e.lineWidth=s.lineWidth),o&&LineToolUtils.setReferenceCtx(e),i.forEach(({specialEdge:h},c)=>{const u=l.splice(0,SEGMENT_NUMBER+1);e.save(),e.beginPath(),a===c&&(e.lineWidth=4),u.forEach(({x:d,y:g},p)=>{const f=p>0?"lineTo":"moveTo";h&&LineToolUtils.setSpecialEdgeStyle(e),e[f](d,g)}),e.stroke(),e.restore()}),e.restore()},this.drawLine=(e,i,s,n=!1,o=!1)=>{const a=i?e.concat(i):e,l={color:s,lineWidth:o?1:this.lineStyle.lineWidth};this.isCurve?LineToolUtils.drawCurveLine(this.ctx,a,l,!n,this.isReference,o?this.hoverLineSegmentIndex:-1):this.drawStraightLine(a,l,o),n&&e.forEach(h=>{var c,u;const d=h.id,g=d&&[this.hoverPointID,(c=this.selectedPoint)==null?void 0:c.id].includes(d)?POINT_ACTIVE_RADIUS:POINT_RADIUS;this.arc(h,g,s),[this.hoverPointID,(u=this.selectedPoint)==null?void 0:u.id].includes(d)||this.arc(h,INNER_POINT_RADIUS,"white")})},this.drawStraightLine=(e,i,s=!1)=>{const{ctx:n}=this;n&&(n.save(),n.lineCap="round",n.lineJoin="round",n.strokeStyle=i.color,n.lineWidth=i.lineWidth,this.isReference&&LineToolUtils.setReferenceCtx(n),e.forEach((o,a)=>{if(n.beginPath(),a>0){const l=e[a-1];n.save(),(l==null?void 0:l.specialEdge)&&LineToolUtils.setSpecialEdgeStyle(n),s&&this.hoverLineSegmentIndex+1===a&&(n.lineWidth=4),n.moveTo(l.x,l.y),n.lineTo(o.x,o.y),n.stroke(),n.restore()}}),n.restore())},this.drawLines=()=>{try{const e=___default.default.cloneDeep(this.attributeFilteredLines);if(this.isHidden)return;e.forEach(i=>{if(i.id!==this.selectedID&&i.pointList){i.pointList.map(l=>Object.assign(l,this.coordUtils.getRenderCoord(l)));const{order:s,label:n}=i,o=s,a=i&&this.getLineColorByAttribute(i);this.drawLine(i.pointList,void 0,a,!1),this.drawLineNumber(i.pointList[0],o,a,n,i.attribute,i.valid),i.id!==this.textEditingID&&this.drawLineTextAttribute(i.pointList[1],a,i==null?void 0:i.textAttribute)}})}catch(e){console.error(e,"\u7EBF\u6761\u5DE5\u5177\u6570\u636E\u89E3\u6790\u9519\u8BEF"),this.lineList=[],this.clearCanvas()}},this.render=e=>{super.render(),this.drawLines(),this.drawActivatedLine(e,void 0,!0),this.renderTextAttribute(),this.renderCursorLine(this.getLineColor(this.defaultAttribute))},this.moveLineInPolygon=(e,i)=>{var s;if(!Array.isArray(this.activeLine))return!1;((s=this.activeLine)==null?void 0:s.every(o=>this.isInBasicPolygon({x:o.x+e,y:o.y+i})))&&(this.lineDragging=!0,this.moveActiveArea(e,i))},this.moveLineInRectRange=(e,i,s,n)=>{if(this.activeArea===void 0)return;const{top:o,left:a,right:l,bottom:h}=this.activeArea,c=[a,l].map(v=>___default.default.isNumber(v)?v+e:0),u=[o,h].map(v=>___default.default.isNumber(v)?v+i:0),d=a>=0&&l&&MathUtils.isInRange(c,s),g=o>=0&&h&&MathUtils.isInRange(u,n),p=d?e:0,f=g?i:0;this.lineDragging=!0,this.moveActiveArea(p,f)},this.onRightClick=e=>{if(this.cursor=void 0,this.isCreate){if(this.isLinePointsNotEnough())return;this.stopLineCreating(!0);return}this.setActiveArea(this.getCoordinate(e),!0),this.emit("contextmenu")},this.updateSelectedAttributeAfterHistoryChanged=()=>{if(this.selectedID){const e=this.lineList.find(s=>s.id===this.selectedID),i=e==null?void 0:e.attribute;typeof i=="string"&&(this.defaultAttribute=i,this.updateAttribute(i),this.render())}},this.onLeftClick=e=>{const i=this.getCoordinate(e),{lineDragging:s}=this;if(this.lineDragging=!1,this.isSpaceKey)return;if(this.isNone&&e.ctrlKey){const o=this.findHoverLine(i);o&&this.setInvalidLine(o.id);return}if(this.isLinePointsExceed())return;const n=this.getNextPoint(e,i);if(this.isCreate||this.isNone){this.setCreatStatusAndAddPoint(n);return}if(this.isActive){if(s)return;if(this.isMouseCoordOutsideActiveArea()){this.setNoneStatus(!1),this.setCreatStatusAndAddPoint(n);return}if(e.shiftKey){this.updateLineSegmentSpecial(i);return}if(this.coordsInsideActiveArea&&e.ctrlKey){this.setInvalidLine(this.selectedID);return}this.addLinePointToActiveLine()}},this.onDblclick=()=>{},this.onKeyUp=e=>{if(super.onKeyUp(e),this.isShift=!1,this.hoverLineSegmentIndex=-1,e.keyCode===EKeyCode$1.Esc){this.stopLineCreating(!1);return}if(this.isActive){if(e.keyCode===EKeyCode$1.Delete){this.deleteLine();return}if(e.keyCode===EKeyCode$1.F){this.setInvalidLine(this.selectedID);return}if(e.keyCode===EKeyCode$1.Space){this.continueToEdit();return}}this.keyboardEventWhileLineCreating(e)},this.onRightDblClick=e=>{super.onRightDblClick(e);const i=this.getCoordinate(e);if(this.isActive){const s=this.findHoveredPoint(i);if(s){this.deleteSelectedLinePoint(s.id);return}this.deleteSelectedLine(i)}},this.setReference=e=>{this.isReference=e},this.pointsWithinRange=e=>!(this.lowerLimitPointNum&&e<this.lowerLimitPointNum||this.upperLimitPointNum&&e>this.upperLimitPointNum),this.setLineList=e=>{const i=e.length!==this.lineListLen;this.lineList=e,i&&this.emit("updatePageNumber")},this.textChange=e=>{this.config.textConfigurable===!1||!this.selectedID||(this.updateSelectedTextAttribute(e),this.emit("selectedChange"))},this.status=2,this.isMousedown=!1,this.lineDragging=!1,this.isLineValid=!0,this.setConfig(t.config),this.prevAxis={x:0,y:0},this.textEditingID="",this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this),this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.actionsHistory=new ActionsHistory,this.dependToolConfig={lineType:ELineTypes.Line}}get isLineSelected(){return this.selectedID&&this.activeLine}get selectedLinePoints(){return this.activeLine?this.getPointList(this.activeLine):[]}get isCreate(){return this.status===0}get isActive(){return this.status===1}get isNone(){return this.status===2}get isCurve(){return this.config.lineType===ELineTypes.Curve}get isMultipleColor(){return this.config.lineColor===ELineColor.MultiColor}get imageSize(){return this.rotate%180==0?this.basicImgInfo:{width:this.basicImgInfo.height,height:this.basicImgInfo.width}}get lineListLen(){return this.lineList.length}get edgeAdsorptionEnabled(){return this.edgeAdsorption&&!this.isCurve&&this.lineListLen>0}get attributeConfigurable(){return this.config.attributeConfigurable}get isTextConfigurable(){return this.config.textConfigurable}get isDependPolygon(){return this.dependToolName===EToolName.Polygon}get isDependRect(){return this.dependToolName===EToolName.Rect}get isCurrentAttributeLocked(){return this.attributeLockList.includes(this.defaultAttribute)}get attributeFilteredLines(){return this.attributeLockList.length>0?this.lineList.filter(t=>this.attributeLockList.includes((t==null?void 0:t.attribute)||"")):this.lineList}get enableOutOfTarget(){return this.config.enableOutOfTarget}get showOrder(){return this.config.showOrder}get edgeAdsorption(){return this.config.edgeAdsorption}get attributeList(){return this.config.attributeList}get lowerLimitPointNum(){return this.config.lowerLimitPointNum}get upperLimitPointNum(){return this.config.upperLimitPointNum}get textCheckType(){return this.config.textCheckType}get customFormat(){return this.config.customFormat}get dataList(){return this.lineList}get hasActiveLine(){return this.activeLine&&this.activeLine.length>0}get viewPortLines(){const t=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom);return this.isHidden?[]:this.attributeFilteredLines.filter(e=>{var i;return(i=e==null?void 0:e.pointList)==null?void 0:i.some(s=>CanvasUtils.inViewPort(s,t))})}get lineStyle(){return{lineWidth:this.style.width,color:this.getLineColor(this.defaultAttribute),opacity:this.style.opacity}}get selectedText(){var t,e;return(e=(t=this.lineList.find(i=>i.id===this.selectedID))==null?void 0:t.textAttribute)!=null?e:""}get currentPageResult(){return this.lineList}updateStatus(t,e=!1){if(t!==this.status){if(e){let i="";this.textCheckType===ETextType.Order&&this.isTextConfigurable&&(i=AttributeUtils.getTextAttribute(this.lineList,this.textCheckType)),this.emit("updateText",i)}this.status=t,this.lineStatusChanged()}}isInBasicPolygon(t){var e,i;return isInPolygon(t,((e=this.basicResult)==null?void 0:e.pointList)||[],(i=this.dependToolConfig)==null?void 0:i.lineType)}getPolygonPointList(){if(!this.basicResult)return[];const{pointList:t}=this.basicResult,{lineType:e}=this.dependToolConfig;return e===ELineTypes.Curve?createSmoothCurvePoints(t.reduce((i,s)=>[...i,s.x,s.y],[]),.5,!0,20):t}getNextCoordByRenderCoord(t){return this.getNextCoordByAbsCoord(this.coordUtils.getAbsCoord(t))}getNextCoordByAbsCoord(t){var e;const i=(e=this.activeLine)==null?void 0:e.slice(-1)[0];return i?this.coordUtils.getNextCoordByDependTool(t,i):t}pointInLine(t,e,i){return t.filter(s=>s).length<2?!1:t.some((s,n)=>{if(n===0)return!1;const o=this.coordUtils.getRenderCoord(t[n-1]),a=this.coordUtils.getRenderCoord(s);return LineToolUtils.isInLine(e,o,a,i)})}arc(t,e=POINT_RADIUS,i){var s,n,o,a,l,h;if(this.ctx){const{x:c,y:u}=t;(s=this.ctx)==null||s.save(),(n=this.ctx)==null||n.beginPath(),this.ctx.fillStyle=i||this.lineStyle.color,(o=this.ctx)==null||o.arc(c,u,e,0,360),(a=this.ctx)==null||a.closePath(),(l=this.ctx)==null||l.fill(),(h=this.ctx)==null||h.restore()}}renderActiveArea(){if(this.isActive&&this.activeArea&&this.ctx){const{top:t,left:e,right:i,bottom:s}=this.activeArea,{x:n,y:o}=this.coordUtils.getRenderCoord({x:e,y:t});this.ctx.save(),this.ctx.beginPath(),this.ctx.strokeStyle="#B3B8FF",this.ctx.rect(n,o,(i-e)*this.zoom,(s-t)*this.zoom),this.ctx.stroke(),this.ctx.restore()}}addLinePoint(t){var e,i,s,n;this.arc(t),(e=this.activeLine)==null||e.push(__spreadProps$5(__spreadValues$6({},t),{id:uuid()})),((i=this.activeLine)==null?void 0:i.length)===1?(s=this.actionsHistory)==null||s.initRecord(this.activeLine):(n=this.actionsHistory)==null||n.pushHistory(this.activeLine),this.render()}setCreatStatusAndAddPoint(t,e=!1){this.updateStatus(0,e),this.addLinePoint(t)}isActiveLineValid(){var t;return this.selectedID?(t=this.lineList.find(e=>e.id===this.selectedID))==null?void 0:t.valid:this.isLineValid}nextOrder(){return this.lineListLen===0?1:this.lineList.slice(-1)[0].order+1}getLineColorByAttribute(t,e=!1){return StyleUtils.getStrokeAndFill(this.getColor(t.attribute),t.valid,{isSelected:e}).stroke}updateActiveArea(){this.activeArea=this.getActiveArea(),this.renderActiveArea()}getActiveArea(){return this.hasActiveLine?MathUtils.calcViewportBoundaries(this.activeLine,this.isCurve,SEGMENT_NUMBER,this.zoom):void 0}drawLineNumber(t,e=1,i,s="",n,o=!0){var a,l,h;if((this.showOrder||this.attributeConfigurable)&&this.ctx){let c=this.showOrder?e.toString():`${s}`;if(this.attributeConfigurable){const u=n?(h=(l=(a=this.attributeList)==null?void 0:a.find(d=>d.value===n))==null?void 0:l.key)!=null?h:n:"";c=[c,`${!o&&u?"\u65E0\u6548":""}${u}`].filter(d=>d).join("_")}this.drawText(t,c,i)}}drawLineTextAttribute(t,e,i){if(t&&i)return this.drawText(t,i,e,200)}drawText(t,e,i,s){var n,o;this.ctx&&((n=this.ctx)==null||n.save(),this.ctx.font="italic bold 14px SourceHanSansCN-Regular",this.ctx.fillStyle=i,this.ctx.strokeStyle=i,this.ctx.shadowColor="rgba(0, 0, 0, 0.6)",this.ctx.shadowOffsetY=2,this.ctx.shadowBlur=4,s?DrawUtils.wrapText(this.canvas,e,t.x-LINE_ORDER_OFFSET.x,t.y-LINE_ORDER_OFFSET.y,s):this.ctx.fillText(e,t.x-LINE_ORDER_OFFSET.x,t.y-LINE_ORDER_OFFSET.y),(o=this.ctx)==null||o.restore())}moveActiveArea(t,e){this.activeArea&&(this.activeArea=Object.assign(this.activeArea,{top:this.activeArea.top+e,bottom:this.activeArea.bottom+e,right:this.activeArea.right+t,left:this.activeArea.left+t})),this.activeLine&&(this.activeLine.map(i=>Object.assign(i,{x:i.x+t,y:i.y+e})),this.updateLines())}findHoveredPoint(t){if(!!this.activeLine)return this.activeLine.find(e=>{const i=this.coordUtils.getRenderCoord(e);return LineToolUtils.calcDistance(i,t)<=POINT_ACTIVE_RADIUS})}findHoverLine(t){return ___default.default.cloneDeep(this.lineList).reverse().find(({pointList:i})=>{const s=i?this.getPointList(i):[],n=this.getLineWidthScope();return s.some((o,a)=>{if(a===0)return!1;const l=this.coordUtils.getRenderCoord(o),h=this.coordUtils.getRenderCoord(s[a-1]);return LineToolUtils.isInLine(t,l,h,n)})})}getAdsorptionPoint(t){let e,i,s;return ___default.default.cloneDeep(this.lineList).reverse().forEach(({pointList:n,id:o})=>{if(o===this.selectedID||!n||(n==null?void 0:n.length)<2)return;const a=this.findNearestPoint(n,t);if(a){if(a.minDistance===0){e=a.point;return}(i===void 0||a.minDistance<i)&&(e=a.point,i=a.minDistance)}}),s||e}findNearestPoint(t,e,i=7){let s;const n=i;for(let o=1;o<=t.length-1;o++){const a=this.coordUtils.getRenderCoord(t[o]),l=this.coordUtils.getRenderCoord(t[o-1]),{length:h,footPoint:c}=MathUtils.getFootOfPerpendicular(e,a,l),u=LineToolUtils.calcTwoPointDistance(a,e),d=LineToolUtils.calcTwoPointDistance(l,e);if(u<=i*2){s=a,i=0;break}if(d<=i*2){s=l,i=0;break}h<i&&(s=c,i=h)}return s?{point:s,minDistance:n}:void 0}getPointList(t){return this.isCurve?createSmoothCurvePointsFromPointList(t,SEGMENT_NUMBER):t}moveSelectedLine(t){const e=(t.x-this.prevAxis.x)/this.zoom,i=(t.y-this.prevAxis.y)/this.zoom;if(this.enableOutOfTarget){this.lineDragging=!0,this.moveActiveArea(e,i);return}if(this.isDependPolygon){this.moveLineInPolygon(e,i);return}let s=[0,this.imageSize.width],n=[0,this.imageSize.height];if(this.isDependRect){const{x:o,y:a,width:l,height:h}=this.basicResult;s=[o,o+l],n=[a,a+h]}this.moveLineInRectRange(e,i,s,n)}moveSelectPoint(t){if(!this.selectedPoint)return;const e=t.x-this.prevAxis.x,i=t.y-this.prevAxis.y,s=(this.selectedPoint?this.selectedPoint.x:0)+e/this.zoom,n=(this.selectedPoint?this.selectedPoint.y:0)+i/this.zoom,o={x:s,y:n};Object.assign(this.selectedPoint,this.getNextCoordByAbsCoord(o)),this.updateLines(),this.render()}getCoordByConfig(t,e){var i;const s=!!t.shiftKey,n=t.altKey;if(((i=this.activeLine)==null?void 0:i.length)>0&&s){const o=this.activeLine.slice(-1)[0];return LineToolUtils.getVHPoint(o,e,this.coordUtils.getAbsCoord(e),this.coordUtils.getRenderCoord(o))}return this.edgeAdsorptionEnabled&&!n?this.getAdsorptionPoint(e):e}getNextPoint(t,e){const i=this.getCoordByConfig(t,e)||e;return this.enableOutOfTarget?i:this.getNextCoordByRenderCoord(i)}lineHover(){this.render()}mouseMoveHandler(t){const e=this.getCoordinate(t),i=t.which===1;if(this.isCreate){this.hasActiveLine&&this.renderNextPoint(t,e);return}if(this.isNone&&(this.lineHover(),this.edgeAdsorptionEnabled&&!t.altKey)){const s=this.getAdsorptionPoint(e);s&&this.arc(s)}if(this.isActive){if(this.isMousedown&&i){if(this.selectedPoint){this.moveSelectPoint(e);return}if(this.coordsInsideActiveArea){this.moveSelectedLine(e),this.drawActivatedLine(void 0,void 0,!0);return}}this.drawHoverPoint(e),this.render()}}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.getCoordinate(t);this.mouseMoveHandler(t),this.prevAxis=e}setActiveArea(t,e=!1){const i=this.findHoverLine(t);if(i){const s=this.lineList.findIndex(a=>a.id===(i==null?void 0:i.id)),n=MathUtils.calcViewportBoundaries((i==null?void 0:i.pointList)||[],this.isCurve,SEGMENT_NUMBER,this.zoom),o=this.lineList[s];this.updateStatus(1),this.setActiveLine(o.pointList),this.setSelectedLineID(o.id),this.activeArea=n,this.updateLineAttributes(o)}else e&&this.setNoneStatus();this.render()}setActiveLineByID(t){const e=this.lineList.find(i=>i.id===t);if(e){const i=MathUtils.calcViewportBoundaries((e==null?void 0:e.pointList)||[],this.isCurve,SEGMENT_NUMBER,this.zoom);this.updateStatus(1),this.setActiveLine(e.pointList),this.setSelectedLineID(e.id),this.activeArea=i,this.updateLineAttributes(e)}this.render()}setActiveLine(t){this.activeLine=t?___default.default.cloneDeep(t):void 0}historyChanged(t){const e=`${t}Enabled`;if(this.isCreate){if(this.actionsHistory&&this.actionsHistory[e]){const i=this.actionsHistory&&this.actionsHistory[t]();this.setActiveLine(i),this.render()}return}if(this.history&&this.history[e]){const i=this.history[t](),s=i==null?void 0:i.find(n=>n.id===this.selectedID);this.lineList=i,this.selectedID&&s?this.setActiveLine(s==null?void 0:s.pointList):this.setNoneStatus(),this.render()}this.emit("dataUpdated",this.lineList)}undo(){this.historyChanged("undo"),this.updateSelectedAttributeAfterHistoryChanged()}redo(){this.historyChanged("redo"),this.updateSelectedAttributeAfterHistoryChanged()}isCoordInsideTarget(t){if(this.isDependPolygon)return this.isInBasicPolygon(t);if(this.isDependRect){const{x:e,y:i,width:s,height:n}=this.basicResult,o=[e,e+s],a=[i,i+n];return MathUtils.isInRange(t.x,o)&&MathUtils.isInRange(t.y,a)}return MathUtils.isInRange(t.x,[0,this.imageSize.width])&&MathUtils.isInRange(t.y,[0,this.imageSize.height])}getPointInsertIndex(t,e){if(t&&this.activeLine){const i=this.getPointList(this.activeLine);return this.activeLine.length===2?1:this.activeLine.findIndex((s,n)=>{if(n>0){const o=this.activeLine?this.activeLine[n-1]:void 0,a=this.isCurve?i.slice((n-1)*(SEGMENT_NUMBER+1),n*(SEGMENT_NUMBER+1)):[o,s];return this.pointInLine(a,t,e||this.getLineWidthScope())}return!1})}return-1}getLineWidthScope(){return this.lineStyle.lineWidth}isMouseCoordOutsideActiveArea(){return!this.coordsInsideActiveArea&&!this.selectedPoint}isLinePointsExceed(){return this.isCreate&&this.activeLine&&this.upperLimitPointNum&&~~this.upperLimitPointNum<=this.activeLine.length}isLinePointsNotEnough(){var t;return this.activeLine&&((t=this.activeLine)==null?void 0:t.length)<this.lowerLimitPointNum}updateLineSegmentSpecial(t){const e=this.getPointInsertIndex(t,2)-1;if(e>-1){const i=this.activeLine[e];i.specialEdge=!i.specialEdge,this.hoverLineSegmentIndex=-1,this.render()}}addLinePointToActiveLine(){var t;const e=this.getPointInsertIndex(this.cursor),i=this.pointsWithinRange(this.activeLine.length+1);this.cursor&&e>-1&&i&&(this.activeLine.splice(e,0,__spreadProps$5(__spreadValues$6({},this.coordUtils.getAbsCoord(this.cursor)),{id:uuid()})),this.updateLines(),(t=this.history)==null||t.pushHistory(this.lineList),this.render(),this.cursor=void 0)}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.getCoordinate(t);if(this.isMousedown=!0,this.prevAxis=e,t.which===3){this.cursor=void 0;return}this.selectedPoint=this.findHoveredPoint(e),this.coordsInsideActiveArea=this.isActive&&this.activeArea?LineToolUtils.inArea(this.activeArea,this.coordUtils.getAbsCoord(e)):!1,this.lineDragging=!1}lineHasChanged(){const t=this.lineList.find(e=>e.id===this.selectedID);return t?JSON.stringify(t.pointList)!==JSON.stringify(this.activeLine):!1}updateLines(){const t=this.lineList.find(e=>e.id===this.selectedID);t&&(t.pointList=___default.default.cloneDeep(this.activeLine),this.emit("dataUpdated",this.lineList))}onMouseUp(t){const e=()=>{this.isMousedown=!1,this.hoverPointID=void 0,this.cursor=void 0,this.selectedPoint=void 0};if(this.hoverPointID=void 0,super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo){e();return}t.which===1&&this.onLeftClick(t),t.which===3&&this.onRightClick(t),e()}isTextValid(t){return AttributeUtils.textAttributeValidate(this.textCheckType,this.customFormat,t)}createLineData(){const t=uuid(),e={pointList:___default.default.cloneDeep(this.activeLine),id:t,valid:this.isLineValid,order:this.nextOrder()};return e.attribute=this.defaultAttribute,e}stopLineCreating(t=!0){var e,i,s,n;const o=this.selectedID?!0:!!this.isTextConfigurable;let a;if(t){if(this.selectedID){const l=this.lineList.find(h=>h.id===this.selectedID);a=this.selectedID,l&&(l.pointList=___default.default.cloneWith(this.activeLine),___default.default.isEqual(l.pointList,(e=this.history)==null?void 0:e.pushHistory(this.lineList))||(i=this.history)==null||i.pushHistory(this.lineList))}else if(this.isCreate&&this.activeLine&&this.activeLine.length>1){const l=this.createLineData();a=l.id,this.setLineList([...this.lineList,l]),(s=this.history)==null||s.pushHistory(this.lineList)}}o?this.setActiveStatus(a):this.setNoneStatus(),(n=this.actionsHistory)==null||n.empty(),this.emit("dataUpdated",this.lineList),this.render()}setActiveStatus(t){const e=t?this.lineList.find(i=>i.id===t):void 0;if(e){const i=e==null?void 0:e.pointList;this.updateStatus(1),this.setActiveLine(i),this.setSelectedLineID(t)}else this.setNoneStatus()}setNoneStatus(t=!0){t&&this.updateStatus(2),this.activeLine=[],this.setSelectedLineID(void 0),this.activeArea=void 0,this.isLineValid=!0,this.cursor=void 0}setKeyDownStatus(t,e){this.isShift=e!=null?e:t.keyCode===EKeyCode$1.Shift}continueToEdit(){var t;this.updateStatus(0),this.cursor=void 0,(t=this.actionsHistory)==null||t.pushHistory(this.activeLine),this.render()}setInvalidLineOnCreating(t){if(this.selectedID&&t.keyCode!==EKeyCode$1.Ctrl||!this.isCreate)return;const e=!t.ctrlKey;this.selectedID?this.setInvalidLine(this.selectedID,e,!1):this.isLineValid=e}onKeyDown(t){if(super.onKeyDown(t),this.setKeyDownStatus(t),t.keyCode===EKeyCode$1.Z&&!t.ctrlKey&&this.toggleIsHide(),t.keyCode===EKeyCode$1.Shift&&this.render(),t.keyCode===EKeyCode$1.Tab){t.preventDefault(),this.selectToNextLine(t);return}if(this.isCreate&&this.keyboardEventWhileLineCreating(t),this.config.attributeConfigurable){const e=AttributeUtils.getAttributeByKeycode(t.keyCode,this.config.attributeList);e!==void 0&&this.setDefaultAttribute(e)}}selectToNextLine(t){const e=CommonToolUtils$1.getNextSelectedRectIDByEvent(this.viewPortLines.map(i=>{var s,n,o,a;return __spreadProps$5(__spreadValues$6({},i),{x:(n=(s=i.pointList[0])==null?void 0:s.x)!=null?n:0,y:(a=(o=i.pointList[0])==null?void 0:o.y)!=null?a:0})}),t,this.selectedID);e&&this.setActiveLineByID(e.id)}keyboardEventWhileLineCreating(t){!this.isCreate||(t.keyCode===EKeyCode$1.Ctrl&&this.setInvalidLineOnCreating(t),[EKeyCode$1.Shift,EKeyCode$1.Alt].includes(t.keyCode)&&this.renderNextPoint(t,this.prevAxis))}renderNextPoint(t,e){const i=this.coordUtils.getRenderCoord(this.getNextPoint(t,e));this.render(i)}deleteSelectedLine(t){const e=MathUtils.calcViewportBoundaries(this.activeLine,this.isCurve,SEGMENT_NUMBER,this.zoom);LineToolUtils.inArea(e,this.coordUtils.getAbsCoord(t))&&this.deleteLine()}deleteSelectedLinePoint(t){var e;this.pointsWithinRange(this.activeLine.length-1)&&t&&(this.setActiveLine(this.activeLine.filter(s=>s.id!==t)),this.updateLines(),(e=this.history)==null||e.pushHistory(this.lineList)),this.cursor=void 0,this.render()}deleteLine(){var t;this.lineList=this.lineList.filter(e=>e.id!==this.selectedID),(t=this.history)==null||t.pushHistory(this.lineList),this.setNoneStatus(),this.emit("dataUpdated",this.lineList),this.render()}setInvalidLine(t,e,i=!0){var s;const n=this.lineList.find(o=>o.id===t);n&&(n.valid=e!==void 0?e:!n.valid,(s=this.history)==null||s.pushHistory(this.lineList),i&&this.render())}empty(){var t,e;this.lineList=[],this.setNoneStatus(),this.selectedPoint=void 0,(t=this.actionsHistory)==null||t.empty(),(e=this.history)==null||e.init(),this.emit("dataUpdated",this.lineList),this.render()}setAttribute(t){var e;this.attributeConfigurable&&(this.defaultAttribute=t,this.setLineAttribute("attribute",t),this.selectedID&&((e=this.history)==null||e.pushHistory(this.lineList)))}setTextAttribute(t){var e;this.isTextConfigurable&&(this.setLineAttribute("textAttribute",t),(e=this.history)==null||e.applyAttribute(this.selectedID,"textAttribute",t))}setLineAttribute(t,e,i){const s=i||this.selectedID;if(s){const n=this.lineList.find(o=>o.id===s);n&&(n[t]=e)}this.render()}updateAttribute(t){this.emit("updateAttribute",t)}updateLineAttributes(t){var e;if(this.attributeConfigurable&&t){const i=(t==null?void 0:t.attribute)||"";this.defaultAttribute=i,this.updateAttribute(i)}if(this.isTextConfigurable&&t){const i=(t==null?void 0:t.textAttribute)||"";this.updateTextAttribute(i)}(e=this.history)==null||e.updateHistory(this.lineList)}lineStatusChanged(){this.emit("lineStatusChanged",{status:this.status,selectedLineID:this.selectedID})}updateTextAttribute(t){if(this.selectedID){const e=this.lineList.find(i=>i.id===this.selectedID);e&&(e.textAttribute=t)}this.emit("updateText",t)}saveData(){this.stopLineCreating(),this.setNoneStatus(),this.render()}setTextEditingID(t){this.textEditingID=t,this.render()}setSelectedLineID(t){var e,i;if(this.selectedID===t)return;const s=this.selectedID;t!==s&&s&&((e=this._textAttributeInstance)==null||e.changeSelected()),t||(i=this._textAttributeInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.emit("selectedChange")}attributeLockListChange(t){this.attributeLockList=t,this.render()}setResult(t){this.setNoneStatus(),this.setLineList(t),this.render()}setConfig(t){super.setConfig(t)}toggleIsHide(){this.setIsHidden(!this.isHidden),this.render()}clearCanvas(){super.clearCanvas()}clearResult(){this.setResult([]),this.setSelectedLineID(void 0),this.render()}exportData(){return[this.lineList,this.basicImgInfo]}setDefaultAttribute(t=""){var e;this.attributeConfigurable&&(this.defaultAttribute=t,this.setLineAttribute("attribute",t),this.selectedID&&((e=this.history)==null||e.pushHistory(this.lineList)),this.emit("changeAttributeSidebar"))}getCurrentSelectedData(){var t,e;const i=this.isActiveLineValid(),s=this.defaultAttribute,n=this.getColor(s),o=i?n==null?void 0:n.valid.stroke:n==null?void 0:n.invalid.stroke,a=(e=(t=this.lineList.find(l=>l.id===this.selectedID))==null?void 0:t.textAttribute)!=null?e:"";return{color:o,textAttribute:a}}renderTextAttribute(){var t,e,i,s;if(!this.ctx||!this.activeLine||((t=this.activeLine)==null?void 0:t.length)<2||this.isCreate)return;const n=this.isActiveLineValid(),o=this.defaultAttribute,{x:a,y:l}=this.activeLine[1],h=this.coordUtils.getRenderCoord({x:a,y:l}),c=this.getColor(o),u=n?c==null?void 0:c.valid.stroke:c==null?void 0:c.invalid.stroke,d=(i=(e=this.lineList.find(g=>g.id===this.selectedID))==null?void 0:e.textAttribute)!=null?i:"";this._textAttributeInstance||(this._textAttributeInstance=new TextAttributeClass({container:this.container,icon:this.getTextIconSvg(o),color:u,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributeInstance&&!((s=this._textAttributeInstance)==null?void 0:s.isExit)&&this._textAttributeInstance.appendToContainer(),this._textAttributeInstance.update(`${d}`,{left:h.x,top:h.y,color:u}),this._textAttributeInstance.updateIcon(this.getTextIconSvg(o))}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}updateSelectedTextAttribute(t){if(this._textAttributeInstance&&t&&this.selectedID){let e=t;!AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setTextAttribute(e),this.emit("updateTextAttribute"),this.render()}}}class TextToolOperation extends BasicToolOperation{constructor(t){super(t);this.getSingleResult=e=>{const i={};return this.config.configList.length>0&&this.config.configList.forEach(s=>{var n;i[s.key]=(n=s.default)!=null?n:""}),{value:i,id:uuid(),sourceID:e!=null?e:CommonToolUtils$1.getSourceID()}},this.getInitResultList=(e,i)=>e>0?i.map(s=>this.getSingleResult(s.id)):[this.getSingleResult()],this.textList=[],this.setShowDefaultCursor(!0),this.setConfig(t.config),this.initTextDisplayContainer()}get dataList(){return this.textList}get textValueContainerID(){return"textValueContainer"}get textValueContainer(){return document.getElementById(this.textValueContainerID)}get currentPageResult(){return this.textList}setResult(t){var e;this.textList=t,this.toggleTextContainerVisible(!0);const i=(e=this.textList[0])==null?void 0:e.value;i&&Object.keys(i).forEach(s=>{this.renderText(s,i[s])}),this.emit("valueUpdated"),this.toggleTextContainerVisible(!!i)}updateTextValue(t,e){this.textList[0].value[t]=e,this.renderText(t,e),this.emit("valueUpdated")}renderText(t,e){const i=document.getElementById(`textKey${t}`);i&&(i.innerText=e)}getTextDomID(t){return`textKey${t}`}initTextDisplayContainer(){const t=document.createElement("div"),e={position:"absolute",right:"0",top:"0","z-index":"20","max-width":"20%","font-family":"SourceHanSansCN-Regular",background:"rgb(102, 230, 255)",color:"white","word-break":"break-all","line-height":"24px","white-space":"pre-wrap","max-height":"80%","overflow-y":"auto",opacity:"0.6"};t.setAttribute("style",Object.keys(e).reduce((i,s)=>(i+=`${s}: ${e[s]};`,i),"")),t.setAttribute("id",this.textValueContainerID),this.config.configList.forEach(i=>{const s=document.createElement("div"),n=document.createElement("div"),o=document.createElement("div");s.setAttribute("style","padding: 8px 16px"),n.innerText=`${i.key}:`,o.innerText="",o.setAttribute("id",this.getTextDomID(i.key)),s.appendChild(n),s.appendChild(o),t.appendChild(s)}),this.container.appendChild(t)}exportData(){return[this.textList,this.basicImgInfo]}destroyCanvas(){super.destroyCanvas(),this.textValueContainer&&this.container.removeChild(this.textValueContainer)}onKeyDown(t){super.onKeyDown(t),t.keyCode===EKeyCode$1.Z&&this.toggleTextContainerVisible()}toggleTextContainerVisible(t){if(this.textValueContainer){const e=(t!==void 0?!t:this.textValueContainer.style.display==="block")?"none":"block";this.textValueContainer.style.display=e}}}var __defProp$6=Object.defineProperty,__defProps$4=Object.defineProperties,__getOwnPropDescs$4=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$5=Object.getOwnPropertySymbols,__hasOwnProp$5=Object.prototype.hasOwnProperty,__propIsEnum$5=Object.prototype.propertyIsEnumerable,__defNormalProp$6=(r,t,e)=>t in r?__defProp$6(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$5=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$5.call(t,e)&&__defNormalProp$6(r,e,t[e]);if(__getOwnPropSymbols$5)for(var e of __getOwnPropSymbols$5(t))__propIsEnum$5.call(t,e)&&__defNormalProp$6(r,e,t[e]);return r},__spreadProps$4=(r,t)=>__defProps$4(r,__getOwnPropDescs$4(t));const TEXT_MAX_WIDTH=164;class PolygonOperation extends BasicToolOperation{constructor(t){super(t);this.isAllowDouble=e=>{const{selectedID:i}=this,s=this.getHoverID(e);return!!(i&&i===s)},this.textChange=e=>{this.config.textConfigurable===!1||!this.selectedID||(this.setPolygonList(AttributeUtils.textChange(e,this.selectedID,this.polygonList)),this.emit("selectedChange"),this.render())},this.config=CommonToolUtils$1.jsonParser(t.config),this.drawingPointList=[],this.polygonList=[],this.hoverPointIndex=-1,this.hoverEdgeIndex=-1,this.drawingHistory=new ActionsHistory,this.isCtrl=!1,this.isAlt=!1,this.isCombined=!1,this.pattern=EPolygonPattern.Normal,this.getCurrentSelectedData=this.getCurrentSelectedData.bind(this),this.updateSelectedTextAttribute=this.updateSelectedTextAttribute.bind(this)}eventBinding(){super.eventBinding(),this.container.removeEventListener("mouseup",this.onMouseUp),this.container.addEventListener("mouseup",this.dragMouseUp),this.dblClickListener.addEvent(this.onMouseUp,this.onLeftDblClick,this.onRightDblClick,this.isAllowDouble)}eventUnbinding(){super.eventUnbinding(),this.container.removeEventListener("mouseup",this.dragMouseUp)}destroy(){super.destroy(),this._textAttributInstance&&this._textAttributInstance.clearTextAttribute()}get selectedPolygon(){return PolygonUtils.getPolygonByID(this.polygonList,this.selectedID)}get hoverPolygon(){return this.polygonList.find(t=>t.id===this.hoverID&&t.id!==this.selectedID)}get polygonListUnderZoom(){return this.polygonList.map(t=>__spreadProps$4(__spreadValues$5({},t),{pointList:AxisUtils.changePointListByZoom(t.pointList,this.zoom)}))}get selectedText(){var t;return(t=this.selectedPolygon)==null?void 0:t.textAttribute}get dataList(){return this.polygonList}setPattern(t,e=!1){var i;((i=this.drawingPointList)==null?void 0:i.length)>0&&e===!0||(this.pattern=t)}get currentShowList(){let t=[];const[e,i]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);return t=e,this.isHidden&&(t=[]),i&&t.push(i),t}get currentPageResult(){const[t]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),[]);return t}setResultAndSelectedID(t,e){this.setPolygonList(t),e&&(this.selectedID=e),this.render()}setResult(t){this.clearActiveStatus(),this.setPolygonList(t),this.render()}setPolygonDataByID(t,e){return this.polygonList.map(i=>i.id===e?__spreadValues$5(__spreadValues$5({},i),t):i)}rotatePolygon(t=1,e=ERotateDirection.Clockwise,i=this.selectedID){if(!i)return;const s=PolygonUtils.getPolygonByID(this.polygonList,i);if(!s)return;const n=PolygonUtils.updatePolygonByRotate(e,t,s==null?void 0:s.pointList);this.setPolygonList(this.setPolygonDataByID({pointList:n},i)),this.render()}addPointInDrawing(t){if(!this.imgInfo||this.forbidAddNewPolygonFuc&&this.forbidAddNewPolygonFuc(t))return;const{upperLimitPointNum:e,edgeAdsorption:i}=this.config;if(e&&this.drawingPointList.length>=e){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UpperLimitErrorNotice,this.lang)}${e}`);return}this.deleteSelectedID();const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changeDrawOutsideTarget(s,{x:0,y:0},this.imgInfo,this.config.drawOutsideTarget,this.basicResult,this.zoom);if(AxisUtils.returnClosePointIndex(n,AxisUtils.changePointListByZoom(this.drawingPointList,this.zoom))===0){this.addDrawingPointToPolygonList();return}const{dropFoot:a}=PolygonUtils.getClosestPoint(n,this.polygonListUnderZoom,this.config.lineType,edgeAdsorptionScope),l=AxisUtils.changePointByZoom(a&&t.altKey===!1&&i?a:n,1/this.zoom);if(this.pattern===EPolygonPattern.Rect&&this.drawingPointList.length===2){const h=MathUtils.getRectangleByRightAngle(l,this.drawingPointList);if(this.drawingPointList=h,this.config.drawOutsideTarget===!1&&this.imgInfo&&this.isPolygonOutSide(this.drawingPointList)){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.ForbiddenCreationOutsideBoundary,this.lang)}`),this.drawingPointList=[];return}this.addDrawingPointToPolygonList(!0);return}this.drawingPointList.push(l),this.drawingPointList.length===1?this.drawingHistory.initRecord(this.drawingPointList):this.drawingHistory.pushHistory(this.drawingPointList)}clearResult(){this.setPolygonList([]),this.deleteSelectedID(),this.render()}clearPolygonDrag(){this.drawingPointList=[],this.dragInfo=void 0,this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.hoverEdgeIndex=-1,this.hoverPointIndex=-1,this.hoverID=""}clearActiveStatus(){this.clearPolygonDrag(),this.deleteSelectedID()}clearDrawingStatus(){this.drawingPointList=[]}setPolygonList(t){const e=this.polygonList.length;this.polygonList=t,e!==t.length&&this.emit("updatePageNumber")}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render(),this.emit("selectedChange")}setDefaultAttribute(t=""){const e=this.defaultAttribute;if(this.defaultAttribute=t,e!==t){this.changeStyle(t),this.emit("changeAttributeSidebar");const{selectedID:i}=this;if(i&&(this.selectedPolygon&&(this.selectedPolygon.attribute=t),this.history.pushHistory(this.polygonList),this.render()),this._textAttributInstance){if(this.attributeLockList.length>0&&!this.attributeLockList.includes(t)){this._textAttributInstance.clearTextAttribute();return}this._textAttributInstance.updateIcon(this.getTextIconSvg(t))}}}setStyle(t){var e;super.setStyle(t),this._textAttributInstance&&this.config.attributeConfigurable===!1&&((e=this._textAttributInstance)==null||e.updateIcon(this.getTextIconSvg()))}setPolygonValidAndRender(t){if(!t)return;const e=this.polygonList.map(i=>i.id===t?__spreadProps$4(__spreadValues$5({},i),{valid:!i.valid}):i);this.setPolygonList(e),this.history.pushHistory(this.polygonList),this.render(),this.emit("updateResult")}addDrawingPointToPolygonList(t){let{lowerLimitPointNum:e=3}=this.config;if(e<3&&(e=3),this.drawingPointList.length<e){this.drawingPointList=[],this.editPolygonID="";return}const i=CommonToolUtils$1.getSourceID(this.basicResult),s=[...this.polygonList];if(this.editPolygonID){const n=s.find(o=>o.id===this.editPolygonID);if(!n)return;n.pointList=this.drawingPointList,this.editPolygonID=""}else{const n=uuid(8,62);let o={id:n,sourceID:i,valid:!this.isCtrl,textAttribute:"",pointList:this.drawingPointList,attribute:this.defaultAttribute,order:CommonToolUtils$1.getMaxOrder(s.filter(a=>CommonToolUtils$1.isSameSourceID(a.sourceID,i)))+1};if(this.config.textConfigurable){let a="";a=AttributeUtils.getTextAttribute(this.polygonList.filter(l=>CommonToolUtils$1.isSameSourceID(l.sourceID,i)),this.config.textCheckType),o=__spreadProps$4(__spreadValues$5({},o),{textAttribute:a})}this.pattern===EPolygonPattern.Rect&&t===!0&&(o=__spreadProps$4(__spreadValues$5({},o),{isRect:!0})),s.push(o),this.emit("polygonCreated",o,this.zoom,this.currentPos),this.setSelectedIdAfterAddingDrawing(n)}this.setPolygonList(s),this.isCtrl=!1,this.drawingPointList=[],this.history.pushHistory(s)}setSelectedIdAfterAddingDrawing(t){this.drawingPointList.length!==0&&(this.config.textConfigurable?this.setSelectedID(t):this.deleteSelectedID())}getHoverID(t){var e;const i=this.getCoordinateUnderZoom(t),s=this.currentShowList.map(n=>__spreadProps$4(__spreadValues$5({},n),{pointList:AxisUtils.changePointListByZoom(n.pointList,this.zoom)}));return PolygonUtils.getHoverPolygonID(i,s,10,(e=this.config)==null?void 0:e.lineType)}getHoverEdgeIndex(t){var e;if(!this.selectedID)return-1;const i=this.selectedPolygon;if(!i)return-1;const s=this.getCoordinateUnderZoom(t),n=AxisUtils.changePointListByZoom(i.pointList,this.zoom);return PolygonUtils.getHoverEdgeIndex(s,n,(e=this.config)==null?void 0:e.lineType)}getHoverPointIndex(t){if(!this.selectedID)return-1;const e=this.selectedPolygon;if(!e)return-1;const i=this.getCoordinateUnderZoom(t),s=AxisUtils.changePointListByZoom(e.pointList,this.zoom);return AxisUtils.returnClosePointIndex(i,s)}deletePolygon(t){var e;if(!t)return;const i=this.polygonList.find(s=>s.id===t);this.emit("deletedObject",{deletedObject:i,id:t}),this.setPolygonList(this.polygonList.filter(s=>s.id!==t)),this.history.pushHistory(this.polygonList),(e=this._textAttributInstance)==null||e.clearTextAttribute(),this.emit("selectedChange"),this.render()}deletePolygonPoint(t){if(!this.selectedID)return;const{selectedPolygon:e}=this;if(!e)return;let{lowerLimitPointNum:i}=this.config;if(i<3&&(i=3),e.pointList.length<=i){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.LowerLimitErrorNotice,this.lang)}${i}`);return}e==null||e.pointList.splice(t,1),this.history.pushHistory(this.polygonList),this.render()}spaceKeydown(){var t,e,i;if(this.selectedID){if(((t=this.selectedPolygon)==null?void 0:t.isRect)===!0){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UnableToReannotation,this.lang)}`);return}this.editPolygonID=this.selectedID,this.drawingPointList=(i=(e=this.selectedPolygon)==null?void 0:e.pointList)!=null?i:[],this.drawingHistory.empty(),this.drawingHistory.initRecord(this.drawingPointList),this.hoverID="",this.deleteSelectedID(),this.render()}}onTabKeyDown(t){t.preventDefault();let e=ESortDirection.ascend;t.shiftKey&&(e=ESortDirection.descend),this.switchToNextPolygon(e)}switchToNextPolygon(t){if(this.drawingPointList.length>0)return;const[e,i]=CommonToolUtils$1.getRenderResultList(this.polygonList,CommonToolUtils$1.getSourceID(this.basicResult),this.attributeLockList,this.selectedID);let s=[...e];i&&(s=[...s,i]);const n=CanvasUtils.getViewPort(this.canvas,this.currentPos,this.zoom),o=s.map(l=>{var h,c,u,d;return __spreadProps$4(__spreadValues$5({},l),{x:(c=(h=l.pointList[0])==null?void 0:h.x)!=null?c:0,y:(d=(u=l.pointList[0])==null?void 0:u.y)!=null?d:0})}).filter(l=>CanvasUtils.inViewPort({x:l.x,y:l.y},n)),a=CommonToolUtils$1.getNextSelectedRectID(o,t,this.selectedID);if(a){this.setSelectedID(a.id);const{selectedPolygon:l}=this;l&&this.setDefaultAttribute(l.attribute)}this.render()}onKeyDown(t){if(!CommonToolUtils$1.hotkeyFilter(t)||super.onKeyDown(t)===!1)return;const{keyCode:e}=t;switch(e){case EKeyCode$1.Space:this.spaceKeydown();break;case EKeyCode$1.Esc:this.drawingPointList=[],this.editPolygonID="";break;case EKeyCode$1.F:this.selectedID&&this.setPolygonValidAndRender(this.selectedID);break;case EKeyCode$1.Z:if(t.altKey){this.onCombinedExecute();return}this.setIsHidden(!this.isHidden),this.render();break;case EKeyCode$1.Delete:this.deletePolygon(this.selectedID),this.render();break;case EKeyCode$1.Ctrl:this.isCtrl=!0;break;case EKeyCode$1.Alt:this.isAlt===!1&&(t.preventDefault(),this.isAlt=!0,this.render());break;case EKeyCode$1.Tab:{this.onTabKeyDown(t);break}case EKeyCode$1.X:t.altKey&&this.segment();break;default:{if(this.config.attributeConfigurable){const i=AttributeUtils.getAttributeByKeycode(e,this.config.attributeList);i!==void 0&&this.setDefaultAttribute(i)}break}}}onKeyUp(t){switch(super.onKeyUp(t),t.keyCode){case EKeyCode$1.Ctrl:this.isCtrl=!1;break;case EKeyCode$1.Alt:{const e=this.isAlt;this.isAlt=!1,e===!0&&this.render();break}}}rightMouseUp(t){if(this.drawingPointList.length>0){this.addDrawingPointToPolygonList();return}this.setSelectedID(this.hoverID);const{selectedPolygon:e}=this;e&&this.setDefaultAttribute(e.attribute)}onLeftDblClick(t){if(this.hoverEdgeIndex>-1){const e=this.getCoordinateUnderZoom(t),{selectedPolygon:i}=this;if(!i)return;const{dropFoot:s}=PolygonUtils.getClosestPoint(e,this.polygonListUnderZoom,this.config.lineType,edgeAdsorptionScope);if(!s)return;const{upperLimitPointNum:n}=this.config;if(n&&i.pointList.length>=n){this.emit("messageInfo",`${Locale.getMessagesByLocale(EMessage.UpperLimitErrorNotice,this.lang)}${n}`),this.clearPolygonDrag();return}i==null||i.pointList.splice(this.hoverEdgeIndex+1,0,AxisUtils.changePointByZoom(s,1/this.zoom)),this.setPolygonDataByID(i,this.selectedID),this.history.pushHistory(this.polygonList),this.hoverPointIndex=-1,this.hoverEdgeIndex=-1,this.render()}this.dragInfo=void 0}onRightDblClick(t){this.dragInfo=void 0,this.clearImgDrag();const e=this.getHoverID(t),i=this.getHoverPointIndex(t);if(this.hoverPointIndex>-1&&this.hoverPointIndex===i){this.deletePolygonPoint(i),this.dragInfo=void 0,this.hoverPointIndex=-1,this.render();return}this.hoverID===this.selectedID&&this.deletePolygon(e),this.render()}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||t.ctrlKey===!0)return;const e=this.selectedPolygon;if(!e||t.button!==0||this.getHoverID(t)!==this.selectedID)return;const s=e.pointList,n=this.getCoordinateUnderZoom(t);let o=[0],a=EDragTarget.Plane;this.dragStatus=EDragStatus.Start;const l=this.getHoverPointIndex(t),h=this.getHoverEdgeIndex(t);return l>-1?(a=EDragTarget.Point,o=[l]):h>-1&&this.hoverEdgeIndex>-1&&(a=EDragTarget.Line,o=[h,(h+1)%s.length]),this.dragInfo={dragStartCoord:n,dragTarget:a,initPointList:s,changePointIndex:o,originPolygon:this.selectedPolygon},!0}segment(){var t;if(!this.selectedID||((t=this.config)==null?void 0:t.lineType)!==ELineTypes.Line)return;const e=PolygonUtils.getPolygonPointList(this.selectedID,this.currentShowList),i=this.currentShowList.filter(o=>o.id!==this.selectedID);if(i.length===0||e.length===0)return;const s=PolygonUtils.getWrapPolygonIndex(e,i);let n=[...this.polygonList];if(s===-1){const o=PolygonUtils.segmentPolygonByPolygon(e,i);if(!o)return;const a=o.shift();if(!a)return;let l="",h=!0;const c=CommonToolUtils$1.getSourceID(this.basicResult);let u="";n=this.polygonList.map(d=>{var g,p;return d.id===this.selectedID?(l=d.attribute,h=(g=d==null?void 0:d.valid)!=null?g:!0,u=(p=d==null?void 0:d.textAttribute)!=null?p:"",__spreadProps$4(__spreadValues$5({},d),{pointList:a})):d}),o.length>0&&o.forEach((d,g)=>{n.push({sourceID:c,id:uuid(8,62),pointList:d,valid:h,order:CommonToolUtils$1.getMaxOrder(this.currentShowList)+1+g,attribute:l,textAttribute:u})})}else n[s].pointList=PolygonUtils.clipPolygonFromWrapPolygon(e,n[s].pointList),n=n.filter(o=>o.id!==this.selectedID);this.setPolygonList(n),this.history.pushHistory(n),this.render()}onCombinedExecute(){if(!this.selectedID){this.emit("messageInfo",lbUtils.i18n.t("PolygonsToBeCombinedNeedToBeSelected"));return}this.isCombined=!this.isCombined}combine(t){var e;const i=this.getHoverID(t);if(!i||!this.selectedID||this.selectedID===i)return;if(((e=this.config)==null?void 0:e.lineType)!==ELineTypes.Line){this.emit("messageInfo",lbUtils.i18n.t("CurveModeDoesNotSupportCutting"));return}const s=this.polygonList.find(h=>h.id===this.selectedID),n=this.currentShowList.find(h=>h.id===i);if(!n||!s)return;const o=PolygonUtils.combinePolygonWithPolygon(s,n);if(!o)return;const{newPolygon:a,unionList:l}=o;if(l.length===1&&a){const h=this.polygonList.filter(c=>!l.includes(c.id)).map(c=>c.id===this.selectedID?a:c);this.setPolygonList(h),this.history.pushHistory(h),this.render(),this.emit("messageInfo",lbUtils.i18n.t("CombineSuccess"))}else this.emit("messageInfo",lbUtils.i18n.t("CombiningFailedNotify"));this.isCombined=!1}isPolygonOutSide(t){if(this.dependToolName&&this.basicCanvas&&this.basicResult){let a=!1;switch(this.dependToolName){case EToolName.Rect:{a=t.filter(l=>!RectUtils.isInRect(l,this.basicResult)).length>0;break}case EToolName.Polygon:{a=PolygonUtils.isPointListOutSidePolygon(t,this.basicResult.pointList,this.config.lineType);break}}return a}if(!this.imgInfo)return!1;const{left:e,top:i,right:s,bottom:n}=MathUtils.calcViewportBoundaries(AxisUtils.changePointListByZoom(t,this.zoom)),o=1e-5;return e<0||i<0||s>this.imgInfo.width+o||n>this.imgInfo.height+o}onDragMove(t){if(!this.dragInfo||!this.selectedID)return;const{selectedPolygon:e}=this;let i=e==null?void 0:e.pointList;if(!i)return;const{initPointList:s,dragStartCoord:n,dragTarget:o,changePointIndex:a}=this.dragInfo,l=this.getCoordinateUnderZoom(t);let h={x:(l.x-n.x)/this.zoom,y:(l.y-n.y)/this.zoom};if(this.pattern===EPolygonPattern.Rect&&(e==null?void 0:e.isRect)===!0&&a&&[EDragTarget.Line].includes(o)){const u=MathUtils.getArrayIndex(a[0]-2,4),d=MathUtils.getArrayIndex(a[0]-1,4),g=[s[u],s[d]];h=MathUtils.getRectPerpendicularOffset(n,l,g),h={x:h.x/this.zoom,y:h.y/this.zoom}}switch(this.dragStatus=EDragStatus.Move,o){case EDragTarget.Plane:i=i.map((u,d)=>__spreadProps$4(__spreadValues$5({},u),{x:s[d].x+h.x,y:s[d].y+h.y}));break;case EDragTarget.Point:case EDragTarget.Line:i=i.map((u,d)=>a&&a.includes(d)?__spreadProps$4(__spreadValues$5({},u),{x:s[d].x+h.x,y:s[d].y+h.y}):u);break}if(this.pattern===EPolygonPattern.Rect&&(e==null?void 0:e.isRect)===!0&&o===EDragTarget.Point&&a&&(i=MathUtils.getPointListFromPointOffset(s,a[0],h)),this.config.drawOutsideTarget===!1&&this.imgInfo&&this.isPolygonOutSide(i))return;const c=this.polygonList.map(u=>{if(u.id===this.selectedID){const d=__spreadProps$4(__spreadValues$5({},u),{pointList:i});return u.isRect===!0&&this.pattern===EPolygonPattern.Normal&&Object.assign(d,{isRect:!1}),d}return u});this.setPolygonList(c),this.render()}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;if(this.selectedID&&this.dragInfo){this.onDragMove(t);return}let e=-1,i=-1;const{selectedID:s}=this;if(s&&(this.hoverEdgeIndex=-1,this.hoverPointIndex=-1,e=this.getHoverPointIndex(t),e>-1?this.hoverPointIndex=e:(i=this.getHoverEdgeIndex(t),this.hoverEdgeIndex=i)),this.drawingPointList.length>0)return;const n=this.getHoverID(t);this.hoverID!==n&&(this.hoverID=n,this.render())}leftMouseUp(t){const e=this.getHoverID(t);if(this.drawingPointList.length===0&&t.ctrlKey===!0&&e){this.setPolygonValidAndRender(e);return}this.addPointInDrawing(t)}onMouseUp(t){if(this.isCombined){switch(t.button){case 0:this.combine(t);break;case 2:this.isCombined=!1;break;default:return}return}if(!(super.onMouseUp(t)||this.forbidMouseOperation||!this.imgInfo)){if(this.dragInfo&&this.dragStatus===EDragStatus.Move){const{originPolygon:e}=this.dragInfo;this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait,this.history.pushHistory(this.polygonList),this.emit("updateResult"),this.emit("updatePolygonByDrag",{newPolygon:this.selectedPolygon,originPolygon:e});return}switch(t.button){case 0:{this.leftMouseUp(t);break}case 2:{this.rightMouseUp(t);break}}this.render()}}dragMouseUp(){this.dragStatus===EDragStatus.Start&&(this.dragInfo=void 0,this.dragStatus=EDragStatus.Wait)}exportData(){const{polygonList:t}=this;return[t,this.basicImgInfo]}getTextIconSvg(t=""){return AttributeUtils.getTextIconSvg(t,this.config.attributeList,this.config.attributeConfigurable,this.baseIcon)}getCurrentSelectedData(){const{selectedPolygon:t}=this;if(!t)return;const e=this.getColor(t.attribute),i=t.valid?e==null?void 0:e.valid.stroke:e==null?void 0:e.invalid.stroke;return{width:TEXT_MAX_WIDTH,textAttribute:t.textAttribute,color:i}}updateSelectedTextAttribute(t){if(this._textAttributInstance&&t&&this.selectedID){let e=t;AttributeUtils.textAttributeValidate(this.config.textCheckType,"",e)===!1&&(this.emit("messageError",AttributeUtils.getErrorNotice(this.config.textCheckType,this.lang)),e=""),this.setPolygonList(AttributeUtils.textChange(e,this.selectedID,this.polygonList)),this.emit("updateTextAttribute"),this.render()}}renderTextAttribute(){var t;const{selectedPolygon:e}=this;if(!this.ctx||this.config.textConfigurable===!1||!e)return;const{pointList:i,attribute:s,valid:n,textAttribute:o}=e,{x:a,y:l}=i[i.length-1],h=TEXT_MAX_WIDTH,c=AxisUtils.getOffsetCoordinate({x:a,y:l},this.currentPos,this.zoom),u=this.getColor(s),d=n?u==null?void 0:u.valid.stroke:u==null?void 0:u.invalid.stroke;this._textAttributInstance||(this._textAttributInstance=new TextAttributeClass({width:h,container:this.container,icon:this.getTextIconSvg(s),color:d,getCurrentSelectedData:this.getCurrentSelectedData,updateSelectedTextAttribute:this.updateSelectedTextAttribute})),this._textAttributInstance&&!((t=this._textAttributInstance)==null?void 0:t.isExit)&&this._textAttributInstance.appendToContainer(),this._textAttributInstance.update(`${o}`,{left:c.x,top:c.y,color:d,width:h})}renderStaticPolygon(){var t;this.isHidden===!1&&((t=this.polygonList)==null||t.forEach(e=>{var i,s,n,o,a;if([this.selectedID,this.editPolygonID].includes(e.id))return;const{textAttribute:l,attribute:h}=e,c=this.getColor(h),u=StyleUtils.getStrokeAndFill(c,e.valid),d=AxisUtils.changePointListByZoom(e.pointList||[],this.zoom,this.currentPos);DrawUtils.drawPolygonWithFillAndLine(this.canvas,d,{fillColor:u.fill,strokeColor:u.stroke,pointColor:"white",thickness:(s=(i=this.style)==null?void 0:i.width)!=null?s:2,lineCap:"round",isClose:!0,lineType:(n=this.config)==null?void 0:n.lineType});let g=`${(o=AttributeUtils.getAttributeShowText(h,this.config.attributeList))!=null?o:""}`;((a=this.config)==null?void 0:a.isShowOrder)&&(e==null?void 0:e.order)>0&&(g=`${e.order} ${g}`),DrawUtils.drawText(this.canvas,d[0],g,__spreadValues$5({color:u.stroke},DEFAULT_TEXT_OFFSET));const p=d[d.length-1];DrawUtils.drawText(this.canvas,{x:p.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:p.y+TEXT_ATTRIBUTE_OFFSET$1.y},l,__spreadValues$5({color:u.stroke},DEFAULT_TEXT_OFFSET))}))}renderSelectedPolygon(){var t,e,i;if(this.selectedID){const s=this.selectedPolygon;if(s){const n=this.getColor(s.attribute),o=StyleUtils.getStrokeAndFill(n,s.valid,{isSelected:!0});DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(s.pointList,this.zoom,this.currentPos),{fillColor:o.fill,strokeColor:o.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!0,lineType:(t=this.config)==null?void 0:t.lineType});let a=`${(e=AttributeUtils.getAttributeShowText(s.attribute,this.config.attributeList))!=null?e:""}`;((i=this.config)==null?void 0:i.isShowOrder)&&(s==null?void 0:s.order)>0&&(a=`${s.order} ${a}`),DrawUtils.drawText(this.canvas,AxisUtils.changePointByZoom(s.pointList[0],this.zoom,this.currentPos),a,__spreadValues$5({color:o.stroke},DEFAULT_TEXT_OFFSET)),this.renderTextAttribute()}}}renderHoverPolygon(){var t;if(this.hoverID&&this.hoverID!==this.editPolygonID){const{hoverPolygon:e}=this;if(e){let i="";const s=this.getColor(e.attribute);e.valid?i=s.validHover.fill:i=StyleUtils.getStrokeAndFill(s,!1,{isHover:!0}).fill,DrawUtils.drawPolygonWithFill(this.canvas,AxisUtils.changePointListByZoom(e.pointList,this.zoom,this.currentPos),{color:i,lineType:(t=this.config)==null?void 0:t.lineType})}}}renderPolygon(){var t,e,i,s;this.renderStaticPolygon(),this.renderHoverPolygon(),this.renderSelectedPolygon();const n=this.getColor(this.defaultAttribute),o=StyleUtils.getStrokeAndFill(n,!this.isCtrl);if(((t=this.drawingPointList)==null?void 0:t.length)>0){let a=[...this.drawingPointList],l=AxisUtils.getOriginCoordinateWithOffsetCoordinate(this.coord,this.zoom,this.currentPos);if(this.pattern===EPolygonPattern.Rect&&a.length===2)a=MathUtils.getRectangleByRightAngle(l,a);else{if(((e=this.config)==null?void 0:e.edgeAdsorption)&&this.isAlt===!1){const{dropFoot:h}=PolygonUtils.getClosestPoint(l,this.polygonList,(i=this.config)==null?void 0:i.lineType,edgeAdsorptionScope/this.zoom);h&&(l=h)}a.push(l)}DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(a,this.zoom,this.currentPos),{fillColor:o.fill,strokeColor:o.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!1,lineType:this.config.lineType})}if(this.hoverPointIndex>-1&&this.selectedID){const a=this.selectedPolygon;if(!a)return;const l=StyleUtils.getStrokeAndFill(n,a.valid,{isSelected:!0}),h=a==null?void 0:a.pointList[this.hoverPointIndex];if(h){const{x:c,y:u}=AxisUtils.changePointByZoom(h,this.zoom,this.currentPos);DrawUtils.drawCircleWithFill(this.canvas,{x:c,y:u},5,{color:l.fill})}}if(this.hoverEdgeIndex>-1&&this.selectedID){const a=this.selectedPolygon;if(!a)return;const l=StyleUtils.getStrokeAndFill(n,a.valid,{isSelected:!0});DrawUtils.drawLineWithPointList(this.canvas,AxisUtils.changePointListByZoom(a.pointList,this.zoom,this.currentPos),{color:l.stroke,thickness:10,hoverEdgeIndex:this.hoverEdgeIndex,lineType:(s=this.config)==null?void 0:s.lineType})}}render(){!this.ctx||(super.render(),this.renderPolygon(),this.renderCursorLine(this.getLineColor(this.defaultAttribute)))}renderCursorLine(t){if(super.renderCursorLine(t),this.isCombined){const{x:e,y:i}=this.coord,s=10,n=186,o=32;DrawUtils.drawRectWithFill(this.canvas,{x:e+s,y:i-s*4-1,width:n,height:o},{color:"black"}),DrawUtils.drawText(this.canvas,{x:e,y:i},lbUtils.i18n.t("ClickAnotherPolygon"),{textAlign:"center",color:"white",offsetX:n/2+s,offsetY:-(o/2+s/2)}),DrawUtils.drawRect(this.canvas,{x:e-s,y:i-s,width:s*2,height:s*2},{lineDash:[6],color:"white"})}}undo(){if(this.drawingPointList.length>0){const e=this.drawingHistory.undo();if(!e)return;this.drawingPointList=e,this.render();return}const t=this.history.undo();t&&(t.length!==this.polygonList.length&&this.deleteSelectedID(),this.setPolygonList(t),this.render())}redo(){if(this.drawingPointList.length>0){const e=this.drawingHistory.redo();if(!e)return;this.drawingPointList=e,this.render();return}const t=this.history.redo();t&&(t.length!==this.polygonList.length&&this.deleteSelectedID(),this.setPolygonList(t),this.render())}deleteSelectedID(){this.setSelectedID("")}}var __defProp$5=Object.defineProperty,__defProps$3=Object.defineProperties,__getOwnPropDescs$3=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$4=Object.getOwnPropertySymbols,__hasOwnProp$4=Object.prototype.hasOwnProperty,__propIsEnum$4=Object.prototype.propertyIsEnumerable,__defNormalProp$5=(r,t,e)=>t in r?__defProp$5(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$4=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$4.call(t,e)&&__defNormalProp$5(r,e,t[e]);if(__getOwnPropSymbols$4)for(var e of __getOwnPropSymbols$4(t))__propIsEnum$4.call(t,e)&&__defNormalProp$5(r,e,t[e]);return r},__spreadProps$3=(r,t)=>__defProps$3(r,__getOwnPropDescs$3(t));const config={textConfigurable:!1,attributeConfigurable:!0,attributeList:[]};class MeasureOperation extends RectOperation{constructor(t){super(__spreadProps$3(__spreadValues$4({},t),{config:JSON.stringify(config)}))}setSelectedIdAfterAddingDrawingRect(){!this.drawingRect||this.setSelectedRectID(this.drawingRect.id)}}class RenderDomClass{constructor(t){this._domMap=new Map,this._container=t.container,this._height=t.height}wheelChange(t){t.stopPropagation()}clearTag(t){const e=this._container,i=window.self.document.getElementById(t);i&&e&&e.contains(i)&&(i.removeEventListener("wheel",this.wheelChange),e==null||e.removeChild(i))}render(t){const e=Array.from(this._domMap.keys()),i=t.map(s=>s.id);t.forEach(s=>{const{text:n,textMaxWidth:o,color:a="white",background:l="rgba(0, 0, 0, 0.6)",style:h}=s;if(this._domMap.has(s.id)){const c=this._domMap.get(s.id);c&&(c.innerHTML=n)}else{const c=DrawUtils.drawTagByDom(this._container,n,s.id);c&&(c.setAttribute("style",`
|
|
78
78
|
position: absolute;
|
|
79
79
|
top: 0;
|
|
80
80
|
right: 0;
|
|
@@ -93,8 +93,8 @@
|
|
|
93
93
|
overflow-y: scroll;
|
|
94
94
|
clear: both;
|
|
95
95
|
${StyleUtils.getStyle2String(h)}
|
|
96
|
-
`),d.addEventListener("wheel",this.wheelChange),this._domMap.set(s.id,d))}}),e.forEach(s=>{i.indexOf(s)===-1&&(this.clearTag(s),this._domMap.delete(s))})}}var __defProp$4=Object.defineProperty,__defProps$2=Object.defineProperties,__getOwnPropDescs$2=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$3=Object.getOwnPropertySymbols,__hasOwnProp$3=Object.prototype.hasOwnProperty,__propIsEnum$3=Object.prototype.propertyIsEnumerable,__defNormalProp$4=(r,t,e)=>t in r?__defProp$4(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$3=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$3.call(t,e)&&__defNormalProp$4(r,e,t[e]);if(__getOwnPropSymbols$3)for(var e of __getOwnPropSymbols$3(t))__propIsEnum$3.call(t,e)&&__defNormalProp$4(r,e,t[e]);return r},__spreadProps$2=(r,t)=>__defProps$2(r,__getOwnPropDescs$2(t));const newScope$1=3,DEFAULT_RADIUS=3,DEFAULT_STROKE_COLOR="#6371FF";class ViewOperation extends BasicToolOperation{constructor(t){super(__spreadProps$2(__spreadValues$3({},t),{showDefaultCursor:!0}));this.style={},this.annotations=[],this.getHoverRectID=i=>{var s,n;const o=this.getCoordinateUnderZoom(i),a=AxisUtils.changePointByZoom(o,1/this.zoom);if(((s=this.annotations)==null?void 0:s.length)<=0||!((n=this.annotations)==null?void 0:n.length))return;let l="",h=Number.MAX_SAFE_INTEGER;for(let d=0;d<this.annotations.length;d++){const u=this.annotations[d];switch(u.type){case"rect":{const c=u.annotation;if(RectUtils.isInRect(o,c,newScope$1,this.zoom)){const g=c.width*c.height;g<h&&(l=c.id,h=g)}break}case"polygon":{const c=u.annotation;if(PolygonUtils.isInPolygon(a,c.pointList)){const g=PolygonUtils.getPolygonArea(c.pointList);g<h&&(l=c.id,h=g)}break}}}return l};var e;this.style=(e=t.style)!=null?e:{stroke:DEFAULT_STROKE_COLOR,thickness:3},this.annotations=t.annotations,this.loading=!1,this.renderDomInstance=new RenderDomClass({container:this.container,height:this.canvas.height})}setLoading(t){this.loading=t,this.render()}onMouseLeave(){super.onMouseLeave(),this.mouseHoverID=void 0,this.emit("onChange","hover",[])}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return!0;const e=this.mouseHoverID;if(t.button===0){let i=[];e&&(i=[e]),this.emit("onChange","selected",i),this.render()}}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.mouseHoverID,i=this.getHoverRectID(t);if(e!==i){this.mouseHoverID=i;let s=[];i&&(s=[i]),this.emit("onChange","hover",s),this.render()}}updateData(t){this.annotations=t,this.render()}getSpecificStyle(t){const e=___default.default.pick(t,["stroke","thickness","fill","radius"]),i=__spreadValues$3(__spreadValues$3({},this.style),e);return i.stroke&&Object.assign(i,{color:i.stroke}),i}getRenderText(t,e=!1){let i="",s="";return!t||e===!0?{headerText:i,bottomText:s}:((t==null?void 0:t.order)&&(i=`${t.order}`),(t==null?void 0:t.label)&&(i?i=`${i}_${t.label}`:i=`${t.label}`),(t==null?void 0:t.attribute)&&(i?i=`${i} ${t.attribute}`:i=`${t.attribute}`),(t==null?void 0:t.textAttribute)&&(s=t==null?void 0:t.textAttribute),{headerText:i,bottomText:s})}getReferenceOptions(t){return t?{lineCap:"butt",lineDash:[20,20]}:{}}render(){try{if(super.render(),this.loading===!0)return;this.renderDomInstance.render(this.annotations.filter(t=>t.type==="text"&&t.annotation.position==="rt").map(t=>t.annotation)),this.annotations.forEach(t=>{var e,i,s,n,o,a,l,h,d,u,c,g,p;switch(t.type){case"rect":{const f=t.annotation,{hiddenText:v=!1,isReference:m,hiddenRectSize:x=!1}=f,{zoom:b}=this,P=AxisUtils.changeRectByZoom(f,this.zoom,this.currentPos),{x:w,y:L,width:R,height:C}=P,D=this.getSpecificStyle(f);if(f.id===this.mouseHoverID||D.fill){const S=rgba__default.default((i=(e=D==null?void 0:D.fill)!=null?e:D==null?void 0:D.stroke)!=null?i:DEFAULT_STROKE_COLOR),F=`rgba(${S[0]}, ${S[1]}, ${S[2]},${S[3]*.8})`;DrawUtils.drawRectWithFill(this.canvas,P,{color:F})}DrawUtils.drawRect(this.canvas,P,__spreadValues$3(__spreadProps$2(__spreadValues$3({},D),{hiddenText:!0}),this.getReferenceOptions(m)));const{headerText:O,bottomText:E}=this.getRenderText(f,f==null?void 0:f.hiddenText);O&&DrawUtils.drawText(this.canvas,{x:w,y:L-6},O,__spreadProps$2(__spreadValues$3({color:D.stroke,font:"normal normal 900 14px SourceHanSansCN-Regular"},DEFAULT_TEXT_SHADOW),{textMaxWidth:300}));const H=`${Math.round(R/b)} * ${Math.round(C/b)}`,M=H.length*7;if(!v&&!x&&DrawUtils.drawText(this.canvas,{x:w+R-M,y:L+C+15},H,__spreadValues$3({color:D.stroke,font:"normal normal 600 14px Arial"},DEFAULT_TEXT_SHADOW)),E){const S=20,F=Math.max(20,R-M);DrawUtils.drawText(this.canvas,{x:w,y:L+C+S},f.textAttribute,__spreadValues$3({color:D.stroke,font:"italic normal 900 14px Arial",textMaxWidth:F},DEFAULT_TEXT_SHADOW))}break}case"polygon":{const f=t.annotation;if(!(((s=f==null?void 0:f.pointList)==null?void 0:s.length)>=3))return;const{lineType:v=ELineTypes.Line}=f,m=AxisUtils.changePointListByZoom((n=f==null?void 0:f.pointList)!=null?n:[],this.zoom,this.currentPos),x=this.getSpecificStyle(f);if(f.id===this.mouseHoverID||x.fill){const C=rgba__default.default((a=(o=x==null?void 0:x.fill)!=null?o:x==null?void 0:x.stroke)!=null?a:DEFAULT_STROKE_COLOR),D=`rgba(${C[0]}, ${C[1]}, ${C[2]},${C[3]*.8})`;DrawUtils.drawPolygonWithFill(this.canvas,m,{color:D,lineType:v})}const b=__spreadProps$2(__spreadValues$3(__spreadProps$2(__spreadValues$3({},x),{isClose:!0}),this.getReferenceOptions(f==null?void 0:f.isReference)),{lineType:v,strokeColor:x.stroke});let P=[];if(f.showKeyPoint?P=DrawUtils.drawPolygonWithKeyPoint(this.canvas,m,b):P=DrawUtils.drawPolygon(this.canvas,m,b),(f==null?void 0:f.showDirection)===!0&&((l=f==null?void 0:f.pointList)==null?void 0:l.length)>2){let C=m[0],D=MathUtils.getLineCenterPoint([m[0],m[1]]);if(v===ELineTypes.Curve){const O=Math.floor(SEGMENT_NUMBER$2/2);C=P[O],D=P[O+1]}DrawUtils.drawArrowByCanvas(this.canvas,C,D,{color:x.stroke,thickness:x.thickness}),DrawUtils.drawCircle(this.canvas,m[0],x.thickness+6,{color:x.stroke,thickness:x.thickness})}const{headerText:L,bottomText:R}=this.getRenderText(f,f==null?void 0:f.hiddenText);if(L&&DrawUtils.drawText(this.canvas,m[0],L,__spreadValues$3({color:x.stroke},DEFAULT_TEXT_OFFSET)),R){const C=m[m.length-1];DrawUtils.drawText(this.canvas,{x:C.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:C.y+TEXT_ATTRIBUTE_OFFSET$1.y},R,__spreadValues$3({color:x.stroke},DEFAULT_TEXT_OFFSET))}break}case"line":{const f=t.annotation;if(!(((h=f==null?void 0:f.pointList)==null?void 0:h.length)>=2))return;const{lineType:v=ELineTypes.Line}=f,m=AxisUtils.changePointListByZoom((d=f==null?void 0:f.pointList)!=null?d:[],this.zoom,this.currentPos),x=this.getSpecificStyle(f),b=DrawUtils.drawPolygon(this.canvas,m,__spreadProps$2(__spreadValues$3(__spreadValues$3({},x),this.getReferenceOptions(f==null?void 0:f.isReference)),{lineType:v}));if((f==null?void 0:f.showDirection)===!0&&((u=f==null?void 0:f.pointList)==null?void 0:u.length)>2){let R=m[0],C=MathUtils.getLineCenterPoint([m[0],m[1]]);if(v===ELineTypes.Curve){const D=Math.floor(SEGMENT_NUMBER$2/2);R=b[D],C=b[D+1]}DrawUtils.drawArrowByCanvas(this.canvas,R,C,{color:x.stroke,thickness:x.thickness}),DrawUtils.drawCircle(this.canvas,m[0],x.thickness+6,{color:x.stroke,thickness:x.thickness})}const{headerText:w,bottomText:L}=this.getRenderText(f,f==null?void 0:f.hiddenText);if(w&&DrawUtils.drawText(this.canvas,m[0],w,__spreadValues$3({color:x.stroke},DEFAULT_TEXT_OFFSET)),L){const R=m[m.length-1];DrawUtils.drawText(this.canvas,{x:R.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:R.y+TEXT_ATTRIBUTE_OFFSET$1.y},L,__spreadValues$3({color:x.stroke},DEFAULT_TEXT_OFFSET))}break}case"point":{const f=t.annotation,v=AxisUtils.changePointByZoom(f,this.zoom,this.currentPos),m=this.getSpecificStyle(f),x=(c=m.radius)!=null?c:DEFAULT_RADIUS;DrawUtils.drawCircle(this.canvas,v,x,m);const{headerText:b,bottomText:P}=this.getRenderText(f,f==null?void 0:f.hiddenText);b&&DrawUtils.drawText(this.canvas,{x:v.x+x/2,y:v.y-x-4},b,{textAlign:"center",color:m.stroke}),P&&DrawUtils.drawText(this.canvas,{x:v.x+x,y:v.y+x+24},P,__spreadValues$3({color:m.stroke},DEFAULT_TEXT_OFFSET));break}case"text":{const f=t.annotation,{text:v,x:m,y:x,textMaxWidth:b,color:P="white",background:w="rgba(0, 0, 0, 0.6)",lineHeight:L=25,font:R=DEFAULT_FONT,position:C}=f,D=10,O=10,E=AxisUtils.changePointByZoom({x:m,y:x},this.zoom,this.currentPos),{width:H,height:M,fontHeight:S=0}=MathUtils.getTextArea(this.canvas,f.text,b,R,L);if(C==="rt")break;DrawUtils.drawRectWithFill(this.canvas,{x:E.x,y:E.y,width:H+O*2,height:M+D*2,id:"",sourceID:"",valid:!0,textAttribute:"",attribute:""},{color:w}),DrawUtils.drawText(this.canvas,{x:E.x+O,y:E.y+S+D},v,{color:P,lineHeight:L,font:R,textMaxWidth:b});break}default:}(p=(g=t.annotation)==null?void 0:g.renderEnhance)==null||p.call(g,{ctx:this.ctx,canvas:this.canvas,currentPos:this.currentPos,zoom:this.zoom,data:t,toolInstance:this})})}catch(t){console.error("ViewOperation Render Error",t)}}}var __defProp$3=Object.defineProperty,__defProps$1=Object.defineProperties,__getOwnPropDescs$1=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$2=Object.getOwnPropertySymbols,__hasOwnProp$2=Object.prototype.hasOwnProperty,__propIsEnum$2=Object.prototype.propertyIsEnumerable,__defNormalProp$3=(r,t,e)=>t in r?__defProp$3(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$2=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$2.call(t,e)&&__defNormalProp$3(r,e,t[e]);if(__getOwnPropSymbols$2)for(var e of __getOwnPropSymbols$2(t))__propIsEnum$2.call(t,e)&&__defNormalProp$3(r,e,t[e]);return r},__spreadProps$1=(r,t)=>__defProps$1(r,__getOwnPropDescs$1(t));class PointCloud2dOperation extends PolygonOperation{constructor(){super(...arguments);this.selectedIDs=[],this.rightMouseUp=t=>{if(this.drawingPointList.length>0){this.addDrawingPointToPolygonList();return}t.ctrlKey&&this.hoverID?this.emit("addSelectedIDs",this.hoverID):this.emit("setSelectedIDs",this.hoverID)},this.onKeyDown=()=>{},this.onKeyUp=()=>{},this.renderSingleSelectedPolygon=t=>{var e;if(this.selectedPolygons){const i=this.getColor(t.attribute),s=StyleUtils.getStrokeAndFill(i,t.valid,{isSelected:!0}),n=AxisUtils.changePointListByZoom(t.pointList,this.zoom,this.currentPos);DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,n,{fillColor:"transparent",strokeColor:s.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!0,lineType:(e=this.config)==null?void 0:e.lineType}),t.isRect===!0&&this.renderRectPolygonDirection(n)}}}get getSelectedIDs(){return this.selectedIDs}setSelectedIDs(t){this.selectedIDs=t,this.setSelectedID(this.selectedIDs.length===1?this.selectedIDs[0]:""),this.render()}deleteSelectedID(){super.deleteSelectedID(),this.selectedIDs=[],this.emit("deleteSelectedIDs")}get selectedPolygons(){return PolygonUtils.getPolygonByIDs(this.polygonList,this.selectedIDs)}getLineColor(){return"rgba(0, 255, 255, 0.5)"}renderStaticPolygon(){var t;this.isHidden===!1&&((t=this.polygonList)==null||t.forEach(e=>{var i,s,n;if([...this.selectedIDs,this.editPolygonID].includes(e.id))return;const{attribute:o}=e,a=this.getColor(o),l=StyleUtils.getStrokeAndFill(a,e.valid),h=AxisUtils.changePointListByZoom(e.pointList||[],this.zoom,this.currentPos);DrawUtils.drawPolygonWithFillAndLine(this.canvas,h,{fillColor:"transparent",strokeColor:l.stroke,pointColor:"white",thickness:(s=(i=this.style)==null?void 0:i.width)!=null?s:2,lineCap:"round",isClose:!0,lineType:(n=this.config)==null?void 0:n.lineType}),e.isRect===!0&&this.renderRectPolygonDirection(h)}))}renderSelectedPolygon(){var t;(t=this.selectedPolygons)==null||t.forEach(e=>{this.renderSingleSelectedPolygon(e)})}renderRectPolygonDirection(t){t.length<2||DrawUtils.drawLine(this.canvas,t[0],t[1],{color:"red",thickness:3})}get currentPolygonListByPattern(){return this.polygonList.filter(t=>this.pattern===EPolygonPattern.Rect?t.isRect===!0:this.pattern===EPolygonPattern.Normal?t.isRect!==!0:!0)}getHoverID(t){var e;const i=this.getCoordinateUnderZoom(t),n=this.currentPolygonListByPattern.map(o=>__spreadProps$1(__spreadValues$2({},o),{pointList:AxisUtils.changePointListByZoom(o.pointList,this.zoom)}));return PolygonUtils.getHoverPolygonID(i,n,10,(e=this.config)==null?void 0:e.lineType)}switchToNextPolygon(t=ESortDirection.ascend){if(this.drawingPointList.length>0)return;const e=this.currentPolygonListByPattern.map(s=>{var n,o,a,l;return __spreadProps$1(__spreadValues$2({},s),{x:(o=(n=s.pointList[0])==null?void 0:n.x)!=null?o:0,y:(l=(a=s.pointList[0])==null?void 0:a.y)!=null?l:0})}),i=CommonToolUtils$1.getNextSelectedRectID(e,t,this.selectedID);i&&this.setSelectedID(i.id),this.render()}setSelectedIdAfterAddingDrawing(t){this.drawingPointList.length!==0&&this.setSelectedID(t)}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render()}}const ANNOTATION_TYPE={0:"\u76EE\u6807\u68C0\u6D4B",1:"\u56FE\u50CF\u5206\u7C7B"},ANNOTATION_STATUS={0:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u4E2D",1:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u91CD\u8BD5",2:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u5931\u8D25",3:"\u6807\u6CE8\u4E2D",4:"\u4EFB\u52A1\u7EC8\u6B62",5:"\u4EFB\u52A1\u5B8C\u6210",6:"\u6570\u636E\u5DF2\u53D1\u5E03"};var EAnnotationStatus;(function(r){r[r.Upload=0]="Upload",r[r.UploadRetry=1]="UploadRetry",r[r.UploadFail=2]="UploadFail",r[r.Annotation=3]="Annotation",r[r.Terminated=4]="Terminated",r[r.Finish=5]="Finish",r[r.Publish=6]="Publish"})(EAnnotationStatus||(EAnnotationStatus={}));var annotationTask=Object.freeze({__proto__:null,ANNOTATION_TYPE,ANNOTATION_STATUS,get EAnnotationStatus(){return EAnnotationStatus}}),__defProp$2=Object.defineProperty,__getOwnPropSymbols$1=Object.getOwnPropertySymbols,__hasOwnProp$1=Object.prototype.hasOwnProperty,__propIsEnum$1=Object.prototype.propertyIsEnumerable,__defNormalProp$2=(r,t,e)=>t in r?__defProp$2(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$1=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$1.call(t,e)&&__defNormalProp$2(r,e,t[e]);if(__getOwnPropSymbols$1)for(var e of __getOwnPropSymbols$1(t))__propIsEnum$1.call(t,e)&&__defNormalProp$2(r,e,t[e]);return r};const TEXT_ATTRIBUTE_OFFSET={x:8,y:26},newScope=2;class CheckOperation extends BasicToolOperation{constructor(t){super(t);this.getHoverRectID=e=>{var i,s;const n=this.getCoordinateUnderZoom(e),o=(s=(i=this.resultList.find(a=>a.toolName===EToolName.Rect))==null?void 0:i.result)!=null?s:[];if(o.length>0){const a=o.filter(l=>RectUtils.isInRect(n,l,newScope,this.zoom));if(a.length===0)return"";if(a.length===1)return a[0].id;if(a.length>1)return a.map(h=>({size:h.width*h.height,id:h.id})).sort((h,d)=>h.size-d.size)[0].id}return""},this.resultList=[],this.hoverID=[],this.fillID=[],this.render=this.render.bind(this),this.drawPolygon=this.drawPolygon.bind(this),this.drawRect=this.drawRect.bind(this),this.drawTag=this.drawTag.bind(this),this.setShowDefaultCursor(!0),this.forbidOperation=!0}onMouseDown(t){var e,i;if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return!0;const s=this.mouseHoverID,n=(i=(e=this.resultList.find(o=>o.toolName===EToolName.Rect))==null?void 0:e.result)!=null?i:[];if(t.button===0){let o=[s],a=!0;s&&n.find(l=>l.id===s&&(l==null?void 0:l.isSelected))&&(a=!1),s||(o=n.map(l=>l.id),a=!1),this.emit("setSelectedID",o,a),this.render()}}updateRotate(){}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.mouseHoverID,i=this.getHoverRectID(t);if(e!==i){this.mouseHoverID=i;let s=[i];i||(s=[]),this.emit("setHoverID",s),this.render()}}setResult(t){this.resultList=_.cloneDeep(t),this.render()}drawPolygon(t,e){t==null||t.forEach(i=>{var s,n,o,a,l;const h=this.getColor(i.attribute,e),d=StyleUtils.getStrokeAndFill(h,i.valid);let u=(n=(s=this.style)==null?void 0:s.width)!=null?n:2;this.hoverID.includes(i.id)?(u=4,DrawUtils.drawPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(i.pointList,this.zoom,this.currentPos),{fillColor:d.fill,strokeColor:d.stroke,pointColor:"white",thickness:u,lineCap:"round",isClose:!0,lineType:e==null?void 0:e.lineType})):DrawUtils.drawPolygon(this.canvas,AxisUtils.changePointListByZoom(i.pointList,this.zoom,this.currentPos),{color:d.fill,lineType:(o=this.config)==null?void 0:o.lineType,thickness:u,isClose:!0});let c=`${(l=AttributeUtils.getAttributeShowText(i.attribute,(a=e==null?void 0:e.attributeList)!=null?a:[]))!=null?l:""}`;(e==null?void 0:e.isShowOrder)&&(i==null?void 0:i.order)>0&&(c=`${i.order} ${c}`),DrawUtils.drawText(this.canvas,AxisUtils.changePointByZoom(i.pointList[0],this.zoom,this.currentPos),c,__spreadValues$1({color:d.stroke},DEFAULT_TEXT_OFFSET));const g=AxisUtils.changePointListByZoom(i.pointList||[],this.zoom,this.currentPos),p=g[g.length-1];DrawUtils.drawText(this.canvas,{x:p.x+TEXT_ATTRIBUTE_OFFSET.x,y:p.y+TEXT_ATTRIBUTE_OFFSET.y},i==null?void 0:i.textAttribute,__spreadValues$1({color:d.stroke},DEFAULT_TEXT_OFFSET))})}drawRect(t,e){t==null||t.forEach(i=>{let s=1;this.hoverID.includes(i.id)&&(s=3);const n=this.getColor(i.attribute,e),o=AxisUtils.changeRectByZoom(i,this.zoom,this.currentPos);DrawUtils.drawRect(this.canvas,o,{color:(i==null?void 0:i.valid)?n.valid.stroke:n.invalid.stroke,thickness:s}),this.fillID.includes(i.id)&&DrawUtils.drawRectWithFill(this.canvas,o,{color:(i==null?void 0:i.valid)?n.valid.fill:n.invalid.fill})})}drawTag(t,e){const i=t.reduce((s,n)=>[...s,...(e==null?void 0:e.inputList)?TagUtil.getTagNameList(n.result,e.inputList):TagUtil.getTagnameListWithoutConfig(n.result)],[]);DrawUtils.drawTag(this.canvas,i)}setHoverID(t){this.hoverID=t,this.render()}setFillID(t){this.fillID=t,this.render()}render(){var t;super.render(),(t=this.resultList)==null||t.forEach(e=>{switch(e==null?void 0:e.toolName){case EToolName.Rect:this.drawRect(e.result,CommonToolUtils$1.jsonParser(e.config));break;case EToolName.Polygon:this.drawPolygon(e.result,CommonToolUtils$1.jsonParser(e.config));break;case EToolName.Tag:this.drawTag(e.result,CommonToolUtils$1.jsonParser(e.config));break}})}exportData(){return[[],{}]}}var __async$2=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});class SegmentByRect extends RectOperation{constructor(t){super(t);this.onKeydown=e=>{switch(e.keyCode){case EKeyCode$1.Esc:e.preventDefault(),e.stopPropagation(),this.clearPredictionInfo();break;case EKeyCode$1.Z:e.ctrlKey&&(e.preventDefault(),e.stopPropagation(),this.rectList=[],this.render());break}},this.segmentPrediction=e=>__async$2(this,null,function*(){const i=this.getCoordinateUnderZoom(e);if(this.isRunSegment=!0,this.render(),!this.runPrediction){this.emit("messageError","You needs to set runPrediction function"),this.clearPredictionInfo();return}yield this.runPrediction({point:i,rect:{x:this.rectList[0].x,y:this.rectList[0].y,w:this.rectList[0].width,h:this.rectList[0].height}}),this.clearPredictionInfo()}),this.isRunSegment=!1,this.runPrediction=t.runPrediction}setRunPrediction(t){this.runPrediction=t}eventBinding(){document.addEventListener("keydown",t=>this.onKeydown(t)),super.eventBinding()}clearPredictionInfo(){this.rectList=[],this.isShowCursor=!1,this.coord={x:-1,y:-1},this.drawingRect=void 0,this.isRunSegment=!1,this.clearCanvas(),this.render()}onMouseUp(t){if(!this.isRunSegment){if(t.button===0&&this.rectList.length===1&&!this.isRunSegment){t.stopPropagation(),this.segmentPrediction(t),this.clearActiveStatus();return}super.onMouseUp(t)}}onMouseDown(t){this.isRunSegment||super.onMouseDown(t)}renderCursorLine(){var t;if(!this.ctx)return;const{ctx:e}=this,i=10,s=1,{x:n,y:o}=this.coord;e.save(),e.strokeStyle="white",e.setLineDash([6]),e.lineWidth=s,e.strokeRect(n-i,o-i,i*2,i*2),e.restore();let a=`\u2460 ${lbUtils.i18n.t("FramingOfObjectToBeDivided")}`;const l=lbUtils.i18n.language==="en";let h=l?326:186;if(((t=this.rectList)==null?void 0:t.length)===1){a=`\u2461 ${lbUtils.i18n.t("ClickOnTarget")}`,h=l?232:142;const d=2;e.save(),e.strokeStyle="white";const u=s+i;e.beginPath(),e.moveTo(n+u+d*2,o+u+d),e.arc(n+u+d,o+u+d,d,0,Math.PI*2,!0),e.stroke(),e.restore()}this.isRunSegment&&(h=l?316:136,a=lbUtils.i18n.t("SplittingAlgorithmPrediction")),e.save(),e.fillStyle=this.style.strokeColor,e.fillRect(n+i,o-i*4-1,h,32),e.restore(),e.save(),e.font="14px Source Han Sans CN",e.fillStyle="white",e.fillText(a,n+i+14,o-i*2),e.restore(),super.renderCursorLine()}renderDrawingRect(t,e,i=!1){if(this.ctx&&t){const s=AxisUtils.changeRectByZoom(t,i?e:this.zoom,this.currentPos),{x:n,y:o,width:a,height:l}=s;this.ctx.save(),this.ctx.lineCap="butt",this.ctx.lineWidth=this.style.strokeWidth,this.ctx.strokeStyle="white",this.ctx.strokeRect(n,o,a,l),this.ctx.strokeStyle=this.style.strokeColor,this.ctx.setLineDash([6]),this.ctx.strokeRect(n,o,a,l),this.ctx.restore()}}renderTextAttribute(){}renderSelectedRect(){}}const getCurrentOperation=r=>{switch(r){case EToolName.Rect:case EToolName.RectTrack:return RectOperation;case EToolName.SegmentByRect:return SegmentByRect;case EToolName.Tag:return TagOperation;case EToolName.Polygon:return PolygonOperation;case ECheckModel.Check:return CheckOperation;case EToolName.Line:return LineToolOperation;case EToolName.Point:return PointOperation;case EToolName.Text:return TextToolOperation;default:throw new Error("not match tool")}};class EnhanceCommonToolUtils extends CommonToolUtils$1{}EnhanceCommonToolUtils.getCurrentOperation=getCurrentOperation;class ImgUtils{static load(t){return new Promise((e,i)=>{const s=new Image;t.startsWith("file")?s.src=encodeURI(t):s.src=t,s.onload=()=>{e(s)},s.onerror=()=>{i(s)}})}}const createEmptyImage$1=r=>{const t=document.createElement("canvas");t.width=r.width,t.height=r.height;const e=t.getContext("2d");return e?(e.fillStyle="transparent",e.fillRect(0,0,r.width,r.height),t.toDataURL()):""},arraySwap=(r,t,e)=>{const i=r[t];return r[t]=r[e],r[e]=i,r},_HybridToolUtils=class{static isSingleTool(r){return!this.isHybridTool(r)}static isHybridTool(r){return Array.isArray(r)}};let HybridToolUtils=_HybridToolUtils;HybridToolUtils.getTopToolName=r=>_HybridToolUtils.isHybridTool(r)?r[r.length-1]:r;class ToolScheduler{constructor(t){this.toolOperationList=[],this.toolOperationDom=[];var e,i;this.init(),this.container=t.container,this.size=t.size,this.imgNode=t.imgNode,this.config=(e=t.config)!=null?e:JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t.toolName))),this.style=(i=t.style)!=null?i:styleDefaultConfig}setImgNode(t,e){this.toolOperationList.forEach(i=>{i.setImgNode(t,e)})}setSize(t){this.toolOperationList.forEach(e=>{e.setSize(t)})}syncPosition(t,e,i,s){this.toolOperationList.forEach(n=>{s!==n&&(n.setCurrentPos(t),n.setZoom(e),n.setImgInfo(i),n.renderBasicCanvas(),n.render())})}get defaultSize(){var t,e;return{width:((t=this.imgNode)==null?void 0:t.width)||this.size.width,height:((e=this.imgNode)==null?void 0:e.height)||this.size.height}}createDom(){const{width:t,height:e}=this.defaultSize,i=window.document.createElement("div");i.style.position="absolute",i.style.left="0",i.style.top="0",i.style.width=`${t}px`,i.style.height=`${e}px`;const s=this.toolOperationList.length+1;return i.style.zIndex=`${s}`,i}getEmptyImage(t,e){const i=createEmptyImage$1({width:t,height:e}),s=new Image;return s.src=i,s}createOperation(t,e,i){var s;const{width:n,height:o}=this.defaultSize,a=this.createDom(),l=this.getEmptyImage(n,o),h={container:a,size:this.size,config:(s=this==null?void 0:this.config)!=null?s:"{}",drawOutSideTarget:!1,style:this.style,imgNode:e||l,hiddenImg:!!t};i&&Object.assign(h,i);let d;if(!t)d=new BasicToolOperation(h),a.style.zIndex="0",d.init();else{const u=getCurrentOperation(t);if(!u)return;d=new u(h)}return d==null||d.init(),d.canvas.id=t!=null?t:"basicCanvas",d.on("dragMove",({currentPos:u,zoom:c,imgInfo:g})=>{this.syncPosition(u,c,g,d)}),d.on("renderZoom",(u,c,g)=>{u&&c&&this.syncPosition(c,u,g,d)}),t?(this.container.appendChild(a),this.toolOperationList.push(d),this.toolOperationDom.push(a),d):(this.container.insertBefore(a,this.container.childNodes[0]),this.toolOperationList.unshift(d),this.toolOperationDom.unshift(a),d)}switchLastTwoCanvas(){if(this.toolOperationDom.length<3){console.error("switchLastTwoCanvas is just used the layer which has 3 canvas");return}const t=this.toolOperationDom.length,e=t-1,i=t-2,s=this.toolOperationDom[e],n=this.toolOperationDom[i];if(!(!n||!s))return s.style.zIndex=`${e-1}`,n.style.zIndex=`${e}`,this.toolOperationList[e].clearActiveStatus(),this.toolOperationList[e].clearCursorLine(),this.toolOperationList[e].render(),this.toolOperationList=arraySwap(this.toolOperationList,e,i),this.toolOperationDom=arraySwap(this.toolOperationDom,e,i),this.toolOperationList[e]}getFirstToolOperation(){return this.toolOperationList.length>1?this.toolOperationList[1]:this.toolOperationList[0]}destroyAllLayer(){this.toolOperationList.forEach(t=>{t.destroyCanvas(),this.init()})}init(){this.toolOperationList=[],this.toolOperationDom=[]}}var __async$1=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const loadImage=r=>new Promise((t,e)=>{const i=document.createElement("img");i.crossOrigin="Anonymous",i.onerror=s=>{console.error(s),e(i)},i.src=r,i.onload=()=>{t(i)}});class AnnotationEngine{constructor(t){this.setImgSrc=s=>__async$1(this,null,function*(){const n=yield loadImage(s);!n||this.setImgNode(n)});var e,i;this.container=t.container,this.size=t.size,this.toolName=t.toolName,this.imgNode=t.imgNode,this.config=(e=t.config)!=null?e:JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t.toolName))),this.style=(i=t.style)!=null?i:styleDefaultConfig,this.toolScheduler=new ToolScheduler(t),this.i18nLanguage="cn",this._initToolOperation()}setToolName(t,e){this.toolName=t;const i=e||JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t)));this.config=i,this._initToolOperation()}setImgNode(t,e){this.toolScheduler.setImgNode(t,e),this.imgNode=t}setSize(t){this.size=t,this.toolScheduler.setSize(t)}setStyle(t){this.style=t}_initToolOperation(){this.toolScheduler.destroyAllLayer();let t=[];const e={hiddenImg:!0};HybridToolUtils.isSingleTool(this.toolName)?(t=[this.toolName],Object.assign(e,{hiddenImg:!1})):t=this.toolName,t.length>1&&this.toolScheduler.createOperation(void 0,this.imgNode),t.forEach((i,s)=>{const n=this.toolScheduler.createOperation(i,void 0,e);s===t.length-1&&(this.toolInstance=n)}),this.setLang(this.i18nLanguage)}setBasicInfo(t,e){this.dependToolName=t,this.basicResult=e,this.toolInstance.setDependName(t),this.toolInstance.setBasicResult(e),this.toolInstance.renderBasicCanvas()}clearBasicResult(){this.setBasicInfo()}forbidOperation(){this.toolInstance.setForbidOperation(!0)}launchOperation(){this.toolInstance.setForbidOperation(!1)}setLang(t){switch(this.i18nLanguage=t,t){case"cn":this.toolInstance.setLang(ELang.Zh);break;case"en":this.toolInstance.setLang(ELang.US);break}}setDataInjectionAtCreation(t){this.toolInstance.setDataInjectionAtCreation(t)}setRenderEnhance(t){this.toolInstance.setRenderEnhance(t)}switchLastTwoCanvas(){const t=this.toolScheduler.switchLastTwoCanvas();if(t)return this.toolInstance=t,t}get firstToolInstance(){return this.toolScheduler.getFirstToolOperation()}setCustomRenderStyle(t){this.toolInstance.setCustomRenderStyle(t)}}class PCDLoader extends THREE.Loader{constructor(t){super(t);this.littleEndian=!0}load(t,e,i,s){const n=this,o=new THREE.FileLoader(n.manager);o.setPath(n.path),o.setResponseType("arraybuffer"),o.setRequestHeader(n.requestHeader),o.setWithCredentials(n.withCredentials),o.load(t,function(a){try{e(n.parse(a))}catch(l){s?s(l):console.error(l),n.manager.itemError(t)}},i,s)}parse(t){function e(u,c){const g=u.length,p=new Uint8Array(c);let f=0,v=0,m,x,b;do if(m=u[f++],m<1<<5){if(m++,v+m>c)throw new Error("Output buffer is not large enough");if(f+m>g)throw new Error("Invalid compressed data");do p[v++]=u[f++];while(--m)}else{if(x=m>>5,b=v-((m&31)<<8)-1,f>=g)throw new Error("Invalid compressed data");if(x===7&&(x+=u[f++],f>=g))throw new Error("Invalid compressed data");if(b-=u[f++],v+x+2>c)throw new Error("Output buffer is not large enough");if(b<0)throw new Error("Invalid compressed data");if(b>=v)throw new Error("Invalid compressed data");do p[v++]=p[b++];while(--x+2)}while(f<g);return p}function i(u){const c={},g=u.search(/[\n\r]data\s(\S*)\s/i),p=/[\n\r]data\s(\S*)\s/i.exec(u.slice(g-1));if(c.data=p[1],c.headerLen=p[0].length+g,c.str=u.slice(0,c.headerLen),c.str=c.str.replace(/#.*/gi,""),c.version=/version (.*)/i.exec(c.str),c.fields=/fields (.*)/i.exec(c.str),c.size=/size (.*)/i.exec(c.str),c.type=/type (.*)/i.exec(c.str),c.count=/count (.*)/i.exec(c.str),c.width=/width (.*)/i.exec(c.str),c.height=/height (.*)/i.exec(c.str),c.viewpoint=/viewpoint (.*)/i.exec(c.str),c.points=/points (.*)/i.exec(c.str),c.version!==null&&(c.version=parseFloat(c.version[1])),c.fields=c.fields!==null?c.fields[1].split(" "):[],c.type!==null&&(c.type=c.type[1].split(" ")),c.width!==null&&(c.width=parseInt(c.width[1])),c.height!==null&&(c.height=parseInt(c.height[1])),c.viewpoint!==null&&(c.viewpoint=c.viewpoint[1]),c.points!==null&&(c.points=parseInt(c.points[1],10)),c.points===null&&(c.points=c.width*c.height),c.size!==null&&(c.size=c.size[1].split(" ").map(function(v){return parseInt(v,10)})),c.count!==null)c.count=c.count[1].split(" ").map(function(v){return parseInt(v,10)});else{c.count=[];for(let v=0,m=c.fields.length;v<m;v++)c.count.push(1)}c.offset={};let f=0;for(let v=0,m=c.fields.length;v<m;v++)c.data==="ascii"?c.offset[c.fields[v]]=v:(c.offset[c.fields[v]]=f,f+=c.size[v]*c.count[v]);return c.rowSize=f,c}const s=THREE.LoaderUtils.decodeText(new Uint8Array(t)),n=i(s),o=[],a=[],l=[];if(n.data==="ascii"){const{offset:u}=n,g=s.slice(n.headerLen).split(`
|
|
97
|
-
`);for(let p=0,f=g.length;p<f;p++){if(g[p]==="")continue;const v=g[p].split(" ");if(u.x!==void 0&&(o.push(parseFloat(v[u.x])),o.push(parseFloat(v[u.y])),o.push(parseFloat(v[u.z]))),this.genColorByCoord){const x=this.genColorByCoord(parseFloat(v[u.x]),parseFloat(v[u.y]),parseFloat(v[u.z])).map(b=>b/255);l.push(...x)}u.normal_x!==void 0&&(a.push(parseFloat(v[u.normal_x])),a.push(parseFloat(v[u.normal_y])),a.push(parseFloat(v[u.normal_z])))}}if(n.data==="binary_compressed"){const u=new Uint32Array(t.slice(n.headerLen,n.headerLen+8)),c=u[0],g=u[1],p=e(new Uint8Array(t,n.headerLen+8,c),g),f=new DataView(p.buffer),{offset:v}=n;for(let m=0;m<n.points;m++)if(v.x!==void 0&&(o.push(f.getFloat32(n.points*v.x+n.size[0]*m,this.littleEndian)),o.push(f.getFloat32(n.points*v.y+n.size[1]*m,this.littleEndian)),o.push(f.getFloat32(n.points*v.z+n.size[2]*m,this.littleEndian))),v.normal_x!==void 0&&(a.push(f.getFloat32(n.points*v.normal_x+n.size[4]*m,this.littleEndian)),a.push(f.getFloat32(n.points*v.normal_y+n.size[5]*m,this.littleEndian)),a.push(f.getFloat32(n.points*v.normal_z+n.size[6]*m,this.littleEndian))),this.genColorByCoord){const b=this.genColorByCoord(f.getFloat32(n.points*v.x+n.size[0]*m,this.littleEndian),f.getFloat32(n.points*v.y+n.size[0]*m,this.littleEndian),f.getFloat32(n.points*v.z+n.size[0]*m,this.littleEndian)).map(P=>P/255);l.push(...b)}}if(n.data==="binary"){const u=new DataView(t,n.headerLen),{offset:c}=n;for(let g=0,p=0;g<n.points;g++,p+=n.rowSize)if(c.x!==void 0&&(o.push(u.getFloat32(p+c.x,this.littleEndian)),o.push(u.getFloat32(p+c.y,this.littleEndian)),o.push(u.getFloat32(p+c.z,this.littleEndian))),c.normal_x!==void 0&&(a.push(u.getFloat32(p+c.normal_x,this.littleEndian)),a.push(u.getFloat32(p+c.normal_y,this.littleEndian)),a.push(u.getFloat32(p+c.normal_z,this.littleEndian))),this.genColorByCoord){const v=this.genColorByCoord(u.getFloat32(p+c.x,this.littleEndian),u.getFloat32(p+c.y,this.littleEndian),u.getFloat32(p+c.z,this.littleEndian)).map(m=>m/255);l.push(...v)}}const h=new THREE.BufferGeometry;o.length>0&&h.setAttribute("position",new THREE.Float32BufferAttribute(o,3)),a.length>0&&h.setAttribute("normal",new THREE.Float32BufferAttribute(a,3)),l.length>0&&h.setAttribute("color",new THREE.Float32BufferAttribute(l,3)),h.computeBoundingSphere();const d=new THREE.PointsMaterial({size:.01});return l.length>0?d.vertexColors=!0:d.color.setHex(16777215),new THREE.Points(h,d)}genColorByCoord(t,e,i){return i<=0?[128,128,128]:i<5?[255,0,0]:i<10?[0,255,0]:[0,0,255]}}var __defProp$1=Object.defineProperty,__defNormalProp$1=(r,t,e)=>t in r?__defProp$1(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__publicField=(r,t,e)=>(__defNormalProp$1(r,typeof t!="symbol"?t+"":t,e),e);const _changeEvent={type:"change"},_startEvent={type:"start"},_endEvent={type:"end"};class OrbitControls extends THREE.EventDispatcher{constructor(t,e){super();__publicField(this,"listenToKeyEvents",y=>{y.addEventListener("keydown",onKeyDown),this._domElementKeyEvents=y}),e===void 0&&console.warn('THREE.OrbitControls: The second parameter "domElement" is now mandatory.'),e===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.object=t,this.domElement=e,this.domElement.style.touchAction="none",this.enabled=!0,this.target=new THREE.Vector3,this.minDistance=0,this.maxDistance=Infinity,this.minZoom=0,this.maxZoom=Infinity,this.minPolarAngle=0,this.maxPolarAngle=Math.PI,this.minAzimuthAngle=-Infinity,this.maxAzimuthAngle=Infinity,this.enableDamping=!1,this.dampingFactor=.05,this.enableZoom=!0,this.zoomSpeed=1,this.enableRotate=!0,this.rotateSpeed=1,this.enablePan=!0,this.panSpeed=1,this.screenSpacePanning=!0,this.keyPanSpeed=7,this.autoRotate=!1,this.autoRotateSpeed=2,this.keys={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",BOTTOM:"ArrowDown"},this.mouseButtons={LEFT:THREE.MOUSE.ROTATE,MIDDLE:THREE.MOUSE.DOLLY,RIGHT:THREE.MOUSE.PAN},this.touches={ONE:THREE.TOUCH.ROTATE,TWO:THREE.TOUCH.DOLLY_PAN},this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object.zoom,this._domElementKeyEvents=null,this.getPolarAngle=function(){return a.phi},this.getAzimuthalAngle=function(){return a.theta},this.getDistance=function(){return this.object.position.distanceTo(this.target)},this.saveState=function(){i.target0.copy(i.target),i.position0.copy(i.object.position),i.zoom0=i.object.zoom},this.reset=function(){i.target.copy(i.target0),i.object.position.copy(i.position0),i.object.zoom=i.zoom0,i.object.updateProjectionMatrix(),i.dispatchEvent(_changeEvent),i.update(),n=s.NONE},this.update=function(){const y=new THREE.Vector3,I=new THREE.Quaternion().setFromUnitVectors(t.up,new THREE.Vector3(0,1,0)),T=I.clone().invert(),A=new THREE.Vector3,k=new THREE.Quaternion,z=2*Math.PI;return function(){const{position:rt}=i.object;y.copy(rt).sub(i.target),y.applyQuaternion(I),a.setFromVector3(y),i.autoRotate&&n===s.NONE&&D(R()),i.enableDamping?(a.theta+=l.theta*i.dampingFactor,a.phi+=l.phi*i.dampingFactor):(a.theta+=l.theta,a.phi+=l.phi);let B=i.minAzimuthAngle,N=i.maxAzimuthAngle;return isFinite(B)&&isFinite(N)&&(B<-Math.PI?B+=z:B>Math.PI&&(B-=z),N<-Math.PI?N+=z:N>Math.PI&&(N-=z),B<=N?a.theta=Math.max(B,Math.min(N,a.theta)):a.theta=a.theta>(B+N)/2?Math.max(B,a.theta):Math.min(N,a.theta)),a.phi=Math.max(i.minPolarAngle,Math.min(i.maxPolarAngle,a.phi)),a.makeSafe(),a.radius*=h,a.radius=Math.max(i.minDistance,Math.min(i.maxDistance,a.radius)),i.enableDamping===!0?i.target.addScaledVector(d,i.dampingFactor):i.target.add(d),y.setFromSpherical(a),y.applyQuaternion(T),rt.copy(i.target).add(y),i.object.lookAt(i.target),i.enableDamping===!0?(l.theta*=1-i.dampingFactor,l.phi*=1-i.dampingFactor,d.multiplyScalar(1-i.dampingFactor)):(l.set(0,0,0),d.set(0,0,0)),h=1,u||A.distanceToSquared(i.object.position)>o||8*(1-k.dot(i.object.quaternion))>o?(i.dispatchEvent(_changeEvent),A.copy(i.object.position),k.copy(i.object.quaternion),u=!1,!0):!1}}(),this.dispose=function(){i.domElement.removeEventListener("contextmenu",it),i.domElement.removeEventListener("pointerdown",Q),i.domElement.removeEventListener("pointercancel",tt),i.domElement.removeEventListener("wheel",et),i.domElement.removeEventListener("pointermove",U),i.domElement.removeEventListener("pointerup",Z),i._domElementKeyEvents!==null&&i._domElementKeyEvents.removeEventListener("keydown",mt)};const i=this,s={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6};let n=s.NONE;const o=1e-6,a=new THREE.Spherical,l=new THREE.Spherical;let h=1;const d=new THREE.Vector3;let u=!1;const c=new THREE.Vector2,g=new THREE.Vector2,p=new THREE.Vector2,f=new THREE.Vector2,v=new THREE.Vector2,m=new THREE.Vector2,x=new THREE.Vector2,b=new THREE.Vector2,P=new THREE.Vector2,w=[],L={};function R(){return 2*Math.PI/60/60*i.autoRotateSpeed}function C(){return Math.pow(.95,i.zoomSpeed)}function D(y){l.theta-=y}function O(y){l.phi-=y}const E=function(){const y=new THREE.Vector3;return function(T,A){y.setFromMatrixColumn(A,0),y.multiplyScalar(-T),d.add(y)}}(),H=function(){const y=new THREE.Vector3;return function(T,A){i.screenSpacePanning===!0?y.setFromMatrixColumn(A,1):(y.setFromMatrixColumn(A,0),y.crossVectors(i.object.up,y)),y.multiplyScalar(T),d.add(y)}}(),M=function(){const y=new THREE.Vector3;return function(T,A){const k=i.domElement;if(i.object.isPerspectiveCamera){const{position:z}=i.object;y.copy(z).sub(i.target);let $=y.length();$*=Math.tan(i.object.fov/2*Math.PI/180),E(2*T*$/k.clientHeight,i.object.matrix),H(2*A*$/k.clientHeight,i.object.matrix)}else i.object.isOrthographicCamera?(E(T*(i.object.right-i.object.left)/i.object.zoom/k.clientWidth,i.object.matrix),H(A*(i.object.top-i.object.bottom)/i.object.zoom/k.clientHeight,i.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),i.enablePan=!1)}}();function S(y){i.object.isPerspectiveCamera?h/=y:i.object.isOrthographicCamera?(i.object.zoom=Math.max(i.minZoom,Math.min(i.maxZoom,i.object.zoom*y)),i.object.updateProjectionMatrix(),u=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),i.enableZoom=!1)}function F(y){i.object.isPerspectiveCamera?h*=y:i.object.isOrthographicCamera?(i.object.zoom=Math.max(i.minZoom,Math.min(i.maxZoom,i.object.zoom/y)),i.object.updateProjectionMatrix(),u=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),i.enableZoom=!1)}function j(y){c.set(y.clientX,y.clientY)}function ot(y){x.set(y.clientX,y.clientY)}function W(y){f.set(y.clientX,y.clientY)}function at(y){g.set(y.clientX,y.clientY),p.subVectors(g,c).multiplyScalar(i.rotateSpeed);const I=i.domElement;D(2*Math.PI*p.x/I.clientHeight),O(2*Math.PI*p.y/I.clientHeight),c.copy(g),i.update()}function lt(y){b.set(y.clientX,y.clientY),P.subVectors(b,x),P.y>0?S(C()):P.y<0&&F(C()),x.copy(b),i.update()}function ht(y){v.set(y.clientX,y.clientY),m.subVectors(v,f).multiplyScalar(i.panSpeed),M(m.x,m.y),f.copy(v),i.update()}function ct(y){y.deltaY<0?F(C()):y.deltaY>0&&S(C()),i.update()}function dt(y){let I=!1;switch(y.code){case i.keys.UP:M(0,i.keyPanSpeed),I=!0;break;case i.keys.BOTTOM:M(0,-i.keyPanSpeed),I=!0;break;case i.keys.LEFT:M(i.keyPanSpeed,0),I=!0;break;case i.keys.RIGHT:M(-i.keyPanSpeed,0),I=!0;break}I&&(y.preventDefault(),i.update())}function X(){if(w.length===1)c.set(w[0].pageX,w[0].pageY);else{const y=.5*(w[0].pageX+w[1].pageX),I=.5*(w[0].pageY+w[1].pageY);c.set(y,I)}}function Y(){if(w.length===1)f.set(w[0].pageX,w[0].pageY);else{const y=.5*(w[0].pageX+w[1].pageX),I=.5*(w[0].pageY+w[1].pageY);f.set(y,I)}}function K(){const y=w[0].pageX-w[1].pageX,I=w[0].pageY-w[1].pageY,T=Math.sqrt(y*y+I*I);x.set(0,T)}function ut(){i.enableZoom&&K(),i.enablePan&&Y()}function gt(){i.enableZoom&&K(),i.enableRotate&&X()}function G(y){if(w.length==1)g.set(y.pageX,y.pageY);else{const T=V(y),A=.5*(y.pageX+T.x),k=.5*(y.pageY+T.y);g.set(A,k)}p.subVectors(g,c).multiplyScalar(i.rotateSpeed);const I=i.domElement;D(2*Math.PI*p.x/I.clientHeight),O(2*Math.PI*p.y/I.clientHeight),c.copy(g)}function q(y){if(w.length===1)v.set(y.pageX,y.pageY);else{const I=V(y),T=.5*(y.pageX+I.x),A=.5*(y.pageY+I.y);v.set(T,A)}m.subVectors(v,f).multiplyScalar(i.panSpeed),M(m.x,m.y),f.copy(v)}function J(y){const I=V(y),T=y.pageX-I.x,A=y.pageY-I.y,k=Math.sqrt(T*T+A*A);b.set(0,k),P.set(0,Math.pow(b.y/x.y,i.zoomSpeed)),S(P.y),x.copy(b)}function ft(y){i.enableZoom&&J(y),i.enablePan&&q(y)}function pt(y){i.enableZoom&&J(y),i.enableRotate&&G(y)}function Q(y){i.enabled!==!1&&(w.length===0&&(i.domElement.setPointerCapture(y.pointerId),i.domElement.addEventListener("pointermove",U),i.domElement.addEventListener("pointerup",Z)),wt(y),y.pointerType==="touch"?xt(y):vt(y))}function U(y){i.enabled!==!1&&(y.pointerType==="touch"?bt(y):yt(y))}function Z(y){st(y),w.length===0&&(i.domElement.releasePointerCapture(y.pointerId),i.domElement.removeEventListener("pointermove",U),i.domElement.removeEventListener("pointerup",Z)),i.dispatchEvent(_endEvent),n=s.NONE}function tt(y){st(y)}function vt(y){let I;switch(y.button){case 0:I=i.mouseButtons.LEFT;break;case 1:I=i.mouseButtons.MIDDLE;break;case 2:I=i.mouseButtons.RIGHT;break;default:I=-1}switch(I){case THREE.MOUSE.DOLLY:if(i.enableZoom===!1)return;ot(y),n=s.DOLLY;break;case THREE.MOUSE.ROTATE:if(y.ctrlKey||y.metaKey||y.shiftKey){if(i.enablePan===!1)return;W(y),n=s.PAN}else{if(i.enableRotate===!1)return;j(y),n=s.ROTATE}break;case THREE.MOUSE.PAN:if(y.ctrlKey||y.metaKey||y.shiftKey){if(i.enableRotate===!1)return;j(y),n=s.ROTATE}else{if(i.enablePan===!1)return;W(y),n=s.PAN}break;default:n=s.NONE}n!==s.NONE&&i.dispatchEvent(_startEvent)}function yt(y){if(i.enabled!==!1)switch(n){case s.ROTATE:if(i.enableRotate===!1)return;at(y);break;case s.DOLLY:if(i.enableZoom===!1)return;lt(y);break;case s.PAN:if(i.enablePan===!1)return;ht(y);break}}function et(y){i.enabled===!1||i.enableZoom===!1||n!==s.NONE||(y.preventDefault(),i.dispatchEvent(_startEvent),ct(y),i.dispatchEvent(_endEvent))}function mt(y){i.enabled===!1||i.enablePan===!1||dt(y)}function xt(y){switch(nt(y),w.length){case 1:switch(i.touches.ONE){case THREE.TOUCH.ROTATE:if(i.enableRotate===!1)return;X(),n=s.TOUCH_ROTATE;break;case THREE.TOUCH.PAN:if(i.enablePan===!1)return;Y(),n=s.TOUCH_PAN;break;default:n=s.NONE}break;case 2:switch(i.touches.TWO){case THREE.TOUCH.DOLLY_PAN:if(i.enableZoom===!1&&i.enablePan===!1)return;ut(),n=s.TOUCH_DOLLY_PAN;break;case THREE.TOUCH.DOLLY_ROTATE:if(i.enableZoom===!1&&i.enableRotate===!1)return;gt(),n=s.TOUCH_DOLLY_ROTATE;break;default:n=s.NONE}break;default:n=s.NONE}n!==s.NONE&&i.dispatchEvent(_startEvent)}function bt(y){switch(nt(y),n){case s.TOUCH_ROTATE:if(i.enableRotate===!1)return;G(y),i.update();break;case s.TOUCH_PAN:if(i.enablePan===!1)return;q(y),i.update();break;case s.TOUCH_DOLLY_PAN:if(i.enableZoom===!1&&i.enablePan===!1)return;ft(y),i.update();break;case s.TOUCH_DOLLY_ROTATE:if(i.enableZoom===!1&&i.enableRotate===!1)return;pt(y),i.update();break;default:n=s.NONE}}function it(y){i.enabled!==!1&&y.preventDefault()}function wt(y){w.push(y)}function st(y){delete L[y.pointerId];for(let I=0;I<w.length;I++)if(w[I].pointerId==y.pointerId){w.splice(I,1);return}}function nt(y){let I=L[y.pointerId];I===void 0&&(I=new THREE.Vector2,L[y.pointerId]=I),I.set(y.pageX,y.pageY)}function V(y){const I=y.pointerId===w[0].pointerId?w[1]:w[0];return L[I.pointerId]}i.domElement.addEventListener("contextmenu",it),i.domElement.addEventListener("pointerdown",Q),i.domElement.addEventListener("pointercancel",tt),i.domElement.addEventListener("wheel",et,{passive:!1}),this.update()}}class PointCloudCache{constructor(){this.MAX_SIZE=50,this.cacheList=[],this.loadPCDFile=t=>new Promise((e,i)=>{var s;if(this.pointsMap.get(t)){const n=(s=this.pointsMap.get(t))==null?void 0:s.clone();e(n);return}if(this.cacheList.length>this.MAX_SIZE){const n=this.cacheList.shift();n&&this.pointsMap.delete(n.src)}this.cacheList.push({src:t}),this.pcdLoader.load(t,n=>{this.pointsMap.set(t,n.clone()),e(n)},()=>{},n=>{i(n)})}),this.pcdLoader=new PCDLoader,this.pointsMap=new Map}static getInstance(){return this.instance==null&&(this.instance=new PointCloudCache),this.instance}}var __defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(r,t,e)=>t in r?__defProp(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues=(r,t)=>{for(var e in t||(t={}))__hasOwnProp.call(t,e)&&__defNormalProp(r,e,t[e]);if(__getOwnPropSymbols)for(var e of __getOwnPropSymbols(t))__propIsEnum.call(t,e)&&__defNormalProp(r,e,t[e]);return r},__spreadProps=(r,t)=>__defProps(r,__getOwnPropDescs(t)),__async=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const DEFAULT_DISTANCE=30;class PointCloud{constructor({container:t,noAppend:e,isOrthographicCamera:i,orthographicParams:s,backgroundColor:n="black"}){this.zAxisLimit=10,this.initCameraPosition=new THREE__namespace.Vector3(-1,0,10),this.isOrthographicCamera=!1,this.pointsUuid="",this.pointCloudObjectName="pointCloud",this.rangeObjectName="range",this.AddBoxToSense=(o,a=16777215)=>{var l;const h=(l=o.id)!=null?l:uuid();this.removeObjectByName(h);const{center:d,width:u,height:c,depth:g,rotation:p}=o,f=new THREE__namespace.Group,v=new THREE__namespace.BoxGeometry(u,c,g),m=new THREE__namespace.MeshBasicMaterial({color:"blue"}),x=new THREE__namespace.Mesh(v,m),b=new THREE__namespace.BoxHelper(x,a),P=this.generateBoxArrow(o),w=this.generateBoxTrackID(o);f.add(b),f.add(P),f.add(w),f.position.set(d.x,d.y,d.z),f.rotation.set(0,0,p),f.name=h,this.scene.add(f)},this.overridePointShader=o=>{o.vertexShader=`
|
|
96
|
+
`),c.addEventListener("wheel",this.wheelChange),this._domMap.set(s.id,c))}}),e.forEach(s=>{i.indexOf(s)===-1&&(this.clearTag(s),this._domMap.delete(s))})}}var __defProp$4=Object.defineProperty,__defProps$2=Object.defineProperties,__getOwnPropDescs$2=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$3=Object.getOwnPropertySymbols,__hasOwnProp$3=Object.prototype.hasOwnProperty,__propIsEnum$3=Object.prototype.propertyIsEnumerable,__defNormalProp$4=(r,t,e)=>t in r?__defProp$4(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$3=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$3.call(t,e)&&__defNormalProp$4(r,e,t[e]);if(__getOwnPropSymbols$3)for(var e of __getOwnPropSymbols$3(t))__propIsEnum$3.call(t,e)&&__defNormalProp$4(r,e,t[e]);return r},__spreadProps$2=(r,t)=>__defProps$2(r,__getOwnPropDescs$2(t));const newScope$1=3,DEFAULT_RADIUS=3,DEFAULT_STROKE_COLOR="#6371FF";class ViewOperation extends BasicToolOperation{constructor(t){super(__spreadProps$2(__spreadValues$3({},t),{showDefaultCursor:!0}));this.style={},this.annotations=[],this.getHoverRectID=i=>{var s,n;const o=this.getCoordinateUnderZoom(i),a=AxisUtils.changePointByZoom(o,1/this.zoom);if(((s=this.annotations)==null?void 0:s.length)<=0||!((n=this.annotations)==null?void 0:n.length))return;let l="",h=Number.MAX_SAFE_INTEGER;for(let c=0;c<this.annotations.length;c++){const u=this.annotations[c];switch(u.type){case"rect":{const d=u.annotation;if(RectUtils.isInRect(o,d,newScope$1,this.zoom)){const g=d.width*d.height;g<h&&(l=d.id,h=g)}break}case"polygon":{const d=u.annotation;if(PolygonUtils.isInPolygon(a,d.pointList)){const g=PolygonUtils.getPolygonArea(d.pointList);g<h&&(l=d.id,h=g)}break}}}return l};var e;this.style=(e=t.style)!=null?e:{stroke:DEFAULT_STROKE_COLOR,thickness:3},this.annotations=t.annotations,this.loading=!1,this.renderDomInstance=new RenderDomClass({container:this.container,height:this.canvas.height})}setLoading(t){this.loading=t,this.render()}onMouseLeave(){super.onMouseLeave(),this.mouseHoverID=void 0,this.emit("onChange","hover",[])}onMouseDown(t){if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return!0;const e=this.mouseHoverID;if(t.button===0){let i=[];e&&(i=[e]),this.emit("onChange","selected",i),this.render()}}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.mouseHoverID,i=this.getHoverRectID(t);if(e!==i){this.mouseHoverID=i;let s=[];i&&(s=[i]),this.emit("onChange","hover",s),this.render()}}updateData(t){this.annotations=t,this.render()}getSpecificStyle(t){const e=___default.default.pick(t,["stroke","thickness","fill","radius"]),i=__spreadValues$3(__spreadValues$3({},this.style),e);return i.stroke&&Object.assign(i,{color:i.stroke}),i}getRenderText(t,e=!1){let i="",s="";return!t||e===!0?{headerText:i,bottomText:s}:((t==null?void 0:t.order)&&(i=`${t.order}`),(t==null?void 0:t.label)&&(i?i=`${i}_${t.label}`:i=`${t.label}`),(t==null?void 0:t.attribute)&&(i?i=`${i} ${t.attribute}`:i=`${t.attribute}`),(t==null?void 0:t.textAttribute)&&(s=t==null?void 0:t.textAttribute),{headerText:i,bottomText:s})}getReferenceOptions(t){return t?{lineCap:"butt",lineDash:[20,20]}:{}}render(){try{if(super.render(),this.loading===!0)return;this.renderDomInstance.render(this.annotations.filter(t=>t.type==="text"&&t.annotation.position==="rt").map(t=>t.annotation)),this.annotations.forEach(t=>{var e,i,s,n,o,a,l,h,c,u,d,g,p;switch(t.type){case"rect":{const f=t.annotation,{hiddenText:v=!1,isReference:m,hiddenRectSize:b=!1}=f,{zoom:x}=this,P=AxisUtils.changeRectByZoom(f,this.zoom,this.currentPos),{x:w,y:L,width:R,height:C}=P,D=this.getSpecificStyle(f);if(f.id===this.mouseHoverID||D.fill){const S=rgba__default.default((i=(e=D==null?void 0:D.fill)!=null?e:D==null?void 0:D.stroke)!=null?i:DEFAULT_STROKE_COLOR),F=`rgba(${S[0]}, ${S[1]}, ${S[2]},${S[3]*.8})`;DrawUtils.drawRectWithFill(this.canvas,P,{color:F})}DrawUtils.drawRect(this.canvas,P,__spreadValues$3(__spreadProps$2(__spreadValues$3({},D),{hiddenText:!0}),this.getReferenceOptions(m)));const{headerText:O,bottomText:E}=this.getRenderText(f,f==null?void 0:f.hiddenText);O&&DrawUtils.drawText(this.canvas,{x:w,y:L-6},O,__spreadProps$2(__spreadValues$3({color:D.stroke,font:"normal normal 900 14px SourceHanSansCN-Regular"},DEFAULT_TEXT_SHADOW),{textMaxWidth:300}));const H=`${Math.round(R/x)} * ${Math.round(C/x)}`,k=H.length*7;if(!v&&!b&&DrawUtils.drawText(this.canvas,{x:w+R-k,y:L+C+15},H,__spreadValues$3({color:D.stroke,font:"normal normal 600 14px Arial"},DEFAULT_TEXT_SHADOW)),E){const S=20,F=Math.max(20,R-k);DrawUtils.drawText(this.canvas,{x:w,y:L+C+S},f.textAttribute,__spreadValues$3({color:D.stroke,font:"italic normal 900 14px Arial",textMaxWidth:F},DEFAULT_TEXT_SHADOW))}break}case"polygon":{const f=t.annotation;if(!(((s=f==null?void 0:f.pointList)==null?void 0:s.length)>=3))return;const{lineType:v=ELineTypes.Line}=f,m=AxisUtils.changePointListByZoom((n=f==null?void 0:f.pointList)!=null?n:[],this.zoom,this.currentPos),b=this.getSpecificStyle(f);if(f.id===this.mouseHoverID||b.fill){const C=rgba__default.default((a=(o=b==null?void 0:b.fill)!=null?o:b==null?void 0:b.stroke)!=null?a:DEFAULT_STROKE_COLOR),D=`rgba(${C[0]}, ${C[1]}, ${C[2]},${C[3]*.8})`;DrawUtils.drawPolygonWithFill(this.canvas,m,{color:D,lineType:v})}const x=__spreadProps$2(__spreadValues$3(__spreadProps$2(__spreadValues$3({},b),{isClose:!0}),this.getReferenceOptions(f==null?void 0:f.isReference)),{lineType:v,strokeColor:b.stroke});let P=[];if(f.showKeyPoint?P=DrawUtils.drawPolygonWithKeyPoint(this.canvas,m,x):P=DrawUtils.drawPolygon(this.canvas,m,x),(f==null?void 0:f.showDirection)===!0&&((l=f==null?void 0:f.pointList)==null?void 0:l.length)>2){let C=m[0],D=MathUtils.getLineCenterPoint([m[0],m[1]]);if(v===ELineTypes.Curve){const O=Math.floor(SEGMENT_NUMBER$2/2);C=P[O],D=P[O+1]}DrawUtils.drawArrowByCanvas(this.canvas,C,D,{color:b.stroke,thickness:b.thickness}),DrawUtils.drawCircle(this.canvas,m[0],b.thickness+6,{color:b.stroke,thickness:b.thickness})}const{headerText:L,bottomText:R}=this.getRenderText(f,f==null?void 0:f.hiddenText);if(L&&DrawUtils.drawText(this.canvas,m[0],L,__spreadValues$3({color:b.stroke},DEFAULT_TEXT_OFFSET)),R){const C=m[m.length-1];DrawUtils.drawText(this.canvas,{x:C.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:C.y+TEXT_ATTRIBUTE_OFFSET$1.y},R,__spreadValues$3({color:b.stroke},DEFAULT_TEXT_OFFSET))}break}case"line":{const f=t.annotation;if(!(((h=f==null?void 0:f.pointList)==null?void 0:h.length)>=2))return;const{lineType:v=ELineTypes.Line}=f,m=AxisUtils.changePointListByZoom((c=f==null?void 0:f.pointList)!=null?c:[],this.zoom,this.currentPos),b=this.getSpecificStyle(f),x=DrawUtils.drawPolygon(this.canvas,m,__spreadProps$2(__spreadValues$3(__spreadValues$3({},b),this.getReferenceOptions(f==null?void 0:f.isReference)),{lineType:v}));if((f==null?void 0:f.showDirection)===!0&&((u=f==null?void 0:f.pointList)==null?void 0:u.length)>2){let R=m[0],C=MathUtils.getLineCenterPoint([m[0],m[1]]);if(v===ELineTypes.Curve){const D=Math.floor(SEGMENT_NUMBER$2/2);R=x[D],C=x[D+1]}DrawUtils.drawArrowByCanvas(this.canvas,R,C,{color:b.stroke,thickness:b.thickness}),DrawUtils.drawCircle(this.canvas,m[0],b.thickness+6,{color:b.stroke,thickness:b.thickness})}const{headerText:w,bottomText:L}=this.getRenderText(f,f==null?void 0:f.hiddenText);if(w&&DrawUtils.drawText(this.canvas,m[0],w,__spreadValues$3({color:b.stroke},DEFAULT_TEXT_OFFSET)),L){const R=m[m.length-1];DrawUtils.drawText(this.canvas,{x:R.x+TEXT_ATTRIBUTE_OFFSET$1.x,y:R.y+TEXT_ATTRIBUTE_OFFSET$1.y},L,__spreadValues$3({color:b.stroke},DEFAULT_TEXT_OFFSET))}break}case"point":{const f=t.annotation,v=AxisUtils.changePointByZoom(f,this.zoom,this.currentPos),m=this.getSpecificStyle(f),b=(d=m.radius)!=null?d:DEFAULT_RADIUS;DrawUtils.drawCircle(this.canvas,v,b,m);const{headerText:x,bottomText:P}=this.getRenderText(f,f==null?void 0:f.hiddenText);x&&DrawUtils.drawText(this.canvas,{x:v.x+b/2,y:v.y-b-4},x,{textAlign:"center",color:m.stroke}),P&&DrawUtils.drawText(this.canvas,{x:v.x+b,y:v.y+b+24},P,__spreadValues$3({color:m.stroke},DEFAULT_TEXT_OFFSET));break}case"text":{const f=t.annotation,{text:v,x:m,y:b,textMaxWidth:x,color:P="white",background:w="rgba(0, 0, 0, 0.6)",lineHeight:L=25,font:R=DEFAULT_FONT,position:C}=f,D=10,O=10,E=AxisUtils.changePointByZoom({x:m,y:b},this.zoom,this.currentPos),{width:H,height:k,fontHeight:S=0}=MathUtils.getTextArea(this.canvas,f.text,x,R,L);if(C==="rt")break;DrawUtils.drawRectWithFill(this.canvas,{x:E.x,y:E.y,width:H+O*2,height:k+D*2,id:"",sourceID:"",valid:!0,textAttribute:"",attribute:""},{color:w}),DrawUtils.drawText(this.canvas,{x:E.x+O,y:E.y+S+D},v,{color:P,lineHeight:L,font:R,textMaxWidth:x});break}default:}(p=(g=t.annotation)==null?void 0:g.renderEnhance)==null||p.call(g,{ctx:this.ctx,canvas:this.canvas,currentPos:this.currentPos,zoom:this.zoom,data:t,toolInstance:this})})}catch(t){console.error("ViewOperation Render Error",t)}}}var __defProp$3=Object.defineProperty,__defProps$1=Object.defineProperties,__getOwnPropDescs$1=Object.getOwnPropertyDescriptors,__getOwnPropSymbols$2=Object.getOwnPropertySymbols,__hasOwnProp$2=Object.prototype.hasOwnProperty,__propIsEnum$2=Object.prototype.propertyIsEnumerable,__defNormalProp$3=(r,t,e)=>t in r?__defProp$3(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$2=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$2.call(t,e)&&__defNormalProp$3(r,e,t[e]);if(__getOwnPropSymbols$2)for(var e of __getOwnPropSymbols$2(t))__propIsEnum$2.call(t,e)&&__defNormalProp$3(r,e,t[e]);return r},__spreadProps$1=(r,t)=>__defProps$1(r,__getOwnPropDescs$1(t));class PointCloud2dOperation extends PolygonOperation{constructor(t){super(t);this.selectedIDs=[],this.rightMouseUp=s=>{if(this.drawingPointList.length>0){this.addDrawingPointToPolygonList();return}s.ctrlKey&&this.hoverID?this.emit("addSelectedIDs",this.hoverID):this.emit("setSelectedIDs",this.hoverID)},this.onKeyDown=()=>{},this.onKeyUp=()=>{},this.renderSingleSelectedPolygon=s=>{var n;if(this.selectedPolygons){const o=this.getColor(s.attribute),a=StyleUtils.getStrokeAndFill(o,s.valid,{isSelected:!0}),l=AxisUtils.changePointListByZoom(s.pointList,this.zoom,this.currentPos);DrawUtils.drawSelectedPolygonWithFillAndLine(this.canvas,l,{fillColor:"transparent",strokeColor:a.stroke,pointColor:"white",thickness:2,lineCap:"round",isClose:!0,lineType:(n=this.config)==null?void 0:n.lineType}),s.isRect===!0&&this.showDirectionLine===!0&&this.renderRectPolygonDirection(l)}};var e,i;this.showDirectionLine=(e=t.showDirectionLine)!=null?e:!0,this.forbidAddNew=(i=t.forbidAddNew)!=null?i:!1}get getSelectedIDs(){return this.selectedIDs}setSelectedIDs(t){this.selectedIDs=t,this.setSelectedID(this.selectedIDs.length===1?this.selectedIDs[0]:""),this.render()}deleteSelectedID(){super.deleteSelectedID(),this.selectedIDs=[],this.emit("deleteSelectedIDs")}get selectedPolygons(){return PolygonUtils.getPolygonByIDs(this.polygonList,this.selectedIDs)}getLineColor(){return"rgba(0, 255, 255, 0.5)"}renderStaticPolygon(){var t;this.isHidden===!1&&((t=this.polygonList)==null||t.forEach(e=>{var i,s,n;if([...this.selectedIDs,this.editPolygonID].includes(e.id))return;const{attribute:o}=e,a=this.getColor(o),l=StyleUtils.getStrokeAndFill(a,e.valid),h=AxisUtils.changePointListByZoom(e.pointList||[],this.zoom,this.currentPos);DrawUtils.drawPolygonWithFillAndLine(this.canvas,h,{fillColor:"transparent",strokeColor:l.stroke,pointColor:"white",thickness:(s=(i=this.style)==null?void 0:i.width)!=null?s:2,lineCap:"round",isClose:!0,lineType:(n=this.config)==null?void 0:n.lineType}),e.isRect===!0&&this.showDirectionLine===!0&&this.renderRectPolygonDirection(h)}))}renderSelectedPolygon(){var t;(t=this.selectedPolygons)==null||t.forEach(e=>{this.renderSingleSelectedPolygon(e)})}renderRectPolygonDirection(t){t.length<2||DrawUtils.drawLine(this.canvas,t[0],t[1],{color:"red",thickness:3})}get currentPolygonListByPattern(){return this.polygonList.filter(t=>this.pattern===EPolygonPattern.Rect?t.isRect===!0:this.pattern===EPolygonPattern.Normal?t.isRect!==!0:!0)}getHoverID(t){var e;const i=this.getCoordinateUnderZoom(t),n=this.currentPolygonListByPattern.map(o=>__spreadProps$1(__spreadValues$2({},o),{pointList:AxisUtils.changePointListByZoom(o.pointList,this.zoom)}));return PolygonUtils.getHoverPolygonID(i,n,10,(e=this.config)==null?void 0:e.lineType)}switchToNextPolygon(t=ESortDirection.ascend){if(this.drawingPointList.length>0)return;const e=this.currentPolygonListByPattern.map(s=>{var n,o,a,l;return __spreadProps$1(__spreadValues$2({},s),{x:(o=(n=s.pointList[0])==null?void 0:n.x)!=null?o:0,y:(l=(a=s.pointList[0])==null?void 0:a.y)!=null?l:0})}),i=CommonToolUtils$1.getNextSelectedRectID(e,t,this.selectedID);return i&&this.setSelectedIDs([i.id]),this.render(),[i.id]}setSelectedIdAfterAddingDrawing(t){this.drawingPointList.length!==0&&this.setSelectedID(t)}setSelectedID(t){var e,i;const s=this.selectedID;t!==s&&s&&((e=this._textAttributInstance)==null||e.changeSelected()),t||(i=this._textAttributInstance)==null||i.clearTextAttribute(),this.selectedID=t,this.render()}addPointInDrawing(t){this.forbidAddNew||super.addPointInDrawing(t)}}const ANNOTATION_TYPE={0:"\u76EE\u6807\u68C0\u6D4B",1:"\u56FE\u50CF\u5206\u7C7B"},ANNOTATION_STATUS={0:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u4E2D",1:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u91CD\u8BD5",2:"\u6807\u6CE8\u6587\u4EF6\u4F20\u8F93\u5931\u8D25",3:"\u6807\u6CE8\u4E2D",4:"\u4EFB\u52A1\u7EC8\u6B62",5:"\u4EFB\u52A1\u5B8C\u6210",6:"\u6570\u636E\u5DF2\u53D1\u5E03"};var EAnnotationStatus;(function(r){r[r.Upload=0]="Upload",r[r.UploadRetry=1]="UploadRetry",r[r.UploadFail=2]="UploadFail",r[r.Annotation=3]="Annotation",r[r.Terminated=4]="Terminated",r[r.Finish=5]="Finish",r[r.Publish=6]="Publish"})(EAnnotationStatus||(EAnnotationStatus={}));var annotationTask=Object.freeze({__proto__:null,ANNOTATION_TYPE,ANNOTATION_STATUS,get EAnnotationStatus(){return EAnnotationStatus}}),__defProp$2=Object.defineProperty,__getOwnPropSymbols$1=Object.getOwnPropertySymbols,__hasOwnProp$1=Object.prototype.hasOwnProperty,__propIsEnum$1=Object.prototype.propertyIsEnumerable,__defNormalProp$2=(r,t,e)=>t in r?__defProp$2(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues$1=(r,t)=>{for(var e in t||(t={}))__hasOwnProp$1.call(t,e)&&__defNormalProp$2(r,e,t[e]);if(__getOwnPropSymbols$1)for(var e of __getOwnPropSymbols$1(t))__propIsEnum$1.call(t,e)&&__defNormalProp$2(r,e,t[e]);return r};const TEXT_ATTRIBUTE_OFFSET={x:8,y:26},newScope=2;class CheckOperation extends BasicToolOperation{constructor(t){super(t);this.getHoverRectID=e=>{var i,s;const n=this.getCoordinateUnderZoom(e),o=(s=(i=this.resultList.find(a=>a.toolName===EToolName.Rect))==null?void 0:i.result)!=null?s:[];if(o.length>0){const a=o.filter(l=>RectUtils.isInRect(n,l,newScope,this.zoom));if(a.length===0)return"";if(a.length===1)return a[0].id;if(a.length>1)return a.map(h=>({size:h.width*h.height,id:h.id})).sort((h,c)=>h.size-c.size)[0].id}return""},this.resultList=[],this.hoverID=[],this.fillID=[],this.render=this.render.bind(this),this.drawPolygon=this.drawPolygon.bind(this),this.drawRect=this.drawRect.bind(this),this.drawTag=this.drawTag.bind(this),this.setShowDefaultCursor(!0),this.forbidOperation=!0}onMouseDown(t){var e,i;if(super.onMouseDown(t)||this.forbidMouseOperation||!this.imgInfo)return!0;const s=this.mouseHoverID,n=(i=(e=this.resultList.find(o=>o.toolName===EToolName.Rect))==null?void 0:e.result)!=null?i:[];if(t.button===0){let o=[s],a=!0;s&&n.find(l=>l.id===s&&(l==null?void 0:l.isSelected))&&(a=!1),s||(o=n.map(l=>l.id),a=!1),this.emit("setSelectedID",o,a),this.render()}}updateRotate(){}onMouseMove(t){if(super.onMouseMove(t)||this.forbidMouseOperation||!this.imgInfo)return;const e=this.mouseHoverID,i=this.getHoverRectID(t);if(e!==i){this.mouseHoverID=i;let s=[i];i||(s=[]),this.emit("setHoverID",s),this.render()}}setResult(t){this.resultList=_.cloneDeep(t),this.render()}drawPolygon(t,e){t==null||t.forEach(i=>{var s,n,o,a,l;const h=this.getColor(i.attribute,e),c=StyleUtils.getStrokeAndFill(h,i.valid);let u=(n=(s=this.style)==null?void 0:s.width)!=null?n:2;this.hoverID.includes(i.id)?(u=4,DrawUtils.drawPolygonWithFillAndLine(this.canvas,AxisUtils.changePointListByZoom(i.pointList,this.zoom,this.currentPos),{fillColor:c.fill,strokeColor:c.stroke,pointColor:"white",thickness:u,lineCap:"round",isClose:!0,lineType:e==null?void 0:e.lineType})):DrawUtils.drawPolygon(this.canvas,AxisUtils.changePointListByZoom(i.pointList,this.zoom,this.currentPos),{color:c.fill,lineType:(o=this.config)==null?void 0:o.lineType,thickness:u,isClose:!0});let d=`${(l=AttributeUtils.getAttributeShowText(i.attribute,(a=e==null?void 0:e.attributeList)!=null?a:[]))!=null?l:""}`;(e==null?void 0:e.isShowOrder)&&(i==null?void 0:i.order)>0&&(d=`${i.order} ${d}`),DrawUtils.drawText(this.canvas,AxisUtils.changePointByZoom(i.pointList[0],this.zoom,this.currentPos),d,__spreadValues$1({color:c.stroke},DEFAULT_TEXT_OFFSET));const g=AxisUtils.changePointListByZoom(i.pointList||[],this.zoom,this.currentPos),p=g[g.length-1];DrawUtils.drawText(this.canvas,{x:p.x+TEXT_ATTRIBUTE_OFFSET.x,y:p.y+TEXT_ATTRIBUTE_OFFSET.y},i==null?void 0:i.textAttribute,__spreadValues$1({color:c.stroke},DEFAULT_TEXT_OFFSET))})}drawRect(t,e){t==null||t.forEach(i=>{let s=1;this.hoverID.includes(i.id)&&(s=3);const n=this.getColor(i.attribute,e),o=AxisUtils.changeRectByZoom(i,this.zoom,this.currentPos);DrawUtils.drawRect(this.canvas,o,{color:(i==null?void 0:i.valid)?n.valid.stroke:n.invalid.stroke,thickness:s}),this.fillID.includes(i.id)&&DrawUtils.drawRectWithFill(this.canvas,o,{color:(i==null?void 0:i.valid)?n.valid.fill:n.invalid.fill})})}drawTag(t,e){const i=t.reduce((s,n)=>[...s,...(e==null?void 0:e.inputList)?TagUtil.getTagNameList(n.result,e.inputList):TagUtil.getTagnameListWithoutConfig(n.result)],[]);DrawUtils.drawTag(this.canvas,i)}setHoverID(t){this.hoverID=t,this.render()}setFillID(t){this.fillID=t,this.render()}render(){var t;super.render(),(t=this.resultList)==null||t.forEach(e=>{switch(e==null?void 0:e.toolName){case EToolName.Rect:this.drawRect(e.result,CommonToolUtils$1.jsonParser(e.config));break;case EToolName.Polygon:this.drawPolygon(e.result,CommonToolUtils$1.jsonParser(e.config));break;case EToolName.Tag:this.drawTag(e.result,CommonToolUtils$1.jsonParser(e.config));break}})}exportData(){return[[],{}]}}var __async$2=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});class SegmentByRect extends RectOperation{constructor(t){super(t);this.onKeydown=e=>{switch(e.keyCode){case EKeyCode$1.Esc:e.preventDefault(),e.stopPropagation(),this.clearPredictionInfo();break;case EKeyCode$1.Z:e.ctrlKey&&(e.preventDefault(),e.stopPropagation(),this.rectList=[],this.render());break}},this.segmentPrediction=e=>__async$2(this,null,function*(){const i=this.getCoordinateUnderZoom(e);if(this.isRunSegment=!0,this.render(),!this.runPrediction){this.emit("messageError","You needs to set runPrediction function"),this.clearPredictionInfo();return}yield this.runPrediction({point:i,rect:{x:this.rectList[0].x,y:this.rectList[0].y,w:this.rectList[0].width,h:this.rectList[0].height}}),this.clearPredictionInfo()}),this.isRunSegment=!1,this.runPrediction=t.runPrediction}setRunPrediction(t){this.runPrediction=t}eventBinding(){document.addEventListener("keydown",t=>this.onKeydown(t)),super.eventBinding()}clearPredictionInfo(){this.rectList=[],this.isShowCursor=!1,this.coord={x:-1,y:-1},this.drawingRect=void 0,this.isRunSegment=!1,this.clearCanvas(),this.render()}onMouseUp(t){if(!this.isRunSegment){if(t.button===0&&this.rectList.length===1&&!this.isRunSegment){t.stopPropagation(),this.segmentPrediction(t),this.clearActiveStatus();return}super.onMouseUp(t)}}onMouseDown(t){this.isRunSegment||super.onMouseDown(t)}renderCursorLine(){var t;if(!this.ctx)return;const{ctx:e}=this,i=10,s=1,{x:n,y:o}=this.coord;e.save(),e.strokeStyle="white",e.setLineDash([6]),e.lineWidth=s,e.strokeRect(n-i,o-i,i*2,i*2),e.restore();let a=`\u2460 ${lbUtils.i18n.t("FramingOfObjectToBeDivided")}`;const l=lbUtils.i18n.language==="en";let h=l?326:186;if(((t=this.rectList)==null?void 0:t.length)===1){a=`\u2461 ${lbUtils.i18n.t("ClickOnTarget")}`,h=l?232:142;const c=2;e.save(),e.strokeStyle="white";const u=s+i;e.beginPath(),e.moveTo(n+u+c*2,o+u+c),e.arc(n+u+c,o+u+c,c,0,Math.PI*2,!0),e.stroke(),e.restore()}this.isRunSegment&&(h=l?316:136,a=lbUtils.i18n.t("SplittingAlgorithmPrediction")),e.save(),e.fillStyle=this.style.strokeColor,e.fillRect(n+i,o-i*4-1,h,32),e.restore(),e.save(),e.font="14px Source Han Sans CN",e.fillStyle="white",e.fillText(a,n+i+14,o-i*2),e.restore(),super.renderCursorLine()}renderDrawingRect(t,e,i=!1){if(this.ctx&&t){const s=AxisUtils.changeRectByZoom(t,i?e:this.zoom,this.currentPos),{x:n,y:o,width:a,height:l}=s;this.ctx.save(),this.ctx.lineCap="butt",this.ctx.lineWidth=this.style.strokeWidth,this.ctx.strokeStyle="white",this.ctx.strokeRect(n,o,a,l),this.ctx.strokeStyle=this.style.strokeColor,this.ctx.setLineDash([6]),this.ctx.strokeRect(n,o,a,l),this.ctx.restore()}}renderTextAttribute(){}renderSelectedRect(){}}const getCurrentOperation=r=>{switch(r){case EToolName.Rect:case EToolName.RectTrack:return RectOperation;case EToolName.SegmentByRect:return SegmentByRect;case EToolName.Tag:return TagOperation;case EToolName.Polygon:return PolygonOperation;case ECheckModel.Check:return CheckOperation;case EToolName.Line:return LineToolOperation;case EToolName.Point:return PointOperation;case EToolName.Text:return TextToolOperation;default:throw new Error("not match tool")}};class EnhanceCommonToolUtils extends CommonToolUtils$1{}EnhanceCommonToolUtils.getCurrentOperation=getCurrentOperation;class ImgUtils{static load(t){return new Promise((e,i)=>{const s=new Image;t.startsWith("file")?s.src=encodeURI(t):s.src=t,s.onload=()=>{e(s)},s.onerror=()=>{i(s)}})}}const createEmptyImage$1=r=>{const t=document.createElement("canvas");t.width=r.width,t.height=r.height;const e=t.getContext("2d");return e?(e.fillStyle="transparent",e.fillRect(0,0,r.width,r.height),t.toDataURL()):""},arraySwap=(r,t,e)=>{const i=r[t];return r[t]=r[e],r[e]=i,r},_HybridToolUtils=class{static isSingleTool(r){return!this.isHybridTool(r)}static isHybridTool(r){return Array.isArray(r)}};let HybridToolUtils=_HybridToolUtils;HybridToolUtils.getTopToolName=r=>_HybridToolUtils.isHybridTool(r)?r[r.length-1]:r;class ToolScheduler{constructor(t){this.toolOperationList=[],this.toolOperationDom=[];var e,i;this.init(),this.container=t.container,this.size=t.size,this.imgNode=t.imgNode,this.config=(e=t.config)!=null?e:JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t.toolName))),this.style=(i=t.style)!=null?i:styleDefaultConfig}setImgNode(t,e){this.toolOperationList.forEach(i=>{i.setImgNode(t,e)})}setSize(t){this.toolOperationList.forEach(e=>{e.setSize(t)})}syncPosition(t,e,i,s){this.toolOperationList.forEach(n=>{s!==n&&(n.setCurrentPos(t),n.setZoom(e),n.setImgInfo(i),n.renderBasicCanvas(),n.render())})}get defaultSize(){var t,e;return{width:((t=this.imgNode)==null?void 0:t.width)||this.size.width,height:((e=this.imgNode)==null?void 0:e.height)||this.size.height}}createDom(){const{width:t,height:e}=this.defaultSize,i=window.document.createElement("div");i.style.position="absolute",i.style.left="0",i.style.top="0",i.style.width=`${t}px`,i.style.height=`${e}px`;const s=this.toolOperationList.length+1;return i.style.zIndex=`${s}`,i}getEmptyImage(t,e){const i=createEmptyImage$1({width:t,height:e}),s=new Image;return s.src=i,s}createOperation(t,e,i){var s;const{width:n,height:o}=this.defaultSize,a=this.createDom(),l=this.getEmptyImage(n,o),h={container:a,size:this.size,config:(s=this==null?void 0:this.config)!=null?s:"{}",drawOutSideTarget:!1,style:this.style,imgNode:e||l,hiddenImg:!!t};i&&Object.assign(h,i);let c;if(!t)c=new BasicToolOperation(h),a.style.zIndex="0",c.init();else{const u=getCurrentOperation(t);if(!u)return;c=new u(h)}return c==null||c.init(),c.canvas.id=t!=null?t:"basicCanvas",c.on("dragMove",({currentPos:u,zoom:d,imgInfo:g})=>{this.syncPosition(u,d,g,c)}),c.on("renderZoom",(u,d,g)=>{u&&d&&this.syncPosition(d,u,g,c)}),t?(this.container.appendChild(a),this.toolOperationList.push(c),this.toolOperationDom.push(a),c):(this.container.insertBefore(a,this.container.childNodes[0]),this.toolOperationList.unshift(c),this.toolOperationDom.unshift(a),c)}switchLastTwoCanvas(){if(this.toolOperationDom.length<3){console.error("switchLastTwoCanvas is just used the layer which has 3 canvas");return}const t=this.toolOperationDom.length,e=t-1,i=t-2,s=this.toolOperationDom[e],n=this.toolOperationDom[i];if(!(!n||!s))return s.style.zIndex=`${e-1}`,n.style.zIndex=`${e}`,this.toolOperationList[e].clearActiveStatus(),this.toolOperationList[e].clearCursorLine(),this.toolOperationList[e].render(),this.toolOperationList=arraySwap(this.toolOperationList,e,i),this.toolOperationDom=arraySwap(this.toolOperationDom,e,i),this.toolOperationList[e]}getFirstToolOperation(){return this.toolOperationList.length>1?this.toolOperationList[1]:this.toolOperationList[0]}destroyAllLayer(){this.toolOperationList.forEach(t=>{t.destroyCanvas(),this.init()})}init(){this.toolOperationList=[],this.toolOperationDom=[]}}var __async$1=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const loadImage=r=>new Promise((t,e)=>{const i=document.createElement("img");i.crossOrigin="Anonymous",i.onerror=s=>{console.error(s),e(i)},i.src=r,i.onload=()=>{t(i)}});class AnnotationEngine{constructor(t){this.setImgSrc=s=>__async$1(this,null,function*(){const n=yield loadImage(s);!n||this.setImgNode(n)});var e,i;this.container=t.container,this.size=t.size,this.toolName=t.toolName,this.imgNode=t.imgNode,this.config=(e=t.config)!=null?e:JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t.toolName))),this.style=(i=t.style)!=null?i:styleDefaultConfig,this.toolScheduler=new ToolScheduler(t),this.i18nLanguage="cn",this._initToolOperation()}setToolName(t,e){this.toolName=t;const i=e||JSON.stringify(getConfig(HybridToolUtils.getTopToolName(t)));this.config=i,this._initToolOperation()}setImgNode(t,e){this.toolScheduler.setImgNode(t,e),this.imgNode=t}setSize(t){this.size=t,this.toolScheduler.setSize(t)}setStyle(t){this.style=t}_initToolOperation(){this.toolScheduler.destroyAllLayer();let t=[];const e={hiddenImg:!0};HybridToolUtils.isSingleTool(this.toolName)?(t=[this.toolName],Object.assign(e,{hiddenImg:!1})):t=this.toolName,t.length>1&&this.toolScheduler.createOperation(void 0,this.imgNode),t.forEach((i,s)=>{const n=this.toolScheduler.createOperation(i,void 0,e);s===t.length-1&&(this.toolInstance=n)}),this.setLang(this.i18nLanguage)}setBasicInfo(t,e){this.dependToolName=t,this.basicResult=e,this.toolInstance.setDependName(t),this.toolInstance.setBasicResult(e),this.toolInstance.renderBasicCanvas()}clearBasicResult(){this.setBasicInfo()}forbidOperation(){this.toolInstance.setForbidOperation(!0)}launchOperation(){this.toolInstance.setForbidOperation(!1)}setLang(t){switch(this.i18nLanguage=t,t){case"cn":this.toolInstance.setLang(ELang.Zh);break;case"en":this.toolInstance.setLang(ELang.US);break}}setDataInjectionAtCreation(t){this.toolInstance.setDataInjectionAtCreation(t)}setRenderEnhance(t){this.toolInstance.setRenderEnhance(t)}switchLastTwoCanvas(){const t=this.toolScheduler.switchLastTwoCanvas();if(t)return this.toolInstance=t,t}get firstToolInstance(){return this.toolScheduler.getFirstToolOperation()}setCustomRenderStyle(t){this.toolInstance.setCustomRenderStyle(t)}}class PCDLoader extends THREE.Loader{constructor(t){super(t);this.littleEndian=!0}load(t,e,i,s){const n=this,o=new THREE.FileLoader(n.manager);o.setPath(n.path),o.setResponseType("arraybuffer"),o.setRequestHeader(n.requestHeader),o.setWithCredentials(n.withCredentials),o.load(t,function(a){try{e(n.parse(a))}catch(l){s?s(l):console.error(l),n.manager.itemError(t)}},i,s)}parse(t){function e(u,d){const g=u.length,p=new Uint8Array(d);let f=0,v=0,m,b,x;do if(m=u[f++],m<1<<5){if(m++,v+m>d)throw new Error("Output buffer is not large enough");if(f+m>g)throw new Error("Invalid compressed data");do p[v++]=u[f++];while(--m)}else{if(b=m>>5,x=v-((m&31)<<8)-1,f>=g)throw new Error("Invalid compressed data");if(b===7&&(b+=u[f++],f>=g))throw new Error("Invalid compressed data");if(x-=u[f++],v+b+2>d)throw new Error("Output buffer is not large enough");if(x<0)throw new Error("Invalid compressed data");if(x>=v)throw new Error("Invalid compressed data");do p[v++]=p[x++];while(--b+2)}while(f<g);return p}function i(u){const d={},g=u.search(/[\n\r]data\s(\S*)\s/i),p=/[\n\r]data\s(\S*)\s/i.exec(u.slice(g-1));if(d.data=p[1],d.headerLen=p[0].length+g,d.str=u.slice(0,d.headerLen),d.str=d.str.replace(/#.*/gi,""),d.version=/version (.*)/i.exec(d.str),d.fields=/fields (.*)/i.exec(d.str),d.size=/size (.*)/i.exec(d.str),d.type=/type (.*)/i.exec(d.str),d.count=/count (.*)/i.exec(d.str),d.width=/width (.*)/i.exec(d.str),d.height=/height (.*)/i.exec(d.str),d.viewpoint=/viewpoint (.*)/i.exec(d.str),d.points=/points (.*)/i.exec(d.str),d.version!==null&&(d.version=parseFloat(d.version[1])),d.fields=d.fields!==null?d.fields[1].split(" "):[],d.type!==null&&(d.type=d.type[1].split(" ")),d.width!==null&&(d.width=parseInt(d.width[1])),d.height!==null&&(d.height=parseInt(d.height[1])),d.viewpoint!==null&&(d.viewpoint=d.viewpoint[1]),d.points!==null&&(d.points=parseInt(d.points[1],10)),d.points===null&&(d.points=d.width*d.height),d.size!==null&&(d.size=d.size[1].split(" ").map(function(v){return parseInt(v,10)})),d.count!==null)d.count=d.count[1].split(" ").map(function(v){return parseInt(v,10)});else{d.count=[];for(let v=0,m=d.fields.length;v<m;v++)d.count.push(1)}d.offset={};let f=0;for(let v=0,m=d.fields.length;v<m;v++)d.data==="ascii"?d.offset[d.fields[v]]=v:(d.offset[d.fields[v]]=f,f+=d.size[v]*d.count[v]);return d.rowSize=f,d}const s=THREE.LoaderUtils.decodeText(new Uint8Array(t)),n=i(s),o=[],a=[],l=[];if(n.data==="ascii"){const{offset:u}=n,g=s.slice(n.headerLen).split(`
|
|
97
|
+
`);for(let p=0,f=g.length;p<f;p++){if(g[p]==="")continue;const v=g[p].split(" ");if(u.x!==void 0&&(o.push(parseFloat(v[u.x])),o.push(parseFloat(v[u.y])),o.push(parseFloat(v[u.z]))),this.genColorByCoord){const b=this.genColorByCoord(parseFloat(v[u.x]),parseFloat(v[u.y]),parseFloat(v[u.z])).map(x=>x/255);l.push(...b)}u.normal_x!==void 0&&(a.push(parseFloat(v[u.normal_x])),a.push(parseFloat(v[u.normal_y])),a.push(parseFloat(v[u.normal_z])))}}if(n.data==="binary_compressed"){const u=new Uint32Array(t.slice(n.headerLen,n.headerLen+8)),d=u[0],g=u[1],p=e(new Uint8Array(t,n.headerLen+8,d),g),f=new DataView(p.buffer),{offset:v}=n;for(let m=0;m<n.points;m++)if(v.x!==void 0&&(o.push(f.getFloat32(n.points*v.x+n.size[0]*m,this.littleEndian)),o.push(f.getFloat32(n.points*v.y+n.size[1]*m,this.littleEndian)),o.push(f.getFloat32(n.points*v.z+n.size[2]*m,this.littleEndian))),v.normal_x!==void 0&&(a.push(f.getFloat32(n.points*v.normal_x+n.size[4]*m,this.littleEndian)),a.push(f.getFloat32(n.points*v.normal_y+n.size[5]*m,this.littleEndian)),a.push(f.getFloat32(n.points*v.normal_z+n.size[6]*m,this.littleEndian))),this.genColorByCoord){const x=this.genColorByCoord(f.getFloat32(n.points*v.x+n.size[0]*m,this.littleEndian),f.getFloat32(n.points*v.y+n.size[0]*m,this.littleEndian),f.getFloat32(n.points*v.z+n.size[0]*m,this.littleEndian)).map(P=>P/255);l.push(...x)}}if(n.data==="binary"){const u=new DataView(t,n.headerLen),{offset:d}=n;for(let g=0,p=0;g<n.points;g++,p+=n.rowSize)if(d.x!==void 0&&(o.push(u.getFloat32(p+d.x,this.littleEndian)),o.push(u.getFloat32(p+d.y,this.littleEndian)),o.push(u.getFloat32(p+d.z,this.littleEndian))),d.normal_x!==void 0&&(a.push(u.getFloat32(p+d.normal_x,this.littleEndian)),a.push(u.getFloat32(p+d.normal_y,this.littleEndian)),a.push(u.getFloat32(p+d.normal_z,this.littleEndian))),this.genColorByCoord){const v=this.genColorByCoord(u.getFloat32(p+d.x,this.littleEndian),u.getFloat32(p+d.y,this.littleEndian),u.getFloat32(p+d.z,this.littleEndian)).map(m=>m/255);l.push(...v)}}const h=new THREE.BufferGeometry;o.length>0&&h.setAttribute("position",new THREE.Float32BufferAttribute(o,3)),a.length>0&&h.setAttribute("normal",new THREE.Float32BufferAttribute(a,3)),l.length>0&&h.setAttribute("color",new THREE.Float32BufferAttribute(l,3)),h.computeBoundingSphere();const c=new THREE.PointsMaterial({size:.01});return l.length>0?c.vertexColors=!0:c.color.setHex(16777215),new THREE.Points(h,c)}genColorByCoord(t,e,i){return i<=0?[128,128,128]:i<5?[255,0,0]:i<10?[0,255,0]:[0,0,255]}}var __defProp$1=Object.defineProperty,__defNormalProp$1=(r,t,e)=>t in r?__defProp$1(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__publicField=(r,t,e)=>(__defNormalProp$1(r,typeof t!="symbol"?t+"":t,e),e);const _changeEvent={type:"change"},_startEvent={type:"start"},_endEvent={type:"end"};class OrbitControls extends THREE.EventDispatcher{constructor(t,e){super();__publicField(this,"listenToKeyEvents",y=>{y.addEventListener("keydown",onKeyDown),this._domElementKeyEvents=y}),e===void 0&&console.warn('THREE.OrbitControls: The second parameter "domElement" is now mandatory.'),e===document&&console.error('THREE.OrbitControls: "document" should not be used as the target "domElement". Please use "renderer.domElement" instead.'),this.object=t,this.domElement=e,this.domElement.style.touchAction="none",this.enabled=!0,this.target=new THREE.Vector3,this.minDistance=0,this.maxDistance=Infinity,this.minZoom=0,this.maxZoom=Infinity,this.minPolarAngle=0,this.maxPolarAngle=Math.PI,this.minAzimuthAngle=-Infinity,this.maxAzimuthAngle=Infinity,this.enableDamping=!1,this.dampingFactor=.05,this.enableZoom=!0,this.zoomSpeed=1,this.enableRotate=!0,this.rotateSpeed=1,this.enablePan=!0,this.panSpeed=1,this.screenSpacePanning=!0,this.keyPanSpeed=7,this.autoRotate=!1,this.autoRotateSpeed=2,this.keys={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",BOTTOM:"ArrowDown"},this.mouseButtons={LEFT:THREE.MOUSE.ROTATE,MIDDLE:THREE.MOUSE.DOLLY,RIGHT:THREE.MOUSE.PAN},this.touches={ONE:THREE.TOUCH.ROTATE,TWO:THREE.TOUCH.DOLLY_PAN},this.target0=this.target.clone(),this.position0=this.object.position.clone(),this.zoom0=this.object.zoom,this._domElementKeyEvents=null,this.getPolarAngle=function(){return a.phi},this.getAzimuthalAngle=function(){return a.theta},this.getDistance=function(){return this.object.position.distanceTo(this.target)},this.saveState=function(){i.target0.copy(i.target),i.position0.copy(i.object.position),i.zoom0=i.object.zoom},this.reset=function(){i.target.copy(i.target0),i.object.position.copy(i.position0),i.object.zoom=i.zoom0,i.object.updateProjectionMatrix(),i.dispatchEvent(_changeEvent),i.update(),n=s.NONE},this.update=function(){const y=new THREE.Vector3,I=new THREE.Quaternion().setFromUnitVectors(t.up,new THREE.Vector3(0,1,0)),A=I.clone().invert(),T=new THREE.Vector3,M=new THREE.Quaternion,z=2*Math.PI;return function(){const{position:rt}=i.object;y.copy(rt).sub(i.target),y.applyQuaternion(I),a.setFromVector3(y),i.autoRotate&&n===s.NONE&&D(R()),i.enableDamping?(a.theta+=l.theta*i.dampingFactor,a.phi+=l.phi*i.dampingFactor):(a.theta+=l.theta,a.phi+=l.phi);let B=i.minAzimuthAngle,N=i.maxAzimuthAngle;return isFinite(B)&&isFinite(N)&&(B<-Math.PI?B+=z:B>Math.PI&&(B-=z),N<-Math.PI?N+=z:N>Math.PI&&(N-=z),B<=N?a.theta=Math.max(B,Math.min(N,a.theta)):a.theta=a.theta>(B+N)/2?Math.max(B,a.theta):Math.min(N,a.theta)),a.phi=Math.max(i.minPolarAngle,Math.min(i.maxPolarAngle,a.phi)),a.makeSafe(),a.radius*=h,a.radius=Math.max(i.minDistance,Math.min(i.maxDistance,a.radius)),i.enableDamping===!0?i.target.addScaledVector(c,i.dampingFactor):i.target.add(c),y.setFromSpherical(a),y.applyQuaternion(A),rt.copy(i.target).add(y),i.object.lookAt(i.target),i.enableDamping===!0?(l.theta*=1-i.dampingFactor,l.phi*=1-i.dampingFactor,c.multiplyScalar(1-i.dampingFactor)):(l.set(0,0,0),c.set(0,0,0)),h=1,u||T.distanceToSquared(i.object.position)>o||8*(1-M.dot(i.object.quaternion))>o?(i.dispatchEvent(_changeEvent),T.copy(i.object.position),M.copy(i.object.quaternion),u=!1,!0):!1}}(),this.dispose=function(){i.domElement.removeEventListener("contextmenu",it),i.domElement.removeEventListener("pointerdown",Q),i.domElement.removeEventListener("pointercancel",tt),i.domElement.removeEventListener("wheel",et),i.domElement.removeEventListener("pointermove",U),i.domElement.removeEventListener("pointerup",Z),i._domElementKeyEvents!==null&&i._domElementKeyEvents.removeEventListener("keydown",mt)};const i=this,s={NONE:-1,ROTATE:0,DOLLY:1,PAN:2,TOUCH_ROTATE:3,TOUCH_PAN:4,TOUCH_DOLLY_PAN:5,TOUCH_DOLLY_ROTATE:6};let n=s.NONE;const o=1e-6,a=new THREE.Spherical,l=new THREE.Spherical;let h=1;const c=new THREE.Vector3;let u=!1;const d=new THREE.Vector2,g=new THREE.Vector2,p=new THREE.Vector2,f=new THREE.Vector2,v=new THREE.Vector2,m=new THREE.Vector2,b=new THREE.Vector2,x=new THREE.Vector2,P=new THREE.Vector2,w=[],L={};function R(){return 2*Math.PI/60/60*i.autoRotateSpeed}function C(){return Math.pow(.95,i.zoomSpeed)}function D(y){l.theta-=y}function O(y){l.phi-=y}const E=function(){const y=new THREE.Vector3;return function(A,T){y.setFromMatrixColumn(T,0),y.multiplyScalar(-A),c.add(y)}}(),H=function(){const y=new THREE.Vector3;return function(A,T){i.screenSpacePanning===!0?y.setFromMatrixColumn(T,1):(y.setFromMatrixColumn(T,0),y.crossVectors(i.object.up,y)),y.multiplyScalar(A),c.add(y)}}(),k=function(){const y=new THREE.Vector3;return function(A,T){const M=i.domElement;if(i.object.isPerspectiveCamera){const{position:z}=i.object;y.copy(z).sub(i.target);let $=y.length();$*=Math.tan(i.object.fov/2*Math.PI/180),E(2*A*$/M.clientHeight,i.object.matrix),H(2*T*$/M.clientHeight,i.object.matrix)}else i.object.isOrthographicCamera?(E(A*(i.object.right-i.object.left)/i.object.zoom/M.clientWidth,i.object.matrix),H(T*(i.object.top-i.object.bottom)/i.object.zoom/M.clientHeight,i.object.matrix)):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - pan disabled."),i.enablePan=!1)}}();function S(y){i.object.isPerspectiveCamera?h/=y:i.object.isOrthographicCamera?(i.object.zoom=Math.max(i.minZoom,Math.min(i.maxZoom,i.object.zoom*y)),i.object.updateProjectionMatrix(),u=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),i.enableZoom=!1)}function F(y){i.object.isPerspectiveCamera?h*=y:i.object.isOrthographicCamera?(i.object.zoom=Math.max(i.minZoom,Math.min(i.maxZoom,i.object.zoom/y)),i.object.updateProjectionMatrix(),u=!0):(console.warn("WARNING: OrbitControls.js encountered an unknown camera type - dolly/zoom disabled."),i.enableZoom=!1)}function j(y){d.set(y.clientX,y.clientY)}function ot(y){b.set(y.clientX,y.clientY)}function W(y){f.set(y.clientX,y.clientY)}function at(y){g.set(y.clientX,y.clientY),p.subVectors(g,d).multiplyScalar(i.rotateSpeed);const I=i.domElement;D(2*Math.PI*p.x/I.clientHeight),O(2*Math.PI*p.y/I.clientHeight),d.copy(g),i.update()}function lt(y){x.set(y.clientX,y.clientY),P.subVectors(x,b),P.y>0?S(C()):P.y<0&&F(C()),b.copy(x),i.update()}function ht(y){v.set(y.clientX,y.clientY),m.subVectors(v,f).multiplyScalar(i.panSpeed),k(m.x,m.y),f.copy(v),i.update()}function ct(y){y.deltaY<0?F(C()):y.deltaY>0&&S(C()),i.update()}function dt(y){let I=!1;switch(y.code){case i.keys.UP:k(0,i.keyPanSpeed),I=!0;break;case i.keys.BOTTOM:k(0,-i.keyPanSpeed),I=!0;break;case i.keys.LEFT:k(i.keyPanSpeed,0),I=!0;break;case i.keys.RIGHT:k(-i.keyPanSpeed,0),I=!0;break}I&&(y.preventDefault(),i.update())}function X(){if(w.length===1)d.set(w[0].pageX,w[0].pageY);else{const y=.5*(w[0].pageX+w[1].pageX),I=.5*(w[0].pageY+w[1].pageY);d.set(y,I)}}function Y(){if(w.length===1)f.set(w[0].pageX,w[0].pageY);else{const y=.5*(w[0].pageX+w[1].pageX),I=.5*(w[0].pageY+w[1].pageY);f.set(y,I)}}function K(){const y=w[0].pageX-w[1].pageX,I=w[0].pageY-w[1].pageY,A=Math.sqrt(y*y+I*I);b.set(0,A)}function ut(){i.enableZoom&&K(),i.enablePan&&Y()}function gt(){i.enableZoom&&K(),i.enableRotate&&X()}function G(y){if(w.length==1)g.set(y.pageX,y.pageY);else{const A=V(y),T=.5*(y.pageX+A.x),M=.5*(y.pageY+A.y);g.set(T,M)}p.subVectors(g,d).multiplyScalar(i.rotateSpeed);const I=i.domElement;D(2*Math.PI*p.x/I.clientHeight),O(2*Math.PI*p.y/I.clientHeight),d.copy(g)}function q(y){if(w.length===1)v.set(y.pageX,y.pageY);else{const I=V(y),A=.5*(y.pageX+I.x),T=.5*(y.pageY+I.y);v.set(A,T)}m.subVectors(v,f).multiplyScalar(i.panSpeed),k(m.x,m.y),f.copy(v)}function J(y){const I=V(y),A=y.pageX-I.x,T=y.pageY-I.y,M=Math.sqrt(A*A+T*T);x.set(0,M),P.set(0,Math.pow(x.y/b.y,i.zoomSpeed)),S(P.y),b.copy(x)}function ft(y){i.enableZoom&&J(y),i.enablePan&&q(y)}function pt(y){i.enableZoom&&J(y),i.enableRotate&&G(y)}function Q(y){i.enabled!==!1&&(w.length===0&&(i.domElement.setPointerCapture(y.pointerId),i.domElement.addEventListener("pointermove",U),i.domElement.addEventListener("pointerup",Z)),wt(y),y.pointerType==="touch"?bt(y):vt(y))}function U(y){i.enabled!==!1&&(y.pointerType==="touch"?xt(y):yt(y))}function Z(y){st(y),w.length===0&&(i.domElement.releasePointerCapture(y.pointerId),i.domElement.removeEventListener("pointermove",U),i.domElement.removeEventListener("pointerup",Z)),i.dispatchEvent(_endEvent),n=s.NONE}function tt(y){st(y)}function vt(y){let I;switch(y.button){case 0:I=i.mouseButtons.LEFT;break;case 1:I=i.mouseButtons.MIDDLE;break;case 2:I=i.mouseButtons.RIGHT;break;default:I=-1}switch(I){case THREE.MOUSE.DOLLY:if(i.enableZoom===!1)return;ot(y),n=s.DOLLY;break;case THREE.MOUSE.ROTATE:if(y.ctrlKey||y.metaKey||y.shiftKey){if(i.enablePan===!1)return;W(y),n=s.PAN}else{if(i.enableRotate===!1)return;j(y),n=s.ROTATE}break;case THREE.MOUSE.PAN:if(y.ctrlKey||y.metaKey||y.shiftKey){if(i.enableRotate===!1)return;j(y),n=s.ROTATE}else{if(i.enablePan===!1)return;W(y),n=s.PAN}break;default:n=s.NONE}n!==s.NONE&&i.dispatchEvent(_startEvent)}function yt(y){if(i.enabled!==!1)switch(n){case s.ROTATE:if(i.enableRotate===!1)return;at(y);break;case s.DOLLY:if(i.enableZoom===!1)return;lt(y);break;case s.PAN:if(i.enablePan===!1)return;ht(y);break}}function et(y){i.enabled===!1||i.enableZoom===!1||n!==s.NONE||(y.preventDefault(),i.dispatchEvent(_startEvent),ct(y),i.dispatchEvent(_endEvent))}function mt(y){i.enabled===!1||i.enablePan===!1||dt(y)}function bt(y){switch(nt(y),w.length){case 1:switch(i.touches.ONE){case THREE.TOUCH.ROTATE:if(i.enableRotate===!1)return;X(),n=s.TOUCH_ROTATE;break;case THREE.TOUCH.PAN:if(i.enablePan===!1)return;Y(),n=s.TOUCH_PAN;break;default:n=s.NONE}break;case 2:switch(i.touches.TWO){case THREE.TOUCH.DOLLY_PAN:if(i.enableZoom===!1&&i.enablePan===!1)return;ut(),n=s.TOUCH_DOLLY_PAN;break;case THREE.TOUCH.DOLLY_ROTATE:if(i.enableZoom===!1&&i.enableRotate===!1)return;gt(),n=s.TOUCH_DOLLY_ROTATE;break;default:n=s.NONE}break;default:n=s.NONE}n!==s.NONE&&i.dispatchEvent(_startEvent)}function xt(y){switch(nt(y),n){case s.TOUCH_ROTATE:if(i.enableRotate===!1)return;G(y),i.update();break;case s.TOUCH_PAN:if(i.enablePan===!1)return;q(y),i.update();break;case s.TOUCH_DOLLY_PAN:if(i.enableZoom===!1&&i.enablePan===!1)return;ft(y),i.update();break;case s.TOUCH_DOLLY_ROTATE:if(i.enableZoom===!1&&i.enableRotate===!1)return;pt(y),i.update();break;default:n=s.NONE}}function it(y){i.enabled!==!1&&y.preventDefault()}function wt(y){w.push(y)}function st(y){delete L[y.pointerId];for(let I=0;I<w.length;I++)if(w[I].pointerId==y.pointerId){w.splice(I,1);return}}function nt(y){let I=L[y.pointerId];I===void 0&&(I=new THREE.Vector2,L[y.pointerId]=I),I.set(y.pageX,y.pageY)}function V(y){const I=y.pointerId===w[0].pointerId?w[1]:w[0];return L[I.pointerId]}i.domElement.addEventListener("contextmenu",it),i.domElement.addEventListener("pointerdown",Q),i.domElement.addEventListener("pointercancel",tt),i.domElement.addEventListener("wheel",et,{passive:!1}),this.update()}}class PointCloudCache{constructor(){this.MAX_SIZE=50,this.cacheList=[],this.loadPCDFile=t=>new Promise((e,i)=>{var s;if(this.pointsMap.get(t)){const n=(s=this.pointsMap.get(t))==null?void 0:s.clone();e(n);return}if(this.cacheList.length>this.MAX_SIZE){const n=this.cacheList.shift();n&&this.pointsMap.delete(n.src)}this.cacheList.push({src:t}),this.pcdLoader.load(t,n=>{this.pointsMap.set(t,n.clone()),e(n)},()=>{},n=>{i(n)})}),this.pcdLoader=new PCDLoader,this.pointsMap=new Map}static getInstance(){return this.instance==null&&(this.instance=new PointCloudCache),this.instance}}var __defProp=Object.defineProperty,__defProps=Object.defineProperties,__getOwnPropDescs=Object.getOwnPropertyDescriptors,__getOwnPropSymbols=Object.getOwnPropertySymbols,__hasOwnProp=Object.prototype.hasOwnProperty,__propIsEnum=Object.prototype.propertyIsEnumerable,__defNormalProp=(r,t,e)=>t in r?__defProp(r,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):r[t]=e,__spreadValues=(r,t)=>{for(var e in t||(t={}))__hasOwnProp.call(t,e)&&__defNormalProp(r,e,t[e]);if(__getOwnPropSymbols)for(var e of __getOwnPropSymbols(t))__propIsEnum.call(t,e)&&__defNormalProp(r,e,t[e]);return r},__spreadProps=(r,t)=>__defProps(r,__getOwnPropDescs(t)),__async=(r,t,e)=>new Promise((i,s)=>{var n=l=>{try{a(e.next(l))}catch(h){s(h)}},o=l=>{try{a(e.throw(l))}catch(h){s(h)}},a=l=>l.done?i(l.value):Promise.resolve(l.value).then(n,o);a((e=e.apply(r,t)).next())});const DEFAULT_DISTANCE=30;class PointCloud{constructor({container:t,noAppend:e,isOrthographicCamera:i,orthographicParams:s,backgroundColor:n="black"}){this.zAxisLimit=10,this.initCameraPosition=new THREE__namespace.Vector3(-1,0,10),this.isOrthographicCamera=!1,this.pointsUuid="",this.pointCloudObjectName="pointCloud",this.rangeObjectName="range",this.showDirection=!0,this.AddBoxToSense=(o,a=16777215)=>{var l;const h=(l=o.id)!=null?l:uuid();this.removeObjectByName(h);const{center:c,width:u,height:d,depth:g,rotation:p}=o,f=new THREE__namespace.Group,v=new THREE__namespace.BoxGeometry(u,d,g),m=new THREE__namespace.MeshBasicMaterial({color:"blue"}),b=new THREE__namespace.Mesh(v,m),x=new THREE__namespace.BoxHelper(b,a),P=this.generateBoxArrow(o),w=this.generateBoxTrackID(o);f.add(x),f.add(P),f.add(w),f.position.set(c.x,c.y,c.z),f.rotation.set(0,0,p),f.name=h,this.scene.add(f)},this.overridePointShader=o=>{o.vertexShader=`
|
|
98
98
|
attribute float sizes;
|
|
99
99
|
attribute float visibility;
|
|
100
100
|
varying float vVisible;
|
|
@@ -104,4 +104,4 @@
|
|
|
104
104
|
varying float vVisible;
|
|
105
105
|
${o.fragmentShader}`.replace("#include <clipping_planes_fragment>",`
|
|
106
106
|
if (vVisible < 0.5) discard;
|
|
107
|
-
#include <clipping_planes_fragment>`)},this.loadPCDFile=(o,a)=>__async(this,null,function*(){this.clearPointCloud();const l=yield this.cacheInstance.loadPCDFile(o);l.name=this.pointCloudObjectName,this.renderPointCloud(l),a&&a()}),this.loadPCDFileByBox=(o,a,l)=>__async(this,null,function*(){this.clearPointCloud();const h=u=>{u.material.size=1;const{width:c=0,height:g=0,depth:p=0}=l!=null?l:{},f=this.filterPointsByBox(__spreadProps(__spreadValues({},a),{width:a.width+c,height:a.height+g,depth:a.depth+p}),u.geometry.attributes.position.array,u.geometry.attributes.color.array),v=new THREE__namespace.Points(f,u.material);v.name=this.pointCloudObjectName,this.scene.add(v),this.render()},d=yield this.cacheInstance.loadPCDFile(o);h(d)}),this.generateBoxArrow=({width:o,depth:a})=>{const l=new THREE__namespace.Vector3(1,0,0),h=new THREE__namespace.Vector3(-o/2,0,-a/2),d=o,u=16776960;return new THREE__namespace.ArrowHelper(l,h,d,u)},this.generateBoxTrackID=o=>{const a=new THREE__namespace.Texture(this.getTextCanvas(o.trackID.toString()));a.needsUpdate=!0;const l=new THREE__namespace.SpriteMaterial({map:a,depthWrite:!1}),h=new THREE__namespace.Sprite(l);return h.scale.set(5,5,5),h.position.set(-o.width/2,0,o.depth/2+.5),h},this.applyZAxisPoints=o=>{this.zAxisLimit=o,this.filterZAxisPoints(),this.render()},this.updatePointSize=o=>{const a=this.scene.getObjectByName(this.pointCloudObjectName);if(!a)return;const l=a.material.size;o?a.material.size=Math.min(l*1.2,10):a.material.size=Math.max(l/1.2,1),this.render()},this.container=t,this.renderer=new THREE__namespace.WebGLRenderer({antialias:!0}),this.backgroundColor=n,i&&s?(this.isOrthographicCamera=!0,this.camera=new THREE__namespace.OrthographicCamera(s.left,s.right,s.top,s.bottom,s.near,s.far)):this.camera=new THREE__namespace.PerspectiveCamera(30,this.containerWidth/this.containerHeight,1,1e3),this.initCamera(),this.scene=new THREE__namespace.Scene,this.controls=new OrbitControls(this.camera,this.renderer.domElement),this.axesHelper=new THREE__namespace.AxesHelper(1e3),this.pcdLoader=new PCDLoader,this.scene.add(this.axesHelper),this.scene.add(this.camera),e||t.appendChild(this.renderer.domElement),this.init(),this.cacheInstance=PointCloudCache.getInstance()}get containerWidth(){return this.container.clientWidth}get containerHeight(){return this.container.clientHeight}setInitCameraPosition(t){this.initCameraPosition=t}initCamera(){const{camera:t}=this;if(this.isOrthographicCamera){const{x:e,y:i,z:s}=this.initCameraPosition;t.position.set(e,i,s)}else t.position.set(-1,0,500);t.up.set(0,0,1)}initControls(){const{controls:t}=this,e=[0,0,0];t.target=new THREE__namespace.Vector3(...e),t.addEventListener("change",()=>{this.render()}),t.maxPolarAngle=Math.PI/2,t.update()}initRenderer(){const{renderer:t}=this;t.setPixelRatio(window.devicePixelRatio),t.setSize(this.containerWidth,this.containerHeight)}init(){const{scene:t}=this;t.background=new THREE__namespace.Color(this.backgroundColor),this.initControls(),this.initRenderer()}removeObjectByName(t){const e=this.scene.getObjectByName(t);e&&e.removeFromParent()}transferKitti2Matrix(t,e,i){const s=lbUtils.MatrixUtils.transferMatrix34FromKitti2Three(t),n=lbUtils.MatrixUtils.transferMatrix33FromKitti2Three(e),o=lbUtils.MatrixUtils.transferMatrix34FromKitti2Three(i),a=this.createThreeMatrix4(s),l=this.createThreeMatrix4(n),h=this.createThreeMatrix4(o);return{composeMatrix4:h.clone().premultiply(l).premultiply(a),PM:a,RM:l,TM:h}}lidar2image(t,e){const i=lbUtils.PointCloudUtils.getAllViewData(t),{P:s,R:n,T:o}=e,{RM:a,TM:l,PM:h}=this.transferKitti2Matrix(s,n,o);return i.map(u=>({type:u.type,pointList:u.pointList.map(c=>this.rotatePoint(c,t.center,t.rotation)).map(c=>{const p=new THREE__namespace.Vector4(c.x,c.y,c.z).applyMatrix4(l);if(p.z<0)return;const f=1/p.z,v=new THREE__namespace.Matrix4().set(f,0,0,0,0,f,0,0,0,0,f,0,0,0,0,1);return p.applyMatrix4(v).applyMatrix4(a).applyMatrix4(h)}).filter(c=>c!==void 0)}))}generateBox(t,e=16777215){this.AddBoxToSense(t,e),this.render()}generateBoxes(t){t.forEach(e=>{this.generateBox(e)}),this.render()}getOrthographicCamera(t){const{center:e,width:i,height:s}=t,n=10,o=e.x-i/2-n,a=e.x-i/2+n,l=e.y+s/2+n,h=e.y-s/2-n,d=100,u=-100,c=500/d;return{left:o,right:a,top:l,bottom:h,near:d,far:u,zoom:c}}updateCameraByBox(t,e){const{center:i,width:s,height:n,depth:o,rotation:a}=t,l=this.getCameraVector(i,a,{width:s,height:n,depth:o},e);return this.updateCamera(l,i),l}updateOrthoCamera(t,e){const i=this.updateCameraByBox(t,e);return this.camera.zoom=1,this.camera.updateProjectionMatrix(),{cameraPositionVector:i}}updateTopCamera(){this.camera.zoom=1,this.initCamera(),this.initControls(),this.camera.updateProjectionMatrix(),this.render()}updateCamera(t,e){this.camera.position.set(t.x,t.y,t.z),this.controls.target=new THREE__namespace.Vector3(e.x,e.y,e.z),this.controls.update()}resetCamera(){this.updateCamera({x:-1,y:0,z:500},{x:0,y:0,z:0})}createThreeMatrix4(t){return new THREE__namespace.Matrix4().set(...t)}rotatePoint(t,e,i){var s;const n=new THREE__namespace.Vector3(t.x,t.y,(s=t==null?void 0:t.z)!=null?s:1),o=new THREE__namespace.Matrix4().makeRotationZ(i),a=new THREE__namespace.Matrix4().makeTranslation(e.x,e.y,e.z),l=new THREE__namespace.Matrix4().makeTranslation(-e.x,-e.y,-e.z);return n.clone().applyMatrix4(l).applyMatrix4(o).applyMatrix4(a)}getCuboidFromPointCloudBox(t){const{center:e,width:i,height:s,depth:n,rotation:o}=t,a=[{x:e.x+i/2,y:e.y+s/2},{x:e.x+i/2,y:e.y-s/2},{x:e.x-i/2,y:e.y-s/2},{x:e.x-i/2,y:e.y+s/2}].map(d=>{const u=this.rotatePoint(d,e,o);return{x:u.x,y:u.y}}),l=e.z+n/2,h=e.z-n/2;return{polygonPointList:a,zMax:l,zMin:h}}filterPointsByBox(t,e,i){const s=[],n=[],{zMin:o,zMax:a,polygonPointList:l}=this.getCuboidFromPointCloudBox(t);for(let d=0;d<e.length;d+=3){const u=e[d],c=e[d+1],g=e[d+2];isInPolygon({x:u,y:c},l)&&g>=o&&g<=a&&(s.push(u),s.push(c),s.push(g),n.push(i[d]),n.push(i[d+1]),n.push(i[d+2]))}const h=new THREE__namespace.BufferGeometry;return h.setAttribute("position",new THREE__namespace.Float32BufferAttribute(s,3)),h.setAttribute("color",new THREE__namespace.Float32BufferAttribute(n,3)),h.computeBoundingSphere(),h}filterPointsColor(t,e,i){const{zMin:s,zMax:n,polygonPointList:o}=this.getCuboidFromPointCloudBox(t);for(let a=0;a<e.length;a+=3){const l=e[a],h=e[a+1],d=e[a+2];if(isInPolygon({x:l,y:h},o)&&d>=s&&d<=n)i[a]=0,i[a+1]=1,i[a+2]=1;else{const[c,g,p]=lbUtils.PointCloudUtils.getStandardColorByCoord(l,h,d);i[a]=c,i[a+1]=g,i[a+2]=p}}}getCameraVector(t,e,i,s=lbUtils.EPerspectiveView.Front,n=DEFAULT_DISTANCE){let o=lbUtils.PerspectiveShiftUtils.frontViewMatrix4(n);switch(s){case lbUtils.EPerspectiveView.Front:break;case lbUtils.EPerspectiveView.Back:o=lbUtils.PerspectiveShiftUtils.backViewMatrix4(n);break;case lbUtils.EPerspectiveView.Left:o=lbUtils.PerspectiveShiftUtils.leftViewMatrix4(n);break;case lbUtils.EPerspectiveView.Right:o=lbUtils.PerspectiveShiftUtils.rightViewMatrix4(n);break;case lbUtils.EPerspectiveView.Top:o=lbUtils.PerspectiveShiftUtils.topViewMatrix4(n);break;case lbUtils.EPerspectiveView.LFT:o=lbUtils.PerspectiveShiftUtils.leftFrontTopViewMatrix4(n,i);break;case lbUtils.EPerspectiveView.RBT:o=lbUtils.PerspectiveShiftUtils.rightBackTopViewMatrix4(n,i);break}const a=this.createThreeMatrix4(o),l=new THREE__namespace.Matrix4().makeTranslation(-t.x,-t.y,-t.z),h=new THREE__namespace.Matrix4().makeTranslation(t.x,t.y,t.z),d=new THREE__namespace.Matrix4().makeRotationZ(e);return new THREE__namespace.Vector3(t.x,t.y,t.z).clone().applyMatrix4(a).applyMatrix4(l).applyMatrix4(d).applyMatrix4(h)}createRange(t){this.removeObjectByName(this.rangeObjectName);const i=new THREE__namespace.EllipseCurve(0,0,t,t,0,2*Math.PI,!1,0).getPoints(50),s=new THREE__namespace.BufferGeometry().setFromPoints(i),n=new THREE__namespace.LineBasicMaterial({color:16711680}),o=new THREE__namespace.Line(s,n);return o.name=this.rangeObjectName,o}renderPointCloud(t){t.material.size=1,t.name=this.pointCloudObjectName;const e=new THREE__namespace.PointsMaterial({vertexColors:!0});e.onBeforeCompile=this.overridePointShader;const i=this.createRange(t.geometry.boundingSphere.radius*2);this.pointsUuid=t.uuid,t.material=e,this.filterZAxisPoints(t),this.scene.add(t),this.scene.add(i),this.render()}clearPointCloud(){this.removeObjectByName(this.pointCloudObjectName)}clearPointCloudAndRender(){this.clearPointCloud(),this.render()}hightLightOriginPointCloud(t){const e=this.scene.getObjectByName(this.pointCloudObjectName);!e||(this.filterPointsColor(t,e.geometry.attributes.position.array,e.geometry.attributes.color.array),e.geometry.attributes.color.needsUpdate=!0,this.render())}getTextCanvas(t){const e=document.createElement("canvas"),i=e.getContext("2d");return i&&(i.font=`${50}px " bold`,i.fillStyle="white",i.textAlign="center",i.textBaseline="middle",i.fillText(t,e.width/2,e.height/2)),e}getSensesPointZAxisInPolygon(t){const e=this.scene.children.find(n=>n.uuid===this.pointsUuid);let i=0,s=0;if(e&&(e==null?void 0:e.geometry)){const n=e==null?void 0:e.geometry.attributes.position;for(let o=0;o<n.count;o++){const a=o*3,l=n.getX(a),h=n.getY(a),d=n.getZ(a);isInPolygon({x:l,y:h},t)&&d&&(s=Math.max(d,s),i=Math.min(d,i))}}return{maxZ:s,minZ:i}}getBasicCoordinate2Canvas(t){const e=this.containerWidth/2,i=this.containerHeight/2;return{x:t.x*e+e,y:t.y*i+i,z:t.z}}get basicCoordinate2CanvasMatrix4(){const t=this.containerWidth/2,e=this.containerHeight/2;return new THREE__namespace.Matrix4().set(t,0,0,t,0,e,0,e,0,0,1,0,0,0,0,1)}getCanvas2BasicCoordinate(t){const e=this.containerWidth/2,i=this.containerHeight/2;return new THREE__namespace.Vector3(t.x/e-e/2,-(t.y/i-i/2),1)}getPolygonSidePoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e+o/2,y:i+n/2,z:s-a/2},h={x:e+o/2,y:i+n/2,z:s+a/2},d={x:e-o/2,y:i+n/2,z:s+a/2},u={x:e-o/2,y:i+n/2,z:s-a/2};return[l,h,d,u]}getPolygonBackPoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e-o/2,y:i+n/2,z:s+a/2},h={x:e-o/2,y:i+n/2,z:s-a/2},d={x:e-o/2,y:i-n/2,z:s-a/2},u={x:e-o/2,y:i-n/2,z:s+a/2};return[l,h,d,u]}getPolygonTopPoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e+o/2,y:i+n/2,z:s+a/2},h={x:e+o/2,y:i-n/2,z:s+a/2},d={x:e-o/2,y:i-n/2,z:s+a/2},u={x:e-o/2,y:i+n/2,z:s+a/2};return[l,h,d,u]}getModelTransformationMatrix(t){const{center:{x:e,y:i,z:s},rotation:n}=t,o=new THREE__namespace.Matrix4().makeTranslation(-e,-i,-s),a=new THREE__namespace.Matrix4().makeTranslation(e,i,s),l=new THREE__namespace.Matrix4().makeRotationZ(n);return new THREE__namespace.Matrix4().multiply(a).multiply(l).multiply(o)}getBoxSidePolygon2DCoordinate(t){return this.getBoxPolygon2DCoordinate(t,lbUtils.EPerspectiveView.Left)}getBoxBackPolygon2DCoordinate(t){return this.getBoxPolygon2DCoordinate(t,lbUtils.EPerspectiveView.Back)}boxParams2ViewPolygon(t,e){switch(e){case lbUtils.EPerspectiveView.Left:return this.getPolygonSidePoints(t);case lbUtils.EPerspectiveView.Back:return this.getPolygonBackPoints(t);default:return this.getPolygonTopPoints(t)}}getBoxPolygon2DCoordinate(t,e){const i=this.boxParams2ViewPolygon(t,e),{width:s,height:n}=t,o=new THREE__namespace.Matrix4().premultiply(this.camera.matrixWorldInverse).premultiply(this.camera.projectionMatrix),a=new THREE__namespace.Matrix4().premultiply(this.getModelTransformationMatrix(t)).premultiply(o).premultiply(this.basicCoordinate2CanvasMatrix4);this.sideMatrix=a;const l=i.map(u=>new THREE__namespace.Vector3(u.x,u.y,u.z)).map(u=>u.applyMatrix4(this.sideMatrix)),h=this.containerWidth/s,d=this.containerHeight/n;return{polygon2d:l,zoom:Math.min(h,d)/2}}getBoxTopPolygon2DCoordinate(t){const{width:e,height:i}=t,n=this.getPolygonTopPoints(t).map(l=>new THREE__namespace.Vector3(l.x,l.y,l.z)).map(l=>l.applyMatrix4(this.getModelTransformationMatrix(t))).map(l=>({x:l.y,y:l.x})).map(l=>({x:-(l.x-this.containerWidth/2),y:-(l.y-this.containerHeight/2)})),o=this.containerWidth/e,a=this.containerHeight/i;return{polygon2d:n,zoom:Math.min(o,a)/2}}getNewBoxBySideUpdate(t,e,i,s){const n=new THREE__namespace.Matrix4().makeRotationZ(s.rotation),o=new THREE__namespace.Vector3(-t.x,0,0).applyMatrix4(n);let a=s;return a.center={x:a.center.x+o.x,y:a.center.y+o.y,z:a.center.z-t.z},a=__spreadProps(__spreadValues({},a),{width:a.width+e,height:a.height,depth:a.depth+i}),{newBoxParams:a}}getNewBoxByBackUpdate(t,e,i,s){const n=new THREE__namespace.Matrix4().makeRotationZ(s.rotation),o=new THREE__namespace.Vector3(0,-t.x,0).applyMatrix4(n);let a=s;return a.center={x:a.center.x+o.x,y:a.center.y+o.y,z:a.center.z-t.z},a=__spreadProps(__spreadValues({},a),{width:a.width,height:a.height+e,depth:a.depth+i}),{newBoxParams:a}}getNewBoxBySideUpdateByPoints(t,e,i,s){var n;const o=(n=this.sideMatrix)==null?void 0:n.invert();if(!this.sideMatrix||!o){console.error("No sideMatrix");return}this.camera.zoom=1,this.camera.updateProjectionMatrix();const a=t.map(v=>new THREE__namespace.Vector3(v.x,v.y,v.z)).map(v=>v.applyMatrix4(o)),[l,h,d,u]=a,c=Math.max(Math.abs(l.x-d.x),Math.abs(l.x-h.x)),p=h.add(u).applyMatrix3(new THREE__namespace.Matrix3().set(1/2,0,0,0,1/2,0,0,0,1/2)).clone().applyMatrix3(new THREE__namespace.Matrix3().set(-1,0,0,0,-1,0,0,0,-1)).add(new THREE__namespace.Vector3(s.center.x,s.center.y,s.center.z));return{newBoxParams:__spreadProps(__spreadValues({},s),{center:{x:s.center.x-p.x,y:s.center.y-p.y,z:s.center.z-i},width:c,height:s.height,depth:s.depth+e,rotation:s.rotation})}}filterZAxisPoints(t){const e=t||this.scene.children.find(i=>i.uuid===this.pointsUuid);if(e){const{attributes:i}=e.geometry,{position:s}=i,n=[],{count:o}=s;for(let a=0;a<o;a++){const l=s.getZ(a);n.push(l>this.zAxisLimit?0:1)}e.geometry.setAttribute("visibility",new THREE__namespace.Float32BufferAttribute(n,1)),e.geometry.attributes.visibility.needsUpdate=!0}}render(){this.renderer.render(this.scene,this.camera)}}class CanvasScheduler{constructor(t){this.container=t.container}createCanvas(t,e){if(typeof t!="string")return this.container.appendChild(t),t.style.position="absolute",t.style.left="0",t.style.top="0",t;const i=document.createElement("canvas");return i.id=t,e&&e.size&&(i.width=e.size.width,i.height=e.size.height),this.container.appendChild(i),i}destroyCanvas(t){const e=document.getElementById(t);return e&&this.container.removeChild(e),e}}const createEmptyImage=r=>{const t=document.createElement("canvas");t.width=r.width,t.height=r.height;const e=t.getContext("2d");return e?(e.fillStyle="black",e.fillRect(0,0,r.width,r.height),t.toDataURL()):""};class PointCloudAnnotation{constructor({size:t,container:e,pcdPath:i}){this.updatePolygonList=d=>{const u=d.map(c=>{const{polygon2d:g}=this.pointCloudInstance.getBoxTopPolygon2DCoordinate(c);return{id:c.id,sourceID:"",pointList:g,isRect:!0}});this.pointCloud2dOperation.setResult(u)};const s={left:-t.width/2,right:t.width/2,top:t.height/2,bottom:-t.height/2,near:100,far:-100},n=createEmptyImage(t),o=new Image;o.src=n;const a=new CanvasScheduler({container:e}),l=new PointCloud({container:e,noAppend:!0,isOrthographicCamera:!0,orthographicParams:s});i&&l.loadPCDFile(i),a.createCanvas(l.renderer.domElement);const h=new PointCloud2dOperation({container:e,size:t,config:'{ "textConfigurable": false }',imgNode:o,isAppend:!1});h.eventBinding(),h.setPattern(EPolygonPattern.Rect),a.createCanvas(h.canvas,{size:t}),this.pointCloud2dOperation=h,this.pointCloudInstance=l,this.canvasScheduler=a}addPolygonListOnTopView(t){const e=lbUtils.PointCloudUtils.getBoxParamsFromResultList(t);this.updatePolygonList(e)}updateData(t,e){!this.pointCloud2dOperation||!this.pointCloudInstance||(this.pointCloudInstance.loadPCDFile(t),this.addPolygonListOnTopView(e))}initAllPosition(){this.pointCloudInstance.updateTopCamera(),this.pointCloud2dOperation.initPosition()}clearAllData(){this.pointCloudInstance.clearPointCloudAndRender(),this.pointCloud2dOperation.clearResult()}}const CommonToolUtils=EnhanceCommonToolUtils,toolUtils=EnhanceCommonToolUtils;exports.AnnotationEngine=AnnotationEngine,exports.AxisUtils=AxisUtils,exports.BasicToolOperation=BasicToolOperation,exports.CanvasScheduler=CanvasScheduler,exports.CommonToolUtils=CommonToolUtils,exports.DblClickEventListener=DblClickEventListener,exports.DrawUtils=DrawUtils,exports.ImgUtils=ImgUtils,exports.LineToolOperation=LineToolOperation,exports.MarkerUtils=MarkerUtils,exports.MathUtils=MathUtils,exports.MeasureOperation=MeasureOperation,exports.PointCloud=PointCloud,exports.PointCloud2dOperation=PointCloud2dOperation,exports.PointCloudAnnotation=PointCloudAnnotation,exports.PointOperation=PointOperation,exports.PolygonOperation=PolygonOperation,exports.RectOperation=RectOperation,exports.RectUtils=RectUtils,exports.TagOperation=TagOperation,exports.TagUtils=TagUtil,exports.TextToolOperation=TextToolOperation,exports.UnitUtils=UnitUtils,exports.ViewOperation=ViewOperation,exports.cAnnotation=annotation,exports.cAnnotationTask=annotationTask,exports.cKeyCode=keyCode,exports.cStyle=style,exports.cTool=tool,exports.toolUtils=toolUtils,exports.uuid=uuid;
|
|
107
|
+
#include <clipping_planes_fragment>`)},this.loadPCDFile=(o,a)=>__async(this,null,function*(){this.clearPointCloud();const l=yield this.cacheInstance.loadPCDFile(o);l.name=this.pointCloudObjectName,this.renderPointCloud(l),a&&a()}),this.loadPCDFileByBox=(o,a,l)=>__async(this,null,function*(){this.clearPointCloud();const h=u=>{u.material.size=1;const{width:d=0,height:g=0,depth:p=0}=l!=null?l:{},f=this.filterPointsByBox(__spreadProps(__spreadValues({},a),{width:a.width+d,height:a.height+g,depth:a.depth+p}),u.geometry.attributes.position.array,u.geometry.attributes.color.array),v=new THREE__namespace.Points(f,u.material);v.name=this.pointCloudObjectName,this.scene.add(v),this.render()},c=yield this.cacheInstance.loadPCDFile(o);h(c)}),this.generateBoxArrow=({width:o,depth:a})=>{const l=new THREE__namespace.Vector3(1,0,0),h=new THREE__namespace.Vector3(-o/2,0,-a/2),c=o,u=16776960,d=new THREE__namespace.ArrowHelper(l,h,c,u);return d.visible=this.showDirection,d},this.generateBoxTrackID=o=>{const a=new THREE__namespace.Texture(this.getTextCanvas(o.trackID.toString()));a.needsUpdate=!0;const l=new THREE__namespace.SpriteMaterial({map:a,depthWrite:!1}),h=new THREE__namespace.Sprite(l);return h.scale.set(5,5,5),h.position.set(-o.width/2,0,o.depth/2+.5),h},this.applyZAxisPoints=o=>{this.zAxisLimit=o,this.filterZAxisPoints(),this.render()},this.updatePointSize=o=>{const a=this.scene.getObjectByName(this.pointCloudObjectName);if(!a)return;const l=a.material.size;o?a.material.size=Math.min(l*1.2,10):a.material.size=Math.max(l/1.2,1),this.render()},this.container=t,this.renderer=new THREE__namespace.WebGLRenderer({antialias:!0}),this.backgroundColor=n,i&&s?(this.isOrthographicCamera=!0,this.camera=new THREE__namespace.OrthographicCamera(s.left,s.right,s.top,s.bottom,s.near,s.far)):this.camera=new THREE__namespace.PerspectiveCamera(30,this.containerWidth/this.containerHeight,1,1e3),this.initCamera(),this.scene=new THREE__namespace.Scene,this.controls=new OrbitControls(this.camera,this.renderer.domElement),this.pcdLoader=new PCDLoader,this.axesHelper=new THREE__namespace.AxesHelper(1e3),this.scene.add(this.camera),e||t.appendChild(this.renderer.domElement),this.init(),this.cacheInstance=PointCloudCache.getInstance()}get containerWidth(){return this.container.clientWidth}get containerHeight(){return this.container.clientHeight}setInitCameraPosition(t){this.initCameraPosition=t}initCamera(){const{camera:t}=this;if(this.isOrthographicCamera){const{x:e,y:i,z:s}=this.initCameraPosition;t.position.set(e,i,s)}else t.position.set(-1,0,500);t.up.set(0,0,1)}initControls(){const{controls:t}=this,e=[0,0,0];t.target=new THREE__namespace.Vector3(...e),t.addEventListener("change",()=>{this.render()}),t.maxPolarAngle=Math.PI/2,t.update()}initRenderer(){const{renderer:t}=this;t.setPixelRatio(window.devicePixelRatio),t.setSize(this.containerWidth,this.containerHeight)}init(){const{scene:t}=this;t.background=new THREE__namespace.Color(this.backgroundColor),this.initControls(),this.initRenderer()}removeObjectByName(t){const e=this.scene.getObjectByName(t);e&&e.removeFromParent()}transferKitti2Matrix(t,e,i){const s=lbUtils.MatrixUtils.transferMatrix34FromKitti2Three(t),n=lbUtils.MatrixUtils.transferMatrix33FromKitti2Three(e),o=lbUtils.MatrixUtils.transferMatrix34FromKitti2Three(i),a=this.createThreeMatrix4(s),l=this.createThreeMatrix4(n),h=this.createThreeMatrix4(o);return{composeMatrix4:h.clone().premultiply(l).premultiply(a),PM:a,RM:l,TM:h}}pointCloudLidar2image(t,e){const i=lbUtils.PointCloudUtils.getAllViewData(t),{P:s,R:n,T:o}=e,{composeMatrix4:a}=this.transferKitti2Matrix(s,n,o);return i.map(h=>({type:h.type,pointList:h.pointList.map(c=>this.rotatePoint(c,t.center,t.rotation)).map(c=>this.lidar2image(c,a)).filter(c=>c!==void 0)}))}lidar2image(t,e){const s=new THREE__namespace.Vector4(t.x,t.y,t.z).applyMatrix4(e);if(s.z<0)return;const n=1/s.z,o=new THREE__namespace.Matrix4().set(n,0,0,0,0,n,0,0,0,0,n,0,0,0,0,1);return s.applyMatrix4(o)}generateBox(t,e=16777215){this.AddBoxToSense(t,e),this.render()}generateBoxes(t){t.forEach(e=>{this.generateBox(e)}),this.render()}getOrthographicCamera(t){const{center:e,width:i,height:s}=t,n=10,o=e.x-i/2-n,a=e.x-i/2+n,l=e.y+s/2+n,h=e.y-s/2-n,c=100,u=-100,d=500/c;return{left:o,right:a,top:l,bottom:h,near:c,far:u,zoom:d}}updateCameraByBox(t,e){const{center:i,width:s,height:n,depth:o,rotation:a}=t,l=this.getCameraVector(i,a,{width:s,height:n,depth:o},e);return this.updateCamera(l,i),l}updateOrthoCamera(t,e){const i=this.updateCameraByBox(t,e);return this.camera.zoom=1,this.camera.updateProjectionMatrix(),{cameraPositionVector:i}}updateTopCamera(){this.camera.zoom=1,this.initCamera(),this.initControls(),this.camera.updateProjectionMatrix(),this.render()}updateCamera(t,e){this.camera.position.set(t.x,t.y,t.z),this.controls.target=new THREE__namespace.Vector3(e.x,e.y,e.z),this.controls.update()}resetCamera(){this.updateCamera({x:-1,y:0,z:500},{x:0,y:0,z:0})}createThreeMatrix4(t){return new THREE__namespace.Matrix4().set(...t)}rotatePoint(t,e,i){var s;const n=new THREE__namespace.Vector3(t.x,t.y,(s=t==null?void 0:t.z)!=null?s:1),o=new THREE__namespace.Matrix4().makeRotationZ(i),a=new THREE__namespace.Matrix4().makeTranslation(e.x,e.y,e.z),l=new THREE__namespace.Matrix4().makeTranslation(-e.x,-e.y,-e.z);return n.clone().applyMatrix4(l).applyMatrix4(o).applyMatrix4(a)}getCuboidFromPointCloudBox(t){const{center:e,width:i,height:s,depth:n,rotation:o}=t,a=[{x:e.x+i/2,y:e.y+s/2},{x:e.x+i/2,y:e.y-s/2},{x:e.x-i/2,y:e.y-s/2},{x:e.x-i/2,y:e.y+s/2}].map(c=>{const u=this.rotatePoint(c,e,o);return{x:u.x,y:u.y}}),l=e.z+n/2,h=e.z-n/2;return{polygonPointList:a,zMax:l,zMin:h}}filterPointsByBox(t,e,i){const s=[],n=[],{zMin:o,zMax:a,polygonPointList:l}=this.getCuboidFromPointCloudBox(t);for(let c=0;c<e.length;c+=3){const u=e[c],d=e[c+1],g=e[c+2];isInPolygon({x:u,y:d},l)&&g>=o&&g<=a&&(s.push(u),s.push(d),s.push(g),n.push(i[c]),n.push(i[c+1]),n.push(i[c+2]))}const h=new THREE__namespace.BufferGeometry;return h.setAttribute("position",new THREE__namespace.Float32BufferAttribute(s,3)),h.setAttribute("color",new THREE__namespace.Float32BufferAttribute(n,3)),h.computeBoundingSphere(),h}filterPointsColor(t,e,i){const{zMin:s,zMax:n,polygonPointList:o}=this.getCuboidFromPointCloudBox(t);for(let a=0;a<e.length;a+=3){const l=e[a],h=e[a+1],c=e[a+2];if(isInPolygon({x:l,y:h},o)&&c>=s&&c<=n)i[a]=0,i[a+1]=1,i[a+2]=1;else{const[d,g,p]=lbUtils.PointCloudUtils.getStandardColorByCoord(l,h,c);i[a]=d,i[a+1]=g,i[a+2]=p}}}getCameraVector(t,e,i,s=lbUtils.EPerspectiveView.Front,n=DEFAULT_DISTANCE){let o=lbUtils.PerspectiveShiftUtils.frontViewMatrix4(n);switch(s){case lbUtils.EPerspectiveView.Front:break;case lbUtils.EPerspectiveView.Back:o=lbUtils.PerspectiveShiftUtils.backViewMatrix4(n);break;case lbUtils.EPerspectiveView.Left:o=lbUtils.PerspectiveShiftUtils.leftViewMatrix4(n);break;case lbUtils.EPerspectiveView.Right:o=lbUtils.PerspectiveShiftUtils.rightViewMatrix4(n);break;case lbUtils.EPerspectiveView.Top:o=lbUtils.PerspectiveShiftUtils.topViewMatrix4(n);break;case lbUtils.EPerspectiveView.LFT:o=lbUtils.PerspectiveShiftUtils.leftFrontTopViewMatrix4(n,i);break;case lbUtils.EPerspectiveView.RBT:o=lbUtils.PerspectiveShiftUtils.rightBackTopViewMatrix4(n,i);break}const a=this.createThreeMatrix4(o),l=new THREE__namespace.Matrix4().makeTranslation(-t.x,-t.y,-t.z),h=new THREE__namespace.Matrix4().makeTranslation(t.x,t.y,t.z),c=new THREE__namespace.Matrix4().makeRotationZ(e);return new THREE__namespace.Vector3(t.x,t.y,t.z).clone().applyMatrix4(a).applyMatrix4(l).applyMatrix4(c).applyMatrix4(h)}createRange(t){this.removeObjectByName(this.rangeObjectName);const i=new THREE__namespace.EllipseCurve(0,0,t,t,0,2*Math.PI,!1,0).getPoints(50),s=new THREE__namespace.BufferGeometry().setFromPoints(i),n=new THREE__namespace.LineBasicMaterial({color:16711680}),o=new THREE__namespace.Line(s,n);return o.name=this.rangeObjectName,o}renderPointCloud(t){t.material.size=1,t.name=this.pointCloudObjectName;const e=new THREE__namespace.PointsMaterial({vertexColors:!0});e.onBeforeCompile=this.overridePointShader;const i=this.createRange(t.geometry.boundingSphere.radius*2);this.pointsUuid=t.uuid,t.material=e,this.filterZAxisPoints(t),this.scene.add(t),this.scene.add(i),this.render()}clearPointCloud(){this.removeObjectByName(this.pointCloudObjectName)}clearPointCloudAndRender(){this.clearPointCloud(),this.render()}hightLightOriginPointCloud(t){const e=this.scene.getObjectByName(this.pointCloudObjectName);!e||(this.filterPointsColor(t,e.geometry.attributes.position.array,e.geometry.attributes.color.array),e.geometry.attributes.color.needsUpdate=!0,this.render())}setShowDirection(t){this.showDirection=t,this.scene.children.forEach(e=>{e.type==="Group"&&e.children.forEach(i=>{i.type==="ArrowHelper"&&(i.visible=t)})}),this.render()}getTextCanvas(t){const e=document.createElement("canvas"),i=e.getContext("2d");return i&&(i.font=`${50}px " bold`,i.fillStyle="white",i.textAlign="center",i.textBaseline="middle",i.fillText(t,e.width/2,e.height/2)),e}getSensesPointZAxisInPolygon(t){const e=this.scene.children.find(n=>n.uuid===this.pointsUuid);let i=0,s=0;if(e&&(e==null?void 0:e.geometry)){const n=e==null?void 0:e.geometry.attributes.position;for(let o=0;o<n.count;o++){const a=o*3,l=n.getX(a),h=n.getY(a),c=n.getZ(a);isInPolygon({x:l,y:h},t)&&c&&(s=Math.max(c,s),i=Math.min(c,i))}}return{maxZ:s,minZ:i}}getBasicCoordinate2Canvas(t){const e=this.containerWidth/2,i=this.containerHeight/2;return{x:t.x*e+e,y:t.y*i+i,z:t.z}}get basicCoordinate2CanvasMatrix4(){const t=this.containerWidth/2,e=this.containerHeight/2;return new THREE__namespace.Matrix4().set(t,0,0,t,0,e,0,e,0,0,1,0,0,0,0,1)}getCanvas2BasicCoordinate(t){const e=this.containerWidth/2,i=this.containerHeight/2;return new THREE__namespace.Vector3(t.x/e-e/2,-(t.y/i-i/2),1)}getPolygonSidePoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e+o/2,y:i+n/2,z:s-a/2},h={x:e+o/2,y:i+n/2,z:s+a/2},c={x:e-o/2,y:i+n/2,z:s+a/2},u={x:e-o/2,y:i+n/2,z:s-a/2};return[l,h,c,u]}getPolygonBackPoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e-o/2,y:i+n/2,z:s+a/2},h={x:e-o/2,y:i+n/2,z:s-a/2},c={x:e-o/2,y:i-n/2,z:s-a/2},u={x:e-o/2,y:i-n/2,z:s+a/2};return[l,h,c,u]}getPolygonTopPoints(t){const{center:{x:e,y:i,z:s},height:n,width:o,depth:a}=t,l={x:e+o/2,y:i+n/2,z:s+a/2},h={x:e+o/2,y:i-n/2,z:s+a/2},c={x:e-o/2,y:i-n/2,z:s+a/2},u={x:e-o/2,y:i+n/2,z:s+a/2};return[l,h,c,u]}getModelTransformationMatrix(t){const{center:{x:e,y:i,z:s},rotation:n}=t,o=new THREE__namespace.Matrix4().makeTranslation(-e,-i,-s),a=new THREE__namespace.Matrix4().makeTranslation(e,i,s),l=new THREE__namespace.Matrix4().makeRotationZ(n);return new THREE__namespace.Matrix4().multiply(a).multiply(l).multiply(o)}getBoxSidePolygon2DCoordinate(t){return this.getBoxPolygon2DCoordinate(t,lbUtils.EPerspectiveView.Left)}getBoxBackPolygon2DCoordinate(t){return this.getBoxPolygon2DCoordinate(t,lbUtils.EPerspectiveView.Back)}boxParams2ViewPolygon(t,e){switch(e){case lbUtils.EPerspectiveView.Left:return this.getPolygonSidePoints(t);case lbUtils.EPerspectiveView.Back:return this.getPolygonBackPoints(t);default:return this.getPolygonTopPoints(t)}}getBoxPolygon2DCoordinate(t,e){const i=this.boxParams2ViewPolygon(t,e),{width:s,height:n}=t,o=new THREE__namespace.Matrix4().premultiply(this.camera.matrixWorldInverse).premultiply(this.camera.projectionMatrix),a=new THREE__namespace.Matrix4().premultiply(this.getModelTransformationMatrix(t)).premultiply(o).premultiply(this.basicCoordinate2CanvasMatrix4);this.sideMatrix=a;const l=i.map(u=>new THREE__namespace.Vector3(u.x,u.y,u.z)).map(u=>u.applyMatrix4(this.sideMatrix)),h=this.containerWidth/s,c=this.containerHeight/n;return{polygon2d:l,zoom:Math.min(h,c)/2}}getBoxTopPolygon2DCoordinate(t){const{width:e,height:i}=t,n=this.getPolygonTopPoints(t).map(l=>new THREE__namespace.Vector3(l.x,l.y,l.z)).map(l=>l.applyMatrix4(this.getModelTransformationMatrix(t))).map(l=>({x:l.y,y:l.x})).map(l=>({x:-(l.x-this.containerWidth/2),y:-(l.y-this.containerHeight/2)})),o=this.containerWidth/e,a=this.containerHeight/i;return{polygon2d:n,zoom:Math.min(o,a)/2}}getNewBoxBySideUpdate(t,e,i,s){const n=new THREE__namespace.Matrix4().makeRotationZ(s.rotation),o=new THREE__namespace.Vector3(-t.x,0,0).applyMatrix4(n);let a=s;return a.center={x:a.center.x+o.x,y:a.center.y+o.y,z:a.center.z-t.z},a=__spreadProps(__spreadValues({},a),{width:a.width+e,height:a.height,depth:a.depth+i}),{newBoxParams:a}}getNewBoxByBackUpdate(t,e,i,s){const n=new THREE__namespace.Matrix4().makeRotationZ(s.rotation),o=new THREE__namespace.Vector3(0,-t.x,0).applyMatrix4(n);let a=s;return a.center={x:a.center.x+o.x,y:a.center.y+o.y,z:a.center.z-t.z},a=__spreadProps(__spreadValues({},a),{width:a.width,height:a.height+e,depth:a.depth+i}),{newBoxParams:a}}getNewBoxBySideUpdateByPoints(t,e,i,s){var n;const o=(n=this.sideMatrix)==null?void 0:n.invert();if(!this.sideMatrix||!o){console.error("No sideMatrix");return}this.camera.zoom=1,this.camera.updateProjectionMatrix();const a=t.map(v=>new THREE__namespace.Vector3(v.x,v.y,v.z)).map(v=>v.applyMatrix4(o)),[l,h,c,u]=a,d=Math.max(Math.abs(l.x-c.x),Math.abs(l.x-h.x)),p=h.add(u).applyMatrix3(new THREE__namespace.Matrix3().set(1/2,0,0,0,1/2,0,0,0,1/2)).clone().applyMatrix3(new THREE__namespace.Matrix3().set(-1,0,0,0,-1,0,0,0,-1)).add(new THREE__namespace.Vector3(s.center.x,s.center.y,s.center.z));return{newBoxParams:__spreadProps(__spreadValues({},s),{center:{x:s.center.x-p.x,y:s.center.y-p.y,z:s.center.z-i},width:d,height:s.height,depth:s.depth+e,rotation:s.rotation})}}filterZAxisPoints(t){const e=t||this.scene.children.find(i=>i.uuid===this.pointsUuid);if(e){const{attributes:i}=e.geometry,{position:s}=i,n=[],{count:o}=s;for(let a=0;a<o;a++){const l=s.getZ(a);n.push(l>this.zAxisLimit?0:1)}e.geometry.setAttribute("visibility",new THREE__namespace.Float32BufferAttribute(n,1)),e.geometry.attributes.visibility.needsUpdate=!0}}render(){this.renderer.render(this.scene,this.camera)}}class CanvasScheduler{constructor(t){this.container=t.container}createCanvas(t,e){if(typeof t!="string")return this.container.appendChild(t),t.style.position="absolute",t.style.left="0",t.style.top="0",t;const i=document.createElement("canvas");return i.id=t,e&&e.size&&(i.width=e.size.width,i.height=e.size.height),this.container.appendChild(i),i}destroyCanvas(t){const e=document.getElementById(t);return e&&this.container.removeChild(e),e}}const createEmptyImage=r=>{const t=document.createElement("canvas");t.width=r.width,t.height=r.height;const e=t.getContext("2d");return e?(e.fillStyle="black",e.fillRect(0,0,r.width,r.height),t.toDataURL()):""};class PointCloudAnnotation{constructor({size:t,container:e,pcdPath:i,polygonOperationProps:s}){this.updatePolygonList=(d,g)=>{let p=d.map(f=>{const{polygon2d:v}=this.pointCloudInstance.getBoxTopPolygon2DCoordinate(f);return{id:f.id,sourceID:"",pointList:v,isRect:!0}});g&&(p=p.concat(g)),this.pointCloud2dOperation.setResult(p)};const n={left:-t.width/2,right:t.width/2,top:t.height/2,bottom:-t.height/2,near:100,far:-100},o=createEmptyImage(t),a=new Image;a.src=o;const l=new CanvasScheduler({container:e}),h=new PointCloud({container:e,noAppend:!0,isOrthographicCamera:!0,orthographicParams:n});i&&h.loadPCDFile(i),l.createCanvas(h.renderer.domElement);const c={container:e,size:t,config:'{ "textConfigurable": false }',imgNode:a,isAppend:!1};s&&Object.assign(c,s);const u=new PointCloud2dOperation(c);u.eventBinding(),u.setPattern(EPolygonPattern.Rect),l.createCanvas(u.canvas,{size:t}),this.pointCloud2dOperation=u,this.pointCloudInstance=h,this.canvasScheduler=l}addPolygonListOnTopView(t){const e=lbUtils.PointCloudUtils.getBoxParamsFromResultList(t),i=lbUtils.PointCloudUtils.getPolygonListFromResultList(t);this.updatePolygonList(e,i)}updateData(t,e){!this.pointCloud2dOperation||!this.pointCloudInstance||(this.pointCloudInstance.loadPCDFile(t),this.addPolygonListOnTopView(e))}initAllPosition(){this.pointCloudInstance.updateTopCamera(),this.pointCloud2dOperation.initPosition()}clearAllData(){this.pointCloudInstance.clearPointCloudAndRender(),this.pointCloud2dOperation.clearResult()}}const CommonToolUtils=EnhanceCommonToolUtils,toolUtils=EnhanceCommonToolUtils;exports.AnnotationEngine=AnnotationEngine,exports.AxisUtils=AxisUtils,exports.BasicToolOperation=BasicToolOperation,exports.CanvasScheduler=CanvasScheduler,exports.CommonToolUtils=CommonToolUtils,exports.DblClickEventListener=DblClickEventListener,exports.DrawUtils=DrawUtils,exports.ImgUtils=ImgUtils,exports.LineToolOperation=LineToolOperation,exports.MarkerUtils=MarkerUtils,exports.MathUtils=MathUtils,exports.MeasureOperation=MeasureOperation,exports.PointCloud=PointCloud,exports.PointCloud2dOperation=PointCloud2dOperation,exports.PointCloudAnnotation=PointCloudAnnotation,exports.PointOperation=PointOperation,exports.PolygonOperation=PolygonOperation,exports.RectOperation=RectOperation,exports.RectUtils=RectUtils,exports.TagOperation=TagOperation,exports.TagUtils=TagUtil,exports.TextToolOperation=TextToolOperation,exports.UnitUtils=UnitUtils,exports.ViewOperation=ViewOperation,exports.cAnnotation=annotation,exports.cAnnotationTask=annotationTask,exports.cKeyCode=keyCode,exports.cStyle=style,exports.cTool=tool,exports.toolUtils=toolUtils,exports.uuid=uuid;
|