@labelbee/lb-annotation 1.28.0-alpha.21 → 1.28.0-alpha.23

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.
@@ -1 +1 @@
1
- "use strict";var _rollupPluginWebWorkerLoader__helper__browser__createBase64WorkerFactory=require("./_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js"),WorkerFactory=_rollupPluginWebWorkerLoader__helper__browser__createBase64WorkerFactory.createBase64WorkerFactory("Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwp2YXIgd29ya2VyX2NvZGU9ZnVuY3Rpb24ocCl7InVzZSBzdHJpY3QiO2NvbnN0IHY9Wy0xLC0xLC0xXTtsZXQgST0hMTtmdW5jdGlvbiBCKGUpe2NvbnN0IHQ9LTcsbz0zLG49by10O3JldHVybiBlPHQmJihlPXQpLGU+byYmKGU9byksTWF0aC5mbG9vcigoZS10KS9uKjI1NSl9ZnVuY3Rpb24gRSgpe2xldCBlO2NvbnN0IHQ9bmV3IEFycmF5KDI1NikuZmlsbCgiIikubWFwKCgpPT5uZXcgQXJyYXkoMykuZmlsbCgiIikpO2ZvcihsZXQgbz0wO288MjA7bysrKXtmb3IoZT0wO2U8MzI7ZSsrKXRbZV1bMF09MTI4KzQqZSx0W2VdWzFdPTAsdFtlXVsyXT0wO2Zvcih0WzMyXVswXT0yNTUsdFszMl1bMV09MCx0WzMyXVsyXT0wLGU9MDtlPDYzO2UrKyl0WzMzK2VdWzBdPTI1NSx0WzMzK2VdWzFdPTQrNCplLHRbMzMrZV1bMl09MDtmb3IodFs5Nl1bMF09MjU0LHRbOTZdWzFdPTI1NSx0Wzk2XVsyXT0yLGU9MDtlPDYyO2UrKyl0Wzk3K2VdWzBdPTI1MC00KmUsdFs5NytlXVsxXT0yNTUsdFs5NytlXVsyXT02KzQqZTtmb3IodFsxNTldWzBdPTEsdFsxNTldWzFdPTI1NSx0WzE1OV1bMl09MjU0LGU9MDtlPDY0O2UrKyl0WzE2MCtlXVswXT0wLHRbMTYwK2VdWzFdPTI1Mi1lKjQsdFsxNjArZV1bMl09MjU1O2ZvcihlPTA7ZTwzMjtlKyspdFsyMjQrZV1bMF09MCx0WzIyNCtlXVsxXT0wLHRbMjI0K2VdWzJdPTI1Mi00KmV9cmV0dXJuIHR9Y29uc3QgUj1FKCk7ZnVuY3Rpb24gaChlLHQsbz0wKXtsZXQgbj0wLGEseCxpLGw7dD1bLi4udF0sbz09PTEmJih0PWNyZWF0ZVNtb290aEN1cnZlUG9pbnRzKHQucmVkdWNlKCh5LGMpPT5bLi4ueSxjLngsYy55XSxbXSksLjUsITAsU0VHTUVOVF9OVU1CRVIpKSxbaV09dDtjb25zdCB1PXQubGVuZ3RoO2ZvcihhPTE7YTw9dTthKyspbD10W2EldV0sZS54Pk1hdGgubWluKGkueCxsLngpJiZlLng8PU1hdGgubWF4KGkueCxsLngpJiZlLnk8PU1hdGgubWF4KGkueSxsLnkpJiZpLnghPT1sLngmJih4PShlLngtaS54KSoobC55LWkueSkvKGwueC1pLngpK2kueSwoaS55PT09bC55fHxlLnk8PXgpJiZuKyspLGk9bDtyZXR1cm4gbiUyIT0wfWZ1bmN0aW9uIE8oe3pNaW46ZSx6TWF4OnQscG9seWdvblBvaW50TGlzdDpvLGF0dHJpYnV0ZTpuLHg6YSx5OngsejppLGNvbG9yTGlzdDpsLHZhbGlkOnV9KXtpZihoKHt4OmEseTp4fSxvKSYmaT49ZSYmaTw9dClyZXR1cm4gdT09PSExP1sxLDEwMy8yNTUsMTAyLzI1NV06bFtuXT9sW25dLnJnYmEuc2xpY2UoMCwzKS5tYXAoYz0+Yy8yNTUpOlsxLDAsMF19ZnVuY3Rpb24gbShlKXtjb25zdCB0PUIoZSksbz1SW3RdLFtuLGEseF09bztyZXR1cm5bbi8yNTUsYS8yNTUseC8yNTVdfXJldHVybiBvbm1lc3NhZ2U9ZnVuY3Rpb24odCl7Y29uc3R7cG9zaXRpb246byxjb2xvcjpuLGN1Ym9pZExpc3Q6YSxjb2xvckxpc3Q6eCxoaWdobGlnaHRJbmRleDppfT10LmRhdGE7bGV0e21vZGlmaWVkQm94SWRzOmw9W10scmVzZXRBcmVhczp1PVtdfT10LmRhdGEseT0wO2Z1bmN0aW9uIGMoKXt5Kz0xfWlmKCFvKXJldHVybjtjb25zdCBfPSEhKGk9PW51bGw/dm9pZCAwOmkubGVuZ3RoKTsoX3x8SSkmJihsPVtdLHU9W10pO2NvbnN0IHc9bC5sZW5ndGg/YS5maWx0ZXIocj0+bC5pbmNsdWRlcyhyLmlkKSk6YTtmb3IobGV0IHI9MDtyPG8ubGVuZ3RoO3IrPTMpe2NvbnN0IEM9b1tyXSxMPW9bcisxXSxkPW9bcisyXTtsZXQgZztpZih1Lmxlbmd0aD09PTEmJiFsLmxlbmd0aCloKHt4OkMseTpMfSx1WzBdKT9nPW0oZCk6Zz12O2Vsc2UgaWYodS5sZW5ndGh8fGwubGVuZ3RoKXtsZXQgcz0hMTt3LnNvbWUoZj0+e2NvbnN0IE09Tyh7cG9seWdvblBvaW50TGlzdDpmLnBvbHlnb25Qb2ludExpc3Qsek1pbjpmLnpNaW4sek1heDpmLnpNYXgseDpDLHk6TCx6OmQsYXR0cmlidXRlOmYuYXR0cmlidXRlLGNvbG9yTGlzdDp4LHZhbGlkOmYudmFsaWR9KTtyZXR1cm4gTT8oYygpLGc9TSxzPSEwLCEwKTohMX0pLCFzJiZ1Lmxlbmd0aCYmKHM9dS5zb21lKGY9Pmgoe3g6Qyx5Okx9LGYpPyhnPW0oZCksITApOiExKSksIXMmJiFfJiYoST9nPW0oZCk6Zz12KX1lbHNlIHcuc29tZShzPT57Y29uc3QgZj1PKHtwb2x5Z29uUG9pbnRMaXN0OnMucG9seWdvblBvaW50TGlzdCx6TWluOnMuek1pbix6TWF4OnMuek1heCx4OkMseTpMLHo6ZCxhdHRyaWJ1dGU6cy5hdHRyaWJ1dGUsY29sb3JMaXN0OngsdmFsaWQ6cy52YWxpZH0pO3JldHVybiBmPyhjKCksZz1mLCEwKTohMX0pO2NvbnN0IEE9cz0+e2NvbnN0IGY9TWF0aC5mbG9vcihzLzMpO3JldHVybiBpJiZpW2ZdPT09MX07aWYoZylpZihnWzBdPT09dlswXSYmQShyKSluW3JdPTAsbltyKzFdPTAsbltyKzJdPTA7ZWxzZXtjb25zdFtzLGYsTV09ZztuW3JdPXMsbltyKzFdPWYsbltyKzJdPU19ZWxzZSBpZihBKHIpKW5bcl09MCxuW3IrMV09MCxuW3IrMl09MDtlbHNle2NvbnN0W3MsZixNXT1tKGQpO25bcl09cyxuW3IrMV09ZixuW3IrMl09TX19ST1fLHBvc3RNZXNzYWdlKHtwb2ludHM6byxjb2xvcjpuLG51bTp5fSl9LHAuaXNJblBvbHlnb249aCxPYmplY3QuZGVmaW5lUHJvcGVydHkocCwiX19lc01vZHVsZSIse3ZhbHVlOiEwfSkscH0oe30pOwoK",null,!1);module.exports=WorkerFactory;
1
+ "use strict";var _rollupPluginWebWorkerLoader__helper__browser__createBase64WorkerFactory=require("./_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js"),WorkerFactory=_rollupPluginWebWorkerLoader__helper__browser__createBase64WorkerFactory.createBase64WorkerFactory("/* rollup-plugin-web-worker-loader */
var worker_code=function(w){"use strict";function q(i,t){const{polygonPointList:e,zMin:n,zMax:r,attribute:c,valid:s,id:h}=i;let l=Infinity,m=-Infinity,f=Infinity,d=-Infinity;const u=e.length;for(let a=0;a<u;a++){const{x,y:X}=e[a];l=x<l?x:l,m=x>m?x:m,f=X<f?X:f,d=X>d?X:d}let o;if(s===!1)o=[1,.4039,.4];else if(t&&t[c]){const{rgba:a}=t[c];o=[a[0]/255,a[1]/255,a[2]/255]}else o=[1,0,0];return{id:h,minX:l,maxX:m,minY:f,maxY:d,zMin:n,zMax:r,width:m-l,height:d-f,depth:r-n,centerX:(l+m)*.5,centerY:(f+d)*.5,centerZ:(n+r)*.5,polygonPointList:e,colorInfo:o,attribute:c,valid:s}}function E(i){if(!i||i.length===0)return{minX:0,maxX:1,minY:0,maxY:1,minZ:0,maxZ:1,width:1,height:1,depth:1};let t=Infinity,e=-Infinity,n=Infinity,r=-Infinity,c=Infinity,s=-Infinity;const h=i.length;for(let u=0;u<h;u+=3){const o=i[u],a=i[u+1],x=i[u+2];o<t&&(t=o),o>e&&(e=o),a<n&&(n=a),a>r&&(r=a),x<c&&(c=x),x>s&&(s=x)}const l=Math.max(e-t,r-n)*.01,m=e-t+l*2,f=r-n+l*2,d=s-c;return{minX:t-l,maxX:e+l,minY:n-l,maxY:r+l,minZ:c,maxZ:s,width:m,height:f,depth:d,centerX:(t+e)*.5,centerY:(n+r)*.5}}class Z{constructor(t,e=16,n=6,r=0){this.minX=t.minX,this.maxX=t.maxX,this.minY=t.minY,this.maxY=t.maxY,this.minZ=t.minZ||-Infinity,this.maxZ=t.maxZ||Infinity,this.width=t.width||this.maxX-this.minX,this.height=t.height||this.maxY-this.minY,this.centerX=t.centerX||(this.minX+this.maxX)*.5,this.centerY=t.centerY||(this.minY+this.maxY)*.5,this.capacity=e,this.maxLevel=n,this.level=r,this.cuboids=[],this.divided=!1,this.children=null,this.pointCount=0}containsPoint(t,e,n){return(t-this.minX)*(this.maxX-t)>=0&&(e-this.minY)*(this.maxY-e)>=0&&(n-this.minZ)*(this.maxZ-n)>=0}intersectsCuboid(t){return!(t.maxX<this.minX||t.minX>this.maxX||t.maxY<this.minY||t.minY>this.maxY||t.zMax<this.minZ||t.zMin>this.maxZ)}subdivide(){if(this.divided)return;const t=this.width*.5,e=this.height*.5,n=this.level+1;this.children=[new Z({minX:this.minX,maxX:this.centerX,minY:this.minY,maxY:this.centerY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.centerX,maxX:this.maxX,minY:this.minY,maxY:this.centerY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.minX,maxX:this.centerX,minY:this.centerY,maxY:this.maxY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.centerX,maxX:this.maxX,minY:this.centerY,maxY:this.maxY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n)],this.divided=!0;const r=this.cuboids.length;for(let c=0;c<r;c++){const s=this.cuboids[c];for(let h=0;h<4;h++)this.children[h].intersectsCuboid(s)&&this.children[h].insert(s)}this.level>0&&(this.cuboids=[])}insert(t){if(!this.intersectsCuboid(t))return!1;if(this.divided){let e=!1;for(let n=0;n<4;n++)this.children[n].insert(t)&&(e=!0);return this.level===0&&this.cuboids.push(t),e}return this.cuboids.push(t),this.pointCount++,this.pointCount>this.capacity&&this.level<this.maxLevel&&this.subdivide(),!0}_findCuboidContainingPoint(t,e,n){const r=this.cuboids.length;for(let c=0;c<r;c++){const s=this.cuboids[c];if(n<s.zMin||n>s.zMax||t<s.minX||t>s.maxX||e<s.minY||e>s.maxY)continue;const h=s.polygonPointList;let l=!1;for(let m=0,f=h.length-1;m<h.length;f=m++){const d=h[m].x,u=h[m].y,o=h[f].x,a=h[f].y;u>e!=a>e&&t<(o-d)*(e-u)/(a-u)+d&&(l=!l)}if(l)return{cuboid:s,colorInfo:s.colorInfo}}return null}queryPoint(t){const{x:e,y:n,z:r}=t;if(e<this.minX||e>this.maxX||n<this.minY||n>this.maxY||r<this.minZ||r>this.maxZ)return null;if(!this.divided)return this._findCuboidContainingPoint(e,n,r);const c=(n<this.centerY?0:2)+(e<this.centerX?0:1);let s=this.children[c].queryPoint(t);if(!s)for(let h=0;h<4&&!(h!==c&&(s=this.children[h].queryPoint(t),s));h++);return!s&&this.level===0&&(s=this._findCuboidContainingPoint(e,n,r)),s}clear(){if(this.cuboids=[],this.pointCount=0,this.divided){for(let t=0;t<4;t++)this.children[t]&&this.children[t].clear();this.divided=!1,this.children=null}}}const M=[-1,-1,-1];let b=!1,C=null;const I=new Map;function O(i){const t=-7,e=3,n=e-t;return i<t&&(i=t),i>e&&(i=e),Math.floor((i-t)/n*255)}function _(){let i;const t=new Array(256).fill("").map(()=>new Array(3).fill(""));for(i=0;i<32;i++)t[i][0]=128+4*i,t[i][1]=0,t[i][2]=0;for(t[32][0]=255,t[32][1]=0,t[32][2]=0,i=0;i<63;i++)t[33+i][0]=255,t[33+i][1]=4+4*i,t[33+i][2]=0;for(t[96][0]=254,t[96][1]=255,t[96][2]=2,i=0;i<62;i++)t[97+i][0]=250-4*i,t[97+i][1]=255,t[97+i][2]=6+4*i;for(t[159][0]=1,t[159][1]=255,t[159][2]=254,i=0;i<64;i++)t[160+i][0]=0,t[160+i][1]=252-i*4,t[160+i][2]=255;for(i=0;i<32;i++)t[224+i][0]=0,t[224+i][1]=0,t[224+i][2]=252-4*i;return t}const A=_();function L(i,t,e=0){let n=0,r,c,s,h;e===1&&(t=createSmoothCurvePoints(t.reduce((m,f)=>[...m,f.x,f.y],[]),.5,!0,SEGMENT_NUMBER)),[s]=t;const l=t.length;for(r=1;r<=l;r++)h=t[r%l],i.x>Math.min(s.x,h.x)&&i.x<=Math.max(s.x,h.x)&&i.y<=Math.max(s.y,h.y)&&s.x!==h.x&&(c=(i.x-s.x)*(h.y-s.y)/(h.x-s.x)+s.y,(s.y===h.y||i.y<=c)&&n++),s=h;return n%2!=0}function p(i){const t=Math.round(i*1e3)/1e3;if(I.has(t))return I.get(t);const e=O(i),n=A[e],[r,c,s]=n,h=[r/255,c/255,s/255];return I.set(t,h),h}return onmessage=function(t){const{position:e,color:n,cuboidList:r,colorList:c,highlightIndex:s}=t.data;let{modifiedBoxIds:h=[],resetAreas:l=[]}=t.data;I.clear();let m=0;function f(){m+=1}if(!e)return;const d=!!(s==null?void 0:s.length);(d||b)&&(h=[],l=[]);const u=h.length?r.filter(o=>h.includes(o.id)):r;if(C)C.clear();else{const o=E(e);C=new Z(o,32,6)}u.forEach(o=>{const a=q(o,c);C.insert(a)});for(let o=0;o<e.length;o+=3){const a=e[o],x=e[o+1],X=e[o+2];let Y;if(l.length===1&&!h.length)L({x:a,y:x},l[0])?Y=p(X):Y=M;else if(l.length||h.length){let g=!1;const y=C.queryPoint({x:a,y:x,z:X});y&&(f(),Y=y.colorInfo,g=!0),!g&&l.length&&(g=l.some(v=>L({x:a,y:x},v)?(Y=p(X),!0):!1)),!g&&!d&&(b?Y=p(X):Y=M)}else{const g=C.queryPoint({x:a,y:x,z:X});g&&(f(),Y=g.colorInfo)}const P=g=>{const y=Math.floor(g/3);return s&&s[y]===1};if(Y)if(Y[0]===M[0]&&P(o))n[o]=0,n[o+1]=0,n[o+2]=0;else{const[g,y,v]=Y;n[o]=g,n[o+1]=y,n[o+2]=v}else if(P(o))n[o]=0,n[o+1]=0,n[o+2]=0;else{const[g,y,v]=p(X);n[o]=g,n[o+1]=y,n[o+2]=v}}b=d,postMessage({points:e,color:n,num:m})},w.isInPolygon=L,Object.defineProperty(w,"__esModule",{value:!0}),w}({});

",null,!1);module.exports=WorkerFactory;
@@ -0,0 +1,78 @@
1
+ /**
2
+ * 2.5D QuadTree implementation
3
+ * For efficient indexing and querying of cuboids in point cloud data
4
+ * Uses quadtree division on XY plane, while storing Z-axis range information in each node
5
+ */
6
+ /**
7
+ * Preprocess cuboid by adding bounding box information and color
8
+ * @param {Object} cuboid - Cuboid object
9
+ * @param {Object} colorList - Color list
10
+ * @returns {Object} - Cuboid object with boundary info and color
11
+ */
12
+ export function preprocessCuboid(cuboid: Object, colorList: Object): Object;
13
+ /**
14
+ * Calculate point cloud boundaries
15
+ * @param {Array} points - Point cloud data array
16
+ * @returns {Object} - Boundary information
17
+ */
18
+ export function getBoundaryFromPoints(points: any[]): Object;
19
+ /**
20
+ * 2.5D QuadTree class - High performance implementation
21
+ */
22
+ export class QuadTree25D {
23
+ /**
24
+ * Create quadtree node
25
+ * @param {Object} boundary - Boundary
26
+ * @param {number} capacity - Node capacity
27
+ * @param {number} maxLevel - Max depth
28
+ * @param {number} level - Current depth
29
+ */
30
+ constructor(boundary: Object, capacity?: number, maxLevel?: number, level?: number);
31
+ minX: any;
32
+ maxX: any;
33
+ minY: any;
34
+ maxY: any;
35
+ minZ: any;
36
+ maxZ: any;
37
+ width: any;
38
+ height: any;
39
+ centerX: any;
40
+ centerY: any;
41
+ capacity: number;
42
+ maxLevel: number;
43
+ level: number;
44
+ cuboids: any[];
45
+ divided: boolean;
46
+ children: QuadTree25D[] | null;
47
+ pointCount: number;
48
+ /**
49
+ * Check if point is within boundary - Inline version
50
+ */
51
+ containsPoint(x: any, y: any, z: any): boolean;
52
+ /**
53
+ * Check if cuboid intersects with current boundary - Inline version
54
+ */
55
+ intersectsCuboid(cuboid: any): boolean;
56
+ /**
57
+ * Split node into four child nodes - Optimized version
58
+ */
59
+ subdivide(): void;
60
+ /**
61
+ * Insert cuboid into quadtree - Optimized version
62
+ */
63
+ insert(cuboid: any): boolean;
64
+ /**
65
+ * Find cuboid containing given point - Internal method
66
+ * @returns {Object|null} Returns first cuboid containing point, or null if not found
67
+ */
68
+ _findCuboidContainingPoint(x: any, y: any, z: any): Object | null;
69
+ /**
70
+ * Query cuboid and color info containing point - High performance version
71
+ * @returns {Object|null} Returns cuboid info containing point, or null if not found
72
+ */
73
+ queryPoint(point: any): Object | null;
74
+ /**
75
+ * Clear quadtree
76
+ */
77
+ clear(): void;
78
+ }
@@ -1 +1 @@
1
- import{createBase64WorkerFactory as b}from"./_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js";var l=b("Lyogcm9sbHVwLXBsdWdpbi13ZWItd29ya2VyLWxvYWRlciAqLwp2YXIgd29ya2VyX2NvZGU9ZnVuY3Rpb24ocCl7InVzZSBzdHJpY3QiO2NvbnN0IHY9Wy0xLC0xLC0xXTtsZXQgST0hMTtmdW5jdGlvbiBCKGUpe2NvbnN0IHQ9LTcsbz0zLG49by10O3JldHVybiBlPHQmJihlPXQpLGU+byYmKGU9byksTWF0aC5mbG9vcigoZS10KS9uKjI1NSl9ZnVuY3Rpb24gRSgpe2xldCBlO2NvbnN0IHQ9bmV3IEFycmF5KDI1NikuZmlsbCgiIikubWFwKCgpPT5uZXcgQXJyYXkoMykuZmlsbCgiIikpO2ZvcihsZXQgbz0wO288MjA7bysrKXtmb3IoZT0wO2U8MzI7ZSsrKXRbZV1bMF09MTI4KzQqZSx0W2VdWzFdPTAsdFtlXVsyXT0wO2Zvcih0WzMyXVswXT0yNTUsdFszMl1bMV09MCx0WzMyXVsyXT0wLGU9MDtlPDYzO2UrKyl0WzMzK2VdWzBdPTI1NSx0WzMzK2VdWzFdPTQrNCplLHRbMzMrZV1bMl09MDtmb3IodFs5Nl1bMF09MjU0LHRbOTZdWzFdPTI1NSx0Wzk2XVsyXT0yLGU9MDtlPDYyO2UrKyl0Wzk3K2VdWzBdPTI1MC00KmUsdFs5NytlXVsxXT0yNTUsdFs5NytlXVsyXT02KzQqZTtmb3IodFsxNTldWzBdPTEsdFsxNTldWzFdPTI1NSx0WzE1OV1bMl09MjU0LGU9MDtlPDY0O2UrKyl0WzE2MCtlXVswXT0wLHRbMTYwK2VdWzFdPTI1Mi1lKjQsdFsxNjArZV1bMl09MjU1O2ZvcihlPTA7ZTwzMjtlKyspdFsyMjQrZV1bMF09MCx0WzIyNCtlXVsxXT0wLHRbMjI0K2VdWzJdPTI1Mi00KmV9cmV0dXJuIHR9Y29uc3QgUj1FKCk7ZnVuY3Rpb24gaChlLHQsbz0wKXtsZXQgbj0wLGEseCxpLGw7dD1bLi4udF0sbz09PTEmJih0PWNyZWF0ZVNtb290aEN1cnZlUG9pbnRzKHQucmVkdWNlKCh5LGMpPT5bLi4ueSxjLngsYy55XSxbXSksLjUsITAsU0VHTUVOVF9OVU1CRVIpKSxbaV09dDtjb25zdCB1PXQubGVuZ3RoO2ZvcihhPTE7YTw9dTthKyspbD10W2EldV0sZS54Pk1hdGgubWluKGkueCxsLngpJiZlLng8PU1hdGgubWF4KGkueCxsLngpJiZlLnk8PU1hdGgubWF4KGkueSxsLnkpJiZpLnghPT1sLngmJih4PShlLngtaS54KSoobC55LWkueSkvKGwueC1pLngpK2kueSwoaS55PT09bC55fHxlLnk8PXgpJiZuKyspLGk9bDtyZXR1cm4gbiUyIT0wfWZ1bmN0aW9uIE8oe3pNaW46ZSx6TWF4OnQscG9seWdvblBvaW50TGlzdDpvLGF0dHJpYnV0ZTpuLHg6YSx5OngsejppLGNvbG9yTGlzdDpsLHZhbGlkOnV9KXtpZihoKHt4OmEseTp4fSxvKSYmaT49ZSYmaTw9dClyZXR1cm4gdT09PSExP1sxLDEwMy8yNTUsMTAyLzI1NV06bFtuXT9sW25dLnJnYmEuc2xpY2UoMCwzKS5tYXAoYz0+Yy8yNTUpOlsxLDAsMF19ZnVuY3Rpb24gbShlKXtjb25zdCB0PUIoZSksbz1SW3RdLFtuLGEseF09bztyZXR1cm5bbi8yNTUsYS8yNTUseC8yNTVdfXJldHVybiBvbm1lc3NhZ2U9ZnVuY3Rpb24odCl7Y29uc3R7cG9zaXRpb246byxjb2xvcjpuLGN1Ym9pZExpc3Q6YSxjb2xvckxpc3Q6eCxoaWdobGlnaHRJbmRleDppfT10LmRhdGE7bGV0e21vZGlmaWVkQm94SWRzOmw9W10scmVzZXRBcmVhczp1PVtdfT10LmRhdGEseT0wO2Z1bmN0aW9uIGMoKXt5Kz0xfWlmKCFvKXJldHVybjtjb25zdCBfPSEhKGk9PW51bGw/dm9pZCAwOmkubGVuZ3RoKTsoX3x8SSkmJihsPVtdLHU9W10pO2NvbnN0IHc9bC5sZW5ndGg/YS5maWx0ZXIocj0+bC5pbmNsdWRlcyhyLmlkKSk6YTtmb3IobGV0IHI9MDtyPG8ubGVuZ3RoO3IrPTMpe2NvbnN0IEM9b1tyXSxMPW9bcisxXSxkPW9bcisyXTtsZXQgZztpZih1Lmxlbmd0aD09PTEmJiFsLmxlbmd0aCloKHt4OkMseTpMfSx1WzBdKT9nPW0oZCk6Zz12O2Vsc2UgaWYodS5sZW5ndGh8fGwubGVuZ3RoKXtsZXQgcz0hMTt3LnNvbWUoZj0+e2NvbnN0IE09Tyh7cG9seWdvblBvaW50TGlzdDpmLnBvbHlnb25Qb2ludExpc3Qsek1pbjpmLnpNaW4sek1heDpmLnpNYXgseDpDLHk6TCx6OmQsYXR0cmlidXRlOmYuYXR0cmlidXRlLGNvbG9yTGlzdDp4LHZhbGlkOmYudmFsaWR9KTtyZXR1cm4gTT8oYygpLGc9TSxzPSEwLCEwKTohMX0pLCFzJiZ1Lmxlbmd0aCYmKHM9dS5zb21lKGY9Pmgoe3g6Qyx5Okx9LGYpPyhnPW0oZCksITApOiExKSksIXMmJiFfJiYoST9nPW0oZCk6Zz12KX1lbHNlIHcuc29tZShzPT57Y29uc3QgZj1PKHtwb2x5Z29uUG9pbnRMaXN0OnMucG9seWdvblBvaW50TGlzdCx6TWluOnMuek1pbix6TWF4OnMuek1heCx4OkMseTpMLHo6ZCxhdHRyaWJ1dGU6cy5hdHRyaWJ1dGUsY29sb3JMaXN0OngsdmFsaWQ6cy52YWxpZH0pO3JldHVybiBmPyhjKCksZz1mLCEwKTohMX0pO2NvbnN0IEE9cz0+e2NvbnN0IGY9TWF0aC5mbG9vcihzLzMpO3JldHVybiBpJiZpW2ZdPT09MX07aWYoZylpZihnWzBdPT09dlswXSYmQShyKSluW3JdPTAsbltyKzFdPTAsbltyKzJdPTA7ZWxzZXtjb25zdFtzLGYsTV09ZztuW3JdPXMsbltyKzFdPWYsbltyKzJdPU19ZWxzZSBpZihBKHIpKW5bcl09MCxuW3IrMV09MCxuW3IrMl09MDtlbHNle2NvbnN0W3MsZixNXT1tKGQpO25bcl09cyxuW3IrMV09ZixuW3IrMl09TX19ST1fLHBvc3RNZXNzYWdlKHtwb2ludHM6byxjb2xvcjpuLG51bTp5fSl9LHAuaXNJblBvbHlnb249aCxPYmplY3QuZGVmaW5lUHJvcGVydHkocCwiX19lc01vZHVsZSIse3ZhbHVlOiEwfSkscH0oe30pOwoK",null,!1);export{l as default};
1
+ import{createBase64WorkerFactory as b}from"./_rollup-plugin-web-worker-loader__helper__browser__createBase64WorkerFactory.js";var W=b("/* rollup-plugin-web-worker-loader */
var worker_code=function(w){"use strict";function q(i,t){const{polygonPointList:e,zMin:n,zMax:r,attribute:c,valid:s,id:h}=i;let l=Infinity,m=-Infinity,f=Infinity,d=-Infinity;const u=e.length;for(let a=0;a<u;a++){const{x,y:X}=e[a];l=x<l?x:l,m=x>m?x:m,f=X<f?X:f,d=X>d?X:d}let o;if(s===!1)o=[1,.4039,.4];else if(t&&t[c]){const{rgba:a}=t[c];o=[a[0]/255,a[1]/255,a[2]/255]}else o=[1,0,0];return{id:h,minX:l,maxX:m,minY:f,maxY:d,zMin:n,zMax:r,width:m-l,height:d-f,depth:r-n,centerX:(l+m)*.5,centerY:(f+d)*.5,centerZ:(n+r)*.5,polygonPointList:e,colorInfo:o,attribute:c,valid:s}}function E(i){if(!i||i.length===0)return{minX:0,maxX:1,minY:0,maxY:1,minZ:0,maxZ:1,width:1,height:1,depth:1};let t=Infinity,e=-Infinity,n=Infinity,r=-Infinity,c=Infinity,s=-Infinity;const h=i.length;for(let u=0;u<h;u+=3){const o=i[u],a=i[u+1],x=i[u+2];o<t&&(t=o),o>e&&(e=o),a<n&&(n=a),a>r&&(r=a),x<c&&(c=x),x>s&&(s=x)}const l=Math.max(e-t,r-n)*.01,m=e-t+l*2,f=r-n+l*2,d=s-c;return{minX:t-l,maxX:e+l,minY:n-l,maxY:r+l,minZ:c,maxZ:s,width:m,height:f,depth:d,centerX:(t+e)*.5,centerY:(n+r)*.5}}class Z{constructor(t,e=16,n=6,r=0){this.minX=t.minX,this.maxX=t.maxX,this.minY=t.minY,this.maxY=t.maxY,this.minZ=t.minZ||-Infinity,this.maxZ=t.maxZ||Infinity,this.width=t.width||this.maxX-this.minX,this.height=t.height||this.maxY-this.minY,this.centerX=t.centerX||(this.minX+this.maxX)*.5,this.centerY=t.centerY||(this.minY+this.maxY)*.5,this.capacity=e,this.maxLevel=n,this.level=r,this.cuboids=[],this.divided=!1,this.children=null,this.pointCount=0}containsPoint(t,e,n){return(t-this.minX)*(this.maxX-t)>=0&&(e-this.minY)*(this.maxY-e)>=0&&(n-this.minZ)*(this.maxZ-n)>=0}intersectsCuboid(t){return!(t.maxX<this.minX||t.minX>this.maxX||t.maxY<this.minY||t.minY>this.maxY||t.zMax<this.minZ||t.zMin>this.maxZ)}subdivide(){if(this.divided)return;const t=this.width*.5,e=this.height*.5,n=this.level+1;this.children=[new Z({minX:this.minX,maxX:this.centerX,minY:this.minY,maxY:this.centerY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.centerX,maxX:this.maxX,minY:this.minY,maxY:this.centerY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.minX,maxX:this.centerX,minY:this.centerY,maxY:this.maxY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n),new Z({minX:this.centerX,maxX:this.maxX,minY:this.centerY,maxY:this.maxY,minZ:this.minZ,maxZ:this.maxZ,width:t,height:e},this.capacity,this.maxLevel,n)],this.divided=!0;const r=this.cuboids.length;for(let c=0;c<r;c++){const s=this.cuboids[c];for(let h=0;h<4;h++)this.children[h].intersectsCuboid(s)&&this.children[h].insert(s)}this.level>0&&(this.cuboids=[])}insert(t){if(!this.intersectsCuboid(t))return!1;if(this.divided){let e=!1;for(let n=0;n<4;n++)this.children[n].insert(t)&&(e=!0);return this.level===0&&this.cuboids.push(t),e}return this.cuboids.push(t),this.pointCount++,this.pointCount>this.capacity&&this.level<this.maxLevel&&this.subdivide(),!0}_findCuboidContainingPoint(t,e,n){const r=this.cuboids.length;for(let c=0;c<r;c++){const s=this.cuboids[c];if(n<s.zMin||n>s.zMax||t<s.minX||t>s.maxX||e<s.minY||e>s.maxY)continue;const h=s.polygonPointList;let l=!1;for(let m=0,f=h.length-1;m<h.length;f=m++){const d=h[m].x,u=h[m].y,o=h[f].x,a=h[f].y;u>e!=a>e&&t<(o-d)*(e-u)/(a-u)+d&&(l=!l)}if(l)return{cuboid:s,colorInfo:s.colorInfo}}return null}queryPoint(t){const{x:e,y:n,z:r}=t;if(e<this.minX||e>this.maxX||n<this.minY||n>this.maxY||r<this.minZ||r>this.maxZ)return null;if(!this.divided)return this._findCuboidContainingPoint(e,n,r);const c=(n<this.centerY?0:2)+(e<this.centerX?0:1);let s=this.children[c].queryPoint(t);if(!s)for(let h=0;h<4&&!(h!==c&&(s=this.children[h].queryPoint(t),s));h++);return!s&&this.level===0&&(s=this._findCuboidContainingPoint(e,n,r)),s}clear(){if(this.cuboids=[],this.pointCount=0,this.divided){for(let t=0;t<4;t++)this.children[t]&&this.children[t].clear();this.divided=!1,this.children=null}}}const M=[-1,-1,-1];let b=!1,C=null;const I=new Map;function O(i){const t=-7,e=3,n=e-t;return i<t&&(i=t),i>e&&(i=e),Math.floor((i-t)/n*255)}function _(){let i;const t=new Array(256).fill("").map(()=>new Array(3).fill(""));for(i=0;i<32;i++)t[i][0]=128+4*i,t[i][1]=0,t[i][2]=0;for(t[32][0]=255,t[32][1]=0,t[32][2]=0,i=0;i<63;i++)t[33+i][0]=255,t[33+i][1]=4+4*i,t[33+i][2]=0;for(t[96][0]=254,t[96][1]=255,t[96][2]=2,i=0;i<62;i++)t[97+i][0]=250-4*i,t[97+i][1]=255,t[97+i][2]=6+4*i;for(t[159][0]=1,t[159][1]=255,t[159][2]=254,i=0;i<64;i++)t[160+i][0]=0,t[160+i][1]=252-i*4,t[160+i][2]=255;for(i=0;i<32;i++)t[224+i][0]=0,t[224+i][1]=0,t[224+i][2]=252-4*i;return t}const A=_();function L(i,t,e=0){let n=0,r,c,s,h;e===1&&(t=createSmoothCurvePoints(t.reduce((m,f)=>[...m,f.x,f.y],[]),.5,!0,SEGMENT_NUMBER)),[s]=t;const l=t.length;for(r=1;r<=l;r++)h=t[r%l],i.x>Math.min(s.x,h.x)&&i.x<=Math.max(s.x,h.x)&&i.y<=Math.max(s.y,h.y)&&s.x!==h.x&&(c=(i.x-s.x)*(h.y-s.y)/(h.x-s.x)+s.y,(s.y===h.y||i.y<=c)&&n++),s=h;return n%2!=0}function p(i){const t=Math.round(i*1e3)/1e3;if(I.has(t))return I.get(t);const e=O(i),n=A[e],[r,c,s]=n,h=[r/255,c/255,s/255];return I.set(t,h),h}return onmessage=function(t){const{position:e,color:n,cuboidList:r,colorList:c,highlightIndex:s}=t.data;let{modifiedBoxIds:h=[],resetAreas:l=[]}=t.data;I.clear();let m=0;function f(){m+=1}if(!e)return;const d=!!(s==null?void 0:s.length);(d||b)&&(h=[],l=[]);const u=h.length?r.filter(o=>h.includes(o.id)):r;if(C)C.clear();else{const o=E(e);C=new Z(o,32,6)}u.forEach(o=>{const a=q(o,c);C.insert(a)});for(let o=0;o<e.length;o+=3){const a=e[o],x=e[o+1],X=e[o+2];let Y;if(l.length===1&&!h.length)L({x:a,y:x},l[0])?Y=p(X):Y=M;else if(l.length||h.length){let g=!1;const y=C.queryPoint({x:a,y:x,z:X});y&&(f(),Y=y.colorInfo,g=!0),!g&&l.length&&(g=l.some(v=>L({x:a,y:x},v)?(Y=p(X),!0):!1)),!g&&!d&&(b?Y=p(X):Y=M)}else{const g=C.queryPoint({x:a,y:x,z:X});g&&(f(),Y=g.colorInfo)}const P=g=>{const y=Math.floor(g/3);return s&&s[y]===1};if(Y)if(Y[0]===M[0]&&P(o))n[o]=0,n[o+1]=0,n[o+2]=0;else{const[g,y,v]=Y;n[o]=g,n[o+1]=y,n[o+2]=v}else if(P(o))n[o]=0,n[o+1]=0,n[o+2]=0;else{const[g,y,v]=p(X);n[o]=g,n[o+1]=y,n[o+2]=v}}b=d,postMessage({points:e,color:n,num:m})},w.isInPolygon=L,Object.defineProperty(w,"__esModule",{value:!0}),w}({});

",null,!1);export{W as default};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@labelbee/lb-annotation",
3
- "version": "1.28.0-alpha.21",
3
+ "version": "1.28.0-alpha.23",
4
4
  "description": "Annotation tool collection",
5
5
  "keywords": [
6
6
  "annotation",
@@ -99,6 +99,6 @@
99
99
  "color-rgba": "^2.3.0",
100
100
  "lodash": "^4.17.20",
101
101
  "mathjs": "11.8.1",
102
- "three": ">=0.141.0"
102
+ "three": "0.173.0"
103
103
  }
104
104
  }