@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("
|
|
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
|
|
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.
|
|
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": "
|
|
102
|
+
"three": "0.173.0"
|
|
103
103
|
}
|
|
104
104
|
}
|