earthsdk3-cesium 3.3.0-beta.3 → 3.3.0-beta.5

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.
@@ -4142,10 +4142,10 @@ void main()
4142
4142
  {
4143
4143
  out_FragColor = u_color;
4144
4144
  }
4145
- `,uniformMap:{u_color:[1,1,0,1]},name:"CzmCustomPrimitive_47fd",attributes:{position:{typedArray:{type:"Float32Array",array:[0,0,0,0,0,1]},componentsPerAttribute:3}}},st,t)}class pQ extends p.HasOwner{constructor(n){super(n);const{czmViewer:e}=this.owner;let i;this.dispose(()=>this.owner.hoveredPlaneType="none");const o=this._createRotatorMoveProcessing();this.dispose(e.pointerMoveEvent.disposableOn(r=>{const s=i=this._getStartInfo(r.pointerEvent);s&&(this.owner.hoveredPlaneType=s.currentPlaneType)})),this.dispose(e.pointerDownEvent.disposableOn(r=>{i&&i.currentPlaneType!=="none"&&(o.restart(void 0,e,i),i=void 0)})),this.dispose(e.dblclickEvent.disposableOn(r=>{do{const s=this._getStartInfo(r.pointerEvent);if(!s||s.currentPlaneType==="none")break;const{currentPlaneType:a}=s,l=[...this.owner.selfRotation];l[ri.rotationNum[a]]=0,this.owner.selfRotation=l;return}while(!1);this.owner.enabled=!1}))}_createRotatorMoveProcessing(){return this.ad(p.createProcessingFromAsyncFunc(async(n,e,i)=>{const o=this.owner.circles[i.currentPlaneType];e.incrementDisabledInputStack(),n.disposer.dispose(()=>e.decrementDisabledInputStack()),n.disposer.dispose(e.pointerMoveEvent.don(r=>{if(i&&r.pointerEvent){const{offsetX:s,offsetY:a}=r.pointerEvent,l=[s,a],{currentPlaneType:c}=i;if(c==="none")return;const h=this.owner.getPlane(c);if(!i.currentV)return;const u=h.pick(l);if(!u||!this.owner.cartesian)return;const A=C.Cartesian3.subtract(i.currentV,this.owner.cartesian,new C.Cartesian3);C.Cartesian3.normalize(A,A);const f=C.Cartesian3.subtract(u,this.owner.cartesian,new C.Cartesian3);if(C.Cartesian3.normalize(f,f),!h.normal||!h.origin)return;const d=_v(A,f,h.normal),g=_v(h.origin,A,h.normal),v=_v(h.origin,f,h.normal);{const y=[...this.owner.selfRotation];y[ri.rotationNum[c]]=i.startRotation+d,this.owner.selfRotation=y,o.circleStartRotation=g,o.circleEndRotation=v}}})),this.owner.movingPlaneType=i.currentPlaneType,n.disposer.dispose(()=>{this.owner.movingPlaneType="none"}),n.disposer.dispose(()=>{o.circleStartRotation=0,o.circleEndRotation=0}),await p.step(n,r=>new Promise((s,a)=>{r.disposer.dispose(a),r.disposer.dispose(e.pointerUpEvent.don(()=>{s()})),r.disposer.dispose(e.pointerOutEvent.don(()=>{s()}))}))}))}_pickPlane(n,e,i,o,r){const s=this.owner.cartesian;if(!s)return;const{selfRotation:a}=this.owner,l=this.owner.getPlane(i).pick(o);if(!l)return;const c=C.Cartesian3.distance(s,l),h=r/4,u=h*3/128;if(!(c>=h-u&&c<=h+u))return;const f=C.Cartesian3.distance(e.camera.positionWC,l);n.currentD2c<=f||(n.currentPlaneType=i,n.currentD2c=f,n.currentV=l,n.startRotation=a[ri.rotationNum[i]])}_getStartInfo(n){var h;const{czmViewer:e}=this.owner,i=(h=e.viewer)==null?void 0:h.scene;if(!this.owner.position||!this.owner.cartesian)return;const o=Di(i,this.owner.cartesian,this.owner.pixelSize);if(!o)return;const{offsetX:r,offsetY:s}=n,a=[r,s],l=n.pointerId,c={currentPlaneType:"none",currentD2c:Number.POSITIVE_INFINITY,currentV:void 0,startRotation:0,pointerId:l};return this._pickPlane(c,i,"heading",a,o),this._pickPlane(c,i,"pitch",a,o),this._pickPlane(c,i,"roll",a,o),c}}function _v(t,n,e){const i=C.Cartesian3.cross(n,t,new C.Cartesian3);if(i.equals(C.Cartesian3.ZERO))return 0;C.Cartesian3.normalize(i,i);const o=C.Cartesian3.dot(i,e);let r=Math.acos(C.Cartesian3.dot(t,n))*180/Math.PI;return r=o>0?r:-r,r}const aa=class aa extends kn{constructor(e){super();L(this,"_hoveredPlaneType",this.disposeVar(p.react("none")));L(this,"_movingPlaneType",this.disposeVar(p.react("none")));L(this,"_circles");L(this,"_czmCameraModel");L(this,"_cartesian");L(this,"_planes",{heading:this.disposeVar(new cQ(this)),pitch:this.disposeVar(new hQ(this)),roll:this.disposeVar(new AQ(this))});L(this,"_rotatorRunningResetting");this._czmViewer=e;const i=this._czmViewer;if(this._rotatorRunningResetting=this.disposeVar(new p.ObjResettingWithEvent(this.enabledChanged,()=>{if(this.enabled)return new pQ(this)})),this._circles={heading:this._createRotatorCircle(i,"heading"),pitch:this._createRotatorCircle(i,"pitch"),roll:this._createRotatorCircle(i,"roll")},!!i.viewer){{const r=()=>{this._cartesian=this.position&&vt(this.position)||void 0};r(),this.dispose(this.positionChanged.disposableOn(r))}this._createCameraModel(i)}}get hoveredPlaneType(){return this._hoveredPlaneType.value}set hoveredPlaneType(e){this._hoveredPlaneType.value=e}get hoveredPlaneTypeChanged(){return this._hoveredPlaneType.changed}get movingPlaneType(){return this._movingPlaneType.value}set movingPlaneType(e){this._movingPlaneType.value=e}get movingPlaneTypeChanged(){return this._movingPlaneType.changed}get circles(){return this._circles}get czmCameraModel(){return this._czmCameraModel}get cartesian(){return this._cartesian}get czmViewer(){return this._czmViewer}getPlane(e){return this._planes[e]}get rotatorRunningResetting(){return this._rotatorRunningResetting}_createCameraModel(e){this._czmCameraModel=new Ht(e),this._czmCameraModel.url="${earthsdk3-assets-script-dir}/assets/glb/camera1/camera1.gltf",this._czmCameraModel.localRotation=[90,0,0],this._czmCameraModel.allowPicking=!1,this._czmCameraModel.opaquePass="OVERLAY",this.dispose(p.track([this._czmCameraModel,"pixelSize"],[this,"pixelSize"],i=>i*.1)),this.dispose(p.track([this._czmCameraModel,"position"],[this,"position"])),this.dispose(p.track([this._czmCameraModel,"rotation"],[this,"rotation"]));{const i=()=>{const o=at({rotation:this.selfRotation});if(!o)throw new Error("!rm");this._czmCameraModel&&(this._czmCameraModel.localModelMatrix=C.Matrix4.toArray(o))};i(),this.dispose(this.selfRotationChanged.disposableOn(i))}{const i=()=>{this.circles.heading.show=this.enabled,this.circles.pitch.show=this.enabled,this.circles.roll.show=this.enabled,this._czmCameraModel&&(this._czmCameraModel.show=this.enabled&&this.showHelper)};i(),this.dispose(this.enabledChanged.disposableOn(i)),this.dispose(this.showHelperChanged.disposableOn(i))}}_createRotatorCircle(e,i){const o=this.ad(new Es(e));this.dispose(p.track([o,"position"],[this,"position"])),this.dispose(p.track([o,"pixelSize"],[this,"pixelSize"])),this.dispose(p.track([o,"debug"],[this,"debug"])),this.dispose(p.track([o,"rotation"],[this,"rotation"]));{const r=()=>{o.selfRotation=aa.rotationFuncs[i](this.selfRotation),o.circleRotation=this.selfRotation[aa.rotationNum[i]]};r(),this.dispose(this.selfRotationChanged.disposableOn(r))}{const r=()=>{const s=this.movingPlaneType===i,a=this.hoveredPlaneType===i,c=[0,0,0,s||a?1:.8];c[aa.rotationNum[i]]=1,o.color=c};r(),this.dispose(this.movingPlaneTypeChanged.disposableOn(r)),this.dispose(this.hoveredPlaneTypeChanged.disposableOn(r))}return o}};L(aa,"rotationNum",{heading:0,pitch:1,roll:2}),L(aa,"rotationFuncs",{heading:([e,i,o])=>[0,0,0],pitch:([e,i,o])=>[e,0,-90],roll:([e,i,o])=>[e,i+90,0]});let ri=aa;(t=>{t.createDefaultProps=()=>({...kn.createDefaultProps(),rotation:p.reactArray([0,0,0]),selfRotation:p.reactArray([0,0,0]),pixelSize:300,showHelper:!1,debug:!1})})(ri||(ri={})),p.extendClassProps(ri.prototype,ri.createDefaultProps);const sa=class sa extends p.Destroyable{get startPosition(){return this.positions&&this.positions[0]}set startPosition(n){this.positions=[n??sa.defaults.positions[0],this.stopPosition??sa.defaults.positions[1]]}get startPositionChanged(){return this.positionsChanged}get stopPosition(){return this.positions&&this.positions[1]}set stopPosition(n){this.positions=[this.startPosition??sa.defaults.positions[0],n??sa.defaults.positions[1]]}get stopPositionChanged(){return this.positionsChanged}constructor(n,e){if(super(),!n.viewer)return;const o=this.ad(new Je(n,e));o.arcType="RHUMB";const r=this.ad(new On(n,e));this.ad(p.track([o,"allowPicking"],[this,"allowPicking"])),this.ad(p.track([r,"allowPicking"],[this,"allowPicking"]));{const s=()=>{o.show=r.show=this.show};s(),this.ad(this.showChanged.don(s))}{const s=()=>{o.width=this.width/2,r.pixelSize=this.width};s(),this.ad(this.widthChanged.don(s))}{const s=()=>{o.color=r.color=this.color};s(),this.ad(this.colorChanged.don(s))}{const s=()=>{o.positions=this.positions,r.position=this.stopPosition};s(),this.dispose(this.startPositionChanged.disposableOn(s)),this.dispose(this.stopPositionChanged.disposableOn(s))}}};L(sa,"defaults",{positions:[[0,0,0],[0,0,1e6]]});let Jo=sa;(t=>{t.createDefaultProps=()=>({show:!0,allowPicking:!1,positions:p.reactPositions(t.defaults.positions),width:10,color:p.reactArray([1,0,0,1])})})(Jo||(Jo={})),p.extendClassProps(Jo.prototype,Jo.createDefaultProps);class rr extends kn{constructor(e){super();L(this,"_lastPosition");L(this,"_opInfo",{step:this.ad(p.react(!1)),moved:this.ad(p.react(!1)),constraintMode:this.disposeVar(p.react("none")),originPosition:this.disposeVar(p.reactArray([0,0,0])),originHeading:this.disposeVar(p.react(0)),originDimensions:this.disposeVar(p.reactArray([1,1,1])),draggingStartPosition:this.disposeVar(p.reactArray([0,0,0])),movingPosition:this.disposeVar(p.reactArray([0,0,0])),targetPosition:this.disposeVar(p.reactArray([0,0,0])),targetHeading:this.disposeVar(p.react(0))});L(this,"_scaleAxis");L(this,"_pickingXYProcessing",e=>this.disposeVar(new p.Processing((i,o,r)=>{const s=[0,0,0],a=new C.Cartographic;return e.pointerMoveEvent.disposableOn(l=>{if(!l.pointerEvent||!e.viewer)return;const c=Zn(p.getDomEventCurrentTargetPos(l.pointerEvent));if(!ha(e.viewer.scene,c,this._opInfo.originPosition.value[2],a))return;ua(a,s),this._opInfo.constraintMode.value==="x"?fo(this._opInfo.originPosition.value,this._opInfo.originHeading.value,s,s):this._opInfo.constraintMode.value==="y"?fo(this._opInfo.originPosition.value,this._opInfo.originHeading.value+90,s,s):this._opInfo.constraintMode.value==="xy"||console.warn("should not be here!"),this._opInfo.movingPosition.value=s,this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const h=[0,0,0];Q.geoRhumbDestination(s,r,o,h),this._opInfo.targetPosition.value=h;let u=this.scale[0],A=this.scale[1];const f=Q.geoDistance(h,this._opInfo.originPosition.value)-Q.geoDistance(this._lastPosition,this._opInfo.originPosition.value);this._lastPosition=[...h];const d=this._opInfo.originDimensions.value[0]/100;f!=0&&this._opInfo.constraintMode.value==="y"&&(f>0?u+=d:u-=d),f!=0&&this._opInfo.constraintMode.value==="x"&&(f>0?A+=d:A-=d),u<=0&&(u+=d),A<=0&&(A+=d),this.scale=[u??1,A??1,this.scale[2]??1]})})));L(this,"_pickingZProcessing",e=>this.disposeVar(new p.Processing(()=>{const i=new C.Cartesian3,o=[0,0,0];return e.pointerMoveEvent.disposableOn(r=>{if(!r.pointerEvent||!e.viewer)return;const s=Zn(p.getDomEventCurrentTargetPos(r.pointerEvent));if(!jc(e.viewer.scene,vt(this._opInfo.originPosition.value),s,i))return;this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const a=this._opInfo.originPosition.value[2]-this._opInfo.draggingStartPosition.value[2];if(Ue(i,o)){this._opInfo.movingPosition.value=o;const l=this._opInfo.originPosition.value;this._opInfo.targetPosition.value=[l[0],l[1],o[2]+a];let c=this.scale[2];const h=o[2]-this._lastPosition[2];this._lastPosition=[...o];const u=this._opInfo.originDimensions.value[0]/100;h!=0&&(h>0?c+=u:c-=u),c<=0&&(c+=u),this.scale=[this.scale[0]??1,this.scale[1]??1,c??1]}})})));const i=e.viewer;if(!i)return;const{scene:o}=i;this.ad(new Vf(e,this.positionReact,this._opInfo.originDimensions,this.axisPixelSize)),this.ad(e.dblclickEvent.don(()=>{this.enabled=!1})),this._scaleAxis={zAxis:this._createScaleAxis(e,"zAxis"),yAxis:this._createScaleAxis(e,"yAxis"),xAxis:this._createScaleAxis(e,"xAxis")};{const c=()=>{if(!this._scaleAxis)return;const{zAxis:h,yAxis:u,xAxis:A}=this._scaleAxis,f=this._opInfo.constraintMode.value,d=this._opInfo.step;h.color=[0,0,1,.99],u.color=[0,1,0,.99],A.color=[1,0,0,.99],f==="x"?A.color=d?[1,1,0,.8]:[1,1,0,.99]:f==="y"?u.color=d?[1,1,0,.8]:[1,1,0,.99]:f==="z"&&(h.color=d?[1,1,0,.8]:[1,1,0,.99])};c(),this.dispose(this._opInfo.constraintMode.changed.disposableOn(c)),this.dispose(this._opInfo.step.changed.disposableOn(c))}{const c=()=>{if(!this._scaleAxis)return;const{position:u=rr.defaults.position}=this,{zAxis:A,yAxis:f,xAxis:d}=this._scaleAxis;A.startPosition=f.startPosition=d.startPosition=u;const[g,v,y]=u;A.stopPosition=[g,v,y+this._opInfo.originDimensions.value[2]];const m=Q.geoRhumbDestination(u,this._opInfo.originDimensions.value[0],90);m&&(d.stopPosition=m);const w=Q.geoRhumbDestination(u,this._opInfo.originDimensions.value[1],0);w&&(f.stopPosition=w)};c();const h=this.ad(p.createNextAnimateFrameEvent(this.positionChanged,this._opInfo.originDimensions.changed));this.ad(h.don(c))}{const c=()=>{if(this._opInfo.constraintMode.value==="none"){this._opInfo.moved.value=!1;return}if(this._opInfo.originHeading.value!==this._opInfo.targetHeading.value){this._opInfo.moved.value=!0;return}if(!this._opInfo.originPosition.value.every((h,u)=>h===this._opInfo.targetPosition.value[u])){this._opInfo.moved.value=!0;return}};c(),this.dispose(this._opInfo.originHeading.changed.disposableOn(c)),this.dispose(this._opInfo.originPosition.changed.disposableOn(c)),this.dispose(this._opInfo.targetHeading.changed.disposableOn(c)),this.dispose(this._opInfo.targetPosition.changed.disposableOn(c))}const r=this._pickingXYProcessing(e),s=this._pickingZProcessing(e),a=this.disposeVar(p.createProcessingFromAsyncFunc(async c=>{do this._opInfo.step.value=!0,this._opInfo.constraintMode.value="none",c.disposer.dispose(()=>{this._opInfo.constraintMode.value="none"}),await p.step(c,async h=>{const u=()=>{const d=[...this.position??rr.defaults.position];e.editingHeightOffset&&(d[2]-=e.editingHeightOffset),this._opInfo.targetPosition.value=this._opInfo.originPosition.value=d};h.disposer.dispose((u(),this.positionChanged.disposableOn(u)));const A={constraintMode:"none",startDragPos:[0,0,0]},f=d=>{if(!this.position)return;const g={position:this.position,dimensions:this._opInfo.originDimensions.value,heading:0};If(d,o,g,this.axisSnapPixelSize,A),this._opInfo.constraintMode.value=A.constraintMode,this._opInfo.movingPosition.value=this._opInfo.draggingStartPosition.value=A.startDragPos};h.disposer.dispose(e.pointerMoveEvent.disposableOn(d=>{d.pointerEvent&&f(d.pointerEvent)})),await p.step(h,d=>new Promise((g,v)=>{d.disposer.dispose(v),d.disposer.dispose(e.pointerDownEvent.don(y=>{y.pointerEvent&&f(y.pointerEvent),y.pointerEvent&&y.pointerEvent.button===0&&A.constraintMode!=="none"&&g()}))}))}),this._opInfo.step.value=!1,await p.step(c,async h=>{if(e.incrementDisabledInputStack(),h.disposer.dispose(()=>e.decrementDisabledInputStack()),["x","y"].includes(this._opInfo.constraintMode.value)){const u=Q.geoRhumbHeading(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value),A=Q.geoRhumbDistance(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value);r.restart(void 0,u,A),h.disposer.dispose(()=>r.cancel())}else this._opInfo.constraintMode.value==="z"&&(s.restart(),h.disposer.dispose(()=>s.cancel()));await p.step(h,u=>new Promise((A,f)=>{u.disposer.dispose(f),u.disposer.dispose(e.pointerUpEvent.don(()=>{A()})),u.disposer.dispose(e.pointerOutEvent.don(()=>{A()}))})),this._lastPosition=void 0});while(!0)})),l=()=>{this.enabled?a.restart():a.isRunning&&a.cancel()};l(),this.dispose(this.enabledChanged.disposableOn(l))}get scaleAxis(){return this._scaleAxis}_createScaleAxis(e,i){const o=this.ad(new Jo(e));return o.width=10,this.ad(p.track([o,"show"],[this,"enabled"])),o}}(t=>{t.createDefaultProps=()=>({...kn.createDefaultProps(),scale:p.reactArray([1,1,1]),axisPixelSize:100,axisSnapPixelSize:5})})(rr||(rr={})),p.extendClassProps(rr.prototype,rr.createDefaultProps);const ho=class ho extends hn{constructor(e){super();L(this,"_editingPoints",this.disposeVar(new p.ObservableArray));L(this,"_cancelEvent",this.disposeVar(new p.Event));L(this,"_currentProcess");L(this,"_menuPoiEnabled",this.disposeVar(p.react(!1)));L(this,"_status",this.disposeVar(p.react("None")));L(this,"_positionsChanged",this.ad(new p.Event));L(this,"_cursorInfo");this._czmViewer=e,this.enabled=!1,this.createPolyline(e),this._createCursorInfo(e),this.dispose(()=>this.resetPositions()),this.dispose(()=>this.editingPoints.length=0),this.dispose(this.editingPoints.changedEvent.disposableOn(()=>this.positionsChanged.emit())),this.dispose(this.editingPoints.toChangeEvent.disposableOn(i=>{for(let{start:o,deleteCount:r,items:s}of i){for(const a of s)a.menuPoi.enabled=this.menuPoiEnabled??!1;for(let a=o;a<o+r;++a)this.editingPoints.get(a).destroy()}})),this.dispose(this.menuPoiEnabledChanged.disposableOn(()=>{for(let i of this.editingPoints)i.menuPoi.enabled=this.menuPoiEnabled??!1})),this.dispose(e.dblclickEvent.don(i=>{this.ad(p.nextAnimateFrame(()=>{var o;((o=i.pointerEvent)==null?void 0:o.button)===0&&this.enabled&&this.currentProcess&&this.currentProcess.cancel()}))})),this.dispose(this.enabledChanged.disposableOn(i=>{this._currentProcess&&(i?this._currentProcess.restart():this._currentProcess.isRunning&&this._currentProcess.cancel())}));{const i=()=>{this.polylineShow=this.czmViewer.editingLineShow};i(),this.ad(this.czmViewer.editingLineShowChanged.don(i))}}get editingPoints(){return this._editingPoints}get cancelEvent(){return this._cancelEvent}cancel(){this._cancelEvent.emit()}get currentProcess(){return this._currentProcess}set currentProcess(e){this._currentProcess=e}get menuPoiEnabled(){return this._menuPoiEnabled.value}set menuPoiEnabled(e){this._menuPoiEnabled.value=e}get menuPoiEnabledChanged(){return this._menuPoiEnabled.changed}get status(){return this._status.value}get statusChanged(){return this._status.changed}set status(e){this._status.value=e}getPositions(){const e=[];for(let i of this._editingPoints)i.position&&e.push([...i.position]);return e}resetPositions(e){if(this.enabled??ho.defaults.enabled)return console.warn("MultiPointsEditing.resetPositions error: this.enabled === true"),!1;const i=e||[];return!(i.length===this.editingPoints.length&&i.every((o,r)=>o.every((s,a)=>{const l=this.editingPoints.get(r);return l.position&&l.position[a]===s})))}forceResetPositions(e){(this.enabled??ho.defaults.enabled)&&(this.enabled=!1),this.resetPositions(e)}get positions(){return this.getPositions()}set positions(e){this.resetPositions(e)}get positionsChanged(){return this._positionsChanged}get czmViewer(){return this._czmViewer}get cursorInfo(){return this._cursorInfo}createPolyline(e){const i=this.ad(new Je(e));this.ad(p.track([i,"color"],[this,"polylineColor"])),this.ad(p.track([i,"width"],[this,"polylineWidth"])),this.ad(p.track([i,"show"],[this,"polylineShow"])),this.ad(p.track([i,"arcType"],[this,"polylineArcType"])),this.ad(p.track([i,"loop"],[this,"loop"]));{const o=()=>{const r=[];for(const s of this.getPositions())s[2]-=e.editingHeightOffset??0,r.push(s);i.positions=r};o(),this.ad(this.positionsChanged.don(o))}}_createCursorInfo(e){const i=this._cursorInfo=this.ad(new p.CursorInfo(e.container,p.CursorFloatDiv));this.dispose(this.statusChanged.disposableOn(()=>{const o=this.status;if(i){if(!this.hideCursorInfo){i.show=!1;return}o==="Adding"?(i.text="右键/BackSpace键:删除上一个控制点;Esc键或左键双击:退出添加状态,进入修改状态",i.show=!0):o==="Modifying"||o==="Modifying_Point"?(i.text="Esc键或左键双击:退出编辑状态",i.show=!0):o==="None"&&(i.text="",i.show=!1)}}))}};L(ho,"baseImageUrl","${earthsdk3-assets-script-dir}/assets/img/"),L(ho,"defaults",{...hn.defaults,debug:!1,polylineShow:!1,polylineWidth:1,polylineColor:[1,1,1,1],polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,loop:!1,firstControlPointImageUrl:ho.baseImageUrl+"point-green.png",otherControlPointImageUrl:ho.baseImageUrl+"point-yellow.png"});let Wn=ho;(t=>{t.createDefaultProps=()=>({...hn.createDefaultProps(),loop:!1,debug:!1,polylineShow:!0,polylineWidth:1,polylineColor:p.reactArray([1,1,1,1]),polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,firstControlPointImageUrl:t.baseImageUrl+"point-green.png",otherControlPointImageUrl:t.baseImageUrl+"point-yellow.png",hideCursorInfo:!1,middlePointShow:!0})})(Wn||(Wn={})),p.extendClassProps(Wn.prototype,Wn.createDefaultProps);let mQ=0;class XS extends p.Destroyable{constructor(e,i){super();L(this,"_position",this.disposeVar(p.reactArrayWithUndefined(void 0)));L(this,"_id",mQ++);L(this,"_menuPoi");i&&(this.position=i),e.debug&&console.log(`PolylinePositionEditor creating! ${this.id}`),this.dispose(()=>{e.debug&&console.log(`PolylinePositionEditor destroying! ${this.id}`)});const o=this._menuPoi=this.ad(new _a(e.czmViewer));o.enabled=!1,this.ad(p.track([o,"show"],[e,"enabled"]));{const r=()=>{if(this.position===void 0){o.position=void 0;return}const s=[...this.position];s[2]-=e.czmViewer.editingHeightOffset??0,o.position=s,e.positionsChanged.emit()};r(),this.d(this.positionChanged.don(r))}{const r=()=>{const s=e.editingPoints.indexOf(this)+1;s!==0&&(o.title=`控制点${s}`,s===1?o.imageUri=e.firstControlPointImageUrl??Wn.defaults.firstControlPointImageUrl:o.imageUri=e.otherControlPointImageUrl??Wn.defaults.otherControlPointImageUrl)};r(),this.dispose(e.editingPoints.changedEvent.disposableOn(r))}}get position(){return this._position.value}set position(e){this._position.value=e}get positionChanged(){return this._position.changed}get id(){return this._id}get menuPoi(){return this._menuPoi}}class $S extends XS{constructor(n,e){super(n,e)}}class Pt extends Wn{constructor(e){super(e);L(this,"_deletePreviousPointWhileAddingEvent",this.disposeVar(new p.Event));L(this,"placeEditing");if(!e.viewer)return;const i=this.placeEditing=this.ad(new ii(e));i.enabled=!1,this.currentProcess=this.disposeVar(p.createProcessingFromAsyncFunc(async o=>{o.disposer.dispose(()=>{(this.debug??Pt.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1}),(this.debug??Pt.defaults.debug)&&console.log("直接进入Adding状态"),this.status="Adding",await o.promise(p.step(o,async r=>{const s=r.disposer,a=s.ad(this._addingEditingProcessing());s.dispose(()=>"adding canceled!"),s.dispose(this.cancelEvent.disposableOn(()=>a.cancel())),await r.promise(new Promise(l=>{s.dispose(a.completeEvent.disposableOnce(l))}))}))})),this.dispose(e.clickEvent.don(o=>{var r;((r=o.pointerEvent)==null?void 0:r.button)===2&&this.deletePreviousPointWhileAdding()}))}deletePreviousPointWhileAdding(){this._deletePreviousPointWhileAddingEvent.emit()}resetPositions(e){if(!super.resetPositions(e))return!0;const i=e?e.map(o=>new $S(this,o)):[];return this.editingPoints.splice(0,this.editingPoints.length,...i),!0}_addingEditingProcessing(){const e=()=>{if(this.maxPointsNum!==void 0)return this.editingPoints.length>=this.maxPointsNum&&(this.debug??Pt.defaults.debug)&&console.log("impl.positionEditors.length >= impl.maxPointsNum"),this.editingPoints.length>=this.maxPointsNum},i=p.createProcessingFromAsyncFunc(async o=>{let r=this.editingPoints.length;this.menuPoiEnabled=!1;do if(!await o.promise(p.step(o,async a=>{let l;!e()&&(l=a.disposer.disposeVar(new gQ(this,r)));const h=a.disposer.disposeVar(new vQ(this,r));return a.disposer.dispose(this._deletePreviousPointWhileAddingEvent.disposableOn(()=>h.do())),await a.promise(new Promise(u=>{l&&a.disposer.dispose(l.overEvent.disposableOnce(A=>{A?(r++,u(!0)):u(!1)})),a.disposer.dispose(h.overEvent.disposableOnce(A=>{A?(r--,u(!0)):u(!1)})),a.disposer.dispose(this.cancelEvent.disposableOn(()=>u(!1)))}))})))break;while(!0)});return i.start(),i}}(t=>{t.createDefaultProps=()=>({...Wn.createDefaultProps()})})(Pt||(Pt={})),p.extendClassProps(Pt.prototype,Pt.createDefaultProps);class gQ extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));const{placeEditing:o}=e;let r=new $S(e,void 0);e.editingPoints.splice(i,0,r);const s=()=>{(e.debug??Pt.defaults.debug)&&console.log("delete currentPosEditor");const c=e.editingPoints.indexOf(r);if(c===-1)throw new Error("currentPosEditor not found");e.editingPoints.splice(c,1)};if(o.enabled??!1)throw console.error("placeEditing.enabled is true!"),new Error("placeEditing.enabled is true!");this.dispose(p.track([r,"position"],[o,"position"])),o.enabled=!0;let a=!1;const l=()=>{s(),this._overEvent.emit(!1)};this.dispose(()=>{o.enabled=!1,!a&&l()}),this.dispose(o.overEvent.disposableOnce(()=>{a=!0,r.position===void 0?l():this._overEvent.emit(!0)})),(e.debug??Pt.defaults.debug)&&console.log(`PointAdding creating! index(${i})`),this.dispose(()=>{(e.debug??Pt.defaults.debug)&&console.log(`PointAdding destroying! index(${i})`)})}get overEvent(){return this._overEvent}}function yQ(t,n){const e=t.editingPoints,i=n-1;return i<0?(console.warn("previousIndex < 0, cannot delete the point!"),!1):(e.splice(i,1),!0)}class vQ extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"_doEvent",this.disposeVar(new p.Event));this.dispose(this._doEvent.disposableOn(()=>this._overEvent.emit(yQ(e,i)))),(e.debug??Pt.defaults.debug)&&console.log(`PreviousPointDeleting creating! currentIndex(${i})`),this.dispose(()=>{(e.debug??Pt.defaults.debug)&&console.log(`PreviousPointDeleting destroying! currentIndex(${i})`)})}get overEvent(){return this._overEvent}do(){return this._doEvent.emit()}}class YS extends Pt{constructor(n){super(n),this.loop=!1}}class JS extends Pt{constructor(n){super(n),this.loop=!0}}class gf extends XS{constructor(n,e){super(n,e);{const{menuPoi:i}=this;i.commands=[["add","增加控制点","",tt.baseImageUrl+"add.png"],["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]],i.clickCommandName="modify",i.rightClickCommandName="delete",this.dispose(i.commandEvent.disposableOn(o=>{n.menuPoiCommand(this,o)})),this.dispose(i.dbclickEvent.disposableOn(()=>{n.menuPoiCommand(this,"dbClick")}))}if(n.middlePointShow){const i=this.ad(new ui(n.czmViewer));{i.imageUri=n.firstControlPointImageUrl??tt.defaults.firstControlPointImageUrl,i.tooltip="点击增加一个控制点",i.bgColor=[0,0,0,.6],i.fgColor=[1,1,1,1],i.size=[8,8],i.originRatioAndOffset=[.5,.5,0,0];{const o=()=>{if(!(n.enabled??tt.defaults.enabled)){i.enabled=!1,i.show=!1;return}do{const s=n.editingPoints.indexOf(this);if(s===-1)break;const a=n.editingPoints.length;if(a===0){console.error("impl.positionEditors.length === 0!");break}if(!(n.loop??tt.defaults.loop)&&s+1>=a)break;const c=this.position;if(!c)break;let h=(s+1)%a;const A=n.editingPoints.get(h).position;if(!A)break;const f=Mf(c,A);if(!f)break;f[2]-=n.czmViewer.editingHeightOffset??0,i.position=f;const d=n.editingPoints.length<(n.maxPointsNum??tt.defaults.maxPointsNum);i.enabled=d,i.show=d;return}while(!1);i.enabled=!1,i.show=!1};o(),this.dispose(n.positionsChanged.disposableOn(o)),this.dispose(n.loopChanged.disposableOn(o)),this.dispose(n.enabledChanged.disposableOn(o))}this.dispose(i.clickEvent.disposableOn(o=>{if(o.button!==0||n.editingPoints.length>=(n.maxPointsNum??tt.defaults.maxPointsNum))return;const r=n.editingPoints.indexOf(this);if(r===-1)return;const s=i.position?[...i.position]:void 0;s&&(s[2]+=n.czmViewer.editingHeightOffset??0);let a=new gf(n,s);n.editingPoints.splice(r+1,0,a),n.modify(a)}))}}}}class tt extends Wn{constructor(e){super(e);L(this,"_menuPoiCommand",this.disposeVar(new p.Event));L(this,"_forceModifyPosEditorEvent",this.disposeVar(new p.Event));L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"translationEditing");{const o=this.ad(p.createNextAnimateFrameEvent(this.moveWithFirstPositionChanged,this.editingPoints.changedEvent));this.ad(new p.ObjResettingWithEvent(o,()=>{if(!(!this.moveWithFirstPosition||this.editingPoints.length<=1))return new wQ(this.editingPoints.get(0),this)}))}const i=this.translationEditing=this.disposeVar(new ir(e));i.enabled=!1,this.currentProcess=this.disposeVar(p.createProcessingFromAsyncFunc(async o=>{o.disposer.dispose(()=>{(this.debug??tt.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1});let r=-1;do if((this.debug??tt.defaults.debug)&&console.log("进入Modifying修改状态"),this.status="Modifying",r=await o.promise(p.step(o,async s=>{const a=s.disposer,l=a.ad(new bQ(this));return a.dispose(()=>"modifying canceled!"),this.editingPoints.length>0&&l.modify(this.editingPoints.get(r===-1||r>=this.editingPoints.length?0:r)),a.dispose(this.cancelEvent.disposableOn(()=>l.cancel())),a.dispose(this._forceModifyPosEditorEvent.disposableOn(h=>l.modify(h))),await s.promise(new Promise(h=>{a.dispose(l.overEvent.disposableOnce(u=>{h(u)}))}))})),r===-1){(this.debug??tt.defaults.debug)&&console.log("退出编辑状态");break}else{if(this.editingPoints.length>=(this.maxPointsNum??tt.defaults.maxPointsNum))return;if(this.editingPoints.length===0){console.error("impl.positionEditors.length === 0!");return}this.loop??tt.defaults.loop;const a=this.editingPoints.get(r-1).position;if(!a)return;let l=r%this.editingPoints.length;const h=this.editingPoints.get(l).position;if(!h)return;const u=Mf(a,h);if(!u)return;u&&(u[2]+=this.czmViewer.editingHeightOffset??0);let A=new gf(this,u);this.editingPoints.splice(r,0,A)}while(!0);this.status="None",this.enabled=!1}))}menuPoiCommand(e,i){this._menuPoiCommand.emit(e,i)}modify(e){this._forceModifyPosEditorEvent.emit(e)}resetPositions(e){if(!super.resetPositions(e))return!0;const i=e?e.map(o=>new gf(this,o)):[];return this.editingPoints.splice(0,this.editingPoints.length,...i),!0}get overEvent(){return this._overEvent}}(t=>{t.createDefaultProps=()=>({...Wn.createDefaultProps(),moveWithFirstPosition:!1})})(tt||(tt={})),p.extendClassProps(tt.prototype,tt.createDefaultProps);class wQ extends p.Destroyable{constructor(n,e){super(),this._firstPositionEditor=n,this.multiPointsModifyEditing=e,this._firstPositionEditor.positionChanged.disposableOn((i,o)=>{if(i===void 0||o===void 0)return;var r=[i[0]-o[0],i[1]-o[1],i[2]-o[2]];const s=this.multiPointsModifyEditing.editingPoints.length;for(let a=1;a<s;a++){const l=this.multiPointsModifyEditing.editingPoints.get(a),c=l.position;c!==void 0&&(l.position=[c[0]+r[0],c[1]+r[1],c[2]+r[2]])}})}}class bQ extends p.Destroyable{constructor(e){super();L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"_cancelEvent",this.disposeVar(new p.Event));L(this,"_forceModifyPosEditorEvent",this.disposeVar(new p.Event));e.menuPoiEnabled=!0,this.dispose(()=>e.menuPoiEnabled=!1);let i;const o=()=>{i==null||i.destroy(),i=void 0,e.status="Modifying"};this.dispose(o);const r=s=>{o(),e.status="Modifying_Point",i=new _Q(e,s),i.dispose(i.overEvent.disposableOn(()=>{o()}))};this.dispose(this._forceModifyPosEditorEvent.disposableOn(r)),this.dispose(e._menuPoiCommand.disposableOn((s,a)=>{if(a==="delete"){if(e.editingPoints.length<=2)return;const l=e.editingPoints.indexOf(s);if(l===-1)throw console.error("posEditor not found"),new Error("posEditor not found");e.editingPoints.splice(l,1)}else if(a==="modify")r(s);else if(a==="add"){const l=e.editingPoints.indexOf(s);if(l===-1)throw console.error("posEditor not found"),new Error("posEditor not found");this._overEvent.emit(l+1)}else a==="dbClick"?this._overEvent.emit(-1):alert(`未知的commandName(${a})`)})),this.dispose(this._cancelEvent.disposableOn(()=>{this._overEvent.emit(-1)}))}get overEvent(){return this._overEvent}cancel(){this._cancelEvent.emit()}modify(e){this._forceModifyPosEditorEvent.emit(e)}}class _Q extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));this._modifying=e,this._posEditor=i,this.dispose(this._posEditor.toDestroyEvent.disposableOn(()=>{this._overEvent.emit()}));const{translationEditing:o}=this._modifying;if(o.enabled=!0,o.heading=0,this.dispose(()=>{o.enabled=!1}),!this._posEditor.position)throw console.error("!this._posEditor.position"),new Error("!this._posEditor.position");o.position=this._posEditor.position,this.dispose(p.track([this._posEditor,"position"],[o,"position"])),this.dispose(o.enabledChanged.disposableOnce(r=>{r||this._overEvent.emit()}))}get overEvent(){return this._overEvent}}class jS extends tt{constructor(n){super(n),this.loop=!1}}class eE extends tt{constructor(n){super(n),this.loop=!0}}class Ps extends Pt{init(){const n=this.startPosition;if(!n)return;const e=this.distance,i=this.rotation,o=e*Math.cos(i[1]*Math.PI/180),r=Q.geoDestination(n,o,i[0]);if(!r){this.positions=[n];return}const s=e*Math.sin(i[1]*Math.PI/180);r[2]+=s,this.positions=[n,r],this.editingPoints.length==2&&(this.editingPoints.get(0).position=n,this.editingPoints.get(1).position=r)}constructor(n){super(n),this.loop=!0,this.maxPointsNum=2;{const e=()=>{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];return}if(this.positions.length==1){this.distance=1,this.rotation=[90,0,0];return}this.startPosition=this.positions[0],this.endPosition=this.positions[1];const i=Q.geoHeading(this.startPosition,this.endPosition),o=Q.geoDistance(this.startPosition,this.endPosition);if(o<=0){this.rotation=[90,0,0],this.distance=1;return}const r=this.endPosition[2]-this.startPosition[2],s=Math.atan(r/o)*180/Math.PI,a=Math.sqrt(o*o+r*r);this.rotation=[i,s,0],this.distance=a};e(),this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...Pt.createDefaultProps(),startPosition:p.reactArrayWithUndefined(void 0),endPosition:p.reactArrayWithUndefined(void 0),rotation:p.reactArray([90,0,0]),distance:p.react(1)})})(Ps||(Ps={})),p.extendClassProps(Ps.prototype,Ps.createDefaultProps);class jo extends tt{init(){const n=this.startPosition;if(!n)return;const e=this.distance,i=this.rotation,o=e*Math.cos(i[1]*Math.PI/180),r=Q.geoDestination(n,o,i[0]);if(!r){this.positions=[n];return}const s=e*Math.sin(i[1]*Math.PI/180);r[2]+=s,this.positions=[n,r],this.editingPoints.length==2&&(this.editingPoints.get(0).position=n,this.editingPoints.get(1).position=r)}constructor(n){super(n),this.loop=!0,this.maxPointsNum=2,this.middlePointShow=!1,this.moveWithFirstPosition=!0;{const e=()=>{do{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];break}if(this.startPosition=this.positions[0],this.positions.length==1){this.editingPoints.get(0).menuPoi.commands=[["add","增加控制点","",tt.baseImageUrl+"add.png"],["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]],this.rotation=[90,0,0],this.distance=1;break}this.endPosition=this.positions[1];for(let l of this.editingPoints)l.menuPoi.commands=[["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]];const i=Q.geoHeading(this.startPosition,this.endPosition),o=Q.geoDistance(this.startPosition,this.endPosition);if(Math.abs(o)<=0){this.rotation=[90,0,0],this.distance=1;return}const r=this.endPosition[2]-this.startPosition[2],s=Math.atan(r/o)*180/Math.PI,a=Math.sqrt(o*o+r*r);this.rotation=[i,s,0],this.distance=a}while(!1)};this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...tt.createDefaultProps(),startPosition:p.reactArrayWithUndefined(void 0),endPosition:p.reactArrayWithUndefined(void 0),rotation:p.reactArray([0,0,0]),distance:p.react(0)})})(jo||(jo={})),p.extendClassProps(jo.prototype,jo.createDefaultProps);class tE extends Pt{constructor(n){super(n),this.loop=!1,this.polylineShow=!1}}class nE extends tt{constructor(n){super(n),this.loop=!1,this.polylineShow=!1,this.middlePointShow=!1}}class Ts extends Pt{constructor(n){super(n),n.viewer||(this.loop=!1);{const e=()=>{if(!this.positions||this.positions.length<2){this.visibilityPositions=void 0;return}const i=[...this.positions[0]];i[2]-=n.editingHeightOffset??0,this.visibilityPositions=this.positions.map(o=>(o[2]-=n.editingHeightOffset??0,[i,o]))};e(),this.ad(this.positionsChanged.don(e))}}createPolyline(n){const e=this.ad(new $n(n));e.topOrBottom="bottom",this.ad(p.track([e,"color"],[this,"polylineColor"])),this.ad(p.track([e,"width"],[this,"polylineWidth"])),this.ad(p.track([e,"show"],[this,"polylineShow"])),this.ad(p.track([e,"arcType"],[this,"polylineArcType"])),this.ad(p.track([e,"loop"],[this,"loop"])),this.ad(p.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...Pt.createDefaultProps(),visibilityPositions:p.reactPositionsSet(void 0)})})(Ts||(Ts={})),p.extendClassProps(Ts.prototype,Ts.createDefaultProps);class Is extends tt{constructor(n){if(super(n),!!n.viewer){this.loop=!1,this.middlePointShow=!1;{const e=()=>{if(!this.positions||this.positions.length<2)return;const i=[...this.positions[0]];i[2]-=n.editingHeightOffset??0,this.visibilityPositions=this.positions.map(o=>(o[2]-=n.editingHeightOffset??0,[i,o]))};e(),this.ad(this.positionsChanged.don(e))}}}createPolyline(n){const e=this.ad(new $n(n));e.topOrBottom="bottom",this.ad(p.track([e,"color"],[this,"polylineColor"])),this.ad(p.track([e,"width"],[this,"polylineWidth"])),this.ad(p.track([e,"show"],[this,"polylineShow"])),this.ad(p.track([e,"arcType"],[this,"polylineArcType"])),this.ad(p.track([e,"loop"],[this,"loop"])),this.ad(p.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...tt.createDefaultProps(),visibilityPositions:p.reactPositionsSet(void 0)})})(Is||(Is={})),p.extendClassProps(Is.prototype,Is.createDefaultProps);class iE extends jo{constructor(n){super(n),this.firstControlPointImageUrl=this.otherControlPointImageUrl,this.translationEditing.xAxisShow=!1,this.translationEditing.yAxisShow=!1,this.translationEditing.zAxisShow=!0,this.translationEditing.showCircle=!1,this.rotation=[0,90,0]}}class rn extends Q.EngineObject{constructor(e,i,o){super(e,i,o??!0);L(this,"_supportEditing",this.disposeVar(p.react(!0)));L(this,"_currentEditing",this.disposeVar(p.react(void 0)));this.ad(this.supportEditingChanged.don(()=>{this.destroy()})),this.ad(this.toDestroyEvent.don(()=>{var r;if(this.currentEditing){if(this.currentEditing instanceof Pt&&((r=this.currentEditing.currentProcess)!=null&&r.isRunning))if(this.currentEditing.currentProcess.cancel(),e!=null&&e.position){if(this.currentEditing.positions.length>1)return;e.position=this.currentEditing.positions[0]??[0,0,0],e!=null&&e.rotation&&(e.rotation=[0,0,0]),e!=null&&e.far&&(e.far=1),e!=null&&e.radius&&(e.radius=1),e!=null&&e.distance&&(e.distance=1)}else e.points=this.currentEditing.positions;this.currentEditing instanceof ii&&this.currentEditing.enabled&&(e.position=[0,0,0])}}))}get supportEditing(){return this._supportEditing.value}set supportEditing(e){this._supportEditing.value=e}get supportEditingChanged(){return this._supportEditing.changed}get currentEditing(){return this._currentEditing.value}set currentEditing(e){this._currentEditing.value=e}get currentEditingChanged(){return this._currentEditing.changed}}const Rc=class Rc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new ii(e));this.ad(e.clickEvent.don(o=>{var r;((r=o.pointerEvent)==null?void 0:r.button)==2&&(i.enabled=!0)}));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"position"],[n,"position"])),i.enabled=!i.position||Q.equalsN3(i.position,[0,0,0]);break}this.supportEditing=!1}while(!1)}};L(Rc,"type",Rc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Place,Rc));let Cv=Rc;const Uc=class Uc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new ri(e));i.rotation=[90,0,0],this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(n instanceof Q.ES3DTileset){Q.registerCreatedEventUpdate(this,n,()=>{const o=e.getEngineObject(n);o&&(this.ad(p.bind([i,"position"],[o.czm3DTiles,"position"])),this.ad(p.bind([i,"selfRotation"],[n,"rotation"])))});break}if(Reflect.has(n,"position")&&Reflect.has(n,"rotation")){this.ad(p.bind([i,"position"],[n,"position"])),this.ad(p.bind([i,"selfRotation"],[n,"rotation"]));break}this.supportEditing=!1}while(!1)}};L(Uc,"type",Uc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Rotation,Uc));let xv=Uc;const Oc=class Oc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new rr(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"position")&&Reflect.has(n,"scale")){this.ad(p.bind([i,"position"],[n,"position"])),this.ad(p.bind([i,"scale"],[n,"scale"]));break}this.supportEditing=!1}while(!1)}};L(Oc,"type",Oc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Scale,Oc));let Sv=Oc;const Lc=class Lc extends rn{constructor(n,e){super(Array.isArray(n)?n[0]:n,e,!0);const i=this.currentEditing=this.ad(new ir(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Array.isArray(n)){const o=[];for(let r=0;r<n.length;r++){const s=n[r];Reflect.has(s,"position")?o.push(s.position):s.points&&o.push(...s.points)}i.position=Q.getMinMaxCorner(o).center,this.ad(i.positionChanged.disposableOn((r,s)=>{if(!(!r||!s)){var a=fn({originPosition:s},[r])[0][0];n.forEach(l=>{if(Reflect.has(l,"position")){const c=fn({originPosition:s},[l.position])[0][0];l.position=pr({originPosition:s},[[c[0]+a[0],c[1]+a[1],c[2]+a[2]]])[0][0]}else if(Reflect.has(l,"points")&&l.points){const c=fn({originPosition:s},l.points)[0];l.points=pr({originPosition:s},c.map(h=>[h[0]+a[0],h[1]+a[1],h[2]+a[2]]))[0]}})}}));break}if(Reflect.has(n,"position")){this.ad(p.bind([i,"position"],[n,"position"]));break}if(n instanceof Q.ES3DTileset){Q.registerCreatedEventUpdate(this,n,()=>{const o=e.getEngineObject(n);this.ad(p.bind([i,"position"],[o.czm3DTiles,"position"]))});break}if(Reflect.has(n,"points")){if(n.points===void 0||n.points.length===0){this.destroy();break}i.position=Q.getMinMaxCorner(n.points).center,this.ad(i.positionChanged.disposableOn((o,r)=>{if(o===void 0||r===void 0||n.points===void 0||n.points.length===0){this.destroy();return}var s=fn({originPosition:r},[o])[0][0];const a=fn({originPosition:r},n.points)[0];n.points=pr({originPosition:r},a.map(l=>[l[0]+s[0],l[1]+s[1],l[2]+s[2]]))[0]}));break}this.supportEditing=!1}while(!1)}};L(Lc,"type",Lc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Translation,Lc));let yf=Lc;const zc=class zc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Ps(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"startPosition"],[n,"position"])),this.ad(Dt([i,"rotation"],[n,"rotation"]));do{if(Reflect.has(n,"far")){this.ad(p.bind([i,"distance"],[n,"far"]));break}if(Reflect.has(n,"radius")){this.ad(p.bind([i,"distance"],[n,"radius"]));break}if(Reflect.has(n,"distance")){this.ad(p.bind([i,"distance"],[n,"distance"]));break}const o=vt(n.position);if(C.Cartesian3.ZERO.equals(o)||!e.viewer)return;i.distance=Di(e.viewer.scene,o,100)??1}while(!1);break}if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1);i.startPosition&&!Q.equalsN3(i.startPosition,[0,0,0])&&i.init(),i.enabled=!0}};L(zc,"type",zc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.DoublePointsAppend,zc));let Ev=zc;const Qc=class Qc extends rn{constructor(n,e){var r;if(super(n,e,!0),!e.viewer)return;const i=this.currentEditing=this.ad(new jo(e));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"startPosition"],[n,"position"])),this.ad(Dt([i,"rotation"],[n,"rotation"]));do{if(Reflect.has(n,"far")){this.ad(p.bind([i,"distance"],[n,"far"]));break}if(Reflect.has(n,"radius")){this.ad(p.bind([i,"distance"],[n,"radius"]));break}if(Reflect.has(n,"distance")){this.ad(p.bind([i,"distance"],[n,"distance"]));break}const s=vt(n.position);if(C.Cartesian3.ZERO.equals(s)||!e.viewer)return;i.distance=Di(e.viewer.scene,s,100)??1}while(!1);break}if(Reflect.has(n,"points")&&((r=n.points)==null?void 0:r.length)==2){i.moveWithFirstPosition=!1;const s=()=>i.positions=n.points??[];s(),this.ad(n.pointsChanged.don(()=>!i.enabled&&s())),this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1;return}while(!1);i.init(),i.enabled=!0;const o=this.ad(p.createNextAnimateFrameEvent(i.enabledChanged,i.startPositionChanged));this.ad(o.don(()=>{(!i.enabled||!i.startPosition||Q.equalsN3(i.startPosition,[0,0,0]))&&this.destroy()}))}};L(Qc,"type",Qc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.DoublePointsModify,Qc));let Pv=Qc;const Vc=class Vc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new JS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Vc,"type",Vc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.CircularAppend,Vc));let Tv=Vc;const Hc=class Hc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new eE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Hc,"type",Hc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.CircularInsert,Hc));let Iv=Hc;const Nc=class Nc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new YS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Nc,"type",Nc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.LineStringAppend,Nc));let kv=Nc;const Gc=class Gc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new jS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Gc,"type",Gc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.LineStringInsert,Gc));let Fv=Gc;const Wc=class Wc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new tE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Wc,"type",Wc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.ScatterAppend,Wc));let Bv=Wc;const qc=class qc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new nE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(qc,"type",qc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.ScatterModify,qc));let Mv=qc;const Kc=class Kc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Ts(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Kc,"type",Kc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.VisibilityAppend,Kc));let Dv=Kc;const Zc=class Zc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Is(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Zc,"type",Zc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.VisibilityModify,Zc));let Rv=Zc;const Xc=class Xc extends rn{constructor(n,e){if(super(n,e,!0),!e.viewer)return;const i=this.currentEditing=this.ad(new iE(e));do{if(Reflect.has(n,"points")){const r=Reflect.has(n,"extrudedHeight"),s=Reflect.has(n,"height"),a=Reflect.has(n,"perPositionHeight")?n.perPositionHeight:!r,l=n instanceof Q.ESClassification||n instanceof Q.ESPolygonFence;let c=Q.getMinMaxCorner(n.points).center,h=[...c],u=l?n.points[0][2]:0;a?r?h[2]=n.extrudedHeight:h[2]=n.height+u:(s&&(c[2]=n.height),r&&(h[2]=n.extrudedHeight)),i.startPosition=c,i.distance=h[2]-c[2],i.moveWithFirstPosition=!1;let A=[...c];this.ad(i.positionsChanged.don(()=>{i.positions.length===2&&(a?(n.points=n.points.map(f=>[f[0],f[1],f[2]+i.positions[0][2]-A[2]]),r?n.extrudedHeight=i.positions[1][2]:s&&(n.height=i.positions[1][2]-(l?i.positions[0][2]:0))):(s&&(n.height=i.positions[0][2]),r&&(n.extrudedHeight=i.positions[1][2])),A=[...i.positions[0]])}));break}this.supportEditing=!1;return}while(!1);i.init(),i.enabled=!0;const o=this.ad(p.createNextAnimateFrameEvent(i.enabledChanged,i.startPositionChanged));this.ad(o.don(()=>{(!i.enabled||!i.startPosition||Q.equalsN3(i.startPosition,[0,0,0]))&&this.destroy()}))}};L(Xc,"type",Xc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.HeightModify,Xc));let Uv=Xc;function rE(){const t=p.createProcessingFromAsyncFunc(async(n,e,i,o,r=!0)=>{const s=Array.isArray(o)?[...o]:[o],a=i.editingID;e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"start",add:{modes:s}});const l=()=>{e.notSupportEditingCount=0,e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"end",add:{modes:s}}),t.isRunning&&t.cancel()};n.disposer.ad(l),n.disposer.ad(i.toDestroyEvent.don(l));const c=u=>{u.code=="Escape"&&l()};document.body.addEventListener("keydown",c),n.disposer.ad(()=>document.body.removeEventListener("keydown",c));let h=0;do{const u=s[h%s.length],A=await p.step(n,async f=>{const d=f.disposer,g=Q.EngineObject.contextEditing.getEngineObjConstructor(u,e.typeName);if(!g||!i.supportEditingModes().includes(u))return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount++,!1;const v=new g(i,e);if(d.ad(()=>{!v.isDestroyed()&&v.destroy()}),v.supportEditing)e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount=0;else return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount++,!1;return await f.promise(new Promise(m=>{if(v.isDestroyed()&&m(!1),d.ad(v.toDestroyEvent.don(()=>{console.log(`编辑模式${u}结束`),m(!1)})),r){const w=_=>{_.code=="Space"&&(console.log(`编辑模式${u}结束`),m(!1))};document.body.addEventListener("keydown",w),d.ad(()=>document.body.removeEventListener("keydown",w)),d.ad(e.dblclickEvent.don(()=>m(!0)))}}))});if(r&&A||!r&&h==s.length-1||e.notSupportEditingCount==s.length)break;h++}while(!0)});return t}function oE(){const t=p.createProcessingFromAsyncFunc(async(n,e,i,o)=>{e.editingEvent.emit({objectIDs:i.map(l=>l.parentID??l.id),editingID:o,type:"start"});const r=()=>{e.editingEvent.emit({objectIDs:i.map(l=>l.parentID??l.id),editingID:o,type:"end"}),t.isRunning&&t.cancel()};n.disposer.ad(r);const s=l=>{l.code=="Escape"&&r()};document.body.addEventListener("keydown",s),n.disposer.ad(()=>document.body.removeEventListener("keydown",s));const a=new yf(i,e);n.disposer.ad(()=>{!a.isDestroyed()&&a.destroy()}),await n.promise(new Promise(l=>{a.isDestroyed()&&l(),n.disposer.ad(a.toDestroyEvent.don(()=>{console.log("移动结束"),l()})),n.disposer.ad(e.dblclickEvent.don(()=>l()))}))});return t}ae.copyright=void 0;try{const t="earthsdk3-cesium",n="3.3.0-beta.3",e="2025-07-15T03:45:59.000Z",i="北京西部世界科技有限公司",o="地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",r="34ba4ad6d65bfee5f2bf36300710c86cb8fb312d",a=((Date.now()-1752551159e3)/36e5).toFixed(1),l=`%c🌏 ${t}%c ${n}.${r.slice(0,8)}.${e} (距今${a}个小时)
4145
+ `,uniformMap:{u_color:[1,1,0,1]},name:"CzmCustomPrimitive_47fd",attributes:{position:{typedArray:{type:"Float32Array",array:[0,0,0,0,0,1]},componentsPerAttribute:3}}},st,t)}class pQ extends p.HasOwner{constructor(n){super(n);const{czmViewer:e}=this.owner;let i;this.dispose(()=>this.owner.hoveredPlaneType="none");const o=this._createRotatorMoveProcessing();this.dispose(e.pointerMoveEvent.disposableOn(r=>{const s=i=this._getStartInfo(r.pointerEvent);s&&(this.owner.hoveredPlaneType=s.currentPlaneType)})),this.dispose(e.pointerDownEvent.disposableOn(r=>{i&&i.currentPlaneType!=="none"&&(o.restart(void 0,e,i),i=void 0)})),this.dispose(e.dblclickEvent.disposableOn(r=>{do{const s=this._getStartInfo(r.pointerEvent);if(!s||s.currentPlaneType==="none")break;const{currentPlaneType:a}=s,l=[...this.owner.selfRotation];l[ri.rotationNum[a]]=0,this.owner.selfRotation=l;return}while(!1);this.owner.enabled=!1}))}_createRotatorMoveProcessing(){return this.ad(p.createProcessingFromAsyncFunc(async(n,e,i)=>{const o=this.owner.circles[i.currentPlaneType];e.incrementDisabledInputStack(),n.disposer.dispose(()=>e.decrementDisabledInputStack()),n.disposer.dispose(e.pointerMoveEvent.don(r=>{if(i&&r.pointerEvent){const{offsetX:s,offsetY:a}=r.pointerEvent,l=[s,a],{currentPlaneType:c}=i;if(c==="none")return;const h=this.owner.getPlane(c);if(!i.currentV)return;const u=h.pick(l);if(!u||!this.owner.cartesian)return;const A=C.Cartesian3.subtract(i.currentV,this.owner.cartesian,new C.Cartesian3);C.Cartesian3.normalize(A,A);const f=C.Cartesian3.subtract(u,this.owner.cartesian,new C.Cartesian3);if(C.Cartesian3.normalize(f,f),!h.normal||!h.origin)return;const d=_v(A,f,h.normal),g=_v(h.origin,A,h.normal),v=_v(h.origin,f,h.normal);{const y=[...this.owner.selfRotation];y[ri.rotationNum[c]]=i.startRotation+d,this.owner.selfRotation=y,o.circleStartRotation=g,o.circleEndRotation=v}}})),this.owner.movingPlaneType=i.currentPlaneType,n.disposer.dispose(()=>{this.owner.movingPlaneType="none"}),n.disposer.dispose(()=>{o.circleStartRotation=0,o.circleEndRotation=0}),await p.step(n,r=>new Promise((s,a)=>{r.disposer.dispose(a),r.disposer.dispose(e.pointerUpEvent.don(()=>{s()})),r.disposer.dispose(e.pointerOutEvent.don(()=>{s()}))}))}))}_pickPlane(n,e,i,o,r){const s=this.owner.cartesian;if(!s)return;const{selfRotation:a}=this.owner,l=this.owner.getPlane(i).pick(o);if(!l)return;const c=C.Cartesian3.distance(s,l),h=r/4,u=h*3/128;if(!(c>=h-u&&c<=h+u))return;const f=C.Cartesian3.distance(e.camera.positionWC,l);n.currentD2c<=f||(n.currentPlaneType=i,n.currentD2c=f,n.currentV=l,n.startRotation=a[ri.rotationNum[i]])}_getStartInfo(n){var h;const{czmViewer:e}=this.owner,i=(h=e.viewer)==null?void 0:h.scene;if(!this.owner.position||!this.owner.cartesian)return;const o=Di(i,this.owner.cartesian,this.owner.pixelSize);if(!o)return;const{offsetX:r,offsetY:s}=n,a=[r,s],l=n.pointerId,c={currentPlaneType:"none",currentD2c:Number.POSITIVE_INFINITY,currentV:void 0,startRotation:0,pointerId:l};return this._pickPlane(c,i,"heading",a,o),this._pickPlane(c,i,"pitch",a,o),this._pickPlane(c,i,"roll",a,o),c}}function _v(t,n,e){const i=C.Cartesian3.cross(n,t,new C.Cartesian3);if(i.equals(C.Cartesian3.ZERO))return 0;C.Cartesian3.normalize(i,i);const o=C.Cartesian3.dot(i,e);let r=Math.acos(C.Cartesian3.dot(t,n))*180/Math.PI;return r=o>0?r:-r,r}const aa=class aa extends kn{constructor(e){super();L(this,"_hoveredPlaneType",this.disposeVar(p.react("none")));L(this,"_movingPlaneType",this.disposeVar(p.react("none")));L(this,"_circles");L(this,"_czmCameraModel");L(this,"_cartesian");L(this,"_planes",{heading:this.disposeVar(new cQ(this)),pitch:this.disposeVar(new hQ(this)),roll:this.disposeVar(new AQ(this))});L(this,"_rotatorRunningResetting");this._czmViewer=e;const i=this._czmViewer;if(this._rotatorRunningResetting=this.disposeVar(new p.ObjResettingWithEvent(this.enabledChanged,()=>{if(this.enabled)return new pQ(this)})),this._circles={heading:this._createRotatorCircle(i,"heading"),pitch:this._createRotatorCircle(i,"pitch"),roll:this._createRotatorCircle(i,"roll")},!!i.viewer){{const r=()=>{this._cartesian=this.position&&vt(this.position)||void 0};r(),this.dispose(this.positionChanged.disposableOn(r))}this._createCameraModel(i)}}get hoveredPlaneType(){return this._hoveredPlaneType.value}set hoveredPlaneType(e){this._hoveredPlaneType.value=e}get hoveredPlaneTypeChanged(){return this._hoveredPlaneType.changed}get movingPlaneType(){return this._movingPlaneType.value}set movingPlaneType(e){this._movingPlaneType.value=e}get movingPlaneTypeChanged(){return this._movingPlaneType.changed}get circles(){return this._circles}get czmCameraModel(){return this._czmCameraModel}get cartesian(){return this._cartesian}get czmViewer(){return this._czmViewer}getPlane(e){return this._planes[e]}get rotatorRunningResetting(){return this._rotatorRunningResetting}_createCameraModel(e){this._czmCameraModel=new Ht(e),this._czmCameraModel.url="${earthsdk3-assets-script-dir}/assets/glb/camera1/camera1.gltf",this._czmCameraModel.localRotation=[90,0,0],this._czmCameraModel.allowPicking=!1,this._czmCameraModel.opaquePass="OVERLAY",this.dispose(p.track([this._czmCameraModel,"pixelSize"],[this,"pixelSize"],i=>i*.1)),this.dispose(p.track([this._czmCameraModel,"position"],[this,"position"])),this.dispose(p.track([this._czmCameraModel,"rotation"],[this,"rotation"]));{const i=()=>{const o=at({rotation:this.selfRotation});if(!o)throw new Error("!rm");this._czmCameraModel&&(this._czmCameraModel.localModelMatrix=C.Matrix4.toArray(o))};i(),this.dispose(this.selfRotationChanged.disposableOn(i))}{const i=()=>{this.circles.heading.show=this.enabled,this.circles.pitch.show=this.enabled,this.circles.roll.show=this.enabled,this._czmCameraModel&&(this._czmCameraModel.show=this.enabled&&this.showHelper)};i(),this.dispose(this.enabledChanged.disposableOn(i)),this.dispose(this.showHelperChanged.disposableOn(i))}}_createRotatorCircle(e,i){const o=this.ad(new Es(e));this.dispose(p.track([o,"position"],[this,"position"])),this.dispose(p.track([o,"pixelSize"],[this,"pixelSize"])),this.dispose(p.track([o,"debug"],[this,"debug"])),this.dispose(p.track([o,"rotation"],[this,"rotation"]));{const r=()=>{o.selfRotation=aa.rotationFuncs[i](this.selfRotation),o.circleRotation=this.selfRotation[aa.rotationNum[i]]};r(),this.dispose(this.selfRotationChanged.disposableOn(r))}{const r=()=>{const s=this.movingPlaneType===i,a=this.hoveredPlaneType===i,c=[0,0,0,s||a?1:.8];c[aa.rotationNum[i]]=1,o.color=c};r(),this.dispose(this.movingPlaneTypeChanged.disposableOn(r)),this.dispose(this.hoveredPlaneTypeChanged.disposableOn(r))}return o}};L(aa,"rotationNum",{heading:0,pitch:1,roll:2}),L(aa,"rotationFuncs",{heading:([e,i,o])=>[0,0,0],pitch:([e,i,o])=>[e,0,-90],roll:([e,i,o])=>[e,i+90,0]});let ri=aa;(t=>{t.createDefaultProps=()=>({...kn.createDefaultProps(),rotation:p.reactArray([0,0,0]),selfRotation:p.reactArray([0,0,0]),pixelSize:300,showHelper:!1,debug:!1})})(ri||(ri={})),p.extendClassProps(ri.prototype,ri.createDefaultProps);const sa=class sa extends p.Destroyable{get startPosition(){return this.positions&&this.positions[0]}set startPosition(n){this.positions=[n??sa.defaults.positions[0],this.stopPosition??sa.defaults.positions[1]]}get startPositionChanged(){return this.positionsChanged}get stopPosition(){return this.positions&&this.positions[1]}set stopPosition(n){this.positions=[this.startPosition??sa.defaults.positions[0],n??sa.defaults.positions[1]]}get stopPositionChanged(){return this.positionsChanged}constructor(n,e){if(super(),!n.viewer)return;const o=this.ad(new Je(n,e));o.arcType="RHUMB";const r=this.ad(new On(n,e));this.ad(p.track([o,"allowPicking"],[this,"allowPicking"])),this.ad(p.track([r,"allowPicking"],[this,"allowPicking"]));{const s=()=>{o.show=r.show=this.show};s(),this.ad(this.showChanged.don(s))}{const s=()=>{o.width=this.width/2,r.pixelSize=this.width};s(),this.ad(this.widthChanged.don(s))}{const s=()=>{o.color=r.color=this.color};s(),this.ad(this.colorChanged.don(s))}{const s=()=>{o.positions=this.positions,r.position=this.stopPosition};s(),this.dispose(this.startPositionChanged.disposableOn(s)),this.dispose(this.stopPositionChanged.disposableOn(s))}}};L(sa,"defaults",{positions:[[0,0,0],[0,0,1e6]]});let Jo=sa;(t=>{t.createDefaultProps=()=>({show:!0,allowPicking:!1,positions:p.reactPositions(t.defaults.positions),width:10,color:p.reactArray([1,0,0,1])})})(Jo||(Jo={})),p.extendClassProps(Jo.prototype,Jo.createDefaultProps);class rr extends kn{constructor(e){super();L(this,"_lastPosition");L(this,"_opInfo",{step:this.ad(p.react(!1)),moved:this.ad(p.react(!1)),constraintMode:this.disposeVar(p.react("none")),originPosition:this.disposeVar(p.reactArray([0,0,0])),originHeading:this.disposeVar(p.react(0)),originDimensions:this.disposeVar(p.reactArray([1,1,1])),draggingStartPosition:this.disposeVar(p.reactArray([0,0,0])),movingPosition:this.disposeVar(p.reactArray([0,0,0])),targetPosition:this.disposeVar(p.reactArray([0,0,0])),targetHeading:this.disposeVar(p.react(0))});L(this,"_scaleAxis");L(this,"_pickingXYProcessing",e=>this.disposeVar(new p.Processing((i,o,r)=>{const s=[0,0,0],a=new C.Cartographic;return e.pointerMoveEvent.disposableOn(l=>{if(!l.pointerEvent||!e.viewer)return;const c=Zn(p.getDomEventCurrentTargetPos(l.pointerEvent));if(!ha(e.viewer.scene,c,this._opInfo.originPosition.value[2],a))return;ua(a,s),this._opInfo.constraintMode.value==="x"?fo(this._opInfo.originPosition.value,this._opInfo.originHeading.value,s,s):this._opInfo.constraintMode.value==="y"?fo(this._opInfo.originPosition.value,this._opInfo.originHeading.value+90,s,s):this._opInfo.constraintMode.value==="xy"||console.warn("should not be here!"),this._opInfo.movingPosition.value=s,this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const h=[0,0,0];Q.geoRhumbDestination(s,r,o,h),this._opInfo.targetPosition.value=h;let u=this.scale[0],A=this.scale[1];const f=Q.geoDistance(h,this._opInfo.originPosition.value)-Q.geoDistance(this._lastPosition,this._opInfo.originPosition.value);this._lastPosition=[...h];const d=this._opInfo.originDimensions.value[0]/100;f!=0&&this._opInfo.constraintMode.value==="y"&&(f>0?u+=d:u-=d),f!=0&&this._opInfo.constraintMode.value==="x"&&(f>0?A+=d:A-=d),u<=0&&(u+=d),A<=0&&(A+=d),this.scale=[u??1,A??1,this.scale[2]??1]})})));L(this,"_pickingZProcessing",e=>this.disposeVar(new p.Processing(()=>{const i=new C.Cartesian3,o=[0,0,0];return e.pointerMoveEvent.disposableOn(r=>{if(!r.pointerEvent||!e.viewer)return;const s=Zn(p.getDomEventCurrentTargetPos(r.pointerEvent));if(!jc(e.viewer.scene,vt(this._opInfo.originPosition.value),s,i))return;this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const a=this._opInfo.originPosition.value[2]-this._opInfo.draggingStartPosition.value[2];if(Ue(i,o)){this._opInfo.movingPosition.value=o;const l=this._opInfo.originPosition.value;this._opInfo.targetPosition.value=[l[0],l[1],o[2]+a];let c=this.scale[2];const h=o[2]-this._lastPosition[2];this._lastPosition=[...o];const u=this._opInfo.originDimensions.value[0]/100;h!=0&&(h>0?c+=u:c-=u),c<=0&&(c+=u),this.scale=[this.scale[0]??1,this.scale[1]??1,c??1]}})})));const i=e.viewer;if(!i)return;const{scene:o}=i;this.ad(new Vf(e,this.positionReact,this._opInfo.originDimensions,this.axisPixelSize)),this.ad(e.dblclickEvent.don(()=>{this.enabled=!1})),this._scaleAxis={zAxis:this._createScaleAxis(e,"zAxis"),yAxis:this._createScaleAxis(e,"yAxis"),xAxis:this._createScaleAxis(e,"xAxis")};{const c=()=>{if(!this._scaleAxis)return;const{zAxis:h,yAxis:u,xAxis:A}=this._scaleAxis,f=this._opInfo.constraintMode.value,d=this._opInfo.step;h.color=[0,0,1,.99],u.color=[0,1,0,.99],A.color=[1,0,0,.99],f==="x"?A.color=d?[1,1,0,.8]:[1,1,0,.99]:f==="y"?u.color=d?[1,1,0,.8]:[1,1,0,.99]:f==="z"&&(h.color=d?[1,1,0,.8]:[1,1,0,.99])};c(),this.dispose(this._opInfo.constraintMode.changed.disposableOn(c)),this.dispose(this._opInfo.step.changed.disposableOn(c))}{const c=()=>{if(!this._scaleAxis)return;const{position:u=rr.defaults.position}=this,{zAxis:A,yAxis:f,xAxis:d}=this._scaleAxis;A.startPosition=f.startPosition=d.startPosition=u;const[g,v,y]=u;A.stopPosition=[g,v,y+this._opInfo.originDimensions.value[2]];const m=Q.geoRhumbDestination(u,this._opInfo.originDimensions.value[0],90);m&&(d.stopPosition=m);const w=Q.geoRhumbDestination(u,this._opInfo.originDimensions.value[1],0);w&&(f.stopPosition=w)};c();const h=this.ad(p.createNextAnimateFrameEvent(this.positionChanged,this._opInfo.originDimensions.changed));this.ad(h.don(c))}{const c=()=>{if(this._opInfo.constraintMode.value==="none"){this._opInfo.moved.value=!1;return}if(this._opInfo.originHeading.value!==this._opInfo.targetHeading.value){this._opInfo.moved.value=!0;return}if(!this._opInfo.originPosition.value.every((h,u)=>h===this._opInfo.targetPosition.value[u])){this._opInfo.moved.value=!0;return}};c(),this.dispose(this._opInfo.originHeading.changed.disposableOn(c)),this.dispose(this._opInfo.originPosition.changed.disposableOn(c)),this.dispose(this._opInfo.targetHeading.changed.disposableOn(c)),this.dispose(this._opInfo.targetPosition.changed.disposableOn(c))}const r=this._pickingXYProcessing(e),s=this._pickingZProcessing(e),a=this.disposeVar(p.createProcessingFromAsyncFunc(async c=>{do this._opInfo.step.value=!0,this._opInfo.constraintMode.value="none",c.disposer.dispose(()=>{this._opInfo.constraintMode.value="none"}),await p.step(c,async h=>{const u=()=>{const d=[...this.position??rr.defaults.position];e.editingHeightOffset&&(d[2]-=e.editingHeightOffset),this._opInfo.targetPosition.value=this._opInfo.originPosition.value=d};h.disposer.dispose((u(),this.positionChanged.disposableOn(u)));const A={constraintMode:"none",startDragPos:[0,0,0]},f=d=>{if(!this.position)return;const g={position:this.position,dimensions:this._opInfo.originDimensions.value,heading:0};If(d,o,g,this.axisSnapPixelSize,A),this._opInfo.constraintMode.value=A.constraintMode,this._opInfo.movingPosition.value=this._opInfo.draggingStartPosition.value=A.startDragPos};h.disposer.dispose(e.pointerMoveEvent.disposableOn(d=>{d.pointerEvent&&f(d.pointerEvent)})),await p.step(h,d=>new Promise((g,v)=>{d.disposer.dispose(v),d.disposer.dispose(e.pointerDownEvent.don(y=>{y.pointerEvent&&f(y.pointerEvent),y.pointerEvent&&y.pointerEvent.button===0&&A.constraintMode!=="none"&&g()}))}))}),this._opInfo.step.value=!1,await p.step(c,async h=>{if(e.incrementDisabledInputStack(),h.disposer.dispose(()=>e.decrementDisabledInputStack()),["x","y"].includes(this._opInfo.constraintMode.value)){const u=Q.geoRhumbHeading(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value),A=Q.geoRhumbDistance(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value);r.restart(void 0,u,A),h.disposer.dispose(()=>r.cancel())}else this._opInfo.constraintMode.value==="z"&&(s.restart(),h.disposer.dispose(()=>s.cancel()));await p.step(h,u=>new Promise((A,f)=>{u.disposer.dispose(f),u.disposer.dispose(e.pointerUpEvent.don(()=>{A()})),u.disposer.dispose(e.pointerOutEvent.don(()=>{A()}))})),this._lastPosition=void 0});while(!0)})),l=()=>{this.enabled?a.restart():a.isRunning&&a.cancel()};l(),this.dispose(this.enabledChanged.disposableOn(l))}get scaleAxis(){return this._scaleAxis}_createScaleAxis(e,i){const o=this.ad(new Jo(e));return o.width=10,this.ad(p.track([o,"show"],[this,"enabled"])),o}}(t=>{t.createDefaultProps=()=>({...kn.createDefaultProps(),scale:p.reactArray([1,1,1]),axisPixelSize:100,axisSnapPixelSize:5})})(rr||(rr={})),p.extendClassProps(rr.prototype,rr.createDefaultProps);const ho=class ho extends hn{constructor(e){super();L(this,"_editingPoints",this.disposeVar(new p.ObservableArray));L(this,"_cancelEvent",this.disposeVar(new p.Event));L(this,"_currentProcess");L(this,"_menuPoiEnabled",this.disposeVar(p.react(!1)));L(this,"_status",this.disposeVar(p.react("None")));L(this,"_positionsChanged",this.ad(new p.Event));L(this,"_cursorInfo");this._czmViewer=e,this.enabled=!1,this.createPolyline(e),this._createCursorInfo(e),this.dispose(()=>this.resetPositions()),this.dispose(()=>this.editingPoints.length=0),this.dispose(this.editingPoints.changedEvent.disposableOn(()=>this.positionsChanged.emit())),this.dispose(this.editingPoints.toChangeEvent.disposableOn(i=>{for(let{start:o,deleteCount:r,items:s}of i){for(const a of s)a.menuPoi.enabled=this.menuPoiEnabled??!1;for(let a=o;a<o+r;++a)this.editingPoints.get(a).destroy()}})),this.dispose(this.menuPoiEnabledChanged.disposableOn(()=>{for(let i of this.editingPoints)i.menuPoi.enabled=this.menuPoiEnabled??!1})),this.dispose(e.dblclickEvent.don(i=>{this.ad(p.nextAnimateFrame(()=>{var o;((o=i.pointerEvent)==null?void 0:o.button)===0&&this.enabled&&this.currentProcess&&this.currentProcess.cancel()}))})),this.dispose(this.enabledChanged.disposableOn(i=>{this._currentProcess&&(i?this._currentProcess.restart():this._currentProcess.isRunning&&this._currentProcess.cancel())}));{const i=()=>{this.polylineShow=this.czmViewer.editingLineShow};i(),this.ad(this.czmViewer.editingLineShowChanged.don(i))}}get editingPoints(){return this._editingPoints}get cancelEvent(){return this._cancelEvent}cancel(){this._cancelEvent.emit()}get currentProcess(){return this._currentProcess}set currentProcess(e){this._currentProcess=e}get menuPoiEnabled(){return this._menuPoiEnabled.value}set menuPoiEnabled(e){this._menuPoiEnabled.value=e}get menuPoiEnabledChanged(){return this._menuPoiEnabled.changed}get status(){return this._status.value}get statusChanged(){return this._status.changed}set status(e){this._status.value=e}getPositions(){const e=[];for(let i of this._editingPoints)i.position&&e.push([...i.position]);return e}resetPositions(e){if(this.enabled??ho.defaults.enabled)return console.warn("MultiPointsEditing.resetPositions error: this.enabled === true"),!1;const i=e||[];return!(i.length===this.editingPoints.length&&i.every((o,r)=>o.every((s,a)=>{const l=this.editingPoints.get(r);return l.position&&l.position[a]===s})))}forceResetPositions(e){(this.enabled??ho.defaults.enabled)&&(this.enabled=!1),this.resetPositions(e)}get positions(){return this.getPositions()}set positions(e){this.resetPositions(e)}get positionsChanged(){return this._positionsChanged}get czmViewer(){return this._czmViewer}get cursorInfo(){return this._cursorInfo}createPolyline(e){const i=this.ad(new Je(e));this.ad(p.track([i,"color"],[this,"polylineColor"])),this.ad(p.track([i,"width"],[this,"polylineWidth"])),this.ad(p.track([i,"show"],[this,"polylineShow"])),this.ad(p.track([i,"arcType"],[this,"polylineArcType"])),this.ad(p.track([i,"loop"],[this,"loop"]));{const o=()=>{const r=[];for(const s of this.getPositions())s[2]-=e.editingHeightOffset??0,r.push(s);i.positions=r};o(),this.ad(this.positionsChanged.don(o))}}_createCursorInfo(e){const i=this._cursorInfo=this.ad(new p.CursorInfo(e.container,p.CursorFloatDiv));this.dispose(this.statusChanged.disposableOn(()=>{const o=this.status;if(i){if(!this.hideCursorInfo){i.show=!1;return}o==="Adding"?(i.text="右键/BackSpace键:删除上一个控制点;Esc键或左键双击:退出添加状态,进入修改状态",i.show=!0):o==="Modifying"||o==="Modifying_Point"?(i.text="Esc键或左键双击:退出编辑状态",i.show=!0):o==="None"&&(i.text="",i.show=!1)}}))}};L(ho,"baseImageUrl","${earthsdk3-assets-script-dir}/assets/img/"),L(ho,"defaults",{...hn.defaults,debug:!1,polylineShow:!1,polylineWidth:1,polylineColor:[1,1,1,1],polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,loop:!1,firstControlPointImageUrl:ho.baseImageUrl+"point-green.png",otherControlPointImageUrl:ho.baseImageUrl+"point-yellow.png"});let Wn=ho;(t=>{t.createDefaultProps=()=>({...hn.createDefaultProps(),loop:!1,debug:!1,polylineShow:!0,polylineWidth:1,polylineColor:p.reactArray([1,1,1,1]),polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,firstControlPointImageUrl:t.baseImageUrl+"point-green.png",otherControlPointImageUrl:t.baseImageUrl+"point-yellow.png",hideCursorInfo:!1,middlePointShow:!0})})(Wn||(Wn={})),p.extendClassProps(Wn.prototype,Wn.createDefaultProps);let mQ=0;class XS extends p.Destroyable{constructor(e,i){super();L(this,"_position",this.disposeVar(p.reactArrayWithUndefined(void 0)));L(this,"_id",mQ++);L(this,"_menuPoi");i&&(this.position=i),e.debug&&console.log(`PolylinePositionEditor creating! ${this.id}`),this.dispose(()=>{e.debug&&console.log(`PolylinePositionEditor destroying! ${this.id}`)});const o=this._menuPoi=this.ad(new _a(e.czmViewer));o.enabled=!1,this.ad(p.track([o,"show"],[e,"enabled"]));{const r=()=>{if(this.position===void 0){o.position=void 0;return}const s=[...this.position];s[2]-=e.czmViewer.editingHeightOffset??0,o.position=s,e.positionsChanged.emit()};r(),this.d(this.positionChanged.don(r))}{const r=()=>{const s=e.editingPoints.indexOf(this)+1;s!==0&&(o.title=`控制点${s}`,s===1?o.imageUri=e.firstControlPointImageUrl??Wn.defaults.firstControlPointImageUrl:o.imageUri=e.otherControlPointImageUrl??Wn.defaults.otherControlPointImageUrl)};r(),this.dispose(e.editingPoints.changedEvent.disposableOn(r))}}get position(){return this._position.value}set position(e){this._position.value=e}get positionChanged(){return this._position.changed}get id(){return this._id}get menuPoi(){return this._menuPoi}}class $S extends XS{constructor(n,e){super(n,e)}}class Pt extends Wn{constructor(e){super(e);L(this,"_deletePreviousPointWhileAddingEvent",this.disposeVar(new p.Event));L(this,"placeEditing");if(!e.viewer)return;const i=this.placeEditing=this.ad(new ii(e));i.enabled=!1,this.currentProcess=this.disposeVar(p.createProcessingFromAsyncFunc(async o=>{o.disposer.dispose(()=>{(this.debug??Pt.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1}),(this.debug??Pt.defaults.debug)&&console.log("直接进入Adding状态"),this.status="Adding",await o.promise(p.step(o,async r=>{const s=r.disposer,a=s.ad(this._addingEditingProcessing());s.dispose(()=>"adding canceled!"),s.dispose(this.cancelEvent.disposableOn(()=>a.cancel())),await r.promise(new Promise(l=>{s.dispose(a.completeEvent.disposableOnce(l))}))}))})),this.dispose(e.clickEvent.don(o=>{var r;((r=o.pointerEvent)==null?void 0:r.button)===2&&this.deletePreviousPointWhileAdding()}))}deletePreviousPointWhileAdding(){this._deletePreviousPointWhileAddingEvent.emit()}resetPositions(e){if(!super.resetPositions(e))return!0;const i=e?e.map(o=>new $S(this,o)):[];return this.editingPoints.splice(0,this.editingPoints.length,...i),!0}_addingEditingProcessing(){const e=()=>{if(this.maxPointsNum!==void 0)return this.editingPoints.length>=this.maxPointsNum&&(this.debug??Pt.defaults.debug)&&console.log("impl.positionEditors.length >= impl.maxPointsNum"),this.editingPoints.length>=this.maxPointsNum},i=p.createProcessingFromAsyncFunc(async o=>{let r=this.editingPoints.length;this.menuPoiEnabled=!1;do if(!await o.promise(p.step(o,async a=>{let l;!e()&&(l=a.disposer.disposeVar(new gQ(this,r)));const h=a.disposer.disposeVar(new vQ(this,r));return a.disposer.dispose(this._deletePreviousPointWhileAddingEvent.disposableOn(()=>h.do())),await a.promise(new Promise(u=>{l&&a.disposer.dispose(l.overEvent.disposableOnce(A=>{A?(r++,u(!0)):u(!1)})),a.disposer.dispose(h.overEvent.disposableOnce(A=>{A?(r--,u(!0)):u(!1)})),a.disposer.dispose(this.cancelEvent.disposableOn(()=>u(!1)))}))})))break;while(!0)});return i.start(),i}}(t=>{t.createDefaultProps=()=>({...Wn.createDefaultProps()})})(Pt||(Pt={})),p.extendClassProps(Pt.prototype,Pt.createDefaultProps);class gQ extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));const{placeEditing:o}=e;let r=new $S(e,void 0);e.editingPoints.splice(i,0,r);const s=()=>{(e.debug??Pt.defaults.debug)&&console.log("delete currentPosEditor");const c=e.editingPoints.indexOf(r);if(c===-1)throw new Error("currentPosEditor not found");e.editingPoints.splice(c,1)};if(o.enabled??!1)throw console.error("placeEditing.enabled is true!"),new Error("placeEditing.enabled is true!");this.dispose(p.track([r,"position"],[o,"position"])),o.enabled=!0;let a=!1;const l=()=>{s(),this._overEvent.emit(!1)};this.dispose(()=>{o.enabled=!1,!a&&l()}),this.dispose(o.overEvent.disposableOnce(()=>{a=!0,r.position===void 0?l():this._overEvent.emit(!0)})),(e.debug??Pt.defaults.debug)&&console.log(`PointAdding creating! index(${i})`),this.dispose(()=>{(e.debug??Pt.defaults.debug)&&console.log(`PointAdding destroying! index(${i})`)})}get overEvent(){return this._overEvent}}function yQ(t,n){const e=t.editingPoints,i=n-1;return i<0?(console.warn("previousIndex < 0, cannot delete the point!"),!1):(e.splice(i,1),!0)}class vQ extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"_doEvent",this.disposeVar(new p.Event));this.dispose(this._doEvent.disposableOn(()=>this._overEvent.emit(yQ(e,i)))),(e.debug??Pt.defaults.debug)&&console.log(`PreviousPointDeleting creating! currentIndex(${i})`),this.dispose(()=>{(e.debug??Pt.defaults.debug)&&console.log(`PreviousPointDeleting destroying! currentIndex(${i})`)})}get overEvent(){return this._overEvent}do(){return this._doEvent.emit()}}class YS extends Pt{constructor(n){super(n),this.loop=!1}}class JS extends Pt{constructor(n){super(n),this.loop=!0}}class gf extends XS{constructor(n,e){super(n,e);{const{menuPoi:i}=this;i.commands=[["add","增加控制点","",tt.baseImageUrl+"add.png"],["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]],i.clickCommandName="modify",i.rightClickCommandName="delete",this.dispose(i.commandEvent.disposableOn(o=>{n.menuPoiCommand(this,o)})),this.dispose(i.dbclickEvent.disposableOn(()=>{n.menuPoiCommand(this,"dbClick")}))}if(n.middlePointShow){const i=this.ad(new ui(n.czmViewer));{i.imageUri=n.firstControlPointImageUrl??tt.defaults.firstControlPointImageUrl,i.tooltip="点击增加一个控制点",i.bgColor=[0,0,0,.6],i.fgColor=[1,1,1,1],i.size=[8,8],i.originRatioAndOffset=[.5,.5,0,0];{const o=()=>{if(!(n.enabled??tt.defaults.enabled)){i.enabled=!1,i.show=!1;return}do{const s=n.editingPoints.indexOf(this);if(s===-1)break;const a=n.editingPoints.length;if(a===0){console.error("impl.positionEditors.length === 0!");break}if(!(n.loop??tt.defaults.loop)&&s+1>=a)break;const c=this.position;if(!c)break;let h=(s+1)%a;const A=n.editingPoints.get(h).position;if(!A)break;const f=Mf(c,A);if(!f)break;f[2]-=n.czmViewer.editingHeightOffset??0,i.position=f;const d=n.editingPoints.length<(n.maxPointsNum??tt.defaults.maxPointsNum);i.enabled=d,i.show=d;return}while(!1);i.enabled=!1,i.show=!1};o(),this.dispose(n.positionsChanged.disposableOn(o)),this.dispose(n.loopChanged.disposableOn(o)),this.dispose(n.enabledChanged.disposableOn(o))}this.dispose(i.clickEvent.disposableOn(o=>{if(o.button!==0||n.editingPoints.length>=(n.maxPointsNum??tt.defaults.maxPointsNum))return;const r=n.editingPoints.indexOf(this);if(r===-1)return;const s=i.position?[...i.position]:void 0;s&&(s[2]+=n.czmViewer.editingHeightOffset??0);let a=new gf(n,s);n.editingPoints.splice(r+1,0,a),n.modify(a)}))}}}}class tt extends Wn{constructor(e){super(e);L(this,"_menuPoiCommand",this.disposeVar(new p.Event));L(this,"_forceModifyPosEditorEvent",this.disposeVar(new p.Event));L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"translationEditing");{const o=this.ad(p.createNextAnimateFrameEvent(this.moveWithFirstPositionChanged,this.editingPoints.changedEvent));this.ad(new p.ObjResettingWithEvent(o,()=>{if(!(!this.moveWithFirstPosition||this.editingPoints.length<=1))return new wQ(this.editingPoints.get(0),this)}))}const i=this.translationEditing=this.disposeVar(new ir(e));i.enabled=!1,this.currentProcess=this.disposeVar(p.createProcessingFromAsyncFunc(async o=>{o.disposer.dispose(()=>{(this.debug??tt.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1});let r=-1;do if((this.debug??tt.defaults.debug)&&console.log("进入Modifying修改状态"),this.status="Modifying",r=await o.promise(p.step(o,async s=>{const a=s.disposer,l=a.ad(new bQ(this));return a.dispose(()=>"modifying canceled!"),this.editingPoints.length>0&&l.modify(this.editingPoints.get(r===-1||r>=this.editingPoints.length?0:r)),a.dispose(this.cancelEvent.disposableOn(()=>l.cancel())),a.dispose(this._forceModifyPosEditorEvent.disposableOn(h=>l.modify(h))),await s.promise(new Promise(h=>{a.dispose(l.overEvent.disposableOnce(u=>{h(u)}))}))})),r===-1){(this.debug??tt.defaults.debug)&&console.log("退出编辑状态");break}else{if(this.editingPoints.length>=(this.maxPointsNum??tt.defaults.maxPointsNum))return;if(this.editingPoints.length===0){console.error("impl.positionEditors.length === 0!");return}this.loop??tt.defaults.loop;const a=this.editingPoints.get(r-1).position;if(!a)return;let l=r%this.editingPoints.length;const h=this.editingPoints.get(l).position;if(!h)return;const u=Mf(a,h);if(!u)return;u&&(u[2]+=this.czmViewer.editingHeightOffset??0);let A=new gf(this,u);this.editingPoints.splice(r,0,A)}while(!0);this.status="None",this.enabled=!1}))}menuPoiCommand(e,i){this._menuPoiCommand.emit(e,i)}modify(e){this._forceModifyPosEditorEvent.emit(e)}resetPositions(e){if(!super.resetPositions(e))return!0;const i=e?e.map(o=>new gf(this,o)):[];return this.editingPoints.splice(0,this.editingPoints.length,...i),!0}get overEvent(){return this._overEvent}}(t=>{t.createDefaultProps=()=>({...Wn.createDefaultProps(),moveWithFirstPosition:!1})})(tt||(tt={})),p.extendClassProps(tt.prototype,tt.createDefaultProps);class wQ extends p.Destroyable{constructor(n,e){super(),this._firstPositionEditor=n,this.multiPointsModifyEditing=e,this._firstPositionEditor.positionChanged.disposableOn((i,o)=>{if(i===void 0||o===void 0)return;var r=[i[0]-o[0],i[1]-o[1],i[2]-o[2]];const s=this.multiPointsModifyEditing.editingPoints.length;for(let a=1;a<s;a++){const l=this.multiPointsModifyEditing.editingPoints.get(a),c=l.position;c!==void 0&&(l.position=[c[0]+r[0],c[1]+r[1],c[2]+r[2]])}})}}class bQ extends p.Destroyable{constructor(e){super();L(this,"_overEvent",this.disposeVar(new p.Event));L(this,"_cancelEvent",this.disposeVar(new p.Event));L(this,"_forceModifyPosEditorEvent",this.disposeVar(new p.Event));e.menuPoiEnabled=!0,this.dispose(()=>e.menuPoiEnabled=!1);let i;const o=()=>{i==null||i.destroy(),i=void 0,e.status="Modifying"};this.dispose(o);const r=s=>{o(),e.status="Modifying_Point",i=new _Q(e,s),i.dispose(i.overEvent.disposableOn(()=>{o()}))};this.dispose(this._forceModifyPosEditorEvent.disposableOn(r)),this.dispose(e._menuPoiCommand.disposableOn((s,a)=>{if(a==="delete"){if(e.editingPoints.length<=2)return;const l=e.editingPoints.indexOf(s);if(l===-1)throw console.error("posEditor not found"),new Error("posEditor not found");e.editingPoints.splice(l,1)}else if(a==="modify")r(s);else if(a==="add"){const l=e.editingPoints.indexOf(s);if(l===-1)throw console.error("posEditor not found"),new Error("posEditor not found");this._overEvent.emit(l+1)}else a==="dbClick"?this._overEvent.emit(-1):alert(`未知的commandName(${a})`)})),this.dispose(this._cancelEvent.disposableOn(()=>{this._overEvent.emit(-1)}))}get overEvent(){return this._overEvent}cancel(){this._cancelEvent.emit()}modify(e){this._forceModifyPosEditorEvent.emit(e)}}class _Q extends p.Destroyable{constructor(e,i){super();L(this,"_overEvent",this.disposeVar(new p.Event));this._modifying=e,this._posEditor=i,this.dispose(this._posEditor.toDestroyEvent.disposableOn(()=>{this._overEvent.emit()}));const{translationEditing:o}=this._modifying;if(o.enabled=!0,o.heading=0,this.dispose(()=>{o.enabled=!1}),!this._posEditor.position)throw console.error("!this._posEditor.position"),new Error("!this._posEditor.position");o.position=this._posEditor.position,this.dispose(p.track([this._posEditor,"position"],[o,"position"])),this.dispose(o.enabledChanged.disposableOnce(r=>{r||this._overEvent.emit()}))}get overEvent(){return this._overEvent}}class jS extends tt{constructor(n){super(n),this.loop=!1}}class eE extends tt{constructor(n){super(n),this.loop=!0}}class Ps extends Pt{init(){const n=this.startPosition;if(!n)return;const e=this.distance,i=this.rotation,o=e*Math.cos(i[1]*Math.PI/180),r=Q.geoDestination(n,o,i[0]);if(!r){this.positions=[n];return}const s=e*Math.sin(i[1]*Math.PI/180);r[2]+=s,this.positions=[n,r],this.editingPoints.length==2&&(this.editingPoints.get(0).position=n,this.editingPoints.get(1).position=r)}constructor(n){super(n),this.loop=!0,this.maxPointsNum=2;{const e=()=>{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];return}if(this.positions.length==1){this.distance=1,this.rotation=[90,0,0];return}this.startPosition=this.positions[0],this.endPosition=this.positions[1];const i=Q.geoHeading(this.startPosition,this.endPosition),o=Q.geoDistance(this.startPosition,this.endPosition);if(o<=0){this.rotation=[90,0,0],this.distance=1;return}const r=this.endPosition[2]-this.startPosition[2],s=Math.atan(r/o)*180/Math.PI,a=Math.sqrt(o*o+r*r);this.rotation=[i,s,0],this.distance=a};e(),this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...Pt.createDefaultProps(),startPosition:p.reactArrayWithUndefined(void 0),endPosition:p.reactArrayWithUndefined(void 0),rotation:p.reactArray([90,0,0]),distance:p.react(1)})})(Ps||(Ps={})),p.extendClassProps(Ps.prototype,Ps.createDefaultProps);class jo extends tt{init(){const n=this.startPosition;if(!n)return;const e=this.distance,i=this.rotation,o=e*Math.cos(i[1]*Math.PI/180),r=Q.geoDestination(n,o,i[0]);if(!r){this.positions=[n];return}const s=e*Math.sin(i[1]*Math.PI/180);r[2]+=s,this.positions=[n,r],this.editingPoints.length==2&&(this.editingPoints.get(0).position=n,this.editingPoints.get(1).position=r)}constructor(n){super(n),this.loop=!0,this.maxPointsNum=2,this.middlePointShow=!1,this.moveWithFirstPosition=!0;{const e=()=>{do{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];break}if(this.startPosition=this.positions[0],this.positions.length==1){this.editingPoints.get(0).menuPoi.commands=[["add","增加控制点","",tt.baseImageUrl+"add.png"],["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]],this.rotation=[90,0,0],this.distance=1;break}this.endPosition=this.positions[1];for(let l of this.editingPoints)l.menuPoi.commands=[["delete","删除当前控制点","",tt.baseImageUrl+"delete.png"],["modify","修改当前控制点","",tt.baseImageUrl+"modify.png"]];const i=Q.geoHeading(this.startPosition,this.endPosition),o=Q.geoDistance(this.startPosition,this.endPosition);if(Math.abs(o)<=0){this.rotation=[90,0,0],this.distance=1;return}const r=this.endPosition[2]-this.startPosition[2],s=Math.atan(r/o)*180/Math.PI,a=Math.sqrt(o*o+r*r);this.rotation=[i,s,0],this.distance=a}while(!1)};this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...tt.createDefaultProps(),startPosition:p.reactArrayWithUndefined(void 0),endPosition:p.reactArrayWithUndefined(void 0),rotation:p.reactArray([0,0,0]),distance:p.react(0)})})(jo||(jo={})),p.extendClassProps(jo.prototype,jo.createDefaultProps);class tE extends Pt{constructor(n){super(n),this.loop=!1,this.polylineShow=!1}}class nE extends tt{constructor(n){super(n),this.loop=!1,this.polylineShow=!1,this.middlePointShow=!1}}class Ts extends Pt{constructor(n){super(n),n.viewer||(this.loop=!1);{const e=()=>{if(!this.positions||this.positions.length<2){this.visibilityPositions=void 0;return}const i=[...this.positions[0]];i[2]-=n.editingHeightOffset??0,this.visibilityPositions=this.positions.map(o=>(o[2]-=n.editingHeightOffset??0,[i,o]))};e(),this.ad(this.positionsChanged.don(e))}}createPolyline(n){const e=this.ad(new $n(n));e.topOrBottom="bottom",this.ad(p.track([e,"color"],[this,"polylineColor"])),this.ad(p.track([e,"width"],[this,"polylineWidth"])),this.ad(p.track([e,"show"],[this,"polylineShow"])),this.ad(p.track([e,"arcType"],[this,"polylineArcType"])),this.ad(p.track([e,"loop"],[this,"loop"])),this.ad(p.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...Pt.createDefaultProps(),visibilityPositions:p.reactPositionsSet(void 0)})})(Ts||(Ts={})),p.extendClassProps(Ts.prototype,Ts.createDefaultProps);class Is extends tt{constructor(n){if(super(n),!!n.viewer){this.loop=!1,this.middlePointShow=!1;{const e=()=>{if(!this.positions||this.positions.length<2)return;const i=[...this.positions[0]];i[2]-=n.editingHeightOffset??0,this.visibilityPositions=this.positions.map(o=>(o[2]-=n.editingHeightOffset??0,[i,o]))};e(),this.ad(this.positionsChanged.don(e))}}}createPolyline(n){const e=this.ad(new $n(n));e.topOrBottom="bottom",this.ad(p.track([e,"color"],[this,"polylineColor"])),this.ad(p.track([e,"width"],[this,"polylineWidth"])),this.ad(p.track([e,"show"],[this,"polylineShow"])),this.ad(p.track([e,"arcType"],[this,"polylineArcType"])),this.ad(p.track([e,"loop"],[this,"loop"])),this.ad(p.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...tt.createDefaultProps(),visibilityPositions:p.reactPositionsSet(void 0)})})(Is||(Is={})),p.extendClassProps(Is.prototype,Is.createDefaultProps);class iE extends jo{constructor(n){super(n),this.firstControlPointImageUrl=this.otherControlPointImageUrl,this.translationEditing.xAxisShow=!1,this.translationEditing.yAxisShow=!1,this.translationEditing.zAxisShow=!0,this.translationEditing.showCircle=!1,this.rotation=[0,90,0]}}class rn extends Q.EngineObject{constructor(e,i,o){super(e,i,o??!0);L(this,"_supportEditing",this.disposeVar(p.react(!0)));L(this,"_currentEditing",this.disposeVar(p.react(void 0)));this.ad(this.supportEditingChanged.don(()=>{this.destroy()})),this.ad(this.toDestroyEvent.don(()=>{var r;if(this.currentEditing){if(this.currentEditing instanceof Pt&&((r=this.currentEditing.currentProcess)!=null&&r.isRunning))if(this.currentEditing.currentProcess.cancel(),e!=null&&e.position){if(this.currentEditing.positions.length>1)return;e.position=this.currentEditing.positions[0]??[0,0,0],e!=null&&e.rotation&&(e.rotation=[0,0,0]),e!=null&&e.far&&(e.far=1),e!=null&&e.radius&&(e.radius=1),e!=null&&e.distance&&(e.distance=1)}else e.points=this.currentEditing.positions;this.currentEditing instanceof ii&&this.currentEditing.enabled&&(e.position=[0,0,0])}}))}get supportEditing(){return this._supportEditing.value}set supportEditing(e){this._supportEditing.value=e}get supportEditingChanged(){return this._supportEditing.changed}get currentEditing(){return this._currentEditing.value}set currentEditing(e){this._currentEditing.value=e}get currentEditingChanged(){return this._currentEditing.changed}}const Rc=class Rc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new ii(e));this.ad(e.clickEvent.don(o=>{var r;((r=o.pointerEvent)==null?void 0:r.button)==2&&(i.enabled=!0)}));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"position"],[n,"position"])),i.enabled=!i.position||Q.equalsN3(i.position,[0,0,0]);break}this.supportEditing=!1}while(!1)}};L(Rc,"type",Rc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Place,Rc));let Cv=Rc;const Uc=class Uc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new ri(e));i.rotation=[90,0,0],this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(n instanceof Q.ES3DTileset){Q.registerCreatedEventUpdate(this,n,()=>{const o=e.getEngineObject(n);o&&(this.ad(p.bind([i,"position"],[o.czm3DTiles,"position"])),this.ad(p.bind([i,"selfRotation"],[n,"rotation"])))});break}if(Reflect.has(n,"position")&&Reflect.has(n,"rotation")){this.ad(p.bind([i,"position"],[n,"position"])),this.ad(p.bind([i,"selfRotation"],[n,"rotation"]));break}this.supportEditing=!1}while(!1)}};L(Uc,"type",Uc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Rotation,Uc));let xv=Uc;const Oc=class Oc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new rr(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"position")&&Reflect.has(n,"scale")){this.ad(p.bind([i,"position"],[n,"position"])),this.ad(p.bind([i,"scale"],[n,"scale"]));break}this.supportEditing=!1}while(!1)}};L(Oc,"type",Oc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Scale,Oc));let Sv=Oc;const Lc=class Lc extends rn{constructor(n,e){super(Array.isArray(n)?n[0]:n,e,!0);const i=this.currentEditing=this.ad(new ir(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Array.isArray(n)){const o=[];for(let r=0;r<n.length;r++){const s=n[r];Reflect.has(s,"position")?o.push(s.position):s.points&&o.push(...s.points)}i.position=Q.getMinMaxCorner(o).center,this.ad(i.positionChanged.disposableOn((r,s)=>{if(!(!r||!s)){var a=fn({originPosition:s},[r])[0][0];n.forEach(l=>{if(Reflect.has(l,"position")){const c=fn({originPosition:s},[l.position])[0][0];l.position=pr({originPosition:s},[[c[0]+a[0],c[1]+a[1],c[2]+a[2]]])[0][0]}else if(Reflect.has(l,"points")&&l.points){const c=fn({originPosition:s},l.points)[0];l.points=pr({originPosition:s},c.map(h=>[h[0]+a[0],h[1]+a[1],h[2]+a[2]]))[0]}})}}));break}if(Reflect.has(n,"position")){this.ad(p.bind([i,"position"],[n,"position"]));break}if(n instanceof Q.ES3DTileset){Q.registerCreatedEventUpdate(this,n,()=>{const o=e.getEngineObject(n);this.ad(p.bind([i,"position"],[o.czm3DTiles,"position"]))});break}if(Reflect.has(n,"points")){if(n.points===void 0||n.points.length===0){this.destroy();break}i.position=Q.getMinMaxCorner(n.points).center,this.ad(i.positionChanged.disposableOn((o,r)=>{if(o===void 0||r===void 0||n.points===void 0||n.points.length===0){this.destroy();return}var s=fn({originPosition:r},[o])[0][0];const a=fn({originPosition:r},n.points)[0];n.points=pr({originPosition:r},a.map(l=>[l[0]+s[0],l[1]+s[1],l[2]+s[2]]))[0]}));break}this.supportEditing=!1}while(!1)}};L(Lc,"type",Lc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.Translation,Lc));let yf=Lc;const zc=class zc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Ps(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"startPosition"],[n,"position"])),this.ad(Dt([i,"rotation"],[n,"rotation"]));do{if(Reflect.has(n,"far")){this.ad(p.bind([i,"distance"],[n,"far"]));break}if(Reflect.has(n,"radius")){this.ad(p.bind([i,"distance"],[n,"radius"]));break}if(Reflect.has(n,"distance")){this.ad(p.bind([i,"distance"],[n,"distance"]));break}const o=vt(n.position);if(C.Cartesian3.ZERO.equals(o)||!e.viewer)return;i.distance=Di(e.viewer.scene,o,100)??1}while(!1);break}if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1);i.startPosition&&!Q.equalsN3(i.startPosition,[0,0,0])&&i.init(),i.enabled=!0}};L(zc,"type",zc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.DoublePointsAppend,zc));let Ev=zc;const Qc=class Qc extends rn{constructor(n,e){var r;if(super(n,e,!0),!e.viewer)return;const i=this.currentEditing=this.ad(new jo(e));do{if(Reflect.has(n,"position")){this.ad(p.bind([i,"startPosition"],[n,"position"])),this.ad(Dt([i,"rotation"],[n,"rotation"]));do{if(Reflect.has(n,"far")){this.ad(p.bind([i,"distance"],[n,"far"]));break}if(Reflect.has(n,"radius")){this.ad(p.bind([i,"distance"],[n,"radius"]));break}if(Reflect.has(n,"distance")){this.ad(p.bind([i,"distance"],[n,"distance"]));break}const s=vt(n.position);if(C.Cartesian3.ZERO.equals(s)||!e.viewer)return;i.distance=Di(e.viewer.scene,s,100)??1}while(!1);break}if(Reflect.has(n,"points")&&((r=n.points)==null?void 0:r.length)==2){i.moveWithFirstPosition=!1;const s=()=>i.positions=n.points??[];s(),this.ad(n.pointsChanged.don(()=>!i.enabled&&s())),this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1;return}while(!1);i.init(),i.enabled=!0;const o=this.ad(p.createNextAnimateFrameEvent(i.enabledChanged,i.startPositionChanged));this.ad(o.don(()=>{(!i.enabled||!i.startPosition||Q.equalsN3(i.startPosition,[0,0,0]))&&this.destroy()}))}};L(Qc,"type",Qc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.DoublePointsModify,Qc));let Pv=Qc;const Vc=class Vc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new JS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Vc,"type",Vc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.CircularAppend,Vc));let Tv=Vc;const Hc=class Hc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new eE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Hc,"type",Hc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.CircularInsert,Hc));let Iv=Hc;const Nc=class Nc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new YS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Nc,"type",Nc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.LineStringAppend,Nc));let kv=Nc;const Gc=class Gc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new jS(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Gc,"type",Gc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.LineStringInsert,Gc));let Fv=Gc;const Wc=class Wc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new tE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Wc,"type",Wc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.ScatterAppend,Wc));let Bv=Wc;const qc=class qc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new nE(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(qc,"type",qc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.ScatterModify,qc));let Mv=qc;const Kc=class Kc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Ts(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Kc,"type",Kc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.VisibilityAppend,Kc));let Dv=Kc;const Zc=class Zc extends rn{constructor(n,e){super(n,e,!0);const i=this.currentEditing=this.ad(new Is(e));this.ad(i.enabledChanged.don(o=>{!o&&this.ad(p.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(n,"points")){const o=()=>i.positions=n.points??[];o(),this.ad(n.pointsChanged.don(()=>!i.enabled&&o())),i.enabled=!0,this.ad(p.track([n,"points"],[i,"positions"]));break}this.supportEditing=!1}while(!1)}};L(Zc,"type",Zc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.VisibilityModify,Zc));let Rv=Zc;const Xc=class Xc extends rn{constructor(n,e){if(super(n,e,!0),!e.viewer)return;const i=this.currentEditing=this.ad(new iE(e));do{if(Reflect.has(n,"points")){const r=Reflect.has(n,"extrudedHeight"),s=Reflect.has(n,"height"),a=Reflect.has(n,"perPositionHeight")?n.perPositionHeight:!r,l=n instanceof Q.ESClassification||n instanceof Q.ESPolygonFence;let c=Q.getMinMaxCorner(n.points).center,h=[...c],u=l?n.points[0][2]:0;a?r?h[2]=n.extrudedHeight:h[2]=n.height+u:(s&&(c[2]=n.height),r&&(h[2]=n.extrudedHeight)),i.startPosition=c,i.distance=h[2]-c[2],i.moveWithFirstPosition=!1;let A=[...c];this.ad(i.positionsChanged.don(()=>{i.positions.length===2&&(a?(n.points=n.points.map(f=>[f[0],f[1],f[2]+i.positions[0][2]-A[2]]),r?n.extrudedHeight=i.positions[1][2]:s&&(n.height=i.positions[1][2]-(l?i.positions[0][2]:0))):(s&&(n.height=i.positions[0][2]),r&&(n.extrudedHeight=i.positions[1][2])),A=[...i.positions[0]])}));break}this.supportEditing=!1;return}while(!1);i.init(),i.enabled=!0;const o=this.ad(p.createNextAnimateFrameEvent(i.enabledChanged,i.startPositionChanged));this.ad(o.don(()=>{(!i.enabled||!i.startPosition||Q.equalsN3(i.startPosition,[0,0,0]))&&this.destroy()}))}};L(Xc,"type",Xc.registerEditing("ESCesiumViewer",Q.ESJEditingMode.HeightModify,Xc));let Uv=Xc;function rE(){const t=p.createProcessingFromAsyncFunc(async(n,e,i,o,r=!0)=>{const s=Array.isArray(o)?[...o]:[o],a=i.editingID;e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"start",add:{modes:s}});const l=()=>{e.notSupportEditingCount=0,e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"end",add:{modes:s}}),t.isRunning&&t.cancel()};n.disposer.ad(l),n.disposer.ad(i.toDestroyEvent.don(l));const c=u=>{u.code=="Escape"&&l()};document.body.addEventListener("keydown",c),n.disposer.ad(()=>document.body.removeEventListener("keydown",c));let h=0;do{const u=s[h%s.length],A=await p.step(n,async f=>{const d=f.disposer,g=Q.EngineObject.contextEditing.getEngineObjConstructor(u,e.typeName);if(!g||!i.supportEditingModes().includes(u))return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount++,!1;const v=new g(i,e);if(d.ad(()=>{!v.isDestroyed()&&v.destroy()}),v.supportEditing)e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount=0;else return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[i.parentID??i.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:h}}),e.notSupportEditingCount++,!1;return await f.promise(new Promise(m=>{if(v.isDestroyed()&&m(!1),d.ad(v.toDestroyEvent.don(()=>{console.log(`编辑模式${u}结束`),m(!1)})),r){const w=_=>{_.code=="Space"&&(console.log(`编辑模式${u}结束`),m(!1))};document.body.addEventListener("keydown",w),d.ad(()=>document.body.removeEventListener("keydown",w)),d.ad(e.dblclickEvent.don(()=>m(!0)))}}))});if(r&&A||!r&&h==s.length-1||e.notSupportEditingCount==s.length)break;h++}while(!0)});return t}function oE(){const t=p.createProcessingFromAsyncFunc(async(n,e,i,o)=>{e.editingEvent.emit({objectIDs:i.map(l=>l.parentID??l.id),editingID:o,type:"start"});const r=()=>{e.editingEvent.emit({objectIDs:i.map(l=>l.parentID??l.id),editingID:o,type:"end"}),t.isRunning&&t.cancel()};n.disposer.ad(r);const s=l=>{l.code=="Escape"&&r()};document.body.addEventListener("keydown",s),n.disposer.ad(()=>document.body.removeEventListener("keydown",s));const a=new yf(i,e);n.disposer.ad(()=>{!a.isDestroyed()&&a.destroy()}),await n.promise(new Promise(l=>{a.isDestroyed()&&l(),n.disposer.ad(a.toDestroyEvent.don(()=>{console.log("移动结束"),l()})),n.disposer.ad(e.dblclickEvent.don(()=>l()))}))});return t}ae.copyright=void 0;try{const t="earthsdk3-cesium",n="3.3.0-beta.5",e="2025-07-15T06:12:13.000Z",i="北京西部世界科技有限公司",o="地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",r="9d13184aed42b04992b38a0b1d398eca01357d5f",a=((Date.now()-1752559933e3)/36e5).toFixed(1),l=`%c🌏 ${t}%c ${n}.${r.slice(0,8)}.${e} (距今${a}个小时)
4146
4146
  %c${o?o+`
4147
4147
  `:""}当前网站正在使用${t},此软件版权归${i}所有
