@vesium/plot 1.0.1-beta.51 → 1.0.1-beta.54
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/README.md +1 -1
- package/dist/index.cjs +723 -200
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +73 -69
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts +73 -69
- package/dist/index.d.mts.map +1 -1
- package/dist/index.iife.js +1887 -1370
- package/dist/index.iife.js.map +1 -1
- package/dist/index.iife.min.js +1 -1
- package/dist/index.iife.min.js.map +1 -1
- package/dist/index.min.cjs +1 -1
- package/dist/index.min.cjs.map +1 -1
- package/dist/index.min.mjs +1 -1
- package/dist/index.min.mjs.map +1 -1
- package/dist/index.mjs +695 -194
- package/dist/index.mjs.map +1 -1
- package/package.json +9 -10
package/dist/index.min.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{CallbackPositionProperty as e,CallbackProperty as t,Cartesian3 as n,Cartographic as r,ClassificationType as i,Color as a,ConstantPositionProperty as o,ConstantProperty as s,CoplanarPolygonGeometry as c,CustomDataSource as l,Ellipsoid as u,Entity as d,Event as f,HorizontalOrigin as p,JulianDate as m,PerInstanceColorAppearance as ee,PolygonGeometry as h,PolygonHierarchy as g,PrimitiveCollection as _,Rectangle as v,ScreenSpaceEventType as y,TimeInterval as b,VertexFormat as te,VerticalOrigin as ne,createGuid as re,sampleTerrainMostDetailed as ie}from"cesium";import{arrayDiff as x,assertError as ae,canvasCoordToCartesian as S,isFunction as C,pickHitGraphic as oe,toCartesian3 as w,toCartographic as T,useCesiumEventListener as E,useDataSource as D,useEntityScope as O,useGraphicEvent as se,usePrimitive as k,usePrimitiveScope as A,useScreenSpaceEventHandler as j,useViewer as M}from"vesium";import{assert as ce,onKeyStroke as N,promiseTimeout as P,watchArray as F}from"@vueuse/core";import{computed as I,nextTick as le,ref as L,shallowReactive as ue,shallowRef as R,toValue as z,watch as B,watchEffect as V}from"vue";var H=class e{constructor(e){this.type=e.type,this.complete=e.complete,this.allowManualComplete=e.allowManualComplete,this.definingCursor=e.definingCursor??`crosshair`,this.skeletons=e.skeletons?.map(e=>e())??[],this.initEntites=e.initEntites,this.initPrimitives=e.initPrimitives,this.initGroundPrimitives=e.initGroundPrimitives,this.render=e.render}type;complete;allowManualComplete;definingCursor;skeletons;initEntites;initPrimitives;initGroundPrimitives;render;static _record=new Map;static getCacheTypes(){return[...this._record.keys()]}static getCache(t){return e._record.get(t)}static setCache(t){ae(!t.type,"`scheme.type` is required"),e._record.set(t.type,t)}static resolve(t){if(typeof t==`string`){let n=e.getCache(t);return ce(!!n,`scheme ${t} not found`),n}else if(t instanceof e)return t;else return new e(t)}};let U=function(e){return e[e.NEAR=0]=`NEAR`,e[e.CYCLE=1]=`CYCLE`,e[e.STRICT=2]=`STRICT`,e}({});const de=(e,t,r,i)=>i===0?{time:e,positions:t.positions?.map(e=>e.clone()),derivative:t.derivative}:i===1?{time:e,positions:r.positions?.map(e=>e.clone()),derivative:t.derivative}:{time:e,positions:r.positions?.map((e,r)=>{let a=t.positions?.[r];return a?n.lerp(a,e,i,new n):e}),derivative:t.derivative};var W=class e{constructor(e){this.interpolationAlgorithm=e?.interpolationAlgorithm,this.strategy=e?.strategy??U.NEAR,e?.packables?.forEach(e=>this.setSample(e)),this._times.length||this.setSample({time:new m(0,0),positions:[],derivative:void 0})}static defaultInterpolationAlgorithm=de;strategy;interpolationAlgorithm;_times=[];_sampleds=[];_derivatives=[];get isConstant(){return this._times.length===0}_definitionChanged=new f;get definitionChanged(){return this._definitionChanged}getTimes(){return this._times.map(e=>e.clone())}getIndexScope(e){if(!this._times.length)return;let t=this._times[0],n=this._times[this._times.length-1];if(m.lessThan(e,t)||m.greaterThan(e,n))switch(this.strategy){case U.STRICT:return;case U.NEAR:e=m.lessThan(e,this._times[0])?this._times[0].clone():this._times[this._times.length-1].clone();break;case U.CYCLE:{let t=m.toDate(this._times[0]).getTime(),n=m.toDate(this._times[this._times.length-1]).getTime(),r=n-t,i=m.toDate(e).getTime(),a=(i-t)%r,o=new Date(t+a);e=m.fromDate(o);break}}let r=this._times.findIndex(t=>m.lessThanOrEquals(e,t)),i=Math.min(r,this._times.length-1),a=m.toDate(this._times[r]).getTime(),o=m.toDate(this._times[i]).getTime(),s=m.toDate(e).getTime();return{prevIndex:r,nextIndex:i,proportion:(s-a)/(o-a)||0}}getValue(t,n){if(n??={time:t},Object.assign(n,{time:t?.clone(),positions:void 0,derivative:void 0}),!t)return n.time=this._times[0].clone(),n.positions=this._sampleds[0]?.map(e=>e.clone(e)),n.derivative=this._derivatives[0],n;let r=this.getIndexScope(t);if(!r)return n;n.time=t;let{prevIndex:i,nextIndex:a,proportion:o}=r,s={time:this._times[i],positions:this._sampleds[i],derivative:this._derivatives[i]},c={time:this._times[a],positions:this._sampleds[a],derivative:this._derivatives[a]},l=(this.interpolationAlgorithm||e.defaultInterpolationAlgorithm)(t,s,c,o);return Object.assign(n,l),n}setSample(e){let t=e.time?.clone()??this._times[0].clone(),n=e.positions?.map(e=>e.clone())??[],r=e.derivative,i=this._times.findIndex(e=>m.equals(t,e));i===-1?this._times.length===0?(this._times[0]=t,this._sampleds[0]=n,this._derivatives[0]=e.derivative):m.lessThan(t,this._times[0])?(this._times.splice(0,0,t),this._sampleds.splice(0,0,n),this._derivatives.splice(0,0,r)):m.greaterThan(t,this._times[this._times.length-1])&&(this._times.push(t),this._sampleds.push(n),this._derivatives.push(r)):(this._times[i]=t,this._sampleds[i]=n,this._derivatives[i]=e.derivative),this.definitionChanged.raiseEvent(this)}setSamples(e){e.forEach(e=>this.setSample(e))}removeSample(e){let t=this._times.findIndex(t=>t.equals(e));if(t!==-1){this._sampleds.splice(t,1),this._derivatives.splice(t,1);let e=this._times.splice(t,1);if(e.length)return this._definitionChanged.raiseEvent(this),!0}return!1}removeSamples(e){for(let t=0;t<this._times.length;t++){let n=this._times[t];b.contains(e,n)&&this.removeSample(n)}}equals(e){return e===this}},G=class{constructor(e){let{id:t,disabled:n=!1,sampled:r}=e;this._id=t||re(),this._scheme=H.resolve(e.scheme),this._definitionChanged=new f,this._defining=!0,this._disabled=n,this._sampled=r instanceof W?r:new W(r),this._sampled.definitionChanged.addEventListener(e=>this._definitionChanged.raiseEvent(this,`sampled`,e,e),this),this._entities=[...this._scheme.initEntites?.()??[]],this._primitives=[...this._scheme.initPrimitives?.()??[]],this._groundPrimitives=[...this._scheme.initGroundPrimitives?.()??[]],this._skeletons=[]}_id;get id(){return this._id}_scheme;get scheme(){return this._scheme}_definitionChanged;get definitionChanged(){return this._definitionChanged}_defining;get defining(){return this._defining}static setDefining(e,t){e._defining!==t&&(e._definitionChanged.raiseEvent(e,`defining`,t,e._defining),e._defining=t)}_disabled;get disabled(){return this._disabled}set disabled(e){this.disabled=e}_sampled;get sampled(){return this._sampled}_entities;get entities(){return this._entities}set entities(e){this._definitionChanged.raiseEvent(this,`entities`,e,this._entities),this._entities=e}_primitives;get primitives(){return this._primitives}set primitives(e){this._definitionChanged.raiseEvent(this,`primitives`,e,this._primitives),this._primitives=e}_groundPrimitives;get groundPrimitives(){return this._groundPrimitives}set groundPrimitives(e){this._definitionChanged.raiseEvent(this,`groundPrimitives`,e,this._groundPrimitives),this._groundPrimitives=e}_skeletons;get skeletons(){return this._skeletons}set skeletons(e){this._definitionChanged.raiseEvent(this,`skeletons`,e,this._skeletons),this._skeletons=e}};let K=function(e){return e[e.IDLE=0]=`IDLE`,e[e.HOVER=1]=`HOVER`,e[e.ACTIVE=2]=`ACTIVE`,e}({});var q=class extends d{constructor(e){super(e)}};function fe(e,t,n){let r=M(),i=k(new _),a=k(new _,{collection:`ground`}),o=D(new l),s=O({collection:()=>o.value.entities}),c=A({collection:()=>i.value}),u=A({collection:()=>a.value}),d=R();j(y.MOUSE_MOVE,e=>{d.value=S(e?.endPosition,r.value.scene)}),F(e,(e,t,n,r=[])=>{r.forEach(e=>{s.removeWhere(t=>e.entities.includes(t)),c.removeWhere(t=>e.primitives.includes(t)),u.removeWhere(t=>e.groundPrimitives.includes(t))}),n.forEach(e=>{e.entities.forEach(e=>s.add(e)),e.primitives.forEach(e=>c.add(e)),e.groundPrimitives.forEach(e=>u.add(e))})},{immediate:!0,flush:`post`}),E(()=>e.value.map(e=>e.definitionChanged),(e,t,n,r)=>{if(t===`entities`){let{added:e,removed:t}=x(n,r);e.forEach(e=>s.add(e)),t.forEach(e=>s.remove(e))}else if(t===`primitives`){let{added:e,removed:t}=x(n,r);e.forEach(e=>c.add(e)),t.forEach(e=>c.remove(e))}else if(t===`groundPrimitives`){let{added:e,removed:t}=x(n,r);e.forEach(e=>u.add(e)),t.forEach(e=>u.remove(e))}});let f=async e=>{let t=await e.scheme.render?.({packable:e.sampled.getValue(n()),mouse:e.defining?d.value:void 0,defining:e.defining,previous:{entities:e.entities,primitives:e.primitives,groundPrimitives:e.groundPrimitives}});e.entities=t?.entities??[],e.primitives=t?.primitives??[],e.groundPrimitives=t?.groundPrimitives??[]};return B(t,(e,t)=>{t&&f(t)}),E(()=>e.value.map(e=>e.definitionChanged),(e,t)=>{[`disabled`,`defining`,`scheme`,`sampled`,`time`].includes(t)&&f(e)}),B(d,()=>{e.value.forEach(e=>e.defining&&f(e))}),{primitives:I(()=>Array.from(c.scope)),groundPrimitives:I(()=>Array.from(c.scope)),entities:I(()=>Array.from(s.scope))}}function J(e,t){let n=M(),r=L(!1),i=I(()=>e.value?.sampled.getValue(t()));j(y.LEFT_CLICK,async t=>{if(await P(1),!e.value||!i.value||r.value)return;let{scheme:a,defining:o,sampled:s}=e.value;if(!o)return;let c=S(t.position,n.value.scene);if(!c)return;i.value.positions??=[],i.value.positions.push(c),s.setSample(i.value);let l=a.complete?.(i.value);l&&G.setDefining(e.value,!1)}),j(y.LEFT_DOUBLE_CLICK,async t=>{if(!e.value||!i.value)return;r.value=!0,await P(2),r.value=!1;let{scheme:a,defining:o}=e.value;if(!o)return;let s=S(t.position,n.value.scene);if(!s)return;let c=a.allowManualComplete?.(i.value);c&&G.setDefining(e.value,!1)}),j(y.RIGHT_CLICK,async()=>{if(!e.value||!i.value)return;let{defining:t,sampled:n}=e.value;t&&(i.value.positions??=[],i.value.positions.length!==0&&(i.value.positions.splice(i.value.positions.length-1,1),n.setSample(i.value)))});let a=L(),o=()=>{if(!e.value?.defining)a.value&&(a.value=void 0,n.value.container.parentElement.style.removeProperty(`cursor`));else{let t=e.value.scheme.definingCursor;a.value=C(t)?t(i.value):t,a.value&&n.value?.container.parentElement.style.setProperty(`cursor`,a.value)}};E(()=>e.value?.definitionChanged,(e,t)=>{(t===`defining`||t===`sampled`)&&o()}),B(e,()=>o())}function pe(e,t,n){let r=M(),i=D(new l),a=O({collection:()=>i.value.entities}),o=R(),s=R(),c=e=>e?s.value?.id===e.id?K.ACTIVE:o.value?.id===e.id?K.HOVER:K.IDLE:K.IDLE,u=(e,r)=>{let i=e.skeletons,a=[];if(r||e.disabled)e.skeletons=[];else{let r=e.sampled.getValue(n()),o=e.defining,s=t.value===e,l=e.scheme.skeletons;l.forEach(t=>{let n=C(t.disabled)?t.disabled({active:s,defining:o}):t.disabled;if(n)return;let l=t.format?.(r)??r?.positions??[];l.forEach((n,u)=>{let d=i.find(e=>e.index===u&&e.skeleton===t),f=t.render?.({defining:o,active:s,index:u,packable:r,positions:l,position:n,action:c(d)}),p=new q(f??{});d?p.propertyNames.forEach(e=>{e!==`id`&&(d[e]=p[e])}):d=p,d.plot=e,d.skeleton=t,d.index=u,a.push(d)})})}e.skeletons=a},{addGraphicEvent:d}=se();return V(e=>{let i=d(`global`,`DRAG`,({event:e,pick:i,dragging:o,lockCamera:c})=>{if(i.id instanceof q&&a.scope.has(i.id)){let a=i.id,l=a.plot;if(l.defining)return;s.value=a;let u=a.skeleton,d=a.index,f=l.sampled.getValue(n());u.onDrag?.({viewer:r.value,sampled:l.sampled,packable:f,active:t.value===l,index:d,event:e,dragging:o,lockCamera:c})}else s.value=void 0},{cursor:({pick:e})=>{if(!t.value?.defining&&a.scope.has(e.id)){let t=e.id.skeleton;return C(t?.cursor)?t.cursor(e):z(t?.cursor)}},dragCursor:({pick:e})=>{if(!t.value?.defining&&a.scope.has(e.id)){let t=e.id.skeleton;return C(t?.dragCursor)?t.dragCursor(e):z(t?.dragCursor)}}});e(i)}),N(e=>{if(s.value){let t=s.value,i=t.plot,a=t.skeleton,o=t.index,c=i.sampled.getValue(n());a.onKeyPressed?.({viewer:r.value,sampled:i.sampled,packable:c,index:o,keyEvent:e})}}),V(e=>{let t=d(`global`,`HOVER`,({hovering:e,pick:t})=>{if(e&&t.id instanceof q&&a.scope.has(t.id)){let e=t.id;o.value=e}else o.value=void 0});e(t)}),V(e=>{let i=d(`global`,`LEFT_CLICK`,({event:e,pick:i})=>{if(i.id instanceof q&&a.scope.has(i.id)){let a=i.id;s.value=a;let o=a.plot,c=a.skeleton,l=a.index,u=o.sampled.getValue(n());c.onLeftClick?.({viewer:r.value,sampled:o.sampled,packable:u,active:t.value===o,defining:o.defining,index:l,event:e})}else s.value=void 0});e(i)}),F(e,(e,t,n,r=[])=>{n.forEach(e=>u(e)),r.forEach(e=>u(e,!0))}),E(()=>e.value.map(e=>e.definitionChanged),(e,t,n,r)=>{if([`disabled`,`defining`,`scheme`,`sampled`,`time`].includes(t))le(()=>u(e));else if(t===`skeletons`){let{added:e,removed:t}=x(n,r);e.forEach(e=>a.add(e)),t.forEach(e=>a.remove(e))}}),B(t,(e,t)=>{e&&u(e),t&&u(t)}),{dataSource:i}}function me(e){let t=e?.time||R(),n=M(),r=()=>t.value?.clone()||new m(0,0),i=ue(new Set),a=I(()=>Array.from(i)),o=R(),s=R();E([()=>o.value?.sampled.definitionChanged],()=>{s.value=o.value?.sampled.getValue(r())}),J(o,r),fe(a,o,r),pe(a,o,r),j(y.LEFT_CLICK,e=>{if(o.value?.defining)return;let t=n.value?.scene.pick(e.position.clone());if(!(t?.id?.plot instanceof G)){if(!t){o.value=void 0;return}o.value=a.value.find(e=>oe(t,[...e.entities,...e.primitives,...e.groundPrimitives]))}});let c,l;B(o,(e,t)=>{if(t&&t.defining){let e=t.sampled.getValue(r()),n=t.scheme.allowManualComplete?.(e);n?(G.setDefining(t,!1),c?.(t)):i.delete(t)}});let u=async e=>new Promise((t,n)=>{c=t,l=n;let r=e instanceof G?e:new G(e);return i.has(r)||i.add(r),o.value=r,t(r)}),d=e=>(e===o.value&&(o.value=void 0),i.has(e)?(i.delete(e),!0):!1);return{plots:a,time:t,operate:u,remove:d,cancel:l}}function Y(){return{disabled:({active:e})=>!e,cursor:`pointer`,dragCursor:`crosshair`,onDrag({viewer:e,sampled:t,packable:n,event:r,index:i,lockCamera:a}){a();let o=S(r.endPosition,e.scene);if(o){let e=[...n.positions??[]];e[i]=o,t.setSample({time:n.time,derivative:n.derivative,positions:e})}},onKeyPressed({viewer:e,keyEvent:t,sampled:n,packable:r,index:i}){let a=T(e.camera.position)?.height;if(!a||![`ArrowUp`,`ArrowRight`,`ArrowDown`,`ArrowLeft`].includes(t.key))return;t.preventDefault();let o=0;switch(t.key){case`ArrowRight`:o=Math.PI/2;break;case`ArrowDown`:o=Math.PI;break;case`ArrowLeft`:o=-Math.PI/2;break;case`ArrowUp`:o=0;break}let s=(e.camera.heading+o)%(2*Math.PI),c=[...r.positions??[]],l=T(c[i]),u=a/1e5,d=u*Math.PI/180/1e3;l.latitude+=d*Math.cos(s),l.longitude+=d*Math.sin(s),c[i]=w(l),n.setSample({time:r.time,derivative:r.derivative,positions:c})},render:({position:e,action:t})=>{let n={[K.IDLE]:a.BLUE.withAlpha(.4),[K.HOVER]:a.BLUE.withAlpha(.6),[K.ACTIVE]:a.AQUA.withAlpha(1)};return{position:e,point:{pixelSize:8,color:n[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}}}}}function X(){let e=-1;return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];return t.length<2?[]:t.map((e,r)=>{let i=r===t.length-1?t[0]:t[r+1];return n.midpoint(e,i,new n)})},onDrag({viewer:t,sampled:n,packable:r,event:i,index:a,lockCamera:o,dragging:s}){o();let c=S(i.endPosition,t.scene);if(!c)return;let l=[...r.positions??[]];e===-1?(e=a,l.splice(a+1,0,c)):l[e+1]=c,s||(e=-1),n.setSample({time:r.time,derivative:r.derivative,positions:l})},render:({position:e,action:t,active:n})=>{if(!n)return;let r={[K.IDLE]:a.GREEN.withAlpha(.4),[K.HOVER]:a.GREEN.withAlpha(.6),[K.ACTIVE]:a.GREEN.withAlpha(1)};return{position:e,point:{pixelSize:6,color:r[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}}}}}function Z(){let e=-1;return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];if(t.length<2)return[];let r=[];for(let e=0;e<t.length-1;e++)r.push(n.midpoint(t[e],t[e+1],new n));return r},onDrag({viewer:t,sampled:n,packable:r,event:i,index:a,lockCamera:o,dragging:s}){o();let c=S(i.endPosition,t.scene);if(!c)return;let l=[...r.positions??[]];e===-1?(e=a,l.splice(a+1,0,c)):l[e+1]=c,s||(e=-1),n.setSample({time:r.time,derivative:r.derivative,positions:l})},render:({position:e,action:t})=>{let n={[K.IDLE]:a.GREEN.withAlpha(.4),[K.HOVER]:a.GREEN.withAlpha(.6),[K.ACTIVE]:a.GREEN.withAlpha(1)};return{position:e,point:{pixelSize:6,color:n[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}}}}}const he=`data:image/svg+xml;utf8,${encodeURIComponent(`<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 24 24"><path stroke="#ffffff" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="m18 9l3 3l-3 3m-3-3h6M6 9l-3 3l3 3m-3-3h6m0 6l3 3l3-3m-3-3v6m3-15l-3-3l-3 3m3-3v6"/></svg>`)}`;function Q(){return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];if(t.length===0)return[];if(t.length===1)return[t[0]];{let e=v.center(v.fromCartesianArray(t));return[w(e)]}},onDrag({viewer:e,sampled:t,packable:r,event:i,lockCamera:a,dragging:o}){o&&a();let s=S(i.startPosition,e.scene),c=S(i.endPosition,e.scene);if(!s||!c)return;let l=n.subtract(c,s,new n),u=[...r.positions??[]];t.setSample({time:r.time,derivative:r.derivative,positions:u.map(e=>n.add(e,l,new n))})},render:({position:e,action:t})=>{let r={[K.IDLE]:a.WHITE,[K.HOVER]:a.WHITE,[K.ACTIVE]:a.AQUA.withAlpha(1)};return{position:e,billboard:{image:he,width:20,height:20,color:r[t],pixelOffset:new n(0,-20),horizontalOrigin:p.CENTER,verticalOrigin:ne.BOTTOM,disableDepthTestDistance:1/0}}}}}function ge(e){if(e.length<3)throw Error(`positions must >= 3`);if(e.length===3)return[[e[0].clone(),e[1].clone(),e[2].clone()]];let t=c.createGeometry(c.fromPositions({positions:e,vertexFormat:te.POSITION_ONLY}));if(!t)throw Error(`positions无法组成有效的geometry,检查点位是否错误`);let r=t.attributes.position.values,i=t.indices,a=[];for(let e=0;e<i.length;e+=3){let t=n.unpack(r,i[e]*3,new n),o=n.unpack(r,i[e+1]*3,new n),s=n.unpack(r,i[e+2]*3,new n);a.push([t,o,s])}return a}async function _e(e){let{positions:t,scene:n,classificationType:a=i.BOTH,terrainProvider:o=n.terrainProvider}=e,s=[i.BOTH,i.CESIUM_3D_TILE].includes(a),c=[i.BOTH,i.TERRAIN].includes(a),l=new Promise(e=>{s?n.clampToHeightMostDetailed(t.map(e=>e.clone())).then(e).catch(t=>{console.warn(t),e([])}):e([])}),d=new Promise(e=>{c&&o?ie(o,t.map(e=>r.fromCartesian(e))).then(t=>e(t)).catch(t=>{console.warn(t),e([])}):e([])}),[f,p]=await Promise.all([l,d]),m=[];return t.forEach((e,t)=>{let n=f[t]||p[t]?u.WGS84.cartographicToCartesian(p[t]):e.clone();m.push(n)}),m}function ve(e){let t=e?.clampToGround??!1,n=e?.classificationType??i.BOTH,r=Math.floor(e?.density??10);return{scene:e?.scene,clampToGround:t,classificationType:n,terrainProvider:e?.terrainProvider,density:r}}async function ye(e,t){if(e.length<3)throw Error(`positions must >= 3`);let{density:r,scene:i,clampToGround:a,classificationType:o,terrainProvider:s}=ve(t);if(r<=0)throw Error(`options.density must > 0`);let c=v.fromCartesianArray(e),l=c.north-c.south,u=c.east-c.west,d=Math.max(u,l),f=d/r,p=h.fromPositions({positions:e,vertexFormat:ee.FLAT_VERTEX_FORMAT,granularity:f}),m=h.createGeometry(p),g=m.attributes.position.values;if(!m||!g)throw Error(`positions无法组成有效的geometry,检查点位是否错误`);let _=m.indices,y=[];for(let e=0;e<_.length;e+=3){let t=n.unpack(g,_[e]*3,new n),r=n.unpack(g,_[e+1]*3,new n),i=n.unpack(g,_[e+2]*3,new n);y.push(t,r,i)}if(a){if(!i)throw Error("scene is required on `clampToGround == true`.");let e=await _e({scene:i,terrainProvider:s,positions:y,classificationType:o});y=e}let b=[];for(;y?.length;){let[e,t,n]=y.splice(0,3);b.push([e,t,n])}return b}function $(e,t,r){let i=n.subtract(e,t,new n),a=n.subtract(r,t,new n),o=n.cross(i,a,i);return n.magnitude(o)*.5}function be(e){let t=e?.clampToGround??!1,n=e?.classificationType??i.BOTH,r=Math.floor(e?.density??10);return{scene:e?.scene,clampToGround:t,classificationType:n,terrainProvider:e?.terrainProvider,density:r}}async function xe(e,t){if(e.length<2)throw Error(`positions.length must >= 2`);let{density:n,scene:r,clampToGround:i,classificationType:a,terrainProvider:o}=be(t);if(n<=0)throw Error(`options.density must > 0`);if(!i){let t=ge(e);return t.reduce((e,t)=>e+=$(...t),0)}let s=await ye(e,{density:n,scene:r,clampToGround:i,classificationType:a,terrainProvider:o});return s.reduce((e,t)=>e+=$(...t),0)}const Se=new H({type:`measureArea`,allowManualComplete:e=>e.positions.length>=3,skeletons:[Y,X],initEntites:()=>[new d({label:{font:`14pt`},polyline:{material:a.YELLOW.withAlpha(.5)},polygon:{material:a.YELLOW.withAlpha(.5)}})],render(e){let{mouse:n,packable:r}=e,i=e.previous.entities?.[0]??new d({label:{font:`14pt`},polyline:{material:a.YELLOW.withAlpha(.5)},polygon:{material:a.YELLOW.withAlpha(.5)}}),c=[...r.positions??[]];return n&&c.push(n),c.length===2?(i.position=void 0,i.label.text=void 0,i.polygon.hierarchy=void 0,i.polyline.positions=new t(()=>c,!1)):c.length>=3?(c.push(c[0]),i.position=new o(w(v.center(v.fromCartesianArray(c)))),i.label.text=new s(``),xe(c).then(e=>{let t=``;t=e/1e3/1e3>10?`${(e/1e3/1e3).toFixed(2)}km²`:`${(+e).toFixed(2)}m²`,i.label.text=new s(t)}),i.polyline.positions=void 0,i.polygon.hierarchy=new t(()=>c.length>=3?new g([...c]):void 0,!1)):(i.position=void 0,i.polygon.hierarchy=void 0,i.polyline.positions=void 0),{entities:[i]}}}),Ce=new H({type:`billboard`,complete:e=>e.positions.length>=1,skeletons:[Q],initEntites:()=>[new d({billboard:{image:`/favicon.svg`,width:32,height:32}})],render(t){let{mouse:n,packable:r}=t,i=t.previous.entities?.[0]??new d({billboard:{}}),a=r.positions?.[0]??n;return i.position=new e(()=>a,!0),{entities:[i]}}}),we=new H({type:`label`,complete:e=>e.positions.length>=1,skeletons:[Q],initEntites:()=>[new d({label:{text:`Label`}})],render(t){let{mouse:n,packable:r}=t,i=t.previous.entities?.[0]??new d({label:{}}),a=r.positions?.[0]??n;return i.position=new e(()=>a,!0),{entities:[i]}}}),Te=new H({type:`polygon`,allowManualComplete:e=>e.positions.length>=3,skeletons:[Y,X,Q],initEntites:()=>[new d({polyline:{material:a.YELLOW.withAlpha(.5)},polygon:{material:a.YELLOW.withAlpha(.5)}})],render(e){let{mouse:n,packable:r}=e,i=e.previous.entities?.[0]??new d({polyline:{material:a.YELLOW.withAlpha(.5)},polygon:{material:a.YELLOW.withAlpha(.5)}}),o=[...r.positions??[]];return n&&o.push(n),o.length===2?(i.polygon.hierarchy=void 0,i.polyline.positions=new t(()=>o,!1)):o.length>=3?(i.polyline.positions=void 0,i.polygon.hierarchy=new t(()=>(o.push(o[0]),o.length>=3?new g([...o]):void 0),!1)):(i.polygon.hierarchy=void 0,i.polyline.positions=void 0),{entities:[i]}}}),Ee=new H({type:`polyline`,allowManualComplete:e=>e.positions.length>=2,skeletons:[Y,Z,Q],initEntites:()=>[new d({polyline:{width:1}})],render(e){let{mouse:n,packable:r}=e,i=e.previous.entities?.[0]??new d({polyline:{}});return i.polyline.positions=new t(()=>{let e=[...r.positions??[]].concat(n?[n]:[]);return e.length>=2?e:[]},!1),{entities:[i]}}}),De=new H({type:`rectangle`,complete:e=>e.positions.length>=2,skeletons:[Y,X,Q],initEntites:()=>[new d({rectangle:{material:a.YELLOW.withAlpha(.5)}})],render(e){let{mouse:n,packable:r}=e,i=e.previous.entities?.[0]??new d({rectangle:{material:a.YELLOW.withAlpha(.5)}}),o=[...r.positions??[]];return n&&o.push(n),o.length>=2?i.rectangle.coordinates=new t(()=>v.fromCartesianArray(o),!1):i.rectangle.coordinates=void 0,{entities:[i]}}});export{K as PlotAction,G as PlotFeature,H as PlotScheme,q as PlotSkeletonEntity,W as SampledPlotProperty,U as SampledPlotStrategy,Y as control,X as interval,Z as intervalNonclosed,Q as moved,Ce as schemeBillboard,we as schemeLabel,Se as schemeMeasureArea,Te as schemePolygon,Ee as schemePolyline,De as schemeRectangle,me as usePlot};
|
|
1
|
+
import{CallbackPositionProperty as e,CallbackProperty as t,Cartesian3 as n,Cartographic as r,ClassificationType as i,Color as a,ConstantPositionProperty as o,ConstantProperty as s,CoplanarPolygonGeometry as c,CustomDataSource as l,Ellipsoid as u,Entity as d,Event as f,HorizontalOrigin as p,JulianDate as m,LabelGraphics as h,PerInstanceColorAppearance as ee,PolygonGeometry as g,PolygonHierarchy as _,PolylineGraphics as v,PrimitiveCollection as te,Rectangle as y,ScreenSpaceEventType as b,TimeInterval as ne,VertexFormat as re,VerticalOrigin as ie,createGuid as ae,sampleTerrainMostDetailed as oe}from"cesium";import{arrayDiff as x,assertError as se,canvasCoordToCartesian as S,isFunction as C,pickHitGraphic as ce,toCartesian3 as w,toCartographic as T,toCoord as E,toProperty as le,toPropertyValue as ue,useCesiumEventListener as D,useDataSource as O,useEntityScope as k,useGraphicEvent as de,usePrimitive as A,usePrimitiveScope as j,useScreenSpaceEventHandler as M,useViewer as N}from"vesium";import{assert as fe,onKeyStroke as pe,promiseTimeout as P,watchArray as F}from"@vueuse/core";import{computed as I,nextTick as L,ref as R,shallowReactive as me,shallowRef as z,toValue as B,watch as V,watchEffect as H}from"vue";import{arc as he,arrowAttackDirection as ge,arrowAttackDirectionTailed as _e,arrowClamped as ve,arrowStraight as ye,arrowStraightSharp as be,arrowUnitCombatOperation as xe,arrowUnitCombatOperationTailed as Se,assemblingPlace as Ce}from"@vesium/geometry";import*as U from"@turf/turf";var W=class e{constructor(e){this.type=e.type,this.complete=e.complete,this.allowManualComplete=e.allowManualComplete,this.definingCursor=e.definingCursor??`crosshair`,this.skeletons=e.skeletons?.map(e=>e())??[],this.initRender=e.initRender,this.render=e.render}type;complete;allowManualComplete;definingCursor;skeletons;initRender;render;static _record=new Map;static getCacheTypes(){return[...this._record.keys()]}static getCache(t){return e._record.get(t)}static setCache(t){se(!t.type,"`scheme.type` is required"),e._record.set(t.type,t)}static resolve(t){if(typeof t==`string`){let n=e.getCache(t);return fe(!!n,`scheme ${t} not found`),n}else if(t instanceof e)return t;else return new e(t)}};let G=function(e){return e[e.NEAR=0]=`NEAR`,e[e.CYCLE=1]=`CYCLE`,e[e.STRICT=2]=`STRICT`,e}({});const we=(e,t,r,i)=>i===0?{time:e,positions:t.positions?.map(e=>e.clone()),derivative:t.derivative}:i===1?{time:e,positions:r.positions?.map(e=>e.clone()),derivative:t.derivative}:{time:e,positions:r.positions?.map((e,r)=>{let a=t.positions?.[r];return a?n.lerp(a,e,i,new n):e}),derivative:t.derivative};var K=class e{constructor(e){this.interpolationAlgorithm=e?.interpolationAlgorithm,this.strategy=e?.strategy??G.NEAR,e?.packables?.forEach(e=>this.setSample(e)),this._times.length||this.setSample({time:new m(0,0),positions:[],derivative:void 0})}static defaultInterpolationAlgorithm=we;strategy;interpolationAlgorithm;_times=[];_sampleds=[];_derivatives=[];get isConstant(){return this._times.length===0}_definitionChanged=new f;get definitionChanged(){return this._definitionChanged}getTimes(){return this._times.map(e=>e.clone())}getIndexScope(e){if(!this._times.length)return;let t=this._times[0],n=this._times[this._times.length-1];if(m.lessThan(e,t)||m.greaterThan(e,n))switch(this.strategy){case G.STRICT:return;case G.NEAR:e=m.lessThan(e,this._times[0])?this._times[0].clone():this._times[this._times.length-1].clone();break;case G.CYCLE:{let t=m.toDate(this._times[0]).getTime(),n=m.toDate(this._times[this._times.length-1]).getTime()-t,r=(m.toDate(e).getTime()-t)%n,i=new Date(t+r);e=m.fromDate(i);break}}let r=this._times.findIndex(t=>m.lessThanOrEquals(e,t)),i=Math.min(r,this._times.length-1),a=m.toDate(this._times[r]).getTime(),o=m.toDate(this._times[i]).getTime();return{prevIndex:r,nextIndex:i,proportion:(m.toDate(e).getTime()-a)/(o-a)||0}}getValue(t,n){if(n??={time:t,positions:[]},Object.assign(n,{time:t?.clone(),positions:[],derivative:void 0}),!t)return n.time=this._times[0].clone(),n.positions=this._sampleds[0]?.map(e=>e.clone(e)),n.derivative=this._derivatives[0],n;let r=this.getIndexScope(t);if(!r)return n;n.time=t;let{prevIndex:i,nextIndex:a,proportion:o}=r,s={time:this._times[i],positions:this._sampleds[i],derivative:this._derivatives[i]},c={time:this._times[a],positions:this._sampleds[a],derivative:this._derivatives[a]},l=(this.interpolationAlgorithm||e.defaultInterpolationAlgorithm)(t,s,c,o);return Object.assign(n,l),n}setSample(e){let t=e.time?.clone()??this._times[0].clone(),n=e.positions?.map(e=>e.clone())??[],r=e.derivative,i=this._times.findIndex(e=>m.equals(t,e));i===-1?this._times.length===0?(this._times[0]=t,this._sampleds[0]=n,this._derivatives[0]=e.derivative):m.lessThan(t,this._times[0])?(this._times.splice(0,0,t),this._sampleds.splice(0,0,n),this._derivatives.splice(0,0,r)):m.greaterThan(t,this._times[this._times.length-1])&&(this._times.push(t),this._sampleds.push(n),this._derivatives.push(r)):(this._times[i]=t,this._sampleds[i]=n,this._derivatives[i]=e.derivative),this.definitionChanged.raiseEvent(this)}setSamples(e){e.forEach(e=>this.setSample(e))}removeSample(e){let t=this._times.findIndex(t=>t.equals(e));return t!==-1&&(this._sampleds.splice(t,1),this._derivatives.splice(t,1),this._times.splice(t,1).length)?(this._definitionChanged.raiseEvent(this),!0):!1}removeSamples(e){for(let t=0;t<this._times.length;t++){let n=this._times[t];ne.contains(e,n)&&this.removeSample(n)}}equals(e){return e===this}},q=class{constructor(e){let{id:t,disabled:n=!1,sampled:r}=e;this._id=t||ae(),this._scheme=W.resolve(e.scheme),this._definitionChanged=new f,this._defining=!0,this._disabled=n,this._sampled=r instanceof K?r:new K(r),this._sampled.definitionChanged.addEventListener(e=>this._definitionChanged.raiseEvent(this,`sampled`,e,e),this);let i=this._scheme.initRender?.()??{};this._entities=[...i.entities??[]],this._primitives=[...i.primitives??[]],this._groundPrimitives=[...i.groundPrimitives??[]],this._skeletons=[]}_id;get id(){return this._id}_scheme;get scheme(){return this._scheme}_definitionChanged;get definitionChanged(){return this._definitionChanged}_defining;get defining(){return this._defining}static setDefining(e,t){e._defining!==t&&(e._definitionChanged.raiseEvent(e,`defining`,t,e._defining),e._defining=t)}_disabled;get disabled(){return this._disabled}set disabled(e){this.disabled=e}_sampled;get sampled(){return this._sampled}_entities;get entities(){return this._entities}set entities(e){this._definitionChanged.raiseEvent(this,`entities`,e,this._entities),this._entities=e}_primitives;get primitives(){return this._primitives}set primitives(e){this._definitionChanged.raiseEvent(this,`primitives`,e,this._primitives),this._primitives=e}_groundPrimitives;get groundPrimitives(){return this._groundPrimitives}set groundPrimitives(e){this._definitionChanged.raiseEvent(this,`groundPrimitives`,e,this._groundPrimitives),this._groundPrimitives=e}_skeletons;get skeletons(){return this._skeletons}set skeletons(e){this._definitionChanged.raiseEvent(this,`skeletons`,e,this._skeletons),this._skeletons=e}};let J=function(e){return e[e.IDLE=0]=`IDLE`,e[e.HOVER=1]=`HOVER`,e[e.ACTIVE=2]=`ACTIVE`,e}({});var Y=class extends d{constructor(e){super(e)}};function Te(e,t,n){let r=N(),i=A(new te),a=A(new te,{collection:`ground`}),o=O(new l),s=k({collection:()=>o.value.entities}),c=j({collection:()=>i.value}),u=j({collection:()=>a.value}),d=z();M(b.MOUSE_MOVE,e=>{d.value=S(e?.endPosition,r.value.scene)}),F(e,(e,t,n,r=[])=>{r.forEach(e=>{s.removeWhere(t=>e.entities.includes(t)),c.removeWhere(t=>e.primitives.includes(t)),u.removeWhere(t=>e.groundPrimitives.includes(t))}),n.forEach(e=>{e.entities.forEach(e=>s.add(e)),e.primitives.forEach(e=>c.add(e)),e.groundPrimitives.forEach(e=>u.add(e))})},{immediate:!0,flush:`post`}),D(()=>e.value.map(e=>e.definitionChanged),(e,t,n,r)=>{if(t===`entities`){let{added:e,removed:t}=x(n,r);e.forEach(e=>s.add(e)),t.forEach(e=>s.remove(e))}else if(t===`primitives`){let{added:e,removed:t}=x(n,r);e.forEach(e=>c.add(e)),t.forEach(e=>c.remove(e))}else if(t===`groundPrimitives`){let{added:e,removed:t}=x(n,r);e.forEach(e=>u.add(e)),t.forEach(e=>u.remove(e))}});let f=async e=>{await L();let t=e.sampled.getValue(n()),r=e.defining?d.value:void 0,i=await e.scheme.render?.({packable:t,mouse:r,defining:e.defining,previous:{entities:e.entities,primitives:e.primitives,groundPrimitives:e.groundPrimitives},getPositions(){let e=t.positions;return r&&e.push(r),e}});e.entities=i?.entities??[],e.primitives=i?.primitives??[],e.groundPrimitives=i?.groundPrimitives??[]};return V(t,(e,t)=>{t&&f(t)}),D(()=>e.value.map(e=>e.definitionChanged),(e,t)=>{[`disabled`,`defining`,`scheme`,`sampled`,`time`].includes(t)&&f(e)}),V(d,()=>{e.value.forEach(e=>e.defining&&f(e))}),{primitives:I(()=>Array.from(c.scope)),groundPrimitives:I(()=>Array.from(c.scope)),entities:I(()=>Array.from(s.scope))}}function Ee(e,t){let n=N(),r=R(!1),i=I(()=>e.value?.sampled.getValue(t()));M(b.LEFT_CLICK,async t=>{if(await P(1),!e.value||!i.value||r.value)return;let{scheme:a,defining:o,sampled:s}=e.value;if(!o)return;let c=S(t.position,n.value.scene);c&&(i.value.positions??=[],i.value.positions.push(c),s.setSample(i.value),a.complete?.(i.value)&&q.setDefining(e.value,!1))}),M(b.LEFT_DOUBLE_CLICK,async t=>{if(!e.value||!i.value)return;r.value=!0,await P(2),r.value=!1;let{scheme:a,defining:o}=e.value;o&&S(t.position,n.value.scene)&&a.allowManualComplete?.(i.value)&&q.setDefining(e.value,!1)}),M(b.RIGHT_CLICK,async()=>{if(!e.value||!i.value)return;let{defining:t,sampled:n}=e.value;t&&(i.value.positions??=[],i.value.positions.length!==0&&(i.value.positions.splice(i.value.positions.length-1,1),n.setSample(i.value)))});let a=R(),o=()=>{if(!e.value?.defining)a.value&&(a.value=void 0,n.value.container.parentElement.style.removeProperty(`cursor`));else{let t=e.value.scheme.definingCursor;a.value=C(t)?t(i.value):t,a.value&&n.value?.container.parentElement.style.setProperty(`cursor`,a.value)}};D(()=>e.value?.definitionChanged,(e,t)=>{(t===`defining`||t===`sampled`)&&o()}),V(e,()=>o())}function De(e,t,n){let r=N(),i=O(new l),a=k({collection:()=>i.value.entities}),o=z(),s=z(),c=e=>e?s.value?.id===e.id?J.ACTIVE:o.value?.id===e.id?J.HOVER:J.IDLE:J.IDLE,u=(e,r)=>{let i=e.skeletons,a=[];if(r||e.disabled)e.skeletons=[];else{let r=e.sampled.getValue(n()),o=e.defining,s=t.value===e;e.scheme.skeletons.forEach(t=>{if(C(t.disabled)?t.disabled({active:s,defining:o}):t.disabled)return;let n=t.format?.(r)??r?.positions??[];n.forEach((l,u)=>{let d=i.find(e=>e.index===u&&e.skeleton===t),f=t.render?.({defining:o,active:s,index:u,packable:r,positions:n,position:l,action:c(d)}),p=new Y(f??{});d?p.propertyNames.forEach(e=>{e!==`id`&&(d[e]=p[e])}):d=p,d.plot=e,d.skeleton=t,d.index=u,a.push(d)})})}e.skeletons=a},d=de();return H(e=>{e(d.add(`global`,`DRAG`,({event:e,pick:i,dragging:o,lockCamera:c})=>{if(i.id instanceof Y&&a.scope.has(i.id)){let a=i.id,l=a.plot;if(l.defining)return;s.value=a;let u=a.skeleton,d=a.index,f=l.sampled.getValue(n());u.onDrag?.({viewer:r.value,sampled:l.sampled,packable:f,active:t.value===l,index:d,event:e,dragging:o,lockCamera:c})}else s.value=void 0},{cursor:({pick:e})=>{if(!t.value?.defining&&a.scope.has(e.id)){let t=e.id.skeleton;return C(t?.cursor)?t.cursor(e):B(t?.cursor)}},dragCursor:({pick:e})=>{if(!t.value?.defining&&a.scope.has(e.id)){let t=e.id.skeleton;return C(t?.dragCursor)?t.dragCursor(e):B(t?.dragCursor)}}}))}),pe(e=>{if(s.value){let t=s.value,i=t.plot,a=t.skeleton,o=t.index,c=i.sampled.getValue(n());a.onKeyPressed?.({viewer:r.value,sampled:i.sampled,packable:c,index:o,keyEvent:e})}}),H(e=>{e(d.add(`global`,`HOVER`,({hovering:e,pick:t})=>{e&&t.id instanceof Y&&a.scope.has(t.id)?o.value=t.id:o.value=void 0}))}),H(e=>{e(d.add(`global`,`LEFT_CLICK`,({event:e,pick:i})=>{if(i.id instanceof Y&&a.scope.has(i.id)){let a=i.id;s.value=a;let o=a.plot,c=a.skeleton,l=a.index,u=o.sampled.getValue(n());c.onLeftClick?.({viewer:r.value,sampled:o.sampled,packable:u,active:t.value===o,defining:o.defining,index:l,event:e})}else s.value=void 0}))}),F(e,(e,t,n,r=[])=>{n.forEach(e=>u(e)),r.forEach(e=>u(e,!0))}),D(()=>e.value.map(e=>e.definitionChanged),(e,t,n,r)=>{if([`disabled`,`defining`,`scheme`,`sampled`,`time`].includes(t))L(()=>u(e));else if(t===`skeletons`){let{added:e,removed:t}=x(n,r);e.forEach(e=>a.add(e)),t.forEach(e=>a.remove(e))}}),V(t,(e,t)=>{e&&u(e),t&&u(t)}),{dataSource:i}}function Oe(e){let t=e?.time||z(),n=N(),r=()=>t.value?.clone()||new m(0,0),i=me(new Set),a=I(()=>Array.from(i)),o=z(),s=z();D([()=>o.value?.sampled.definitionChanged],()=>{s.value=o.value?.sampled.getValue(r())}),Ee(o,r),Te(a,o,r),De(a,o,r),M(b.LEFT_CLICK,e=>{if(o.value?.defining)return;let t=n.value?.scene.pick(e.position.clone());if(!(t?.id?.plot instanceof q)){if(!t){o.value=void 0;return}o.value=a.value.find(e=>ce(t,[...e.entities,...e.primitives,...e.groundPrimitives]))}});let c,l;return V(o,(e,t)=>{if(t&&t.defining){let e=t.sampled.getValue(r());t.scheme.allowManualComplete?.(e)?(q.setDefining(t,!1),c?.(t)):i.delete(t)}}),{plots:a,time:t,operate:async e=>new Promise((t,n)=>{c=t,l=n;let r=e instanceof q?e:new q(e);return i.has(r)||i.add(r),o.value=r,t(r)}),remove:e=>(e===o.value&&(o.value=void 0),i.has(e)?(i.delete(e),!0):!1),cancel:l}}function X(){return{disabled:({active:e})=>!e,cursor:`pointer`,dragCursor:`crosshair`,onDrag({viewer:e,sampled:t,packable:n,event:r,index:i,lockCamera:a}){a();let o=S(r.endPosition,e.scene);if(o){let e=[...n.positions??[]];e[i]=o,t.setSample({time:n.time,derivative:n.derivative,positions:e})}},onKeyPressed({viewer:e,keyEvent:t,sampled:n,packable:r,index:i}){let a=T(e.camera.position)?.height;if(!a||![`ArrowUp`,`ArrowRight`,`ArrowDown`,`ArrowLeft`].includes(t.key))return;t.preventDefault();let o=0;switch(t.key){case`ArrowRight`:o=Math.PI/2;break;case`ArrowDown`:o=Math.PI;break;case`ArrowLeft`:o=-Math.PI/2;break;case`ArrowUp`:o=0;break}let s=(e.camera.heading+o)%(2*Math.PI),c=[...r.positions??[]],l=T(c[i]),u=a/1e5*Math.PI/180/1e3;l.latitude+=u*Math.cos(s),l.longitude+=u*Math.sin(s),c[i]=w(l),n.setSample({time:r.time,derivative:r.derivative,positions:c})},render:({position:e,action:t})=>({position:e,point:{pixelSize:8,color:{[J.IDLE]:a.BLUE.withAlpha(.4),[J.HOVER]:a.BLUE.withAlpha(.6),[J.ACTIVE]:a.AQUA.withAlpha(1)}[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}})}}function Z(){let e=-1;return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];return t.length<2?[]:t.map((e,r)=>{let i=r===t.length-1?t[0]:t[r+1];return n.midpoint(e,i,new n)})},onDrag({viewer:t,sampled:n,packable:r,event:i,index:a,lockCamera:o,dragging:s}){o();let c=S(i.endPosition,t.scene);if(!c)return;let l=[...r.positions??[]];e===-1?(e=a,l.splice(a+1,0,c)):l[e+1]=c,s||(e=-1),n.setSample({time:r.time,derivative:r.derivative,positions:l})},render:({position:e,action:t,active:n})=>{if(n)return{position:e,point:{pixelSize:6,color:{[J.IDLE]:a.GREEN.withAlpha(.4),[J.HOVER]:a.GREEN.withAlpha(.6),[J.ACTIVE]:a.GREEN.withAlpha(1)}[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}}}}}function Q(){let e=-1;return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];if(t.length<2)return[];let r=[];for(let e=0;e<t.length-1;e++)r.push(n.midpoint(t[e],t[e+1],new n));return r},onDrag({viewer:t,sampled:n,packable:r,event:i,index:a,lockCamera:o,dragging:s}){o();let c=S(i.endPosition,t.scene);if(!c)return;let l=[...r.positions??[]];e===-1?(e=a,l.splice(a+1,0,c)):l[e+1]=c,s||(e=-1),n.setSample({time:r.time,derivative:r.derivative,positions:l})},render:({position:e,action:t})=>({position:e,point:{pixelSize:6,color:{[J.IDLE]:a.GREEN.withAlpha(.4),[J.HOVER]:a.GREEN.withAlpha(.6),[J.ACTIVE]:a.GREEN.withAlpha(1)}[t],disableDepthTestDistance:1/0,outlineWidth:1,outlineColor:a.WHITE.withAlpha(.4)}})}}function $(){return{disabled:({active:e,defining:t})=>!e||t,cursor:`pointer`,dragCursor:`crosshair`,format(e){let t=e.positions??[];return t.length===0?[]:t.length===1?[t[0]]:[w(y.center(y.fromCartesianArray(t)))]},onDrag({viewer:e,sampled:t,packable:r,event:i,lockCamera:a,dragging:o}){o&&a();let s=S(i.startPosition,e.scene),c=S(i.endPosition,e.scene);if(!s||!c)return;let l=n.subtract(c,s,new n),u=[...r.positions??[]];t.setSample({time:r.time,derivative:r.derivative,positions:u.map(e=>n.add(e,l,new n))})},render:({position:e,action:t})=>({position:e,billboard:{image:`data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20%20stroke%3D%22%23ffffff%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%20d%3D%22m18%209l3%203l-3%203m-3-3h6M6%209l-3%203l3%203m-3-3h6m0%206l3%203l3-3m-3-3v6m3-15l-3-3l-3%203m3-3v6%22%2F%3E%3C%2Fsvg%3E`,width:20,height:20,color:{[J.IDLE]:a.WHITE,[J.HOVER]:a.WHITE,[J.ACTIVE]:a.AQUA.withAlpha(1)}[t],pixelOffset:new n(0,-20),horizontalOrigin:p.CENTER,verticalOrigin:ie.BOTTOM,disableDepthTestDistance:1/0}})}}function ke(e){if(e.length<3)throw Error(`positions must >= 3`);if(e.length===3)return[[e[0].clone(),e[1].clone(),e[2].clone()]];let t=c.createGeometry(c.fromPositions({positions:e,vertexFormat:re.POSITION_ONLY}));if(!t)throw Error(`positions无法组成有效的geometry,检查点位是否错误`);let r=t.attributes.position.values,i=t.indices,a=[];for(let e=0;e<i.length;e+=3){let t=n.unpack(r,i[e]*3,new n),o=n.unpack(r,i[e+1]*3,new n),s=n.unpack(r,i[e+2]*3,new n);a.push([t,o,s])}return a}async function Ae(e){let{positions:t,scene:n,classificationType:a=i.BOTH,terrainProvider:o=n.terrainProvider}=e,s=[i.BOTH,i.CESIUM_3D_TILE].includes(a),c=[i.BOTH,i.TERRAIN].includes(a),l=new Promise(e=>{s?n.clampToHeightMostDetailed(t.map(e=>e.clone())).then(e).catch(t=>{console.warn(t),e([])}):e([])}),d=new Promise(e=>{c&&o?oe(o,t.map(e=>r.fromCartesian(e))).then(t=>e(t)).catch(t=>{console.warn(t),e([])}):e([])}),[f,p]=await Promise.all([l,d]),m=[];return t.forEach((e,t)=>{let n=f[t]||p[t]?u.WGS84.cartographicToCartesian(p[t]):e.clone();m.push(n)}),m}function je(e){let t=e?.clampToGround??!1,n=e?.classificationType??i.BOTH,r=Math.floor(e?.density??10);return{scene:e?.scene,clampToGround:t,classificationType:n,terrainProvider:e?.terrainProvider,density:r}}async function Me(e,t){if(e.length<3)throw Error(`positions must >= 3`);let{density:r,scene:i,clampToGround:a,classificationType:o,terrainProvider:s}=je(t);if(r<=0)throw Error(`options.density must > 0`);let c=y.fromCartesianArray(e),l=c.north-c.south,u=c.east-c.west,d=Math.max(u,l)/r,f=g.fromPositions({positions:e,vertexFormat:ee.FLAT_VERTEX_FORMAT,granularity:d}),p=g.createGeometry(f),m=p.attributes.position.values;if(!p||!m)throw Error(`positions无法组成有效的geometry,检查点位是否错误`);let h=p.indices,_=[];for(let e=0;e<h.length;e+=3){let t=n.unpack(m,h[e]*3,new n),r=n.unpack(m,h[e+1]*3,new n),i=n.unpack(m,h[e+2]*3,new n);_.push(t,r,i)}if(a){if(!i)throw Error("scene is required on `clampToGround == true`.");_=await Ae({scene:i,terrainProvider:s,positions:_,classificationType:o})}let v=[];for(;_?.length;){let[e,t,n]=_.splice(0,3);v.push([e,t,n])}return v}function Ne(e,t,r){let i=n.subtract(e,t,new n),a=n.subtract(r,t,new n),o=n.cross(i,a,i);return n.magnitude(o)*.5}function Pe(e){let t=e?.clampToGround??!1,n=e?.classificationType??i.BOTH,r=Math.floor(e?.density??10);return{scene:e?.scene,clampToGround:t,classificationType:n,terrainProvider:e?.terrainProvider,density:r}}async function Fe(e,t){if(e.length<2)throw Error(`positions.length must >= 2`);let{density:n,scene:r,clampToGround:i,classificationType:a,terrainProvider:o}=Pe(t);if(n<=0)throw Error(`options.density must > 0`);return i?(await Me(e,{density:n,scene:r,clampToGround:i,classificationType:a,terrainProvider:o})).reduce((e,t)=>e+=Ne(...t),0):ke(e).reduce((e,t)=>e+=Ne(...t),0)}async function Ie(e){let{start:t,end:r,count:i,scene:a,clampToGround:o,classificationType:s,terrainProvider:c}=e,l=[];for(let e=0;e<i;e++){let e=n.lerp(t,r,1/i,new n);l.push(e)}if(l.push(r.clone()),!o)return l;if(!a)throw Error("scene is required on `clampToGround == true`.");return await Ae({scene:a,terrainProvider:c,positions:l,classificationType:s})}function Le(e){let t=e?.clampToGround??!1,n=e?.classificationType??i.BOTH,r=Math.floor(e?.density??50);return{scene:e?.scene,clampToGround:t,classificationType:n,terrainProvider:e?.terrainProvider,density:r}}async function Re(e,t){if(e.length<2)throw Error(`positions.length must >= 2`);let r=Le(t),i=[],a=0;if(e.forEach((t,r)=>{if(r!==e.length-1){let o=e[r+1],s=n.distance(t,o);i.push(s),a+=s}}),!r.clampToGround)return{stages:i,count:a};let o=r.density;if(o<=0)throw Error(`options.density must > 0`);let s=i.map(e=>Math.floor(e/a*o)),c=o-s.reduce((e,t)=>e+=t,0);c&&(s[s.length-1]+=c);let l=s.map((t,n)=>Ie({scene:r.scene,start:e[n],end:e[n+1],count:t,clampToGround:!0,classificationType:r.classificationType,terrainProvider:r.terrainProvider})),u=(await Promise.all(l)).map(async e=>{let{count:t}=await Re(e);return t}),d=await Promise.all(u);return{stages:d,count:d.reduce((e,t)=>e+=t,0)}}const ze=new W({type:`MeasureArea`,allowManualComplete:e=>e.positions.length>=3,skeletons:[X,Z],initRender(){return{entities:[new d({label:{font:`14pt`},polyline:{material:a.YELLOW.withAlpha(.5)},polygon:{material:a.YELLOW.withAlpha(.5)}})]}},render(e){let n=e.previous.entities[0],{mouse:r,packable:i}=e,a=[...i.positions??[]];return r&&a.push(r),a.length===2?(n.position=void 0,n.label.text=void 0,n.polygon.hierarchy=void 0,n.polyline.positions=new t(()=>a,!1)):a.length>=3?(a.push(a[0]),n.position=new o(w(y.center(y.fromCartesianArray(a)))),n.label.text=new s(``),Fe(a).then(e=>{let t=``;t=e/1e3/1e3>10?`${(e/1e3/1e3).toFixed(2)}km²`:`${(+e).toFixed(2)}m²`,n.label.text=new s(t)}),n.polyline.positions=void 0,n.polygon.hierarchy=new t(()=>a.length>=3?new _([...a]):void 0,!1)):(n.position=void 0,n.polygon.hierarchy=void 0,n.polyline.positions=void 0),{entities:[n]}}}),Be=new W({type:`MeasureDistance`,allowManualComplete:e=>e.positions.length>=2,skeletons:[X],initRender(){return{entities:[new d({polyline:{width:2,material:a.YELLOW.withAlpha(.5)}})]}},render(r){r.previous.entities[0];let{mouse:i,packable:o,previous:s}=r,c=s.entities,l=[...o.positions??[]];if(i&&l.push(i),l.length<2)return{entities:c};let u=c[0];return u.polyline??=new v,u.polyline.positions=new t(()=>l,!1),l.forEach((e,t)=>{c[t+1]||(c[t+1]=new d({position:e,label:new h({backgroundColor:a.fromCssColorString(`#fff`),font:`12pt sans-serif`})}))}),c.splice(l.length,c.length-l.length-1),Re(l).then(({count:r,stages:i})=>{i.forEach((r,i)=>{c[i+1].position=new e(()=>n.midpoint(l[i],l[i+1],new n),!1),c[i+1].label.text=new t(()=>`${r.toFixed(2)} m`,!1)}),i.length>1?(c[c.length-1].position=new e(()=>l[l.length-1],!1),c[c.length-1].label.text=new t(()=>`${r.toFixed(2)} m`,!1)):(c[c.length-1].position=void 0,c[c.length-1].label.text=void 0)}),{entities:c}}}),Ve=new W({type:`Billboard`,complete:e=>e.positions.length>=1,skeletons:[$],initRender:()=>({entities:[new d({billboard:{image:`/favicon.svg`,width:32,height:32}})]}),render(t){let{mouse:n,packable:r}=t,i=t.previous.entities?.[0]??new d({billboard:{}}),a=r.positions?.[0]??n;return i.position=new e(()=>a,!0),{entities:[i]}}}),He=new W({type:`BillboardPinBuilder`,complete:e=>e.positions.length>=1,skeletons:[$],initRender(){return{entities:[new d({billboard:{}})]}},render(t){let n=t.previous.entities[0],r=t.packable.positions[0]??t.mouse;return n.position=new e(()=>r,!0),{entities:[n]}}}),Ue=new W({type:`Cylinder`,complete:e=>e.positions.length>=2,skeletons:[$,X],initRender(){return{entities:[new d({cylinder:{}})]}},render(e){let r=e.previous.entities[0],i=[...e.packable.positions];if(i.length===0)return e.previous;if(i.length===1){let t=e.mouse;t&&i.push(t)}if(i.length<2)return e.previous;r.position=new o(i[0]);let a=n.distance(i[0],i[1]);return r.cylinder.bottomRadius=new t(()=>a,!1),(e.defining||!ue(r.cylinder.length))&&(r.cylinder.length=le(a*2)),{entities:[r]}}}),We=new W({type:`Ellipse`,complete:e=>e.positions.length>=2,skeletons:[$,X],initRender(){return{entities:[new d({ellipse:{}})]}},render(e){let r=e.previous.entities[0],i=[...e.packable.positions];if(i.length===0)return e.previous;if(i.length===1){let t=e.mouse;t&&i.push(t)}if(i.length<2)return e.previous;r.position=new o(i[0]);let a=n.distance(i[0],i[1]);return r.ellipse.semiMinorAxis=new t(()=>a||1,!1),r.ellipse.semiMajorAxis=r.ellipse.semiMinorAxis,{entities:[r]}}}),Ge=new W({type:`Label`,complete:e=>e.positions.length>=1,skeletons:[$],initRender(){return{entities:[new d({label:{text:`Label`}})]}},render(t){let n=t.previous.entities[0],r=t.packable.positions[0]??t.mouse;return n.position=new e(()=>r,!0),{entities:[n]}}}),Ke=new W({type:`Point`,complete:e=>e.positions.length>=1,skeletons:[$],initRender(){return{entities:[new d({point:{pixelSize:10,color:a.RED}})]}},render(t){let n=t.previous.entities[0],r=t.packable.positions[0]??t.mouse;return n.position=new e(()=>r,!0),{entities:[n]}}}),qe=new W({type:`Polygon`,allowManualComplete:e=>e.positions.length>=2,skeletons:[$,X,Z],initRender:()=>({entities:[new d({polyline:{},polygon:{}})]}),render(e){let{mouse:n,packable:r}=e,i=e.previous.entities[0],a=[...r.positions??[]];return n&&a.push(n),a.length===2?(i.polygon.hierarchy=void 0,i.polyline.positions=new t(()=>a,!1)):a.length>=3?(i.polyline.positions=void 0,i.polygon.hierarchy=new t(()=>(a.push(a[0]),a.length>=3?new _([...a]):void 0),!1)):(i.polygon.hierarchy=void 0,i.polyline.positions=void 0),{entities:[i]}}}),Je=new W({type:`PolygonArc`,complete:e=>e.positions.length>=3,skeletons:[$,X],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;r.length<3&&e.mouse&&r.push(e.mouse.clone());let i=r.map(e=>E(e));if(i.length<3)return n.polygon.hierarchy=void 0,e.previous;let a=new _(he(i).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>a,!1),{entities:[n]}}}),Ye=new W({type:`PolygonArrowAttackDirection`,allowManualComplete:e=>e.positions.length>=3,skeletons:[$,X,Q],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;e.mouse&&r.push(e.mouse.clone());let i=r.map(e=>E(e));if(i.length<3)return n.polygon.hierarchy=void 0,e.previous;let a=new _(ge(i).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>a,!1),{entities:[n]}}}),Xe=new W({type:`PolygonArrowAttackDirectionTailed`,allowManualComplete:e=>e.positions.length>=3,skeletons:[$,X,Q],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;e.mouse&&r.push(e.mouse.clone());let i=r.map(e=>E(e));if(i.length<3)return n.polygon.hierarchy=void 0,e.previous;let a=new _(_e(i).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>a,!1),{entities:[n]}}}),Ze=new W({type:`PolygonArrowClamped`,complete:e=>e.positions.length>=5,skeletons:[$,X],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;if(r.length<5){let t=e.mouse;t&&r.push(t.clone())}let i=r.map(e=>E(e));if(i.length>=3){let e=new _(ve(i).map(e=>w(e)));n.polygon.hierarchy=new t(()=>e,!1)}else n.polygon.hierarchy=void 0;return{entities:[n]}}}),Qe=new W({type:`PolygonArrowStraight`,complete:e=>e.positions.length>=2,skeletons:[$,X],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;if(r.length<2){let t=e.mouse;t&&r.push(t.clone())}let i=r.map(e=>E(e));if(i.length>=2){let e=new _(ye(i).map(e=>w(e)));n.polygon.hierarchy=new t(()=>e,!1)}else n.polygon.hierarchy=void 0;return{entities:[n]}}}),$e=new W({type:`PolygonArrowStraightSharp`,complete:e=>e.positions.length>=2,skeletons:[$,X],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;if(r.length<2){let t=e.mouse;t&&r.push(t.clone())}let i=r.map(e=>E(e));if(i.length>=2){let e=new _(be(i).map(e=>w(e)));n.polygon.hierarchy=new t(()=>e,!1)}else n.polygon.hierarchy=void 0;return{entities:[n]}}}),et=new W({type:`PolygonArrowUnitCombatOperation`,allowManualComplete:e=>e.positions.length>=2,skeletons:[$,X,Q],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;e.mouse&&r.push(e.mouse.clone());let i=r.map(e=>E(e));if(i.length<2)return n.polygon.hierarchy=void 0,e.previous;let a=new _(xe(i).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>a,!1),{entities:[n]}}}),tt=new W({type:`PolygonArrowUnitCombatOperationTailed`,allowManualComplete:e=>e.positions.length>=2,skeletons:[$,X,Z],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions;e.mouse&&r.push(e.mouse.clone());let i=r.map(e=>E(e));if(i.length<2)return n.polygon.hierarchy=void 0,e.previous;let a=new _(Se(i).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>a,!1),{entities:[n]}}}),nt=new W({type:`PolygonAssemblingPlace`,complete:e=>e.positions.length>=3,skeletons:[$,X,Z],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],i=e.packable.positions;e.mouse&&i.push(e.mouse.clone());let a=i.map(e=>E(e));if(a.length<2)return n.polygon.hierarchy=void 0,e.previous;if(a.length===2){let e=T(a[0]),t=T(a[1]),n=e.latitude,i=e.height,o=t.longitude-(e.longitude-t.longitude);a.push(E(new r(o,n,i)))}let o=new _(Ce(a).map(e=>w(e)));return n.polygon.hierarchy=new t(()=>o,!1),{entities:[n]}}}),rt=new W({type:`PolygonSmooth`,allowManualComplete:e=>e.positions.length>=3,skeletons:[$,X,Q],initRender(){return{entities:[new d({polygon:{}})]}},render(e){let n=e.previous.entities[0],r=e.packable.positions,i=e.mouse;if(i&&r.push(i.clone()),r.length<=2)return n.polygon.hierarchy=void 0,e.previous;let a=r.map(e=>E(e));a.push(a[0]);let{features:o}=U.polygonSmooth(U.polygon([a]),{iterations:3}),s=new _(o[0].geometry.coordinates[0].map(e=>w(e)).filter(e=>!!e));return n.polygon.hierarchy=new t(()=>s,!1),{entities:[n]}}}),it=new W({type:`Polyline`,allowManualComplete:e=>e.positions.length>1,skeletons:[$,X,Q],initRender(){return{entities:[new d({polyline:{material:a.RED,width:2}})]}},render(e){let n=e.previous.entities[0],r=[...e.packable.positions],i=e.mouse;i&&r.push(i.clone());let a=r.length>=2?r:[];return n.polyline.positions=new t(()=>a,!1),{entities:[n]}}}),at=new W({type:`PolylineCurve`,allowManualComplete:e=>e.positions.length>1,skeletons:[$,X,Q],initRender(){return{entities:[new d({polyline:{material:a.RED,width:2}})]}},render(e){let n=e.previous.entities[0],r=[...e.packable.positions],i=e.mouse;if(i&&r.push(i.clone()),r.length<2)return n.polyline.positions=void 0,e.previous;let a=r.map(e=>E(e)),{geometry:{coordinates:o}}=U.bezierSpline(U.lineString(a));return n.polyline.positions=new t(()=>o.map(w),!1),{entities:[n]}}}),ot=new W({type:`Rectangle`,complete:e=>e.positions.length>=2,skeletons:[$,X],initRender(){return{entities:[new d({rectangle:{}})]}},render(e){let n=e.previous.entities[0],r=[...e.packable.positions],i=e.mouse;if(i&&r.push(i.clone()),r.length<2)return n.rectangle.coordinates=void 0,e.previous;let a=y.fromCartesianArray(r??[]);return n.rectangle.coordinates=new t(()=>a,!1),{entities:[n]}}});export{J as PlotAction,q as PlotFeature,W as PlotScheme,Ve as PlotSchemeBillboard,He as PlotSchemeBillboardPinBuilder,Ue as PlotSchemeCylinder,We as PlotSchemeEllipse,Ge as PlotSchemeLabel,Ke as PlotSchemePoint,qe as PlotSchemePolygon,Je as PlotSchemePolygonArc,Ye as PlotSchemePolygonArrowAttackDirection,Xe as PlotSchemePolygonArrowAttackDirectionTailed,Ze as PlotSchemePolygonArrowClamped,Qe as PlotSchemePolygonArrowStraight,$e as PlotSchemePolygonArrowStraightSharp,et as PlotSchemePolygonArrowUnitCombatOperation,tt as PlotSchemePolygonArrowUnitCombatOperationTailed,nt as PlotSchemePolygonAssemblingPlace,rt as PlotSchemePolygonSmooth,it as PlotSchemePolyline,at as PlotSchemePolylineCurve,ot as PlotSchemeRectangle,Y as PlotSkeletonEntity,K as SampledPlotProperty,G as SampledPlotStrategy,X as control,Z as interval,Q as intervalNonclosed,$ as moved,ze as schemeMeasureArea,Be as schemeMeasureDistance,Oe as usePlot};
|
|
2
2
|
//# sourceMappingURL=index.min.mjs.map
|