4148
- `;ae.copyright=Object.freeze({get owner(){return"北京西部世界科技有限公司"},get ownerlink(){return OWNERLINK_},get gituri(){return GITURI_&&GITURI_.replace("${commitId}","34ba4ad6d65bfee5f2bf36300710c86cb8fb312d")},get info(){return l},get date(){return"2025-07-15T03:45:59.000Z"},get author(){return"suplyang"},get version(){return"3.3.0-beta.3"},get name(){return"earthsdk3-cesium"},get commitId(){return"34ba4ad6d65bfee5f2bf36300710c86cb8fb312d"},print(){console.info(this.info,`
4148
+ `;ae.copyright=Object.freeze({get owner(){return"北京西部世界科技有限公司"},get ownerlink(){return OWNERLINK_},get gituri(){return GITURI_&&GITURI_.replace("${commitId}","9d13184aed42b04992b38a0b1d398eca01357d5f")},get info(){return l},get date(){return"2025-07-15T06:12:13.000Z"},get author(){return"suplyang"},get version(){return"3.3.0-beta.5"},get name(){return"earthsdk3-cesium"},get commitId(){return"9d13184aed42b04992b38a0b1d398eca01357d5f"},print(){console.info(this.info,`
4149
4149
  font-size: 18px;
4150
4150
  font-weight: 1000;
4151
4151
  line-height: 1;
@@ -49057,7 +49057,7 @@ function Dz() {
49057
49057
  }
49058
49058
  let Yp;
49059
49059
  try {
49060
- const t = "earthsdk3-cesium", i = "3.3.0-beta.3", e = "2025-07-15T03:45:59.000Z", s = "北京西部世界科技有限公司", n = "地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn", o = "34ba4ad6d65bfee5f2bf36300710c86cb8fb312d", a = ((Date.now() - 1752551159e3) / 36e5).toFixed(1), l = `%c🌏 ${t}%c ${i}.${o.slice(0, 8)}.${e} (距今${a}个小时)
49060
+ const t = "earthsdk3-cesium", i = "3.3.0-beta.5", e = "2025-07-15T06:12:13.000Z", s = "北京西部世界科技有限公司", n = "地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn", o = "9d13184aed42b04992b38a0b1d398eca01357d5f", a = ((Date.now() - 1752559933e3) / 36e5).toFixed(1), l = `%c🌏 ${t}%c ${i}.${o.slice(0, 8)}.${e} (距今${a}个小时)
49061
49061
  %c${n ? n + `
49062
49062
  ` : ""}当前网站正在使用${t},此软件版权归${s}所有
49063
49063
  `;
@@ -49071,7 +49071,7 @@ try {
49071
49071
  },
49072
49072
  // @ts-ignore
49073
49073
  get gituri() {
49074
- return GITURI_ && GITURI_.replace("${commitId}", "34ba4ad6d65bfee5f2bf36300710c86cb8fb312d");
49074
+ return GITURI_ && GITURI_.replace("${commitId}", "9d13184aed42b04992b38a0b1d398eca01357d5f");
49075
49075
  },
49076
49076
  // @ts-ignore
49077
49077
  get info() {
@@ -49079,7 +49079,7 @@ try {
49079
49079
  },
49080
49080
  // @ts-ignore
49081
49081
  get date() {
49082
- return "2025-07-15T03:45:59.000Z";
49082
+ return "2025-07-15T06:12:13.000Z";
49083
49083
  },
49084
49084
  // @ts-ignore
49085
49085
  get author() {
@@ -49087,7 +49087,7 @@ try {
49087
49087
  },
49088
49088
  // @ts-ignore
49089
49089
  get version() {
49090
- return "3.3.0-beta.3";
49090
+ return "3.3.0-beta.5";
49091
49091
  },
49092
49092
  // @ts-ignore
49093
49093
  get name() {
@@ -49095,7 +49095,7 @@ try {
49095
49095
  },
49096
49096
  // @ts-ignore
49097
49097
  get commitId() {
49098
- return "34ba4ad6d65bfee5f2bf36300710c86cb8fb312d";
49098
+ return "9d13184aed42b04992b38a0b1d398eca01357d5f";
49099
49099
  },
49100
49100
  print() {
49101
49101
  console.info(
@@ -2291,10 +2291,10 @@ void main()
2291
2291
  {
2292
2292
  out_FragColor = u_color;
2293
2293
  }
2294
- `,uniformMap:{u_color:[1,1,0,1]},name:"CzmCustomPrimitive_47fd",attributes:{position:{typedArray:{type:"Float32Array",array:[0,0,0,0,0,1]},componentsPerAttribute:3}}},Fe,t)}class qx extends l.HasOwner{constructor(i){super(i);const{czmViewer:e}=this.owner;let n;this.dispose(()=>this.owner.hoveredPlaneType="none");const r=this._createRotatorMoveProcessing();this.dispose(e.pointerMoveEvent.disposableOn(o=>{const s=n=this._getStartInfo(o.pointerEvent);s&&(this.owner.hoveredPlaneType=s.currentPlaneType)})),this.dispose(e.pointerDownEvent.disposableOn(o=>{n&&n.currentPlaneType!=="none"&&(r.restart(void 0,e,n),n=void 0)})),this.dispose(e.dblclickEvent.disposableOn(o=>{do{const s=this._getStartInfo(o.pointerEvent);if(!s||s.currentPlaneType==="none")break;const{currentPlaneType:a}=s,c=[...this.owner.selfRotation];c[di.rotationNum[a]]=0,this.owner.selfRotation=c;return}while(!1);this.owner.enabled=!1}))}_createRotatorMoveProcessing(){return this.ad(l.createProcessingFromAsyncFunc(async(i,e,n)=>{const r=this.owner.circles[n.currentPlaneType];e.incrementDisabledInputStack(),i.disposer.dispose(()=>e.decrementDisabledInputStack()),i.disposer.dispose(e.pointerMoveEvent.don(o=>{if(n&&o.pointerEvent){const{offsetX:s,offsetY:a}=o.pointerEvent,c=[s,a],{currentPlaneType:h}=n;if(h==="none")return;const p=this.owner.getPlane(h);if(!n.currentV)return;const u=p.pick(c);if(!u||!this.owner.cartesian)return;const f=d.Cartesian3.subtract(n.currentV,this.owner.cartesian,new d.Cartesian3);d.Cartesian3.normalize(f,f);const g=d.Cartesian3.subtract(u,this.owner.cartesian,new d.Cartesian3);if(d.Cartesian3.normalize(g,g),!p.normal||!p.origin)return;const m=zg(f,g,p.normal),y=zg(p.origin,f,p.normal),S=zg(p.origin,g,p.normal);{const _=[...this.owner.selfRotation];_[di.rotationNum[h]]=n.startRotation+m,this.owner.selfRotation=_,r.circleStartRotation=y,r.circleEndRotation=S}}})),this.owner.movingPlaneType=n.currentPlaneType,i.disposer.dispose(()=>{this.owner.movingPlaneType="none"}),i.disposer.dispose(()=>{r.circleStartRotation=0,r.circleEndRotation=0}),await l.step(i,o=>new Promise((s,a)=>{o.disposer.dispose(a),o.disposer.dispose(e.pointerUpEvent.don(()=>{s()})),o.disposer.dispose(e.pointerOutEvent.don(()=>{s()}))}))}))}_pickPlane(i,e,n,r,o){const s=this.owner.cartesian;if(!s)return;const{selfRotation:a}=this.owner,c=this.owner.getPlane(n).pick(r);if(!c)return;const h=d.Cartesian3.distance(s,c),p=o/4,u=p*3/128;if(!(h>=p-u&&h<=p+u))return;const g=d.Cartesian3.distance(e.camera.positionWC,c);i.currentD2c<=g||(i.currentPlaneType=n,i.currentD2c=g,i.currentV=c,i.startRotation=a[di.rotationNum[n]])}_getStartInfo(i){var p;const{czmViewer:e}=this.owner,n=(p=e.viewer)==null?void 0:p.scene;if(!this.owner.position||!this.owner.cartesian)return;const r=Li(n,this.owner.cartesian,this.owner.pixelSize);if(!r)return;const{offsetX:o,offsetY:s}=i,a=[o,s],c=i.pointerId,h={currentPlaneType:"none",currentD2c:Number.POSITIVE_INFINITY,currentV:void 0,startRotation:0,pointerId:c};return this._pickPlane(h,n,"heading",a,r),this._pickPlane(h,n,"pitch",a,r),this._pickPlane(h,n,"roll",a,r),h}}function zg(t,i,e){const n=d.Cartesian3.cross(i,t,new d.Cartesian3);if(n.equals(d.Cartesian3.ZERO))return 0;d.Cartesian3.normalize(n,n);const r=d.Cartesian3.dot(n,e);let o=Math.acos(d.Cartesian3.dot(t,i))*180/Math.PI;return o=r>0?o:-o,o}const $o=class $o extends Ht{constructor(e){super();v(this,"_hoveredPlaneType",this.disposeVar(l.react("none")));v(this,"_movingPlaneType",this.disposeVar(l.react("none")));v(this,"_circles");v(this,"_czmCameraModel");v(this,"_cartesian");v(this,"_planes",{heading:this.disposeVar(new Vx(this)),pitch:this.disposeVar(new Ux(this)),roll:this.disposeVar(new Wx(this))});v(this,"_rotatorRunningResetting");this._czmViewer=e;const n=this._czmViewer;if(this._rotatorRunningResetting=this.disposeVar(new l.ObjResettingWithEvent(this.enabledChanged,()=>{if(this.enabled)return new qx(this)})),this._circles={heading:this._createRotatorCircle(n,"heading"),pitch:this._createRotatorCircle(n,"pitch"),roll:this._createRotatorCircle(n,"roll")},!!n.viewer){{const o=()=>{this._cartesian=this.position&&$e(this.position)||void 0};o(),this.dispose(this.positionChanged.disposableOn(o))}this._createCameraModel(n)}}get hoveredPlaneType(){return this._hoveredPlaneType.value}set hoveredPlaneType(e){this._hoveredPlaneType.value=e}get hoveredPlaneTypeChanged(){return this._hoveredPlaneType.changed}get movingPlaneType(){return this._movingPlaneType.value}set movingPlaneType(e){this._movingPlaneType.value=e}get movingPlaneTypeChanged(){return this._movingPlaneType.changed}get circles(){return this._circles}get czmCameraModel(){return this._czmCameraModel}get cartesian(){return this._cartesian}get czmViewer(){return this._czmViewer}getPlane(e){return this._planes[e]}get rotatorRunningResetting(){return this._rotatorRunningResetting}_createCameraModel(e){this._czmCameraModel=new ct(e),this._czmCameraModel.url="${earthsdk3-assets-script-dir}/assets/glb/camera1/camera1.gltf",this._czmCameraModel.localRotation=[90,0,0],this._czmCameraModel.allowPicking=!1,this._czmCameraModel.opaquePass="OVERLAY",this.dispose(l.track([this._czmCameraModel,"pixelSize"],[this,"pixelSize"],n=>n*.1)),this.dispose(l.track([this._czmCameraModel,"position"],[this,"position"])),this.dispose(l.track([this._czmCameraModel,"rotation"],[this,"rotation"]));{const n=()=>{const r=ke({rotation:this.selfRotation});if(!r)throw new Error("!rm");this._czmCameraModel&&(this._czmCameraModel.localModelMatrix=d.Matrix4.toArray(r))};n(),this.dispose(this.selfRotationChanged.disposableOn(n))}{const n=()=>{this.circles.heading.show=this.enabled,this.circles.pitch.show=this.enabled,this.circles.roll.show=this.enabled,this._czmCameraModel&&(this._czmCameraModel.show=this.enabled&&this.showHelper)};n(),this.dispose(this.enabledChanged.disposableOn(n)),this.dispose(this.showHelperChanged.disposableOn(n))}}_createRotatorCircle(e,n){const r=this.ad(new Jr(e));this.dispose(l.track([r,"position"],[this,"position"])),this.dispose(l.track([r,"pixelSize"],[this,"pixelSize"])),this.dispose(l.track([r,"debug"],[this,"debug"])),this.dispose(l.track([r,"rotation"],[this,"rotation"]));{const o=()=>{r.selfRotation=$o.rotationFuncs[n](this.selfRotation),r.circleRotation=this.selfRotation[$o.rotationNum[n]]};o(),this.dispose(this.selfRotationChanged.disposableOn(o))}{const o=()=>{const s=this.movingPlaneType===n,a=this.hoveredPlaneType===n,h=[0,0,0,s||a?1:.8];h[$o.rotationNum[n]]=1,r.color=h};o(),this.dispose(this.movingPlaneTypeChanged.disposableOn(o)),this.dispose(this.hoveredPlaneTypeChanged.disposableOn(o))}return r}};v($o,"rotationNum",{heading:0,pitch:1,roll:2}),v($o,"rotationFuncs",{heading:([e,n,r])=>[0,0,0],pitch:([e,n,r])=>[e,0,-90],roll:([e,n,r])=>[e,n+90,0]});let di=$o;(t=>{t.createDefaultProps=()=>({...Ht.createDefaultProps(),rotation:l.reactArray([0,0,0]),selfRotation:l.reactArray([0,0,0]),pixelSize:300,showHelper:!1,debug:!1})})(di||(di={})),l.extendClassProps(di.prototype,di.createDefaultProps);const Xo=class Xo extends l.Destroyable{get startPosition(){return this.positions&&this.positions[0]}set startPosition(i){this.positions=[i??Xo.defaults.positions[0],this.stopPosition??Xo.defaults.positions[1]]}get startPositionChanged(){return this.positionsChanged}get stopPosition(){return this.positions&&this.positions[1]}set stopPosition(i){this.positions=[this.startPosition??Xo.defaults.positions[0],i??Xo.defaults.positions[1]]}get stopPositionChanged(){return this.positionsChanged}constructor(i,e){if(super(),!i.viewer)return;const r=this.ad(new Ie(i,e));r.arcType="RHUMB";const o=this.ad(new Kt(i,e));this.ad(l.track([r,"allowPicking"],[this,"allowPicking"])),this.ad(l.track([o,"allowPicking"],[this,"allowPicking"]));{const s=()=>{r.show=o.show=this.show};s(),this.ad(this.showChanged.don(s))}{const s=()=>{r.width=this.width/2,o.pixelSize=this.width};s(),this.ad(this.widthChanged.don(s))}{const s=()=>{r.color=o.color=this.color};s(),this.ad(this.colorChanged.don(s))}{const s=()=>{r.positions=this.positions,o.position=this.stopPosition};s(),this.dispose(this.startPositionChanged.disposableOn(s)),this.dispose(this.stopPositionChanged.disposableOn(s))}}};v(Xo,"defaults",{positions:[[0,0,0],[0,0,1e6]]});let No=Xo;(t=>{t.createDefaultProps=()=>({show:!0,allowPicking:!1,positions:l.reactPositions(t.defaults.positions),width:10,color:l.reactArray([1,0,0,1])})})(No||(No={})),l.extendClassProps(No.prototype,No.createDefaultProps);class nn extends Ht{constructor(e){super();v(this,"_lastPosition");v(this,"_opInfo",{step:this.ad(l.react(!1)),moved:this.ad(l.react(!1)),constraintMode:this.disposeVar(l.react("none")),originPosition:this.disposeVar(l.reactArray([0,0,0])),originHeading:this.disposeVar(l.react(0)),originDimensions:this.disposeVar(l.reactArray([1,1,1])),draggingStartPosition:this.disposeVar(l.reactArray([0,0,0])),movingPosition:this.disposeVar(l.reactArray([0,0,0])),targetPosition:this.disposeVar(l.reactArray([0,0,0])),targetHeading:this.disposeVar(l.react(0))});v(this,"_scaleAxis");v(this,"_pickingXYProcessing",e=>this.disposeVar(new l.Processing((n,r,o)=>{const s=[0,0,0],a=new d.Cartographic;return e.pointerMoveEvent.disposableOn(c=>{if(!c.pointerEvent||!e.viewer)return;const h=ni(l.getDomEventCurrentTargetPos(c.pointerEvent));if(!Ko(e.viewer.scene,h,this._opInfo.originPosition.value[2],a))return;Zo(a,s),this._opInfo.constraintMode.value==="x"?no(this._opInfo.originPosition.value,this._opInfo.originHeading.value,s,s):this._opInfo.constraintMode.value==="y"?no(this._opInfo.originPosition.value,this._opInfo.originHeading.value+90,s,s):this._opInfo.constraintMode.value==="xy"||console.warn("should not be here!"),this._opInfo.movingPosition.value=s,this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const p=[0,0,0];w.geoRhumbDestination(s,o,r,p),this._opInfo.targetPosition.value=p;let u=this.scale[0],f=this.scale[1];const g=w.geoDistance(p,this._opInfo.originPosition.value)-w.geoDistance(this._lastPosition,this._opInfo.originPosition.value);this._lastPosition=[...p];const m=this._opInfo.originDimensions.value[0]/100;g!=0&&this._opInfo.constraintMode.value==="y"&&(g>0?u+=m:u-=m),g!=0&&this._opInfo.constraintMode.value==="x"&&(g>0?f+=m:f-=m),u<=0&&(u+=m),f<=0&&(f+=m),this.scale=[u??1,f??1,this.scale[2]??1]})})));v(this,"_pickingZProcessing",e=>this.disposeVar(new l.Processing(()=>{const n=new d.Cartesian3,r=[0,0,0];return e.pointerMoveEvent.disposableOn(o=>{if(!o.pointerEvent||!e.viewer)return;const s=ni(l.getDomEventCurrentTargetPos(o.pointerEvent));if(!ic(e.viewer.scene,$e(this._opInfo.originPosition.value),s,n))return;this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const a=this._opInfo.originPosition.value[2]-this._opInfo.draggingStartPosition.value[2];if(ce(n,r)){this._opInfo.movingPosition.value=r;const c=this._opInfo.originPosition.value;this._opInfo.targetPosition.value=[c[0],c[1],r[2]+a];let h=this.scale[2];const p=r[2]-this._lastPosition[2];this._lastPosition=[...r];const u=this._opInfo.originDimensions.value[0]/100;p!=0&&(p>0?h+=u:h-=u),h<=0&&(h+=u),this.scale=[this.scale[0]??1,this.scale[1]??1,h??1]}})})));const n=e.viewer;if(!n)return;const{scene:r}=n;this.ad(new ed(e,this.positionReact,this._opInfo.originDimensions,this.axisPixelSize)),this.ad(e.dblclickEvent.don(()=>{this.enabled=!1})),this._scaleAxis={zAxis:this._createScaleAxis(e,"zAxis"),yAxis:this._createScaleAxis(e,"yAxis"),xAxis:this._createScaleAxis(e,"xAxis")};{const h=()=>{if(!this._scaleAxis)return;const{zAxis:p,yAxis:u,xAxis:f}=this._scaleAxis,g=this._opInfo.constraintMode.value,m=this._opInfo.step;p.color=[0,0,1,.99],u.color=[0,1,0,.99],f.color=[1,0,0,.99],g==="x"?f.color=m?[1,1,0,.8]:[1,1,0,.99]:g==="y"?u.color=m?[1,1,0,.8]:[1,1,0,.99]:g==="z"&&(p.color=m?[1,1,0,.8]:[1,1,0,.99])};h(),this.dispose(this._opInfo.constraintMode.changed.disposableOn(h)),this.dispose(this._opInfo.step.changed.disposableOn(h))}{const h=()=>{if(!this._scaleAxis)return;const{position:u=nn.defaults.position}=this,{zAxis:f,yAxis:g,xAxis:m}=this._scaleAxis;f.startPosition=g.startPosition=m.startPosition=u;const[y,S,_]=u;f.stopPosition=[y,S,_+this._opInfo.originDimensions.value[2]];const C=w.geoRhumbDestination(u,this._opInfo.originDimensions.value[0],90);C&&(m.stopPosition=C);const E=w.geoRhumbDestination(u,this._opInfo.originDimensions.value[1],0);E&&(g.stopPosition=E)};h();const p=this.ad(l.createNextAnimateFrameEvent(this.positionChanged,this._opInfo.originDimensions.changed));this.ad(p.don(h))}{const h=()=>{if(this._opInfo.constraintMode.value==="none"){this._opInfo.moved.value=!1;return}if(this._opInfo.originHeading.value!==this._opInfo.targetHeading.value){this._opInfo.moved.value=!0;return}if(!this._opInfo.originPosition.value.every((p,u)=>p===this._opInfo.targetPosition.value[u])){this._opInfo.moved.value=!0;return}};h(),this.dispose(this._opInfo.originHeading.changed.disposableOn(h)),this.dispose(this._opInfo.originPosition.changed.disposableOn(h)),this.dispose(this._opInfo.targetHeading.changed.disposableOn(h)),this.dispose(this._opInfo.targetPosition.changed.disposableOn(h))}const o=this._pickingXYProcessing(e),s=this._pickingZProcessing(e),a=this.disposeVar(l.createProcessingFromAsyncFunc(async h=>{do this._opInfo.step.value=!0,this._opInfo.constraintMode.value="none",h.disposer.dispose(()=>{this._opInfo.constraintMode.value="none"}),await l.step(h,async p=>{const u=()=>{const m=[...this.position??nn.defaults.position];e.editingHeightOffset&&(m[2]-=e.editingHeightOffset),this._opInfo.targetPosition.value=this._opInfo.originPosition.value=m};p.disposer.dispose((u(),this.positionChanged.disposableOn(u)));const f={constraintMode:"none",startDragPos:[0,0,0]},g=m=>{if(!this.position)return;const y={position:this.position,dimensions:this._opInfo.originDimensions.value,heading:0};Gh(m,r,y,this.axisSnapPixelSize,f),this._opInfo.constraintMode.value=f.constraintMode,this._opInfo.movingPosition.value=this._opInfo.draggingStartPosition.value=f.startDragPos};p.disposer.dispose(e.pointerMoveEvent.disposableOn(m=>{m.pointerEvent&&g(m.pointerEvent)})),await l.step(p,m=>new Promise((y,S)=>{m.disposer.dispose(S),m.disposer.dispose(e.pointerDownEvent.don(_=>{_.pointerEvent&&g(_.pointerEvent),_.pointerEvent&&_.pointerEvent.button===0&&f.constraintMode!=="none"&&y()}))}))}),this._opInfo.step.value=!1,await l.step(h,async p=>{if(e.incrementDisabledInputStack(),p.disposer.dispose(()=>e.decrementDisabledInputStack()),["x","y"].includes(this._opInfo.constraintMode.value)){const u=w.geoRhumbHeading(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value),f=w.geoRhumbDistance(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value);o.restart(void 0,u,f),p.disposer.dispose(()=>o.cancel())}else this._opInfo.constraintMode.value==="z"&&(s.restart(),p.disposer.dispose(()=>s.cancel()));await l.step(p,u=>new Promise((f,g)=>{u.disposer.dispose(g),u.disposer.dispose(e.pointerUpEvent.don(()=>{f()})),u.disposer.dispose(e.pointerOutEvent.don(()=>{f()}))})),this._lastPosition=void 0});while(!0)})),c=()=>{this.enabled?a.restart():a.isRunning&&a.cancel()};c(),this.dispose(this.enabledChanged.disposableOn(c))}get scaleAxis(){return this._scaleAxis}_createScaleAxis(e,n){const r=this.ad(new No(e));return r.width=10,this.ad(l.track([r,"show"],[this,"enabled"])),r}}(t=>{t.createDefaultProps=()=>({...Ht.createDefaultProps(),scale:l.reactArray([1,1,1]),axisPixelSize:100,axisSnapPixelSize:5})})(nn||(nn={})),l.extendClassProps(nn.prototype,nn.createDefaultProps);const to=class to extends At{constructor(e){super();v(this,"_editingPoints",this.disposeVar(new l.ObservableArray));v(this,"_cancelEvent",this.disposeVar(new l.Event));v(this,"_currentProcess");v(this,"_menuPoiEnabled",this.disposeVar(l.react(!1)));v(this,"_status",this.disposeVar(l.react("None")));v(this,"_positionsChanged",this.ad(new l.Event));v(this,"_cursorInfo");this._czmViewer=e,this.enabled=!1,this.createPolyline(e),this._createCursorInfo(e),this.dispose(()=>this.resetPositions()),this.dispose(()=>this.editingPoints.length=0),this.dispose(this.editingPoints.changedEvent.disposableOn(()=>this.positionsChanged.emit())),this.dispose(this.editingPoints.toChangeEvent.disposableOn(n=>{for(let{start:r,deleteCount:o,items:s}of n){for(const a of s)a.menuPoi.enabled=this.menuPoiEnabled??!1;for(let a=r;a<r+o;++a)this.editingPoints.get(a).destroy()}})),this.dispose(this.menuPoiEnabledChanged.disposableOn(()=>{for(let n of this.editingPoints)n.menuPoi.enabled=this.menuPoiEnabled??!1})),this.dispose(e.dblclickEvent.don(n=>{this.ad(l.nextAnimateFrame(()=>{var r;((r=n.pointerEvent)==null?void 0:r.button)===0&&this.enabled&&this.currentProcess&&this.currentProcess.cancel()}))})),this.dispose(this.enabledChanged.disposableOn(n=>{this._currentProcess&&(n?this._currentProcess.restart():this._currentProcess.isRunning&&this._currentProcess.cancel())}));{const n=()=>{this.polylineShow=this.czmViewer.editingLineShow};n(),this.ad(this.czmViewer.editingLineShowChanged.don(n))}}get editingPoints(){return this._editingPoints}get cancelEvent(){return this._cancelEvent}cancel(){this._cancelEvent.emit()}get currentProcess(){return this._currentProcess}set currentProcess(e){this._currentProcess=e}get menuPoiEnabled(){return this._menuPoiEnabled.value}set menuPoiEnabled(e){this._menuPoiEnabled.value=e}get menuPoiEnabledChanged(){return this._menuPoiEnabled.changed}get status(){return this._status.value}get statusChanged(){return this._status.changed}set status(e){this._status.value=e}getPositions(){const e=[];for(let n of this._editingPoints)n.position&&e.push([...n.position]);return e}resetPositions(e){if(this.enabled??to.defaults.enabled)return console.warn("MultiPointsEditing.resetPositions error: this.enabled === true"),!1;const n=e||[];return!(n.length===this.editingPoints.length&&n.every((r,o)=>r.every((s,a)=>{const c=this.editingPoints.get(o);return c.position&&c.position[a]===s})))}forceResetPositions(e){(this.enabled??to.defaults.enabled)&&(this.enabled=!1),this.resetPositions(e)}get positions(){return this.getPositions()}set positions(e){this.resetPositions(e)}get positionsChanged(){return this._positionsChanged}get czmViewer(){return this._czmViewer}get cursorInfo(){return this._cursorInfo}createPolyline(e){const n=this.ad(new Ie(e));this.ad(l.track([n,"color"],[this,"polylineColor"])),this.ad(l.track([n,"width"],[this,"polylineWidth"])),this.ad(l.track([n,"show"],[this,"polylineShow"])),this.ad(l.track([n,"arcType"],[this,"polylineArcType"])),this.ad(l.track([n,"loop"],[this,"loop"]));{const r=()=>{const o=[];for(const s of this.getPositions())s[2]-=e.editingHeightOffset??0,o.push(s);n.positions=o};r(),this.ad(this.positionsChanged.don(r))}}_createCursorInfo(e){const n=this._cursorInfo=this.ad(new l.CursorInfo(e.container,l.CursorFloatDiv));this.dispose(this.statusChanged.disposableOn(()=>{const r=this.status;if(n){if(!this.hideCursorInfo){n.show=!1;return}r==="Adding"?(n.text="右键/BackSpace键:删除上一个控制点;Esc键或左键双击:退出添加状态,进入修改状态",n.show=!0):r==="Modifying"||r==="Modifying_Point"?(n.text="Esc键或左键双击:退出编辑状态",n.show=!0):r==="None"&&(n.text="",n.show=!1)}}))}};v(to,"baseImageUrl","${earthsdk3-assets-script-dir}/assets/img/"),v(to,"defaults",{...At.defaults,debug:!1,polylineShow:!1,polylineWidth:1,polylineColor:[1,1,1,1],polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,loop:!1,firstControlPointImageUrl:to.baseImageUrl+"point-green.png",otherControlPointImageUrl:to.baseImageUrl+"point-yellow.png"});let ei=to;(t=>{t.createDefaultProps=()=>({...At.createDefaultProps(),loop:!1,debug:!1,polylineShow:!0,polylineWidth:1,polylineColor:l.reactArray([1,1,1,1]),polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,firstControlPointImageUrl:t.baseImageUrl+"point-green.png",otherControlPointImageUrl:t.baseImageUrl+"point-yellow.png",hideCursorInfo:!1,middlePointShow:!0})})(ei||(ei={})),l.extendClassProps(ei.prototype,ei.createDefaultProps);let $x=0;class o1 extends l.Destroyable{constructor(e,n){super();v(this,"_position",this.disposeVar(l.reactArrayWithUndefined(void 0)));v(this,"_id",$x++);v(this,"_menuPoi");n&&(this.position=n),e.debug&&console.log(`PolylinePositionEditor creating! ${this.id}`),this.dispose(()=>{e.debug&&console.log(`PolylinePositionEditor destroying! ${this.id}`)});const r=this._menuPoi=this.ad(new ar(e.czmViewer));r.enabled=!1,this.ad(l.track([r,"show"],[e,"enabled"]));{const o=()=>{if(this.position===void 0){r.position=void 0;return}const s=[...this.position];s[2]-=e.czmViewer.editingHeightOffset??0,r.position=s,e.positionsChanged.emit()};o(),this.d(this.positionChanged.don(o))}{const o=()=>{const s=e.editingPoints.indexOf(this)+1;s!==0&&(r.title=`控制点${s}`,s===1?r.imageUri=e.firstControlPointImageUrl??ei.defaults.firstControlPointImageUrl:r.imageUri=e.otherControlPointImageUrl??ei.defaults.otherControlPointImageUrl)};o(),this.dispose(e.editingPoints.changedEvent.disposableOn(o))}}get position(){return this._position.value}set position(e){this._position.value=e}get positionChanged(){return this._position.changed}get id(){return this._id}get menuPoi(){return this._menuPoi}}class r1 extends o1{constructor(i,e){super(i,e)}}class Je extends ei{constructor(e){super(e);v(this,"_deletePreviousPointWhileAddingEvent",this.disposeVar(new l.Event));v(this,"placeEditing");if(!e.viewer)return;const n=this.placeEditing=this.ad(new hi(e));n.enabled=!1,this.currentProcess=this.disposeVar(l.createProcessingFromAsyncFunc(async r=>{r.disposer.dispose(()=>{(this.debug??Je.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1}),(this.debug??Je.defaults.debug)&&console.log("直接进入Adding状态"),this.status="Adding",await r.promise(l.step(r,async o=>{const s=o.disposer,a=s.ad(this._addingEditingProcessing());s.dispose(()=>"adding canceled!"),s.dispose(this.cancelEvent.disposableOn(()=>a.cancel())),await o.promise(new Promise(c=>{s.dispose(a.completeEvent.disposableOnce(c))}))}))})),this.dispose(e.clickEvent.don(r=>{var o;((o=r.pointerEvent)==null?void 0:o.button)===2&&this.deletePreviousPointWhileAdding()}))}deletePreviousPointWhileAdding(){this._deletePreviousPointWhileAddingEvent.emit()}resetPositions(e){if(!super.resetPositions(e))return!0;const n=e?e.map(r=>new r1(this,r)):[];return this.editingPoints.splice(0,this.editingPoints.length,...n),!0}_addingEditingProcessing(){const e=()=>{if(this.maxPointsNum!==void 0)return this.editingPoints.length>=this.maxPointsNum&&(this.debug??Je.defaults.debug)&&console.log("impl.positionEditors.length >= impl.maxPointsNum"),this.editingPoints.length>=this.maxPointsNum},n=l.createProcessingFromAsyncFunc(async r=>{let o=this.editingPoints.length;this.menuPoiEnabled=!1;do if(!await r.promise(l.step(r,async a=>{let c;!e()&&(c=a.disposer.disposeVar(new Xx(this,o)));const p=a.disposer.disposeVar(new Zx(this,o));return a.disposer.dispose(this._deletePreviousPointWhileAddingEvent.disposableOn(()=>p.do())),await a.promise(new Promise(u=>{c&&a.disposer.dispose(c.overEvent.disposableOnce(f=>{f?(o++,u(!0)):u(!1)})),a.disposer.dispose(p.overEvent.disposableOnce(f=>{f?(o--,u(!0)):u(!1)})),a.disposer.dispose(this.cancelEvent.disposableOn(()=>u(!1)))}))})))break;while(!0)});return n.start(),n}}(t=>{t.createDefaultProps=()=>({...ei.createDefaultProps()})})(Je||(Je={})),l.extendClassProps(Je.prototype,Je.createDefaultProps);class Xx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));const{placeEditing:r}=e;let o=new r1(e,void 0);e.editingPoints.splice(n,0,o);const s=()=>{(e.debug??Je.defaults.debug)&&console.log("delete currentPosEditor");const h=e.editingPoints.indexOf(o);if(h===-1)throw new Error("currentPosEditor not found");e.editingPoints.splice(h,1)};if(r.enabled??!1)throw console.error("placeEditing.enabled is true!"),new Error("placeEditing.enabled is true!");this.dispose(l.track([o,"position"],[r,"position"])),r.enabled=!0;let a=!1;const c=()=>{s(),this._overEvent.emit(!1)};this.dispose(()=>{r.enabled=!1,!a&&c()}),this.dispose(r.overEvent.disposableOnce(()=>{a=!0,o.position===void 0?c():this._overEvent.emit(!0)})),(e.debug??Je.defaults.debug)&&console.log(`PointAdding creating! index(${n})`),this.dispose(()=>{(e.debug??Je.defaults.debug)&&console.log(`PointAdding destroying! index(${n})`)})}get overEvent(){return this._overEvent}}function Yx(t,i){const e=t.editingPoints,n=i-1;return n<0?(console.warn("previousIndex < 0, cannot delete the point!"),!1):(e.splice(n,1),!0)}class Zx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"_doEvent",this.disposeVar(new l.Event));this.dispose(this._doEvent.disposableOn(()=>this._overEvent.emit(Yx(e,n)))),(e.debug??Je.defaults.debug)&&console.log(`PreviousPointDeleting creating! currentIndex(${n})`),this.dispose(()=>{(e.debug??Je.defaults.debug)&&console.log(`PreviousPointDeleting destroying! currentIndex(${n})`)})}get overEvent(){return this._overEvent}do(){return this._doEvent.emit()}}class s1 extends Je{constructor(i){super(i),this.loop=!1}}class a1 extends Je{constructor(i){super(i),this.loop=!0}}class Eh extends o1{constructor(i,e){super(i,e);{const{menuPoi:n}=this;n.commands=[["add","增加控制点","",be.baseImageUrl+"add.png"],["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]],n.clickCommandName="modify",n.rightClickCommandName="delete",this.dispose(n.commandEvent.disposableOn(r=>{i.menuPoiCommand(this,r)})),this.dispose(n.dbclickEvent.disposableOn(()=>{i.menuPoiCommand(this,"dbClick")}))}if(i.middlePointShow){const n=this.ad(new gi(i.czmViewer));{n.imageUri=i.firstControlPointImageUrl??be.defaults.firstControlPointImageUrl,n.tooltip="点击增加一个控制点",n.bgColor=[0,0,0,.6],n.fgColor=[1,1,1,1],n.size=[8,8],n.originRatioAndOffset=[.5,.5,0,0];{const r=()=>{if(!(i.enabled??be.defaults.enabled)){n.enabled=!1,n.show=!1;return}do{const s=i.editingPoints.indexOf(this);if(s===-1)break;const a=i.editingPoints.length;if(a===0){console.error("impl.positionEditors.length === 0!");break}if(!(i.loop??be.defaults.loop)&&s+1>=a)break;const h=this.position;if(!h)break;let p=(s+1)%a;const f=i.editingPoints.get(p).position;if(!f)break;const g=Xh(h,f);if(!g)break;g[2]-=i.czmViewer.editingHeightOffset??0,n.position=g;const m=i.editingPoints.length<(i.maxPointsNum??be.defaults.maxPointsNum);n.enabled=m,n.show=m;return}while(!1);n.enabled=!1,n.show=!1};r(),this.dispose(i.positionsChanged.disposableOn(r)),this.dispose(i.loopChanged.disposableOn(r)),this.dispose(i.enabledChanged.disposableOn(r))}this.dispose(n.clickEvent.disposableOn(r=>{if(r.button!==0||i.editingPoints.length>=(i.maxPointsNum??be.defaults.maxPointsNum))return;const o=i.editingPoints.indexOf(this);if(o===-1)return;const s=n.position?[...n.position]:void 0;s&&(s[2]+=i.czmViewer.editingHeightOffset??0);let a=new Eh(i,s);i.editingPoints.splice(o+1,0,a),i.modify(a)}))}}}}class be extends ei{constructor(e){super(e);v(this,"_menuPoiCommand",this.disposeVar(new l.Event));v(this,"_forceModifyPosEditorEvent",this.disposeVar(new l.Event));v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"translationEditing");{const r=this.ad(l.createNextAnimateFrameEvent(this.moveWithFirstPositionChanged,this.editingPoints.changedEvent));this.ad(new l.ObjResettingWithEvent(r,()=>{if(!(!this.moveWithFirstPosition||this.editingPoints.length<=1))return new Qx(this.editingPoints.get(0),this)}))}const n=this.translationEditing=this.disposeVar(new tn(e));n.enabled=!1,this.currentProcess=this.disposeVar(l.createProcessingFromAsyncFunc(async r=>{r.disposer.dispose(()=>{(this.debug??be.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1});let o=-1;do if((this.debug??be.defaults.debug)&&console.log("进入Modifying修改状态"),this.status="Modifying",o=await r.promise(l.step(r,async s=>{const a=s.disposer,c=a.ad(new Kx(this));return a.dispose(()=>"modifying canceled!"),this.editingPoints.length>0&&c.modify(this.editingPoints.get(o===-1||o>=this.editingPoints.length?0:o)),a.dispose(this.cancelEvent.disposableOn(()=>c.cancel())),a.dispose(this._forceModifyPosEditorEvent.disposableOn(p=>c.modify(p))),await s.promise(new Promise(p=>{a.dispose(c.overEvent.disposableOnce(u=>{p(u)}))}))})),o===-1){(this.debug??be.defaults.debug)&&console.log("退出编辑状态");break}else{if(this.editingPoints.length>=(this.maxPointsNum??be.defaults.maxPointsNum))return;if(this.editingPoints.length===0){console.error("impl.positionEditors.length === 0!");return}this.loop??be.defaults.loop;const a=this.editingPoints.get(o-1).position;if(!a)return;let c=o%this.editingPoints.length;const p=this.editingPoints.get(c).position;if(!p)return;const u=Xh(a,p);if(!u)return;u&&(u[2]+=this.czmViewer.editingHeightOffset??0);let f=new Eh(this,u);this.editingPoints.splice(o,0,f)}while(!0);this.status="None",this.enabled=!1}))}menuPoiCommand(e,n){this._menuPoiCommand.emit(e,n)}modify(e){this._forceModifyPosEditorEvent.emit(e)}resetPositions(e){if(!super.resetPositions(e))return!0;const n=e?e.map(r=>new Eh(this,r)):[];return this.editingPoints.splice(0,this.editingPoints.length,...n),!0}get overEvent(){return this._overEvent}}(t=>{t.createDefaultProps=()=>({...ei.createDefaultProps(),moveWithFirstPosition:!1})})(be||(be={})),l.extendClassProps(be.prototype,be.createDefaultProps);class Qx extends l.Destroyable{constructor(i,e){super(),this._firstPositionEditor=i,this.multiPointsModifyEditing=e,this._firstPositionEditor.positionChanged.disposableOn((n,r)=>{if(n===void 0||r===void 0)return;var o=[n[0]-r[0],n[1]-r[1],n[2]-r[2]];const s=this.multiPointsModifyEditing.editingPoints.length;for(let a=1;a<s;a++){const c=this.multiPointsModifyEditing.editingPoints.get(a),h=c.position;h!==void 0&&(c.position=[h[0]+o[0],h[1]+o[1],h[2]+o[2]])}})}}class Kx extends l.Destroyable{constructor(e){super();v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"_cancelEvent",this.disposeVar(new l.Event));v(this,"_forceModifyPosEditorEvent",this.disposeVar(new l.Event));e.menuPoiEnabled=!0,this.dispose(()=>e.menuPoiEnabled=!1);let n;const r=()=>{n==null||n.destroy(),n=void 0,e.status="Modifying"};this.dispose(r);const o=s=>{r(),e.status="Modifying_Point",n=new Jx(e,s),n.dispose(n.overEvent.disposableOn(()=>{r()}))};this.dispose(this._forceModifyPosEditorEvent.disposableOn(o)),this.dispose(e._menuPoiCommand.disposableOn((s,a)=>{if(a==="delete"){if(e.editingPoints.length<=2)return;const c=e.editingPoints.indexOf(s);if(c===-1)throw console.error("posEditor not found"),new Error("posEditor not found");e.editingPoints.splice(c,1)}else if(a==="modify")o(s);else if(a==="add"){const c=e.editingPoints.indexOf(s);if(c===-1)throw console.error("posEditor not found"),new Error("posEditor not found");this._overEvent.emit(c+1)}else a==="dbClick"?this._overEvent.emit(-1):alert(`未知的commandName(${a})`)})),this.dispose(this._cancelEvent.disposableOn(()=>{this._overEvent.emit(-1)}))}get overEvent(){return this._overEvent}cancel(){this._cancelEvent.emit()}modify(e){this._forceModifyPosEditorEvent.emit(e)}}class Jx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));this._modifying=e,this._posEditor=n,this.dispose(this._posEditor.toDestroyEvent.disposableOn(()=>{this._overEvent.emit()}));const{translationEditing:r}=this._modifying;if(r.enabled=!0,r.heading=0,this.dispose(()=>{r.enabled=!1}),!this._posEditor.position)throw console.error("!this._posEditor.position"),new Error("!this._posEditor.position");r.position=this._posEditor.position,this.dispose(l.track([this._posEditor,"position"],[r,"position"])),this.dispose(r.enabledChanged.disposableOnce(o=>{o||this._overEvent.emit()}))}get overEvent(){return this._overEvent}}class l1 extends be{constructor(i){super(i),this.loop=!1}}class c1 extends be{constructor(i){super(i),this.loop=!0}}class Br extends Je{init(){const i=this.startPosition;if(!i)return;const e=this.distance,n=this.rotation,r=e*Math.cos(n[1]*Math.PI/180),o=w.geoDestination(i,r,n[0]);if(!o){this.positions=[i];return}const s=e*Math.sin(n[1]*Math.PI/180);o[2]+=s,this.positions=[i,o],this.editingPoints.length==2&&(this.editingPoints.get(0).position=i,this.editingPoints.get(1).position=o)}constructor(i){super(i),this.loop=!0,this.maxPointsNum=2;{const e=()=>{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];return}if(this.positions.length==1){this.distance=1,this.rotation=[90,0,0];return}this.startPosition=this.positions[0],this.endPosition=this.positions[1];const n=w.geoHeading(this.startPosition,this.endPosition),r=w.geoDistance(this.startPosition,this.endPosition);if(r<=0){this.rotation=[90,0,0],this.distance=1;return}const o=this.endPosition[2]-this.startPosition[2],s=Math.atan(o/r)*180/Math.PI,a=Math.sqrt(r*r+o*o);this.rotation=[n,s,0],this.distance=a};e(),this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...Je.createDefaultProps(),startPosition:l.reactArrayWithUndefined(void 0),endPosition:l.reactArrayWithUndefined(void 0),rotation:l.reactArray([90,0,0]),distance:l.react(1)})})(Br||(Br={})),l.extendClassProps(Br.prototype,Br.createDefaultProps);class Oo extends be{init(){const i=this.startPosition;if(!i)return;const e=this.distance,n=this.rotation,r=e*Math.cos(n[1]*Math.PI/180),o=w.geoDestination(i,r,n[0]);if(!o){this.positions=[i];return}const s=e*Math.sin(n[1]*Math.PI/180);o[2]+=s,this.positions=[i,o],this.editingPoints.length==2&&(this.editingPoints.get(0).position=i,this.editingPoints.get(1).position=o)}constructor(i){super(i),this.loop=!0,this.maxPointsNum=2,this.middlePointShow=!1,this.moveWithFirstPosition=!0;{const e=()=>{do{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];break}if(this.startPosition=this.positions[0],this.positions.length==1){this.editingPoints.get(0).menuPoi.commands=[["add","增加控制点","",be.baseImageUrl+"add.png"],["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]],this.rotation=[90,0,0],this.distance=1;break}this.endPosition=this.positions[1];for(let c of this.editingPoints)c.menuPoi.commands=[["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]];const n=w.geoHeading(this.startPosition,this.endPosition),r=w.geoDistance(this.startPosition,this.endPosition);if(Math.abs(r)<=0){this.rotation=[90,0,0],this.distance=1;return}const o=this.endPosition[2]-this.startPosition[2],s=Math.atan(o/r)*180/Math.PI,a=Math.sqrt(r*r+o*o);this.rotation=[n,s,0],this.distance=a}while(!1)};this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...be.createDefaultProps(),startPosition:l.reactArrayWithUndefined(void 0),endPosition:l.reactArrayWithUndefined(void 0),rotation:l.reactArray([0,0,0]),distance:l.react(0)})})(Oo||(Oo={})),l.extendClassProps(Oo.prototype,Oo.createDefaultProps);class h1 extends Je{constructor(i){super(i),this.loop=!1,this.polylineShow=!1}}class d1 extends be{constructor(i){super(i),this.loop=!1,this.polylineShow=!1,this.middlePointShow=!1}}class jr extends Je{constructor(i){super(i),i.viewer||(this.loop=!1);{const e=()=>{if(!this.positions||this.positions.length<2){this.visibilityPositions=void 0;return}const n=[...this.positions[0]];n[2]-=i.editingHeightOffset??0,this.visibilityPositions=this.positions.map(r=>(r[2]-=i.editingHeightOffset??0,[n,r]))};e(),this.ad(this.positionsChanged.don(e))}}createPolyline(i){const e=this.ad(new ri(i));e.topOrBottom="bottom",this.ad(l.track([e,"color"],[this,"polylineColor"])),this.ad(l.track([e,"width"],[this,"polylineWidth"])),this.ad(l.track([e,"show"],[this,"polylineShow"])),this.ad(l.track([e,"arcType"],[this,"polylineArcType"])),this.ad(l.track([e,"loop"],[this,"loop"])),this.ad(l.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...Je.createDefaultProps(),visibilityPositions:l.reactPositionsSet(void 0)})})(jr||(jr={})),l.extendClassProps(jr.prototype,jr.createDefaultProps);class es extends be{constructor(i){if(super(i),!!i.viewer){this.loop=!1,this.middlePointShow=!1;{const e=()=>{if(!this.positions||this.positions.length<2)return;const n=[...this.positions[0]];n[2]-=i.editingHeightOffset??0,this.visibilityPositions=this.positions.map(r=>(r[2]-=i.editingHeightOffset??0,[n,r]))};e(),this.ad(this.positionsChanged.don(e))}}}createPolyline(i){const e=this.ad(new ri(i));e.topOrBottom="bottom",this.ad(l.track([e,"color"],[this,"polylineColor"])),this.ad(l.track([e,"width"],[this,"polylineWidth"])),this.ad(l.track([e,"show"],[this,"polylineShow"])),this.ad(l.track([e,"arcType"],[this,"polylineArcType"])),this.ad(l.track([e,"loop"],[this,"loop"])),this.ad(l.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...be.createDefaultProps(),visibilityPositions:l.reactPositionsSet(void 0)})})(es||(es={})),l.extendClassProps(es.prototype,es.createDefaultProps);class u1 extends Oo{constructor(i){super(i),this.firstControlPointImageUrl=this.otherControlPointImageUrl,this.translationEditing.xAxisShow=!1,this.translationEditing.yAxisShow=!1,this.translationEditing.zAxisShow=!0,this.translationEditing.showCircle=!1,this.rotation=[0,90,0]}}class Ct extends w.EngineObject{constructor(e,n,r){super(e,n,r??!0);v(this,"_supportEditing",this.disposeVar(l.react(!0)));v(this,"_currentEditing",this.disposeVar(l.react(void 0)));this.ad(this.supportEditingChanged.don(()=>{this.destroy()})),this.ad(this.toDestroyEvent.don(()=>{var o;if(this.currentEditing){if(this.currentEditing instanceof Je&&((o=this.currentEditing.currentProcess)!=null&&o.isRunning))if(this.currentEditing.currentProcess.cancel(),e!=null&&e.position){if(this.currentEditing.positions.length>1)return;e.position=this.currentEditing.positions[0]??[0,0,0],e!=null&&e.rotation&&(e.rotation=[0,0,0]),e!=null&&e.far&&(e.far=1),e!=null&&e.radius&&(e.radius=1),e!=null&&e.distance&&(e.distance=1)}else e.points=this.currentEditing.positions;this.currentEditing instanceof hi&&this.currentEditing.enabled&&(e.position=[0,0,0])}}))}get supportEditing(){return this._supportEditing.value}set supportEditing(e){this._supportEditing.value=e}get supportEditingChanged(){return this._supportEditing.changed}get currentEditing(){return this._currentEditing.value}set currentEditing(e){this._currentEditing.value=e}get currentEditingChanged(){return this._currentEditing.changed}}const Nl=class Nl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new hi(e));this.ad(e.clickEvent.don(r=>{var o;((o=r.pointerEvent)==null?void 0:o.button)==2&&(n.enabled=!0)}));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"position"],[i,"position"])),n.enabled=!n.position||w.equalsN3(n.position,[0,0,0]);break}this.supportEditing=!1}while(!1)}};v(Nl,"type",Nl.registerEditing("ESCesiumViewer",w.ESJEditingMode.Place,Nl));let Lg=Nl;const Ol=class Ol extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new di(e));n.rotation=[90,0,0],this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(i instanceof w.ES3DTileset){w.registerCreatedEventUpdate(this,i,()=>{const r=e.getEngineObject(i);r&&(this.ad(l.bind([n,"position"],[r.czm3DTiles,"position"])),this.ad(l.bind([n,"selfRotation"],[i,"rotation"])))});break}if(Reflect.has(i,"position")&&Reflect.has(i,"rotation")){this.ad(l.bind([n,"position"],[i,"position"])),this.ad(l.bind([n,"selfRotation"],[i,"rotation"]));break}this.supportEditing=!1}while(!1)}};v(Ol,"type",Ol.registerEditing("ESCesiumViewer",w.ESJEditingMode.Rotation,Ol));let Ng=Ol;const Vl=class Vl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new nn(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"position")&&Reflect.has(i,"scale")){this.ad(l.bind([n,"position"],[i,"position"])),this.ad(l.bind([n,"scale"],[i,"scale"]));break}this.supportEditing=!1}while(!1)}};v(Vl,"type",Vl.registerEditing("ESCesiumViewer",w.ESJEditingMode.Scale,Vl));let Og=Vl;const Ul=class Ul extends Ct{constructor(i,e){super(Array.isArray(i)?i[0]:i,e,!0);const n=this.currentEditing=this.ad(new tn(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Array.isArray(i)){const r=[];for(let o=0;o<i.length;o++){const s=i[o];Reflect.has(s,"position")?r.push(s.position):s.points&&r.push(...s.points)}n.position=w.getMinMaxCorner(r).center,this.ad(n.positionChanged.disposableOn((o,s)=>{if(!(!o||!s)){var a=Mt({originPosition:s},[o])[0][0];i.forEach(c=>{if(Reflect.has(c,"position")){const h=Mt({originPosition:s},[c.position])[0][0];c.position=fn({originPosition:s},[[h[0]+a[0],h[1]+a[1],h[2]+a[2]]])[0][0]}else if(Reflect.has(c,"points")&&c.points){const h=Mt({originPosition:s},c.points)[0];c.points=fn({originPosition:s},h.map(p=>[p[0]+a[0],p[1]+a[1],p[2]+a[2]]))[0]}})}}));break}if(Reflect.has(i,"position")){this.ad(l.bind([n,"position"],[i,"position"]));break}if(i instanceof w.ES3DTileset){w.registerCreatedEventUpdate(this,i,()=>{const r=e.getEngineObject(i);this.ad(l.bind([n,"position"],[r.czm3DTiles,"position"]))});break}if(Reflect.has(i,"points")){if(i.points===void 0||i.points.length===0){this.destroy();break}n.position=w.getMinMaxCorner(i.points).center,this.ad(n.positionChanged.disposableOn((r,o)=>{if(r===void 0||o===void 0||i.points===void 0||i.points.length===0){this.destroy();return}var s=Mt({originPosition:o},[r])[0][0];const a=Mt({originPosition:o},i.points)[0];i.points=fn({originPosition:o},a.map(c=>[c[0]+s[0],c[1]+s[1],c[2]+s[2]]))[0]}));break}this.supportEditing=!1}while(!1)}};v(Ul,"type",Ul.registerEditing("ESCesiumViewer",w.ESJEditingMode.Translation,Ul));let Ah=Ul;const Wl=class Wl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new Br(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"startPosition"],[i,"position"])),this.ad(it([n,"rotation"],[i,"rotation"]));do{if(Reflect.has(i,"far")){this.ad(l.bind([n,"distance"],[i,"far"]));break}if(Reflect.has(i,"radius")){this.ad(l.bind([n,"distance"],[i,"radius"]));break}if(Reflect.has(i,"distance")){this.ad(l.bind([n,"distance"],[i,"distance"]));break}const r=$e(i.position);if(d.Cartesian3.ZERO.equals(r)||!e.viewer)return;n.distance=Li(e.viewer.scene,r,100)??1}while(!1);break}if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1);n.startPosition&&!w.equalsN3(n.startPosition,[0,0,0])&&n.init(),n.enabled=!0}};v(Wl,"type",Wl.registerEditing("ESCesiumViewer",w.ESJEditingMode.DoublePointsAppend,Wl));let Vg=Wl;const Gl=class Gl extends Ct{constructor(i,e){var o;if(super(i,e,!0),!e.viewer)return;const n=this.currentEditing=this.ad(new Oo(e));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"startPosition"],[i,"position"])),this.ad(it([n,"rotation"],[i,"rotation"]));do{if(Reflect.has(i,"far")){this.ad(l.bind([n,"distance"],[i,"far"]));break}if(Reflect.has(i,"radius")){this.ad(l.bind([n,"distance"],[i,"radius"]));break}if(Reflect.has(i,"distance")){this.ad(l.bind([n,"distance"],[i,"distance"]));break}const s=$e(i.position);if(d.Cartesian3.ZERO.equals(s)||!e.viewer)return;n.distance=Li(e.viewer.scene,s,100)??1}while(!1);break}if(Reflect.has(i,"points")&&((o=i.points)==null?void 0:o.length)==2){n.moveWithFirstPosition=!1;const s=()=>n.positions=i.points??[];s(),this.ad(i.pointsChanged.don(()=>!n.enabled&&s())),this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1;return}while(!1);n.init(),n.enabled=!0;const r=this.ad(l.createNextAnimateFrameEvent(n.enabledChanged,n.startPositionChanged));this.ad(r.don(()=>{(!n.enabled||!n.startPosition||w.equalsN3(n.startPosition,[0,0,0]))&&this.destroy()}))}};v(Gl,"type",Gl.registerEditing("ESCesiumViewer",w.ESJEditingMode.DoublePointsModify,Gl));let Ug=Gl;const Hl=class Hl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new a1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Hl,"type",Hl.registerEditing("ESCesiumViewer",w.ESJEditingMode.CircularAppend,Hl));let Wg=Hl;const ql=class ql extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new c1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(ql,"type",ql.registerEditing("ESCesiumViewer",w.ESJEditingMode.CircularInsert,ql));let Gg=ql;const $l=class $l extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new s1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v($l,"type",$l.registerEditing("ESCesiumViewer",w.ESJEditingMode.LineStringAppend,$l));let Hg=$l;const Xl=class Xl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new l1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Xl,"type",Xl.registerEditing("ESCesiumViewer",w.ESJEditingMode.LineStringInsert,Xl));let qg=Xl;const Yl=class Yl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new h1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Yl,"type",Yl.registerEditing("ESCesiumViewer",w.ESJEditingMode.ScatterAppend,Yl));let $g=Yl;const Zl=class Zl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new d1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Zl,"type",Zl.registerEditing("ESCesiumViewer",w.ESJEditingMode.ScatterModify,Zl));let Xg=Zl;const Ql=class Ql extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new jr(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Ql,"type",Ql.registerEditing("ESCesiumViewer",w.ESJEditingMode.VisibilityAppend,Ql));let Yg=Ql;const Kl=class Kl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new es(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Kl,"type",Kl.registerEditing("ESCesiumViewer",w.ESJEditingMode.VisibilityModify,Kl));let Zg=Kl;const Jl=class Jl extends Ct{constructor(i,e){if(super(i,e,!0),!e.viewer)return;const n=this.currentEditing=this.ad(new u1(e));do{if(Reflect.has(i,"points")){const o=Reflect.has(i,"extrudedHeight"),s=Reflect.has(i,"height"),a=Reflect.has(i,"perPositionHeight")?i.perPositionHeight:!o,c=i instanceof w.ESClassification||i instanceof w.ESPolygonFence;let h=w.getMinMaxCorner(i.points).center,p=[...h],u=c?i.points[0][2]:0;a?o?p[2]=i.extrudedHeight:p[2]=i.height+u:(s&&(h[2]=i.height),o&&(p[2]=i.extrudedHeight)),n.startPosition=h,n.distance=p[2]-h[2],n.moveWithFirstPosition=!1;let f=[...h];this.ad(n.positionsChanged.don(()=>{n.positions.length===2&&(a?(i.points=i.points.map(g=>[g[0],g[1],g[2]+n.positions[0][2]-f[2]]),o?i.extrudedHeight=n.positions[1][2]:s&&(i.height=n.positions[1][2]-(c?n.positions[0][2]:0))):(s&&(i.height=n.positions[0][2]),o&&(i.extrudedHeight=n.positions[1][2])),f=[...n.positions[0]])}));break}this.supportEditing=!1;return}while(!1);n.init(),n.enabled=!0;const r=this.ad(l.createNextAnimateFrameEvent(n.enabledChanged,n.startPositionChanged));this.ad(r.don(()=>{(!n.enabled||!n.startPosition||w.equalsN3(n.startPosition,[0,0,0]))&&this.destroy()}))}};v(Jl,"type",Jl.registerEditing("ESCesiumViewer",w.ESJEditingMode.HeightModify,Jl));let Qg=Jl;function p1(){const t=l.createProcessingFromAsyncFunc(async(i,e,n,r,o=!0)=>{const s=Array.isArray(r)?[...r]:[r],a=n.editingID;e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"start",add:{modes:s}});const c=()=>{e.notSupportEditingCount=0,e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"end",add:{modes:s}}),t.isRunning&&t.cancel()};i.disposer.ad(c),i.disposer.ad(n.toDestroyEvent.don(c));const h=u=>{u.code=="Escape"&&c()};document.body.addEventListener("keydown",h),i.disposer.ad(()=>document.body.removeEventListener("keydown",h));let p=0;do{const u=s[p%s.length],f=await l.step(i,async g=>{const m=g.disposer,y=w.EngineObject.contextEditing.getEngineObjConstructor(u,e.typeName);if(!y||!n.supportEditingModes().includes(u))return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount++,!1;const S=new y(n,e);if(m.ad(()=>{!S.isDestroyed()&&S.destroy()}),S.supportEditing)e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount=0;else return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount++,!1;return await g.promise(new Promise(C=>{if(S.isDestroyed()&&C(!1),m.ad(S.toDestroyEvent.don(()=>{console.log(`编辑模式${u}结束`),C(!1)})),o){const E=M=>{M.code=="Space"&&(console.log(`编辑模式${u}结束`),C(!1))};document.body.addEventListener("keydown",E),m.ad(()=>document.body.removeEventListener("keydown",E)),m.ad(e.dblclickEvent.don(()=>C(!0)))}}))});if(o&&f||!o&&p==s.length-1||e.notSupportEditingCount==s.length)break;p++}while(!0)});return t}function f1(){const t=l.createProcessingFromAsyncFunc(async(i,e,n,r)=>{e.editingEvent.emit({objectIDs:n.map(c=>c.parentID??c.id),editingID:r,type:"start"});const o=()=>{e.editingEvent.emit({objectIDs:n.map(c=>c.parentID??c.id),editingID:r,type:"end"}),t.isRunning&&t.cancel()};i.disposer.ad(o);const s=c=>{c.code=="Escape"&&o()};document.body.addEventListener("keydown",s),i.disposer.ad(()=>document.body.removeEventListener("keydown",s));const a=new Ah(n,e);i.disposer.ad(()=>{!a.isDestroyed()&&a.destroy()}),await i.promise(new Promise(c=>{a.isDestroyed()&&c(),i.disposer.ad(a.toDestroyEvent.don(()=>{console.log("移动结束"),c()})),i.disposer.ad(e.dblclickEvent.don(()=>c()))}))});return t}R.copyright=void 0;try{const t="earthsdk3-cesium",i="3.3.0-beta.3",e="2025-07-15T03:45:59.000Z",n="北京西部世界科技有限公司",r="地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",o="34ba4ad6d65bfee5f2bf36300710c86cb8fb312d",a=((Date.now()-1752551159e3)/36e5).toFixed(1),c=`%c🌏 ${t}%c ${i}.${o.slice(0,8)}.${e} (距今${a}个小时)
2294
+ `,uniformMap:{u_color:[1,1,0,1]},name:"CzmCustomPrimitive_47fd",attributes:{position:{typedArray:{type:"Float32Array",array:[0,0,0,0,0,1]},componentsPerAttribute:3}}},Fe,t)}class qx extends l.HasOwner{constructor(i){super(i);const{czmViewer:e}=this.owner;let n;this.dispose(()=>this.owner.hoveredPlaneType="none");const r=this._createRotatorMoveProcessing();this.dispose(e.pointerMoveEvent.disposableOn(o=>{const s=n=this._getStartInfo(o.pointerEvent);s&&(this.owner.hoveredPlaneType=s.currentPlaneType)})),this.dispose(e.pointerDownEvent.disposableOn(o=>{n&&n.currentPlaneType!=="none"&&(r.restart(void 0,e,n),n=void 0)})),this.dispose(e.dblclickEvent.disposableOn(o=>{do{const s=this._getStartInfo(o.pointerEvent);if(!s||s.currentPlaneType==="none")break;const{currentPlaneType:a}=s,c=[...this.owner.selfRotation];c[di.rotationNum[a]]=0,this.owner.selfRotation=c;return}while(!1);this.owner.enabled=!1}))}_createRotatorMoveProcessing(){return this.ad(l.createProcessingFromAsyncFunc(async(i,e,n)=>{const r=this.owner.circles[n.currentPlaneType];e.incrementDisabledInputStack(),i.disposer.dispose(()=>e.decrementDisabledInputStack()),i.disposer.dispose(e.pointerMoveEvent.don(o=>{if(n&&o.pointerEvent){const{offsetX:s,offsetY:a}=o.pointerEvent,c=[s,a],{currentPlaneType:h}=n;if(h==="none")return;const p=this.owner.getPlane(h);if(!n.currentV)return;const u=p.pick(c);if(!u||!this.owner.cartesian)return;const f=d.Cartesian3.subtract(n.currentV,this.owner.cartesian,new d.Cartesian3);d.Cartesian3.normalize(f,f);const g=d.Cartesian3.subtract(u,this.owner.cartesian,new d.Cartesian3);if(d.Cartesian3.normalize(g,g),!p.normal||!p.origin)return;const m=zg(f,g,p.normal),y=zg(p.origin,f,p.normal),S=zg(p.origin,g,p.normal);{const _=[...this.owner.selfRotation];_[di.rotationNum[h]]=n.startRotation+m,this.owner.selfRotation=_,r.circleStartRotation=y,r.circleEndRotation=S}}})),this.owner.movingPlaneType=n.currentPlaneType,i.disposer.dispose(()=>{this.owner.movingPlaneType="none"}),i.disposer.dispose(()=>{r.circleStartRotation=0,r.circleEndRotation=0}),await l.step(i,o=>new Promise((s,a)=>{o.disposer.dispose(a),o.disposer.dispose(e.pointerUpEvent.don(()=>{s()})),o.disposer.dispose(e.pointerOutEvent.don(()=>{s()}))}))}))}_pickPlane(i,e,n,r,o){const s=this.owner.cartesian;if(!s)return;const{selfRotation:a}=this.owner,c=this.owner.getPlane(n).pick(r);if(!c)return;const h=d.Cartesian3.distance(s,c),p=o/4,u=p*3/128;if(!(h>=p-u&&h<=p+u))return;const g=d.Cartesian3.distance(e.camera.positionWC,c);i.currentD2c<=g||(i.currentPlaneType=n,i.currentD2c=g,i.currentV=c,i.startRotation=a[di.rotationNum[n]])}_getStartInfo(i){var p;const{czmViewer:e}=this.owner,n=(p=e.viewer)==null?void 0:p.scene;if(!this.owner.position||!this.owner.cartesian)return;const r=Li(n,this.owner.cartesian,this.owner.pixelSize);if(!r)return;const{offsetX:o,offsetY:s}=i,a=[o,s],c=i.pointerId,h={currentPlaneType:"none",currentD2c:Number.POSITIVE_INFINITY,currentV:void 0,startRotation:0,pointerId:c};return this._pickPlane(h,n,"heading",a,r),this._pickPlane(h,n,"pitch",a,r),this._pickPlane(h,n,"roll",a,r),h}}function zg(t,i,e){const n=d.Cartesian3.cross(i,t,new d.Cartesian3);if(n.equals(d.Cartesian3.ZERO))return 0;d.Cartesian3.normalize(n,n);const r=d.Cartesian3.dot(n,e);let o=Math.acos(d.Cartesian3.dot(t,i))*180/Math.PI;return o=r>0?o:-o,o}const $o=class $o extends Ht{constructor(e){super();v(this,"_hoveredPlaneType",this.disposeVar(l.react("none")));v(this,"_movingPlaneType",this.disposeVar(l.react("none")));v(this,"_circles");v(this,"_czmCameraModel");v(this,"_cartesian");v(this,"_planes",{heading:this.disposeVar(new Vx(this)),pitch:this.disposeVar(new Ux(this)),roll:this.disposeVar(new Wx(this))});v(this,"_rotatorRunningResetting");this._czmViewer=e;const n=this._czmViewer;if(this._rotatorRunningResetting=this.disposeVar(new l.ObjResettingWithEvent(this.enabledChanged,()=>{if(this.enabled)return new qx(this)})),this._circles={heading:this._createRotatorCircle(n,"heading"),pitch:this._createRotatorCircle(n,"pitch"),roll:this._createRotatorCircle(n,"roll")},!!n.viewer){{const o=()=>{this._cartesian=this.position&&$e(this.position)||void 0};o(),this.dispose(this.positionChanged.disposableOn(o))}this._createCameraModel(n)}}get hoveredPlaneType(){return this._hoveredPlaneType.value}set hoveredPlaneType(e){this._hoveredPlaneType.value=e}get hoveredPlaneTypeChanged(){return this._hoveredPlaneType.changed}get movingPlaneType(){return this._movingPlaneType.value}set movingPlaneType(e){this._movingPlaneType.value=e}get movingPlaneTypeChanged(){return this._movingPlaneType.changed}get circles(){return this._circles}get czmCameraModel(){return this._czmCameraModel}get cartesian(){return this._cartesian}get czmViewer(){return this._czmViewer}getPlane(e){return this._planes[e]}get rotatorRunningResetting(){return this._rotatorRunningResetting}_createCameraModel(e){this._czmCameraModel=new ct(e),this._czmCameraModel.url="${earthsdk3-assets-script-dir}/assets/glb/camera1/camera1.gltf",this._czmCameraModel.localRotation=[90,0,0],this._czmCameraModel.allowPicking=!1,this._czmCameraModel.opaquePass="OVERLAY",this.dispose(l.track([this._czmCameraModel,"pixelSize"],[this,"pixelSize"],n=>n*.1)),this.dispose(l.track([this._czmCameraModel,"position"],[this,"position"])),this.dispose(l.track([this._czmCameraModel,"rotation"],[this,"rotation"]));{const n=()=>{const r=ke({rotation:this.selfRotation});if(!r)throw new Error("!rm");this._czmCameraModel&&(this._czmCameraModel.localModelMatrix=d.Matrix4.toArray(r))};n(),this.dispose(this.selfRotationChanged.disposableOn(n))}{const n=()=>{this.circles.heading.show=this.enabled,this.circles.pitch.show=this.enabled,this.circles.roll.show=this.enabled,this._czmCameraModel&&(this._czmCameraModel.show=this.enabled&&this.showHelper)};n(),this.dispose(this.enabledChanged.disposableOn(n)),this.dispose(this.showHelperChanged.disposableOn(n))}}_createRotatorCircle(e,n){const r=this.ad(new Jr(e));this.dispose(l.track([r,"position"],[this,"position"])),this.dispose(l.track([r,"pixelSize"],[this,"pixelSize"])),this.dispose(l.track([r,"debug"],[this,"debug"])),this.dispose(l.track([r,"rotation"],[this,"rotation"]));{const o=()=>{r.selfRotation=$o.rotationFuncs[n](this.selfRotation),r.circleRotation=this.selfRotation[$o.rotationNum[n]]};o(),this.dispose(this.selfRotationChanged.disposableOn(o))}{const o=()=>{const s=this.movingPlaneType===n,a=this.hoveredPlaneType===n,h=[0,0,0,s||a?1:.8];h[$o.rotationNum[n]]=1,r.color=h};o(),this.dispose(this.movingPlaneTypeChanged.disposableOn(o)),this.dispose(this.hoveredPlaneTypeChanged.disposableOn(o))}return r}};v($o,"rotationNum",{heading:0,pitch:1,roll:2}),v($o,"rotationFuncs",{heading:([e,n,r])=>[0,0,0],pitch:([e,n,r])=>[e,0,-90],roll:([e,n,r])=>[e,n+90,0]});let di=$o;(t=>{t.createDefaultProps=()=>({...Ht.createDefaultProps(),rotation:l.reactArray([0,0,0]),selfRotation:l.reactArray([0,0,0]),pixelSize:300,showHelper:!1,debug:!1})})(di||(di={})),l.extendClassProps(di.prototype,di.createDefaultProps);const Xo=class Xo extends l.Destroyable{get startPosition(){return this.positions&&this.positions[0]}set startPosition(i){this.positions=[i??Xo.defaults.positions[0],this.stopPosition??Xo.defaults.positions[1]]}get startPositionChanged(){return this.positionsChanged}get stopPosition(){return this.positions&&this.positions[1]}set stopPosition(i){this.positions=[this.startPosition??Xo.defaults.positions[0],i??Xo.defaults.positions[1]]}get stopPositionChanged(){return this.positionsChanged}constructor(i,e){if(super(),!i.viewer)return;const r=this.ad(new Ie(i,e));r.arcType="RHUMB";const o=this.ad(new Kt(i,e));this.ad(l.track([r,"allowPicking"],[this,"allowPicking"])),this.ad(l.track([o,"allowPicking"],[this,"allowPicking"]));{const s=()=>{r.show=o.show=this.show};s(),this.ad(this.showChanged.don(s))}{const s=()=>{r.width=this.width/2,o.pixelSize=this.width};s(),this.ad(this.widthChanged.don(s))}{const s=()=>{r.color=o.color=this.color};s(),this.ad(this.colorChanged.don(s))}{const s=()=>{r.positions=this.positions,o.position=this.stopPosition};s(),this.dispose(this.startPositionChanged.disposableOn(s)),this.dispose(this.stopPositionChanged.disposableOn(s))}}};v(Xo,"defaults",{positions:[[0,0,0],[0,0,1e6]]});let No=Xo;(t=>{t.createDefaultProps=()=>({show:!0,allowPicking:!1,positions:l.reactPositions(t.defaults.positions),width:10,color:l.reactArray([1,0,0,1])})})(No||(No={})),l.extendClassProps(No.prototype,No.createDefaultProps);class nn extends Ht{constructor(e){super();v(this,"_lastPosition");v(this,"_opInfo",{step:this.ad(l.react(!1)),moved:this.ad(l.react(!1)),constraintMode:this.disposeVar(l.react("none")),originPosition:this.disposeVar(l.reactArray([0,0,0])),originHeading:this.disposeVar(l.react(0)),originDimensions:this.disposeVar(l.reactArray([1,1,1])),draggingStartPosition:this.disposeVar(l.reactArray([0,0,0])),movingPosition:this.disposeVar(l.reactArray([0,0,0])),targetPosition:this.disposeVar(l.reactArray([0,0,0])),targetHeading:this.disposeVar(l.react(0))});v(this,"_scaleAxis");v(this,"_pickingXYProcessing",e=>this.disposeVar(new l.Processing((n,r,o)=>{const s=[0,0,0],a=new d.Cartographic;return e.pointerMoveEvent.disposableOn(c=>{if(!c.pointerEvent||!e.viewer)return;const h=ni(l.getDomEventCurrentTargetPos(c.pointerEvent));if(!Ko(e.viewer.scene,h,this._opInfo.originPosition.value[2],a))return;Zo(a,s),this._opInfo.constraintMode.value==="x"?no(this._opInfo.originPosition.value,this._opInfo.originHeading.value,s,s):this._opInfo.constraintMode.value==="y"?no(this._opInfo.originPosition.value,this._opInfo.originHeading.value+90,s,s):this._opInfo.constraintMode.value==="xy"||console.warn("should not be here!"),this._opInfo.movingPosition.value=s,this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const p=[0,0,0];w.geoRhumbDestination(s,o,r,p),this._opInfo.targetPosition.value=p;let u=this.scale[0],f=this.scale[1];const g=w.geoDistance(p,this._opInfo.originPosition.value)-w.geoDistance(this._lastPosition,this._opInfo.originPosition.value);this._lastPosition=[...p];const m=this._opInfo.originDimensions.value[0]/100;g!=0&&this._opInfo.constraintMode.value==="y"&&(g>0?u+=m:u-=m),g!=0&&this._opInfo.constraintMode.value==="x"&&(g>0?f+=m:f-=m),u<=0&&(u+=m),f<=0&&(f+=m),this.scale=[u??1,f??1,this.scale[2]??1]})})));v(this,"_pickingZProcessing",e=>this.disposeVar(new l.Processing(()=>{const n=new d.Cartesian3,r=[0,0,0];return e.pointerMoveEvent.disposableOn(o=>{if(!o.pointerEvent||!e.viewer)return;const s=ni(l.getDomEventCurrentTargetPos(o.pointerEvent));if(!ic(e.viewer.scene,$e(this._opInfo.originPosition.value),s,n))return;this._lastPosition||(this._lastPosition=[...this._opInfo.draggingStartPosition.value]);const a=this._opInfo.originPosition.value[2]-this._opInfo.draggingStartPosition.value[2];if(ce(n,r)){this._opInfo.movingPosition.value=r;const c=this._opInfo.originPosition.value;this._opInfo.targetPosition.value=[c[0],c[1],r[2]+a];let h=this.scale[2];const p=r[2]-this._lastPosition[2];this._lastPosition=[...r];const u=this._opInfo.originDimensions.value[0]/100;p!=0&&(p>0?h+=u:h-=u),h<=0&&(h+=u),this.scale=[this.scale[0]??1,this.scale[1]??1,h??1]}})})));const n=e.viewer;if(!n)return;const{scene:r}=n;this.ad(new ed(e,this.positionReact,this._opInfo.originDimensions,this.axisPixelSize)),this.ad(e.dblclickEvent.don(()=>{this.enabled=!1})),this._scaleAxis={zAxis:this._createScaleAxis(e,"zAxis"),yAxis:this._createScaleAxis(e,"yAxis"),xAxis:this._createScaleAxis(e,"xAxis")};{const h=()=>{if(!this._scaleAxis)return;const{zAxis:p,yAxis:u,xAxis:f}=this._scaleAxis,g=this._opInfo.constraintMode.value,m=this._opInfo.step;p.color=[0,0,1,.99],u.color=[0,1,0,.99],f.color=[1,0,0,.99],g==="x"?f.color=m?[1,1,0,.8]:[1,1,0,.99]:g==="y"?u.color=m?[1,1,0,.8]:[1,1,0,.99]:g==="z"&&(p.color=m?[1,1,0,.8]:[1,1,0,.99])};h(),this.dispose(this._opInfo.constraintMode.changed.disposableOn(h)),this.dispose(this._opInfo.step.changed.disposableOn(h))}{const h=()=>{if(!this._scaleAxis)return;const{position:u=nn.defaults.position}=this,{zAxis:f,yAxis:g,xAxis:m}=this._scaleAxis;f.startPosition=g.startPosition=m.startPosition=u;const[y,S,_]=u;f.stopPosition=[y,S,_+this._opInfo.originDimensions.value[2]];const C=w.geoRhumbDestination(u,this._opInfo.originDimensions.value[0],90);C&&(m.stopPosition=C);const E=w.geoRhumbDestination(u,this._opInfo.originDimensions.value[1],0);E&&(g.stopPosition=E)};h();const p=this.ad(l.createNextAnimateFrameEvent(this.positionChanged,this._opInfo.originDimensions.changed));this.ad(p.don(h))}{const h=()=>{if(this._opInfo.constraintMode.value==="none"){this._opInfo.moved.value=!1;return}if(this._opInfo.originHeading.value!==this._opInfo.targetHeading.value){this._opInfo.moved.value=!0;return}if(!this._opInfo.originPosition.value.every((p,u)=>p===this._opInfo.targetPosition.value[u])){this._opInfo.moved.value=!0;return}};h(),this.dispose(this._opInfo.originHeading.changed.disposableOn(h)),this.dispose(this._opInfo.originPosition.changed.disposableOn(h)),this.dispose(this._opInfo.targetHeading.changed.disposableOn(h)),this.dispose(this._opInfo.targetPosition.changed.disposableOn(h))}const o=this._pickingXYProcessing(e),s=this._pickingZProcessing(e),a=this.disposeVar(l.createProcessingFromAsyncFunc(async h=>{do this._opInfo.step.value=!0,this._opInfo.constraintMode.value="none",h.disposer.dispose(()=>{this._opInfo.constraintMode.value="none"}),await l.step(h,async p=>{const u=()=>{const m=[...this.position??nn.defaults.position];e.editingHeightOffset&&(m[2]-=e.editingHeightOffset),this._opInfo.targetPosition.value=this._opInfo.originPosition.value=m};p.disposer.dispose((u(),this.positionChanged.disposableOn(u)));const f={constraintMode:"none",startDragPos:[0,0,0]},g=m=>{if(!this.position)return;const y={position:this.position,dimensions:this._opInfo.originDimensions.value,heading:0};Gh(m,r,y,this.axisSnapPixelSize,f),this._opInfo.constraintMode.value=f.constraintMode,this._opInfo.movingPosition.value=this._opInfo.draggingStartPosition.value=f.startDragPos};p.disposer.dispose(e.pointerMoveEvent.disposableOn(m=>{m.pointerEvent&&g(m.pointerEvent)})),await l.step(p,m=>new Promise((y,S)=>{m.disposer.dispose(S),m.disposer.dispose(e.pointerDownEvent.don(_=>{_.pointerEvent&&g(_.pointerEvent),_.pointerEvent&&_.pointerEvent.button===0&&f.constraintMode!=="none"&&y()}))}))}),this._opInfo.step.value=!1,await l.step(h,async p=>{if(e.incrementDisabledInputStack(),p.disposer.dispose(()=>e.decrementDisabledInputStack()),["x","y"].includes(this._opInfo.constraintMode.value)){const u=w.geoRhumbHeading(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value),f=w.geoRhumbDistance(this._opInfo.draggingStartPosition.value,this._opInfo.originPosition.value);o.restart(void 0,u,f),p.disposer.dispose(()=>o.cancel())}else this._opInfo.constraintMode.value==="z"&&(s.restart(),p.disposer.dispose(()=>s.cancel()));await l.step(p,u=>new Promise((f,g)=>{u.disposer.dispose(g),u.disposer.dispose(e.pointerUpEvent.don(()=>{f()})),u.disposer.dispose(e.pointerOutEvent.don(()=>{f()}))})),this._lastPosition=void 0});while(!0)})),c=()=>{this.enabled?a.restart():a.isRunning&&a.cancel()};c(),this.dispose(this.enabledChanged.disposableOn(c))}get scaleAxis(){return this._scaleAxis}_createScaleAxis(e,n){const r=this.ad(new No(e));return r.width=10,this.ad(l.track([r,"show"],[this,"enabled"])),r}}(t=>{t.createDefaultProps=()=>({...Ht.createDefaultProps(),scale:l.reactArray([1,1,1]),axisPixelSize:100,axisSnapPixelSize:5})})(nn||(nn={})),l.extendClassProps(nn.prototype,nn.createDefaultProps);const to=class to extends At{constructor(e){super();v(this,"_editingPoints",this.disposeVar(new l.ObservableArray));v(this,"_cancelEvent",this.disposeVar(new l.Event));v(this,"_currentProcess");v(this,"_menuPoiEnabled",this.disposeVar(l.react(!1)));v(this,"_status",this.disposeVar(l.react("None")));v(this,"_positionsChanged",this.ad(new l.Event));v(this,"_cursorInfo");this._czmViewer=e,this.enabled=!1,this.createPolyline(e),this._createCursorInfo(e),this.dispose(()=>this.resetPositions()),this.dispose(()=>this.editingPoints.length=0),this.dispose(this.editingPoints.changedEvent.disposableOn(()=>this.positionsChanged.emit())),this.dispose(this.editingPoints.toChangeEvent.disposableOn(n=>{for(let{start:r,deleteCount:o,items:s}of n){for(const a of s)a.menuPoi.enabled=this.menuPoiEnabled??!1;for(let a=r;a<r+o;++a)this.editingPoints.get(a).destroy()}})),this.dispose(this.menuPoiEnabledChanged.disposableOn(()=>{for(let n of this.editingPoints)n.menuPoi.enabled=this.menuPoiEnabled??!1})),this.dispose(e.dblclickEvent.don(n=>{this.ad(l.nextAnimateFrame(()=>{var r;((r=n.pointerEvent)==null?void 0:r.button)===0&&this.enabled&&this.currentProcess&&this.currentProcess.cancel()}))})),this.dispose(this.enabledChanged.disposableOn(n=>{this._currentProcess&&(n?this._currentProcess.restart():this._currentProcess.isRunning&&this._currentProcess.cancel())}));{const n=()=>{this.polylineShow=this.czmViewer.editingLineShow};n(),this.ad(this.czmViewer.editingLineShowChanged.don(n))}}get editingPoints(){return this._editingPoints}get cancelEvent(){return this._cancelEvent}cancel(){this._cancelEvent.emit()}get currentProcess(){return this._currentProcess}set currentProcess(e){this._currentProcess=e}get menuPoiEnabled(){return this._menuPoiEnabled.value}set menuPoiEnabled(e){this._menuPoiEnabled.value=e}get menuPoiEnabledChanged(){return this._menuPoiEnabled.changed}get status(){return this._status.value}get statusChanged(){return this._status.changed}set status(e){this._status.value=e}getPositions(){const e=[];for(let n of this._editingPoints)n.position&&e.push([...n.position]);return e}resetPositions(e){if(this.enabled??to.defaults.enabled)return console.warn("MultiPointsEditing.resetPositions error: this.enabled === true"),!1;const n=e||[];return!(n.length===this.editingPoints.length&&n.every((r,o)=>r.every((s,a)=>{const c=this.editingPoints.get(o);return c.position&&c.position[a]===s})))}forceResetPositions(e){(this.enabled??to.defaults.enabled)&&(this.enabled=!1),this.resetPositions(e)}get positions(){return this.getPositions()}set positions(e){this.resetPositions(e)}get positionsChanged(){return this._positionsChanged}get czmViewer(){return this._czmViewer}get cursorInfo(){return this._cursorInfo}createPolyline(e){const n=this.ad(new Ie(e));this.ad(l.track([n,"color"],[this,"polylineColor"])),this.ad(l.track([n,"width"],[this,"polylineWidth"])),this.ad(l.track([n,"show"],[this,"polylineShow"])),this.ad(l.track([n,"arcType"],[this,"polylineArcType"])),this.ad(l.track([n,"loop"],[this,"loop"]));{const r=()=>{const o=[];for(const s of this.getPositions())s[2]-=e.editingHeightOffset??0,o.push(s);n.positions=o};r(),this.ad(this.positionsChanged.don(r))}}_createCursorInfo(e){const n=this._cursorInfo=this.ad(new l.CursorInfo(e.container,l.CursorFloatDiv));this.dispose(this.statusChanged.disposableOn(()=>{const r=this.status;if(n){if(!this.hideCursorInfo){n.show=!1;return}r==="Adding"?(n.text="右键/BackSpace键:删除上一个控制点;Esc键或左键双击:退出添加状态,进入修改状态",n.show=!0):r==="Modifying"||r==="Modifying_Point"?(n.text="Esc键或左键双击:退出编辑状态",n.show=!0):r==="None"&&(n.text="",n.show=!1)}}))}};v(to,"baseImageUrl","${earthsdk3-assets-script-dir}/assets/img/"),v(to,"defaults",{...At.defaults,debug:!1,polylineShow:!1,polylineWidth:1,polylineColor:[1,1,1,1],polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,loop:!1,firstControlPointImageUrl:to.baseImageUrl+"point-green.png",otherControlPointImageUrl:to.baseImageUrl+"point-yellow.png"});let ei=to;(t=>{t.createDefaultProps=()=>({...At.createDefaultProps(),loop:!1,debug:!1,polylineShow:!0,polylineWidth:1,polylineColor:l.reactArray([1,1,1,1]),polylineArcType:"GEODESIC",maxPointsNum:Number.MAX_SAFE_INTEGER,firstControlPointImageUrl:t.baseImageUrl+"point-green.png",otherControlPointImageUrl:t.baseImageUrl+"point-yellow.png",hideCursorInfo:!1,middlePointShow:!0})})(ei||(ei={})),l.extendClassProps(ei.prototype,ei.createDefaultProps);let $x=0;class o1 extends l.Destroyable{constructor(e,n){super();v(this,"_position",this.disposeVar(l.reactArrayWithUndefined(void 0)));v(this,"_id",$x++);v(this,"_menuPoi");n&&(this.position=n),e.debug&&console.log(`PolylinePositionEditor creating! ${this.id}`),this.dispose(()=>{e.debug&&console.log(`PolylinePositionEditor destroying! ${this.id}`)});const r=this._menuPoi=this.ad(new ar(e.czmViewer));r.enabled=!1,this.ad(l.track([r,"show"],[e,"enabled"]));{const o=()=>{if(this.position===void 0){r.position=void 0;return}const s=[...this.position];s[2]-=e.czmViewer.editingHeightOffset??0,r.position=s,e.positionsChanged.emit()};o(),this.d(this.positionChanged.don(o))}{const o=()=>{const s=e.editingPoints.indexOf(this)+1;s!==0&&(r.title=`控制点${s}`,s===1?r.imageUri=e.firstControlPointImageUrl??ei.defaults.firstControlPointImageUrl:r.imageUri=e.otherControlPointImageUrl??ei.defaults.otherControlPointImageUrl)};o(),this.dispose(e.editingPoints.changedEvent.disposableOn(o))}}get position(){return this._position.value}set position(e){this._position.value=e}get positionChanged(){return this._position.changed}get id(){return this._id}get menuPoi(){return this._menuPoi}}class r1 extends o1{constructor(i,e){super(i,e)}}class Je extends ei{constructor(e){super(e);v(this,"_deletePreviousPointWhileAddingEvent",this.disposeVar(new l.Event));v(this,"placeEditing");if(!e.viewer)return;const n=this.placeEditing=this.ad(new hi(e));n.enabled=!1,this.currentProcess=this.disposeVar(l.createProcessingFromAsyncFunc(async r=>{r.disposer.dispose(()=>{(this.debug??Je.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1}),(this.debug??Je.defaults.debug)&&console.log("直接进入Adding状态"),this.status="Adding",await r.promise(l.step(r,async o=>{const s=o.disposer,a=s.ad(this._addingEditingProcessing());s.dispose(()=>"adding canceled!"),s.dispose(this.cancelEvent.disposableOn(()=>a.cancel())),await o.promise(new Promise(c=>{s.dispose(a.completeEvent.disposableOnce(c))}))}))})),this.dispose(e.clickEvent.don(r=>{var o;((o=r.pointerEvent)==null?void 0:o.button)===2&&this.deletePreviousPointWhileAdding()}))}deletePreviousPointWhileAdding(){this._deletePreviousPointWhileAddingEvent.emit()}resetPositions(e){if(!super.resetPositions(e))return!0;const n=e?e.map(r=>new r1(this,r)):[];return this.editingPoints.splice(0,this.editingPoints.length,...n),!0}_addingEditingProcessing(){const e=()=>{if(this.maxPointsNum!==void 0)return this.editingPoints.length>=this.maxPointsNum&&(this.debug??Je.defaults.debug)&&console.log("impl.positionEditors.length >= impl.maxPointsNum"),this.editingPoints.length>=this.maxPointsNum},n=l.createProcessingFromAsyncFunc(async r=>{let o=this.editingPoints.length;this.menuPoiEnabled=!1;do if(!await r.promise(l.step(r,async a=>{let c;!e()&&(c=a.disposer.disposeVar(new Xx(this,o)));const p=a.disposer.disposeVar(new Zx(this,o));return a.disposer.dispose(this._deletePreviousPointWhileAddingEvent.disposableOn(()=>p.do())),await a.promise(new Promise(u=>{c&&a.disposer.dispose(c.overEvent.disposableOnce(f=>{f?(o++,u(!0)):u(!1)})),a.disposer.dispose(p.overEvent.disposableOnce(f=>{f?(o--,u(!0)):u(!1)})),a.disposer.dispose(this.cancelEvent.disposableOn(()=>u(!1)))}))})))break;while(!0)});return n.start(),n}}(t=>{t.createDefaultProps=()=>({...ei.createDefaultProps()})})(Je||(Je={})),l.extendClassProps(Je.prototype,Je.createDefaultProps);class Xx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));const{placeEditing:r}=e;let o=new r1(e,void 0);e.editingPoints.splice(n,0,o);const s=()=>{(e.debug??Je.defaults.debug)&&console.log("delete currentPosEditor");const h=e.editingPoints.indexOf(o);if(h===-1)throw new Error("currentPosEditor not found");e.editingPoints.splice(h,1)};if(r.enabled??!1)throw console.error("placeEditing.enabled is true!"),new Error("placeEditing.enabled is true!");this.dispose(l.track([o,"position"],[r,"position"])),r.enabled=!0;let a=!1;const c=()=>{s(),this._overEvent.emit(!1)};this.dispose(()=>{r.enabled=!1,!a&&c()}),this.dispose(r.overEvent.disposableOnce(()=>{a=!0,o.position===void 0?c():this._overEvent.emit(!0)})),(e.debug??Je.defaults.debug)&&console.log(`PointAdding creating! index(${n})`),this.dispose(()=>{(e.debug??Je.defaults.debug)&&console.log(`PointAdding destroying! index(${n})`)})}get overEvent(){return this._overEvent}}function Yx(t,i){const e=t.editingPoints,n=i-1;return n<0?(console.warn("previousIndex < 0, cannot delete the point!"),!1):(e.splice(n,1),!0)}class Zx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"_doEvent",this.disposeVar(new l.Event));this.dispose(this._doEvent.disposableOn(()=>this._overEvent.emit(Yx(e,n)))),(e.debug??Je.defaults.debug)&&console.log(`PreviousPointDeleting creating! currentIndex(${n})`),this.dispose(()=>{(e.debug??Je.defaults.debug)&&console.log(`PreviousPointDeleting destroying! currentIndex(${n})`)})}get overEvent(){return this._overEvent}do(){return this._doEvent.emit()}}class s1 extends Je{constructor(i){super(i),this.loop=!1}}class a1 extends Je{constructor(i){super(i),this.loop=!0}}class Eh extends o1{constructor(i,e){super(i,e);{const{menuPoi:n}=this;n.commands=[["add","增加控制点","",be.baseImageUrl+"add.png"],["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]],n.clickCommandName="modify",n.rightClickCommandName="delete",this.dispose(n.commandEvent.disposableOn(r=>{i.menuPoiCommand(this,r)})),this.dispose(n.dbclickEvent.disposableOn(()=>{i.menuPoiCommand(this,"dbClick")}))}if(i.middlePointShow){const n=this.ad(new gi(i.czmViewer));{n.imageUri=i.firstControlPointImageUrl??be.defaults.firstControlPointImageUrl,n.tooltip="点击增加一个控制点",n.bgColor=[0,0,0,.6],n.fgColor=[1,1,1,1],n.size=[8,8],n.originRatioAndOffset=[.5,.5,0,0];{const r=()=>{if(!(i.enabled??be.defaults.enabled)){n.enabled=!1,n.show=!1;return}do{const s=i.editingPoints.indexOf(this);if(s===-1)break;const a=i.editingPoints.length;if(a===0){console.error("impl.positionEditors.length === 0!");break}if(!(i.loop??be.defaults.loop)&&s+1>=a)break;const h=this.position;if(!h)break;let p=(s+1)%a;const f=i.editingPoints.get(p).position;if(!f)break;const g=Xh(h,f);if(!g)break;g[2]-=i.czmViewer.editingHeightOffset??0,n.position=g;const m=i.editingPoints.length<(i.maxPointsNum??be.defaults.maxPointsNum);n.enabled=m,n.show=m;return}while(!1);n.enabled=!1,n.show=!1};r(),this.dispose(i.positionsChanged.disposableOn(r)),this.dispose(i.loopChanged.disposableOn(r)),this.dispose(i.enabledChanged.disposableOn(r))}this.dispose(n.clickEvent.disposableOn(r=>{if(r.button!==0||i.editingPoints.length>=(i.maxPointsNum??be.defaults.maxPointsNum))return;const o=i.editingPoints.indexOf(this);if(o===-1)return;const s=n.position?[...n.position]:void 0;s&&(s[2]+=i.czmViewer.editingHeightOffset??0);let a=new Eh(i,s);i.editingPoints.splice(o+1,0,a),i.modify(a)}))}}}}class be extends ei{constructor(e){super(e);v(this,"_menuPoiCommand",this.disposeVar(new l.Event));v(this,"_forceModifyPosEditorEvent",this.disposeVar(new l.Event));v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"translationEditing");{const r=this.ad(l.createNextAnimateFrameEvent(this.moveWithFirstPositionChanged,this.editingPoints.changedEvent));this.ad(new l.ObjResettingWithEvent(r,()=>{if(!(!this.moveWithFirstPosition||this.editingPoints.length<=1))return new Qx(this.editingPoints.get(0),this)}))}const n=this.translationEditing=this.disposeVar(new tn(e));n.enabled=!1,this.currentProcess=this.disposeVar(l.createProcessingFromAsyncFunc(async r=>{r.disposer.dispose(()=>{(this.debug??be.defaults.debug)&&console.log("---editing canceled~~~"),this.status="None",this.enabled=!1});let o=-1;do if((this.debug??be.defaults.debug)&&console.log("进入Modifying修改状态"),this.status="Modifying",o=await r.promise(l.step(r,async s=>{const a=s.disposer,c=a.ad(new Kx(this));return a.dispose(()=>"modifying canceled!"),this.editingPoints.length>0&&c.modify(this.editingPoints.get(o===-1||o>=this.editingPoints.length?0:o)),a.dispose(this.cancelEvent.disposableOn(()=>c.cancel())),a.dispose(this._forceModifyPosEditorEvent.disposableOn(p=>c.modify(p))),await s.promise(new Promise(p=>{a.dispose(c.overEvent.disposableOnce(u=>{p(u)}))}))})),o===-1){(this.debug??be.defaults.debug)&&console.log("退出编辑状态");break}else{if(this.editingPoints.length>=(this.maxPointsNum??be.defaults.maxPointsNum))return;if(this.editingPoints.length===0){console.error("impl.positionEditors.length === 0!");return}this.loop??be.defaults.loop;const a=this.editingPoints.get(o-1).position;if(!a)return;let c=o%this.editingPoints.length;const p=this.editingPoints.get(c).position;if(!p)return;const u=Xh(a,p);if(!u)return;u&&(u[2]+=this.czmViewer.editingHeightOffset??0);let f=new Eh(this,u);this.editingPoints.splice(o,0,f)}while(!0);this.status="None",this.enabled=!1}))}menuPoiCommand(e,n){this._menuPoiCommand.emit(e,n)}modify(e){this._forceModifyPosEditorEvent.emit(e)}resetPositions(e){if(!super.resetPositions(e))return!0;const n=e?e.map(r=>new Eh(this,r)):[];return this.editingPoints.splice(0,this.editingPoints.length,...n),!0}get overEvent(){return this._overEvent}}(t=>{t.createDefaultProps=()=>({...ei.createDefaultProps(),moveWithFirstPosition:!1})})(be||(be={})),l.extendClassProps(be.prototype,be.createDefaultProps);class Qx extends l.Destroyable{constructor(i,e){super(),this._firstPositionEditor=i,this.multiPointsModifyEditing=e,this._firstPositionEditor.positionChanged.disposableOn((n,r)=>{if(n===void 0||r===void 0)return;var o=[n[0]-r[0],n[1]-r[1],n[2]-r[2]];const s=this.multiPointsModifyEditing.editingPoints.length;for(let a=1;a<s;a++){const c=this.multiPointsModifyEditing.editingPoints.get(a),h=c.position;h!==void 0&&(c.position=[h[0]+o[0],h[1]+o[1],h[2]+o[2]])}})}}class Kx extends l.Destroyable{constructor(e){super();v(this,"_overEvent",this.disposeVar(new l.Event));v(this,"_cancelEvent",this.disposeVar(new l.Event));v(this,"_forceModifyPosEditorEvent",this.disposeVar(new l.Event));e.menuPoiEnabled=!0,this.dispose(()=>e.menuPoiEnabled=!1);let n;const r=()=>{n==null||n.destroy(),n=void 0,e.status="Modifying"};this.dispose(r);const o=s=>{r(),e.status="Modifying_Point",n=new Jx(e,s),n.dispose(n.overEvent.disposableOn(()=>{r()}))};this.dispose(this._forceModifyPosEditorEvent.disposableOn(o)),this.dispose(e._menuPoiCommand.disposableOn((s,a)=>{if(a==="delete"){if(e.editingPoints.length<=2)return;const c=e.editingPoints.indexOf(s);if(c===-1)throw console.error("posEditor not found"),new Error("posEditor not found");e.editingPoints.splice(c,1)}else if(a==="modify")o(s);else if(a==="add"){const c=e.editingPoints.indexOf(s);if(c===-1)throw console.error("posEditor not found"),new Error("posEditor not found");this._overEvent.emit(c+1)}else a==="dbClick"?this._overEvent.emit(-1):alert(`未知的commandName(${a})`)})),this.dispose(this._cancelEvent.disposableOn(()=>{this._overEvent.emit(-1)}))}get overEvent(){return this._overEvent}cancel(){this._cancelEvent.emit()}modify(e){this._forceModifyPosEditorEvent.emit(e)}}class Jx extends l.Destroyable{constructor(e,n){super();v(this,"_overEvent",this.disposeVar(new l.Event));this._modifying=e,this._posEditor=n,this.dispose(this._posEditor.toDestroyEvent.disposableOn(()=>{this._overEvent.emit()}));const{translationEditing:r}=this._modifying;if(r.enabled=!0,r.heading=0,this.dispose(()=>{r.enabled=!1}),!this._posEditor.position)throw console.error("!this._posEditor.position"),new Error("!this._posEditor.position");r.position=this._posEditor.position,this.dispose(l.track([this._posEditor,"position"],[r,"position"])),this.dispose(r.enabledChanged.disposableOnce(o=>{o||this._overEvent.emit()}))}get overEvent(){return this._overEvent}}class l1 extends be{constructor(i){super(i),this.loop=!1}}class c1 extends be{constructor(i){super(i),this.loop=!0}}class Br extends Je{init(){const i=this.startPosition;if(!i)return;const e=this.distance,n=this.rotation,r=e*Math.cos(n[1]*Math.PI/180),o=w.geoDestination(i,r,n[0]);if(!o){this.positions=[i];return}const s=e*Math.sin(n[1]*Math.PI/180);o[2]+=s,this.positions=[i,o],this.editingPoints.length==2&&(this.editingPoints.get(0).position=i,this.editingPoints.get(1).position=o)}constructor(i){super(i),this.loop=!0,this.maxPointsNum=2;{const e=()=>{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];return}if(this.positions.length==1){this.distance=1,this.rotation=[90,0,0];return}this.startPosition=this.positions[0],this.endPosition=this.positions[1];const n=w.geoHeading(this.startPosition,this.endPosition),r=w.geoDistance(this.startPosition,this.endPosition);if(r<=0){this.rotation=[90,0,0],this.distance=1;return}const o=this.endPosition[2]-this.startPosition[2],s=Math.atan(o/r)*180/Math.PI,a=Math.sqrt(r*r+o*o);this.rotation=[n,s,0],this.distance=a};e(),this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...Je.createDefaultProps(),startPosition:l.reactArrayWithUndefined(void 0),endPosition:l.reactArrayWithUndefined(void 0),rotation:l.reactArray([90,0,0]),distance:l.react(1)})})(Br||(Br={})),l.extendClassProps(Br.prototype,Br.createDefaultProps);class Oo extends be{init(){const i=this.startPosition;if(!i)return;const e=this.distance,n=this.rotation,r=e*Math.cos(n[1]*Math.PI/180),o=w.geoDestination(i,r,n[0]);if(!o){this.positions=[i];return}const s=e*Math.sin(n[1]*Math.PI/180);o[2]+=s,this.positions=[i,o],this.editingPoints.length==2&&(this.editingPoints.get(0).position=i,this.editingPoints.get(1).position=o)}constructor(i){super(i),this.loop=!0,this.maxPointsNum=2,this.middlePointShow=!1,this.moveWithFirstPosition=!0;{const e=()=>{do{if(!this.positions||this.positions.length==0){this.distance=1,this.rotation=[90,0,0],this.startPosition=[0,0,0];break}if(this.startPosition=this.positions[0],this.positions.length==1){this.editingPoints.get(0).menuPoi.commands=[["add","增加控制点","",be.baseImageUrl+"add.png"],["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]],this.rotation=[90,0,0],this.distance=1;break}this.endPosition=this.positions[1];for(let c of this.editingPoints)c.menuPoi.commands=[["delete","删除当前控制点","",be.baseImageUrl+"delete.png"],["modify","修改当前控制点","",be.baseImageUrl+"modify.png"]];const n=w.geoHeading(this.startPosition,this.endPosition),r=w.geoDistance(this.startPosition,this.endPosition);if(Math.abs(r)<=0){this.rotation=[90,0,0],this.distance=1;return}const o=this.endPosition[2]-this.startPosition[2],s=Math.atan(o/r)*180/Math.PI,a=Math.sqrt(r*r+o*o);this.rotation=[n,s,0],this.distance=a}while(!1)};this.ad(this.positionsChanged.don(e))}}}(t=>{t.createDefaultProps=()=>({...be.createDefaultProps(),startPosition:l.reactArrayWithUndefined(void 0),endPosition:l.reactArrayWithUndefined(void 0),rotation:l.reactArray([0,0,0]),distance:l.react(0)})})(Oo||(Oo={})),l.extendClassProps(Oo.prototype,Oo.createDefaultProps);class h1 extends Je{constructor(i){super(i),this.loop=!1,this.polylineShow=!1}}class d1 extends be{constructor(i){super(i),this.loop=!1,this.polylineShow=!1,this.middlePointShow=!1}}class jr extends Je{constructor(i){super(i),i.viewer||(this.loop=!1);{const e=()=>{if(!this.positions||this.positions.length<2){this.visibilityPositions=void 0;return}const n=[...this.positions[0]];n[2]-=i.editingHeightOffset??0,this.visibilityPositions=this.positions.map(r=>(r[2]-=i.editingHeightOffset??0,[n,r]))};e(),this.ad(this.positionsChanged.don(e))}}createPolyline(i){const e=this.ad(new ri(i));e.topOrBottom="bottom",this.ad(l.track([e,"color"],[this,"polylineColor"])),this.ad(l.track([e,"width"],[this,"polylineWidth"])),this.ad(l.track([e,"show"],[this,"polylineShow"])),this.ad(l.track([e,"arcType"],[this,"polylineArcType"])),this.ad(l.track([e,"loop"],[this,"loop"])),this.ad(l.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...Je.createDefaultProps(),visibilityPositions:l.reactPositionsSet(void 0)})})(jr||(jr={})),l.extendClassProps(jr.prototype,jr.createDefaultProps);class es extends be{constructor(i){if(super(i),!!i.viewer){this.loop=!1,this.middlePointShow=!1;{const e=()=>{if(!this.positions||this.positions.length<2)return;const n=[...this.positions[0]];n[2]-=i.editingHeightOffset??0,this.visibilityPositions=this.positions.map(r=>(r[2]-=i.editingHeightOffset??0,[n,r]))};e(),this.ad(this.positionsChanged.don(e))}}}createPolyline(i){const e=this.ad(new ri(i));e.topOrBottom="bottom",this.ad(l.track([e,"color"],[this,"polylineColor"])),this.ad(l.track([e,"width"],[this,"polylineWidth"])),this.ad(l.track([e,"show"],[this,"polylineShow"])),this.ad(l.track([e,"arcType"],[this,"polylineArcType"])),this.ad(l.track([e,"loop"],[this,"loop"])),this.ad(l.track([e,"positions"],[this,"visibilityPositions"]))}}(t=>{t.createDefaultProps=()=>({...be.createDefaultProps(),visibilityPositions:l.reactPositionsSet(void 0)})})(es||(es={})),l.extendClassProps(es.prototype,es.createDefaultProps);class u1 extends Oo{constructor(i){super(i),this.firstControlPointImageUrl=this.otherControlPointImageUrl,this.translationEditing.xAxisShow=!1,this.translationEditing.yAxisShow=!1,this.translationEditing.zAxisShow=!0,this.translationEditing.showCircle=!1,this.rotation=[0,90,0]}}class Ct extends w.EngineObject{constructor(e,n,r){super(e,n,r??!0);v(this,"_supportEditing",this.disposeVar(l.react(!0)));v(this,"_currentEditing",this.disposeVar(l.react(void 0)));this.ad(this.supportEditingChanged.don(()=>{this.destroy()})),this.ad(this.toDestroyEvent.don(()=>{var o;if(this.currentEditing){if(this.currentEditing instanceof Je&&((o=this.currentEditing.currentProcess)!=null&&o.isRunning))if(this.currentEditing.currentProcess.cancel(),e!=null&&e.position){if(this.currentEditing.positions.length>1)return;e.position=this.currentEditing.positions[0]??[0,0,0],e!=null&&e.rotation&&(e.rotation=[0,0,0]),e!=null&&e.far&&(e.far=1),e!=null&&e.radius&&(e.radius=1),e!=null&&e.distance&&(e.distance=1)}else e.points=this.currentEditing.positions;this.currentEditing instanceof hi&&this.currentEditing.enabled&&(e.position=[0,0,0])}}))}get supportEditing(){return this._supportEditing.value}set supportEditing(e){this._supportEditing.value=e}get supportEditingChanged(){return this._supportEditing.changed}get currentEditing(){return this._currentEditing.value}set currentEditing(e){this._currentEditing.value=e}get currentEditingChanged(){return this._currentEditing.changed}}const Nl=class Nl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new hi(e));this.ad(e.clickEvent.don(r=>{var o;((o=r.pointerEvent)==null?void 0:o.button)==2&&(n.enabled=!0)}));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"position"],[i,"position"])),n.enabled=!n.position||w.equalsN3(n.position,[0,0,0]);break}this.supportEditing=!1}while(!1)}};v(Nl,"type",Nl.registerEditing("ESCesiumViewer",w.ESJEditingMode.Place,Nl));let Lg=Nl;const Ol=class Ol extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new di(e));n.rotation=[90,0,0],this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(i instanceof w.ES3DTileset){w.registerCreatedEventUpdate(this,i,()=>{const r=e.getEngineObject(i);r&&(this.ad(l.bind([n,"position"],[r.czm3DTiles,"position"])),this.ad(l.bind([n,"selfRotation"],[i,"rotation"])))});break}if(Reflect.has(i,"position")&&Reflect.has(i,"rotation")){this.ad(l.bind([n,"position"],[i,"position"])),this.ad(l.bind([n,"selfRotation"],[i,"rotation"]));break}this.supportEditing=!1}while(!1)}};v(Ol,"type",Ol.registerEditing("ESCesiumViewer",w.ESJEditingMode.Rotation,Ol));let Ng=Ol;const Vl=class Vl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new nn(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"position")&&Reflect.has(i,"scale")){this.ad(l.bind([n,"position"],[i,"position"])),this.ad(l.bind([n,"scale"],[i,"scale"]));break}this.supportEditing=!1}while(!1)}};v(Vl,"type",Vl.registerEditing("ESCesiumViewer",w.ESJEditingMode.Scale,Vl));let Og=Vl;const Ul=class Ul extends Ct{constructor(i,e){super(Array.isArray(i)?i[0]:i,e,!0);const n=this.currentEditing=this.ad(new tn(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Array.isArray(i)){const r=[];for(let o=0;o<i.length;o++){const s=i[o];Reflect.has(s,"position")?r.push(s.position):s.points&&r.push(...s.points)}n.position=w.getMinMaxCorner(r).center,this.ad(n.positionChanged.disposableOn((o,s)=>{if(!(!o||!s)){var a=Mt({originPosition:s},[o])[0][0];i.forEach(c=>{if(Reflect.has(c,"position")){const h=Mt({originPosition:s},[c.position])[0][0];c.position=fn({originPosition:s},[[h[0]+a[0],h[1]+a[1],h[2]+a[2]]])[0][0]}else if(Reflect.has(c,"points")&&c.points){const h=Mt({originPosition:s},c.points)[0];c.points=fn({originPosition:s},h.map(p=>[p[0]+a[0],p[1]+a[1],p[2]+a[2]]))[0]}})}}));break}if(Reflect.has(i,"position")){this.ad(l.bind([n,"position"],[i,"position"]));break}if(i instanceof w.ES3DTileset){w.registerCreatedEventUpdate(this,i,()=>{const r=e.getEngineObject(i);this.ad(l.bind([n,"position"],[r.czm3DTiles,"position"]))});break}if(Reflect.has(i,"points")){if(i.points===void 0||i.points.length===0){this.destroy();break}n.position=w.getMinMaxCorner(i.points).center,this.ad(n.positionChanged.disposableOn((r,o)=>{if(r===void 0||o===void 0||i.points===void 0||i.points.length===0){this.destroy();return}var s=Mt({originPosition:o},[r])[0][0];const a=Mt({originPosition:o},i.points)[0];i.points=fn({originPosition:o},a.map(c=>[c[0]+s[0],c[1]+s[1],c[2]+s[2]]))[0]}));break}this.supportEditing=!1}while(!1)}};v(Ul,"type",Ul.registerEditing("ESCesiumViewer",w.ESJEditingMode.Translation,Ul));let Ah=Ul;const Wl=class Wl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new Br(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"startPosition"],[i,"position"])),this.ad(it([n,"rotation"],[i,"rotation"]));do{if(Reflect.has(i,"far")){this.ad(l.bind([n,"distance"],[i,"far"]));break}if(Reflect.has(i,"radius")){this.ad(l.bind([n,"distance"],[i,"radius"]));break}if(Reflect.has(i,"distance")){this.ad(l.bind([n,"distance"],[i,"distance"]));break}const r=$e(i.position);if(d.Cartesian3.ZERO.equals(r)||!e.viewer)return;n.distance=Li(e.viewer.scene,r,100)??1}while(!1);break}if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1);n.startPosition&&!w.equalsN3(n.startPosition,[0,0,0])&&n.init(),n.enabled=!0}};v(Wl,"type",Wl.registerEditing("ESCesiumViewer",w.ESJEditingMode.DoublePointsAppend,Wl));let Vg=Wl;const Gl=class Gl extends Ct{constructor(i,e){var o;if(super(i,e,!0),!e.viewer)return;const n=this.currentEditing=this.ad(new Oo(e));do{if(Reflect.has(i,"position")){this.ad(l.bind([n,"startPosition"],[i,"position"])),this.ad(it([n,"rotation"],[i,"rotation"]));do{if(Reflect.has(i,"far")){this.ad(l.bind([n,"distance"],[i,"far"]));break}if(Reflect.has(i,"radius")){this.ad(l.bind([n,"distance"],[i,"radius"]));break}if(Reflect.has(i,"distance")){this.ad(l.bind([n,"distance"],[i,"distance"]));break}const s=$e(i.position);if(d.Cartesian3.ZERO.equals(s)||!e.viewer)return;n.distance=Li(e.viewer.scene,s,100)??1}while(!1);break}if(Reflect.has(i,"points")&&((o=i.points)==null?void 0:o.length)==2){n.moveWithFirstPosition=!1;const s=()=>n.positions=i.points??[];s(),this.ad(i.pointsChanged.don(()=>!n.enabled&&s())),this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1;return}while(!1);n.init(),n.enabled=!0;const r=this.ad(l.createNextAnimateFrameEvent(n.enabledChanged,n.startPositionChanged));this.ad(r.don(()=>{(!n.enabled||!n.startPosition||w.equalsN3(n.startPosition,[0,0,0]))&&this.destroy()}))}};v(Gl,"type",Gl.registerEditing("ESCesiumViewer",w.ESJEditingMode.DoublePointsModify,Gl));let Ug=Gl;const Hl=class Hl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new a1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Hl,"type",Hl.registerEditing("ESCesiumViewer",w.ESJEditingMode.CircularAppend,Hl));let Wg=Hl;const ql=class ql extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new c1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(ql,"type",ql.registerEditing("ESCesiumViewer",w.ESJEditingMode.CircularInsert,ql));let Gg=ql;const $l=class $l extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new s1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v($l,"type",$l.registerEditing("ESCesiumViewer",w.ESJEditingMode.LineStringAppend,$l));let Hg=$l;const Xl=class Xl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new l1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Xl,"type",Xl.registerEditing("ESCesiumViewer",w.ESJEditingMode.LineStringInsert,Xl));let qg=Xl;const Yl=class Yl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new h1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Yl,"type",Yl.registerEditing("ESCesiumViewer",w.ESJEditingMode.ScatterAppend,Yl));let $g=Yl;const Zl=class Zl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new d1(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Zl,"type",Zl.registerEditing("ESCesiumViewer",w.ESJEditingMode.ScatterModify,Zl));let Xg=Zl;const Ql=class Ql extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new jr(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Ql,"type",Ql.registerEditing("ESCesiumViewer",w.ESJEditingMode.VisibilityAppend,Ql));let Yg=Ql;const Kl=class Kl extends Ct{constructor(i,e){super(i,e,!0);const n=this.currentEditing=this.ad(new es(e));this.ad(n.enabledChanged.don(r=>{!r&&this.ad(l.nextAnimateFrame(()=>{this.destroy()}))}));do{if(Reflect.has(i,"points")){const r=()=>n.positions=i.points??[];r(),this.ad(i.pointsChanged.don(()=>!n.enabled&&r())),n.enabled=!0,this.ad(l.track([i,"points"],[n,"positions"]));break}this.supportEditing=!1}while(!1)}};v(Kl,"type",Kl.registerEditing("ESCesiumViewer",w.ESJEditingMode.VisibilityModify,Kl));let Zg=Kl;const Jl=class Jl extends Ct{constructor(i,e){if(super(i,e,!0),!e.viewer)return;const n=this.currentEditing=this.ad(new u1(e));do{if(Reflect.has(i,"points")){const o=Reflect.has(i,"extrudedHeight"),s=Reflect.has(i,"height"),a=Reflect.has(i,"perPositionHeight")?i.perPositionHeight:!o,c=i instanceof w.ESClassification||i instanceof w.ESPolygonFence;let h=w.getMinMaxCorner(i.points).center,p=[...h],u=c?i.points[0][2]:0;a?o?p[2]=i.extrudedHeight:p[2]=i.height+u:(s&&(h[2]=i.height),o&&(p[2]=i.extrudedHeight)),n.startPosition=h,n.distance=p[2]-h[2],n.moveWithFirstPosition=!1;let f=[...h];this.ad(n.positionsChanged.don(()=>{n.positions.length===2&&(a?(i.points=i.points.map(g=>[g[0],g[1],g[2]+n.positions[0][2]-f[2]]),o?i.extrudedHeight=n.positions[1][2]:s&&(i.height=n.positions[1][2]-(c?n.positions[0][2]:0))):(s&&(i.height=n.positions[0][2]),o&&(i.extrudedHeight=n.positions[1][2])),f=[...n.positions[0]])}));break}this.supportEditing=!1;return}while(!1);n.init(),n.enabled=!0;const r=this.ad(l.createNextAnimateFrameEvent(n.enabledChanged,n.startPositionChanged));this.ad(r.don(()=>{(!n.enabled||!n.startPosition||w.equalsN3(n.startPosition,[0,0,0]))&&this.destroy()}))}};v(Jl,"type",Jl.registerEditing("ESCesiumViewer",w.ESJEditingMode.HeightModify,Jl));let Qg=Jl;function p1(){const t=l.createProcessingFromAsyncFunc(async(i,e,n,r,o=!0)=>{const s=Array.isArray(r)?[...r]:[r],a=n.editingID;e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"start",add:{modes:s}});const c=()=>{e.notSupportEditingCount=0,e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"end",add:{modes:s}}),t.isRunning&&t.cancel()};i.disposer.ad(c),i.disposer.ad(n.toDestroyEvent.don(c));const h=u=>{u.code=="Escape"&&c()};document.body.addEventListener("keydown",h),i.disposer.ad(()=>document.body.removeEventListener("keydown",h));let p=0;do{const u=s[p%s.length],f=await l.step(i,async g=>{const m=g.disposer,y=w.EngineObject.contextEditing.getEngineObjConstructor(u,e.typeName);if(!y||!n.supportEditingModes().includes(u))return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount++,!1;const S=new y(n,e);if(m.ad(()=>{!S.isDestroyed()&&S.destroy()}),S.supportEditing)e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount=0;else return console.log(`未找到编辑模式或不支持当前编辑模式${u},已跳过当前编辑模式,请检查输入`),e.editingEvent.emit({objectIDs:[n.parentID??n.id],editingID:a,type:"changedFailed",add:{cMode:u,cIndex:p}}),e.notSupportEditingCount++,!1;return await g.promise(new Promise(C=>{if(S.isDestroyed()&&C(!1),m.ad(S.toDestroyEvent.don(()=>{console.log(`编辑模式${u}结束`),C(!1)})),o){const E=M=>{M.code=="Space"&&(console.log(`编辑模式${u}结束`),C(!1))};document.body.addEventListener("keydown",E),m.ad(()=>document.body.removeEventListener("keydown",E)),m.ad(e.dblclickEvent.don(()=>C(!0)))}}))});if(o&&f||!o&&p==s.length-1||e.notSupportEditingCount==s.length)break;p++}while(!0)});return t}function f1(){const t=l.createProcessingFromAsyncFunc(async(i,e,n,r)=>{e.editingEvent.emit({objectIDs:n.map(c=>c.parentID??c.id),editingID:r,type:"start"});const o=()=>{e.editingEvent.emit({objectIDs:n.map(c=>c.parentID??c.id),editingID:r,type:"end"}),t.isRunning&&t.cancel()};i.disposer.ad(o);const s=c=>{c.code=="Escape"&&o()};document.body.addEventListener("keydown",s),i.disposer.ad(()=>document.body.removeEventListener("keydown",s));const a=new Ah(n,e);i.disposer.ad(()=>{!a.isDestroyed()&&a.destroy()}),await i.promise(new Promise(c=>{a.isDestroyed()&&c(),i.disposer.ad(a.toDestroyEvent.don(()=>{console.log("移动结束"),c()})),i.disposer.ad(e.dblclickEvent.don(()=>c()))}))});return t}R.copyright=void 0;try{const t="earthsdk3-cesium",i="3.3.0-beta.5",e="2025-07-15T06:12:13.000Z",n="北京西部世界科技有限公司",r="地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",o="9d13184aed42b04992b38a0b1d398eca01357d5f",a=((Date.now()-1752559933e3)/36e5).toFixed(1),c=`%c🌏 ${t}%c ${i}.${o.slice(0,8)}.${e} (距今${a}个小时)
2295
2295
  %c${r?r+`
2296
2296
  `:""}当前网站正在使用${t},此软件版权归${n}所有
2297
- `;R.copyright=Object.freeze({get owner(){return"北京西部世界科技有限公司"},get ownerlink(){},get gituri(){return GITURI_&&GITURI_.replace("${commitId}","34ba4ad6d65bfee5f2bf36300710c86cb8fb312d")},get info(){return c},get date(){return"2025-07-15T03:45:59.000Z"},get author(){return"suplyang"},get version(){return"3.3.0-beta.3"},get name(){return"earthsdk3-cesium"},get commitId(){return"34ba4ad6d65bfee5f2bf36300710c86cb8fb312d"},print(){console.info(this.info,`
2297
+ `;R.copyright=Object.freeze({get owner(){return"北京西部世界科技有限公司"},get ownerlink(){},get gituri(){return GITURI_&&GITURI_.replace("${commitId}","9d13184aed42b04992b38a0b1d398eca01357d5f")},get info(){return c},get date(){return"2025-07-15T06:12:13.000Z"},get author(){return"suplyang"},get version(){return"3.3.0-beta.5"},get name(){return"earthsdk3-cesium"},get commitId(){return"9d13184aed42b04992b38a0b1d398eca01357d5f"},print(){console.info(this.info,`
2298
2298
  font-size: 18px;
2299
2299
  font-weight: 1000;
2300
2300
  line-height: 1;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "earthsdk3-cesium",
3
- "version": "3.3.0-beta.3",
3
+ "version": "3.3.0-beta.5",
4
4
  "description": "地球可视化实验室 (EarthSDK&CesiumLab) https://www.bjxbsj.cn",
5
5
  "type": "module",
6
6
  "main": "./dist/earthsdk3-cesium.umd.cjs",
@@ -53,4 +53,4 @@
53
53
  "types": "./dist/types/index.d.ts",
54
54
  "import": "./dist/earthsdk3-cesium.js"
55
55
  }
56
- }
56
+ }
@@ -1,29 +0,0 @@
1
- import * as Cesium from 'cesium';
2
- import { XbsjRoutePath } from './XbsjRoutePath';
3
- import { SceneObjectKey } from 'xbsj-base';
4
-
5
- export type XbsjPositionCallbackResultType = {
6
- timeRatio: number;
7
- repeat: number;
8
- color: [number, number, number, number];
9
- bgColor: [number, number, number, number];
10
- bidirectional: 0 | 1 | 2 | 3; // 0/1表示单向,2表示双向, 3表示无信号
11
- };
12
-
13
- export type XbsjODLinesPostionCallback = (
14
- instanceIndex: number,
15
- frameState: Cesium.FrameState,
16
- result: XbsjPositionCallbackResultType,
17
- ) => XbsjPositionCallbackResultType;
18
-
19
- export default function xbsjCreateODLinesPrimitive(
20
- routePaths: XbsjRoutePath[],
21
- color: [number, number, number, number],
22
- arcType: Cesium.ArcType,
23
- postionCallback: (instanceIndex: number, frameState: Cesium.FrameState | undefined, result: XbsjPositionCallbackResultType) => XbsjPositionCallbackResultType,
24
- brightening?: boolean,
25
- depthTest?: boolean,
26
- getTextureFunc?: () => Cesium.Texture,
27
- id?: SceneObjectKey
28
- ): Cesium.Primitive;
29
-
@@ -1,18 +0,0 @@
1
- import * as Cesium from 'cesium';
2
-
3
- export declare class XbsjCameraVideo {
4
- constructor(options: {
5
- inverseViewMatrix: Cesium.Matrix4,
6
- frustum: Cesium.PerspectiveFrustum,
7
- // videoElement: HTMLVideoElement | string | undefined,
8
- videoTextureFunc?: (() => Cesium.Texture | undefined) | undefined,
9
- alphaTextureFunc?: (() => Cesium.Texture | undefined) | undefined,
10
- showHelperPrimitive: true,
11
- });
12
- // videoElement: HTMLVideoElement | string | undefined;
13
- // alphaImage: string;
14
- videoTextureFunc: (() => Cesium.Texture | undefined) | undefined;
15
- alphaTextureFunc: (() => Cesium.Texture | undefined) | undefined;
16
- showHelperPrimitive: boolean;
17
- destroy(): void;
18
- }
@@ -1,16 +0,0 @@
1
- import * as Cesium from 'cesium';
2
-
3
- export declare class XbsjViewshed {
4
- constructor(scene: Cesium.Scene, id?: string);
5
- enabled: boolean;
6
- showHelper: boolean;
7
- fovH: number;
8
- fovV: number;
9
- near: number;
10
- far: number;
11
- position: Cesium.Cartesian3;
12
- heading: number;
13
- pitch: number;
14
- roll: number;
15
- destroy(): void;
16
- }
@@ -1,5 +0,0 @@
1
- export declare class BackGroundImage {
2
- show: boolean;
3
- material: Cesium.Material;
4
- destroy(): void;
5
- }
@@ -1,14 +0,0 @@
1
- import * as Cesium from 'cesium';
2
-
3
- declare class SkyAtmosphere {
4
- constructor(ellipsoid: Cesium.Ellipsoid | undefined, sources: {
5
- positiveX: string;
6
- negativeX: string;
7
- positiveY: string;
8
- negativeY: string;
9
- positiveZ: string;
10
- negativeZ: string;
11
- });
12
- }
13
-
14
- export = SkyAtmosphere;
@@ -1,12 +0,0 @@
1
- import * as Cesium from 'cesium';
2
-
3
- declare const GaussianSplatPipelineStage: {
4
- name: string;
5
- process: (
6
- renderResources: any,
7
- primitive: Cesium.Primitive,
8
- frameState: Cesium.FrameState
9
- ) => void;
10
- };
11
-
12
- export default GaussianSplatPipelineStage;
@@ -1,11 +0,0 @@
1
- import * as Cesium from 'cesium';
2
- declare const GaussianSplatTexturePipelineStage: {
3
- name: string;
4
- process: (
5
- renderResources: any,
6
- primitive: Cesium.Primitive,
7
- frameState: Cesium.FrameState
8
- ) => void;
9
- };
10
-
11
- export default GaussianSplatTexturePipelineStage;
@@ -1 +0,0 @@
1
- export declare function cesiumFixGoogleEarth(Cesium: any): void;
@@ -1,405 +0,0 @@
1
- // cesium声明文件补充
2
- // 注意此声明文件不全,用到哪儿写到哪儿
3
- // vtxf 20211215
4
-
5
- declare module 'cesium' {
6
- interface Destroyable {
7
- isDestroyed(): boolean;
8
- destroy(): undefined;
9
- }
10
-
11
- interface Context {
12
- defaultTexture: Texture;
13
- }
14
-
15
- // @ts-ignore
16
- type TextureOptions = {
17
- context: Context;
18
- pixelFormat?: number;
19
- width: number;
20
- height: number;
21
- flipY?: boolean;
22
- }
23
-
24
- const enum MipmapHint {
25
- DONT_CARE = WebGLConstants.DONT_CARE,
26
- FASTEST = WebGLConstants.FASTEST,
27
- NICEST = WebGLConstants.NICEST,
28
- }
29
-
30
- interface Texture extends Destroyable {
31
- copyFrom(options: {
32
- // arrayBufferView: ArrayBufferView,
33
- // width: number;
34
- // height: number;
35
- source: {
36
- width: number;
37
- height: number;
38
- arrayBufferView: ArrayBufferView;
39
- } | ImageData | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement;
40
- xOffset?: number;
41
- yOffset?: number;
42
- skipColorSpaceConversion?: boolean; // false
43
- }): void;
44
-
45
- generateMipmap(hint: MipmapHint): void;
46
- }
47
-
48
- var Texture: {
49
- prototype: Texture;
50
- new(options: TextureOptions): Texture;
51
- };
52
-
53
- interface Scene {
54
- context: Context;
55
- }
56
-
57
- interface AttributeLocations {
58
- [k: string]: number;
59
- }
60
-
61
- const enum BufferUsage {
62
- STREAM_DRAW = WebGLConstants.STREAM_DRAW,
63
- STATIC_DRAW = WebGLConstants.STATIC_DRAW,
64
- DYNAMIC_DRAW = WebGLConstants.DYNAMIC_DRAW,
65
- }
66
-
67
- interface VertexArrayOptions {
68
- context: Context;
69
- attributes: {
70
- index: number,
71
- vertexBuffer: Buffer,
72
- componentsPerAttribute: number,
73
- componentDatatype: ComponentDatatype,
74
- normalize?: boolean, // false
75
- }[];
76
- attributeLocations: AttributeLocations;
77
- bufferUsage: BufferUsage;
78
- indexBuffer?: Buffer;
79
- }
80
-
81
- namespace ComponentDatatype {
82
- function createTypedArray(componentDatatype: ComponentDatatype, valuesOrLength: number | number[]): Int8Array | Uint8Array | Int16Array | Uint16Array | Int32Array | Uint32Array | Float32Array | Float64Array;
83
- }
84
-
85
- interface VertexArray extends Destroyable {
86
- isDestroyed(): boolean;
87
- destroy(): undefined;
88
- }
89
-
90
- var VertexArray: {
91
- prototype: VertexArray;
92
- new(options: VertexArrayOptions): VertexArray;
93
- }
94
-
95
- // interface ShaderProgramOptions {
96
- // gl: WebGLRenderingContext | WebGL2RenderingContext;
97
- // // debugShaders: boolean;
98
- // vertexShaderText: string;
99
- // fragmentShaderText: string;
100
- // attributeLocations: AttributeLocations;
101
- // }
102
-
103
- interface ShaderProgram extends Destroyable {
104
-
105
- }
106
-
107
- // var ShaderProgram: {
108
- // prototype: ShaderProgram;
109
- // new(options: ShaderProgramOptions): ShaderProgram;
110
- // }
111
-
112
- interface ShaderSource {
113
-
114
- }
115
-
116
- var ShaderSource: {
117
- prototype: ShaderSource;
118
- new(options: {
119
- defines?: string[];
120
- sources: string[];
121
- includeBuiltIns?: boolean;
122
- }): ShaderSource;
123
- };
124
-
125
- namespace ShaderProgram {
126
- function fromCache(options: {
127
- context: Context,
128
- vertexShaderSource: ShaderSource,
129
- fragmentShaderSource: ShaderSource,
130
- attributeLocations: AttributeLocations,
131
- }): ShaderProgram;
132
- }
133
-
134
- interface UniformMap {
135
- [k: string]: () => Texture | number | Cartesian2 | Cartesian3 | Cartesian4;
136
- }
137
-
138
- interface RenderState {
139
-
140
- }
141
-
142
- interface RenderStateOptions {
143
- frontFace?: WindingOrder, // WindingOrder.COUNTER_CLOCKWISE,
144
- cull?: {
145
- enabled?: boolean, // false
146
- face?: CullFace, // CullFace.BACK
147
- },
148
- lineWidth?: number, // 1
149
- polygonOffset?: {
150
- enabled?: boolean, // false
151
- factor?: number, // 0,
152
- units?: number, // 0
153
- },
154
- scissorTest?: {
155
- enabled?: boolean, // false,
156
- rectangle?: {
157
- x?: number, // 0,
158
- y?: number, // 0,
159
- width?: number, // 0,
160
- height?: number, // 0
161
- }
162
- },
163
- depthRange?: {
164
- near?: number, // 0,
165
- far?: number, // 1
166
- },
167
- depthTest?: {
168
- enabled?: boolean; // false,
169
- func?: DepthFunction; //DepthFunction.LESS
170
- },
171
- colorMask?: {
172
- red?: boolean, // true,
173
- green?: boolean, // true,
174
- blue?: boolean, // true,
175
- alpha?: boolean, // true
176
- },
177
- depthMask?: boolean, // true,
178
- stencilMask?: number, // ~0
179
- blending?: {
180
- enabled?: boolean, // false,
181
- color?: {
182
- red?: number, // 0.0,
183
- green?: number, // 0.0,
184
- blue?: number, // 0.0,
185
- alpha?: number, // 0.0
186
- },
187
- equationRgb?: BlendEquation, // BlendEquation.ADD,
188
- equationAlpha?: BlendEquation, // BlendEquation.ADD,
189
- functionSourceRgb?: BlendFunction, // BlendFunction.ONE,
190
- functionSourceAlpha?: BlendFunction, // BlendFunction.ONE,
191
- functionDestinationRgb?: BlendFunction, // BlendFunction.ZERO,
192
- functionDestinationAlpha?: BlendFunction, // BlendFunction.ZERO
193
- },
194
- stencilTest?: {
195
- enabled?: boolean, // false,
196
- frontFunction?: StencilFunction, // StencilFunction.ALWAYS,
197
- backFunction?: StencilFunction, // StencilFunction.ALWAYS,
198
- reference?: number; // 0,
199
- mask?: number; // ~0,
200
- frontOperation?: {
201
- fail?: StencilOperation, // StencilOperation.KEEP,
202
- zFail?: StencilOperation, // StencilOperation.KEEP,
203
- zPass?: StencilOperation, // StencilOperation.KEEP
204
- },
205
- backOperation?: {
206
- fail?: StencilOperation, // StencilOperation.KEEP,
207
- zFail?: StencilOperation, // StencilOperation.KEEP,
208
- zPass?: StencilOperation, // StencilOperation.KEEP
209
- }
210
- },
211
- sampleCoverage?: {
212
- enabled?: boolean, // false,
213
- value?: number, // 1.0,
214
- invert?: boolean, // false
215
- }
216
- }
217
-
218
- namespace RenderState {
219
- function fromCache(options: RenderStateOptions): RenderState;
220
- }
221
-
222
- namespace Appearance {
223
- /**
224
- *
225
- * @param translucent 是否是透明的?透明对象的depthMask设为false,blending设为ALPHA_BLEND
226
- * @param closed 是否为封闭体,如果是封闭体,会开启背面裁剪 cull { enabled: true, face: CullFace.BACK }
227
- * @param existing 是否和一个已存在的RenderState进行合并,已存在的RenderState不做修改
228
- */
229
- function getDefaultRenderState(translucent: boolean, closed: boolean, existing?: RenderStateOptions): RenderStateOptions;
230
- }
231
-
232
-
233
- const enum Pass {
234
- ENVIRONMENT = 0,
235
- COMPUTE = 1,
236
- GLOBE = 2,
237
- TERRAIN_CLASSIFICATION = 3,
238
- CESIUM_3D_TILE = 4,
239
- CESIUM_3D_TILE_CLASSIFICATION = 5,
240
- CESIUM_3D_TILE_CLASSIFICATION_IGNORE_SHOW = 6,
241
- OPAQUE = 7,
242
- TRANSLUCENT = 8,
243
- OVERLAY = 9,
244
- NUMBER_OF_PASSES = 10,
245
- }
246
-
247
- // interface DrawCommandOptions
248
-
249
- interface PickId {
250
- key: number;
251
- color: Cesium.Color;
252
- }
253
-
254
- interface DrawCommand {
255
- boundingVolume: BoundingRectangle | BoundingSphere | OrientedBoundingBox | undefined;
256
- orientedBoundingBox: OrientedBoundingBox | undefined;
257
- cull: boolean; // deafult true
258
- occlude: boolean; // default true
259
- modelMatrix: Cesium.Matrix4 | undefined; // default undefined
260
- primitiveType: PrimitiveType; // default TRIANGLES
261
- vertexArray: VertexArray | undefined; // default undefined
262
- count: number | undefined;
263
- offset: number; // default 0
264
- instanceCount: number; // default 0
265
- shaderProgram: ShaderProgram | undefined; // default undefined
266
- castShadows: boolean; // default false
267
- receiveShadows: boolean; // default false
268
- uniformMap: UniformMap | undefined; // default undefine
269
- renderState: RenderState | undefined; // default undefined
270
- // framebuffer: FrameB
271
- pass: Pass | undefined; // default undefined
272
- executeInClosestFrustum: boolean;
273
- owner: Object | undefined;
274
- debugShowBoundingVolume: boolean;
275
- debugOverlappingFrustums: number;
276
- pickId: string | undefined;
277
- pickOnly: boolean;
278
- depthForTranslucentClassification: boolean;
279
- }
280
-
281
- var DrawCommand: {
282
- prototype: DrawCommand;
283
- new(options: {
284
- // boundingVolume: BoundingVoluem;
285
- cull?: boolean;
286
- occlude?: boolean;
287
- modelMatrix: Matrix4;
288
- primitiveType?: PrimitiveType; // TRIANGLES
289
- vertexArray: VertexArray;
290
- count?: number;
291
- offset?: number;
292
- instanceCount?: number; // 0
293
- shaderProgram: ShaderProgram;
294
- uniformMap?: UniformMap;
295
- renderState: RenderState;
296
- // framebuffer: ;
297
- pass: Pass;
298
- executeInClosestFrustum: boolean;
299
- owner?: any;
300
- debugShowBoundingVolume?: boolean;
301
- castShadows?: boolean; // false;
302
- receiveShadows?: boolean; // false
303
- pickId?: string;
304
- pickOnly?: boolean; // false
305
- depthForTranslucentClassification?: boolean; // false
306
- boundingVolume?: BoundingRectangle | BoundingSphere | OrientedBoundingBox;
307
- orientedBoundingBox?: OrientedBoundingBox;
308
- }): DrawCommand;
309
- };
310
-
311
- interface ShadowMap {
312
-
313
- }
314
-
315
- interface FrameState {
316
- context: Context;
317
- commandList: DrawCommand[];
318
- shadowMaps: ShadowMap[];
319
- // brdfLutGenerator
320
- // environmentMap
321
- // sphericalHarmonicCoefficients
322
- // specularEnvironmentMaps
323
- mode: SceneMode;
324
- morphTime: number;
325
- frameNumber: number; // 0
326
- newFrame: boolean;
327
- time: JulianDate;
328
- // jobScheduler
329
- // mapProjection
330
- camera: Camera;
331
- cameraUnderground: boolean;
332
- // globeTranslucencyState
333
- // cullingVolume
334
- // occluder
335
- maximumScreenSpaceError: number; // 2
336
- pixelRatio: number; // 1.0
337
- passes: {
338
- render: boolean;
339
- pick: boolean;
340
- depth: boolean;
341
- postProcess: boolean;
342
- offscreen: boolean;
343
- };
344
- // creditDisplay
345
- afterRender: (() => void)[];
346
- scene3DOnly: boolean;
347
- // fog: FrameState.Fog
348
- terrainExaggeration: number; // 1.0
349
- imagerySplitPosition: number;
350
- // frustumSplits
351
- // light
352
- // minimumDisableDepthTestDistance
353
- // invertClassification
354
- useLogDepth: boolean;
355
- // tilesetPassState
356
- minimumTerrainHeight: number; // 0.0
357
- }
358
-
359
- interface Buffer {
360
- copyFromArrayView(arrayView: ArrayBufferView, offsetInBytes?: number): void;
361
- readonly sizeInBytes: number;
362
- readonly usage: BufferUsage;
363
- isDestroyed(): boolean;
364
- destroy(): undefined;
365
- }
366
-
367
- // const enum IndexDatatype {
368
- // /**
369
- // * 8-bit unsigned byte corresponding to <code>UNSIGNED_BYTE</code> and the type
370
- // * of an element in <code>Uint8Array</code>.
371
- // */
372
- // UNSIGNED_BYTE = WebGLConstants.UNSIGNED_BYTE,
373
- // /**
374
- // * 16-bit unsigned short corresponding to <code>UNSIGNED_SHORT</code> and the type
375
- // * of an element in <code>Uint16Array</code>.
376
- // */
377
- // UNSIGNED_SHORT = WebGLConstants.UNSIGNED_SHORT,
378
- // /**
379
- // * 32-bit unsigned int corresponding to <code>UNSIGNED_INT</code> and the type
380
- // * of an element in <code>Uint32Array</code>.
381
- // */
382
- // UNSIGNED_INT = WebGLConstants.UNSIGNED_INT
383
- // }
384
-
385
- interface IndexBuffer extends Buffer {
386
- indexDatatype: IndexDatatype;
387
- bytesPerIndex: number;
388
- numberOfIndices: number;
389
- }
390
-
391
- namespace Buffer {
392
- function createVertexBuffer(options: {
393
- context: Context;
394
- typedArray: ArrayBufferView;
395
- usage: BufferUsage;
396
- }): Buffer;
397
-
398
- function createIndexBuffer(options: {
399
- context: Context;
400
- typedArray: Uint8Array | Uint16Array | Uint32Array;
401
- usage: BufferUsage;
402
- indexDatatype: IndexDatatype;
403
- }): IndexBuffer;
404
- }
405
- }
@@ -1,8 +0,0 @@
1
- import * as Cesium from 'cesium';
2
-
3
- export function generateCartesianArc(options: {
4
- positions: Cesium.Cartesian3[],
5
- arcType: Cesium.ArcType;
6
- granularity: number;
7
- ellipsoid: Cesium.Ellipsoid;
8
- }): Cesium.Cartesian3[] | undefined;
@@ -1,37 +0,0 @@
1
- import { Feature, LineString, Properties } from "@turf/helpers";
2
- /**
3
- * Takes a {@link LineString|line} and returns a curved version
4
- * by applying a [Bezier spline](http://en.wikipedia.org/wiki/B%C3%A9zier_spline)
5
- * algorithm.
6
- *
7
- * The bezier spline implementation is by [Leszek Rybicki](http://leszek.rybicki.cc/).
8
- *
9
- * @name bezierSpline
10
- * @param {Feature<LineString>} line input LineString
11
- * @param {Object} [options={}] Optional parameters
12
- * @param {Object} [options.properties={}] Translate properties to output
13
- * @param {number} [options.resolution=10000] time in milliseconds between points
14
- * @param {number} [options.sharpness=0.85] a measure of how curvy the path should be between splines
15
- * @returns {Feature<LineString>} curved line
16
- * @example
17
- * var line = turf.lineString([
18
- * [-76.091308, 18.427501],
19
- * [-76.695556, 18.729501],
20
- * [-76.552734, 19.40443],
21
- * [-74.61914, 19.134789],
22
- * [-73.652343, 20.07657],
23
- * [-73.157958, 20.210656]
24
- * ]);
25
- *
26
- * var curved = turf.bezierSpline(line);
27
- *
28
- * //addToMap
29
- * var addToMap = [line, curved]
30
- * curved.properties = { stroke: '#0F0' };
31
- */
32
- declare function bezier<P = Properties>(line: Feature<LineString> | LineString, options?: {
33
- properties?: P;
34
- resolution?: number;
35
- sharpness?: number;
36
- }): Feature<LineString, P>;
37
- export default bezier;
@@ -1,62 +0,0 @@
1
- export interface Point {
2
- x: number;
3
- y: number;
4
- z: number;
5
- }
6
- /**
7
- * BezierSpline
8
- * https://github.com/leszekr/bezier-spline-js
9
- *
10
- * @private
11
- * @copyright
12
- * Copyright (c) 2013 Leszek Rybicki
13
- *
14
- * Permission is hereby granted, free of charge, to any person obtaining a copy
15
- * of this software and associated documentation files (the "Software"), to deal
16
- * in the Software without restriction, including without limitation the rights
17
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
18
- * copies of the Software, and to permit persons to whom the Software is
19
- * furnished to do so, subject to the following conditions:
20
- *
21
- * The above copyright notice and this permission notice shall be included in all
22
- * copies or substantial portions of the Software.
23
- *
24
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
29
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30
- * SOFTWARE.
31
- */
32
- export default class Spline {
33
- duration: number;
34
- points: Point[];
35
- sharpness: number;
36
- centers: Point[];
37
- controls: Array<[Point, Point]>;
38
- stepLength: number;
39
- length: number;
40
- delay: number;
41
- steps: number[];
42
- constructor(options?: any);
43
- /**
44
- * Caches an array of equidistant (more or less) points on the curve.
45
- */
46
- cacheSteps(mindist: number): number[];
47
- /**
48
- * returns angle and speed in the given point in the curve
49
- */
50
- vector(t: number): {
51
- angle: number;
52
- speed: number;
53
- };
54
- /**
55
- * Gets the position of the point, given time.
56
- *
57
- * WARNING: The speed is not constant. The time it takes between control points is constant.
58
- *
59
- * For constant speed, use Spline.steps[i];
60
- */
61
- pos(time: number): Point;
62
- }