From b1ec910ae7c0c19f6afabafd3cb75722a6b059dd Mon Sep 17 00:00:00 2001 From: jihongshun <1151753686@qq.com> Date: 星期三, 30 七月 2025 15:54:33 +0800 Subject: [PATCH] 鼠标缩放控制视锥体 --- src/utils/components/init-map.vue | 93 ++++++++++++++++------------------------------ 1 files changed, 33 insertions(+), 60 deletions(-) diff --git a/src/utils/components/init-map.vue b/src/utils/components/init-map.vue index 6cb1d61..4ecd9e3 100644 --- a/src/utils/components/init-map.vue +++ b/src/utils/components/init-map.vue @@ -209,7 +209,6 @@ control.enableTilt = false; control.enableLook = false; viewerC.scene.camera.percentageChanged = 0.05聽 - this.cammove_measure_point(); },1000) }, @@ -248,13 +247,6 @@ fullscreenButton: false, vrButton: false, }); - // 鍏抽棴澶╃┖鐩掓晥鏋� - // viewer.scene.skyAtmosphere = undefined; // 鎴栬�呰缃负 null - - // // 鍏抽棴鍏夌収鏁堟灉 - // viewer.scene.globe.enableLighting = false; // 鍏抽棴鍏夌収鏁堟灉 - - // viewer.imageryLayers.add(bdtvectoranoimagery); viewer._cesiumWidget._creditContainer.style.display="none"; return viewer; @@ -271,7 +263,6 @@ // 璁剧疆瑙嗚锛屼娇鍏堕粯璁ゆ煡鐪嬫煇涓湴鐞嗕綅缃� viewerM.scene.camera.setView({ destination: Cesium.Cartesian3.fromDegrees(globalon, globalat, 349.0), // 浠ョ粡绾害璁剧疆浣嶇疆锛堜緥濡傦細澶у簡榫欏叴璺級 - // destination: Cesium.Cartesian3.fromDegrees(0.0005, 0.0017, 207.8), // 浠ョ粡绾害璁剧疆浣嶇疆锛堜緥濡傦細澶у簡榫欏叴璺級 orientation: { heading: Cesium.Math.toRadians(194.65), // 鏂瑰悜 pitch: Cesium.Math.toRadians(-31.43), // 淇 @@ -303,12 +294,10 @@ }, addSyncListener() { // 瀛樹笅鍥炶皟浠ヤ究閿�姣� - // this._preRenderCallback = () => this.syncViewer(); viewerM.scene.preRender.addEventListener( this.syncViewer()); window.addEventListener("keydown", this.handleKeydown); }, syncViewer(){ - console.log(viewerM.camera) viewerC.camera.flyTo({ destination: viewerM.camera.position, orientation: { @@ -351,7 +340,6 @@ let lng = Cesium.Math.toDegrees(cartographic.longitude); let lat = Cesium.Math.toDegrees(cartographic.latitude); height = cartographic.height; - console.log(lng+','+lat+','+height) } //鍦ㄤ袱涓獥鍙e垱寤烘爣娉� @@ -380,37 +368,27 @@ //鏍规嵁鍋忕Щ閲忔眰鍋忕Щ鍚戦噺 聽聽聽聽const scalerNormalize聽=聽Cesium.Cartesian3.multiplyByScalar(normalize,distance,new聽Cesium.Cartesian3()); const tagert = Cesium.Cartesian3.add(holdingPosition,scalerNormalize,new聽Cesium.Cartesian3()); - console.log(Cesium.Cartographic.fromCartesian(tagert)) + //鍒涘缓绌轰腑鐐筽in _this.creatPin("aerialPoiId"+counter,tagert,`绌�${counter}`,Cesium.Color.RED,viewerM); - // preVideoScopePrimitiveArrTie = [] - console.log(preVideoScopePrimitiveArrTie) - - console.log(Cesium.Math.toDegrees(Cesium.Cartographic.fromCartesian(tagert).height)) + //鏇存柊閿洏浜嬩欢 _this.updateCameraMovement(); - // if(cameraVideo){ - // viewerM.scene.primitives.remove(cameraVideo) - // } - chooseId = crypto.randomUUID() - //鍒涘缓瑙嗛敟浣� + //褰撳墠閫夋嫨鐨刬d + chooseId = crypto.randomUUID() + //鍒涘缓瑙嗛敟浣� let data = { - "FHorFieldAngle": 32.13, - "FVerFieldAngle": 18.39, "altitude": Cesium.Cartographic.fromCartesian(tagert).height, "id": chooseId, - "chanNo": 1, "latitude": Cesium.Math.toDegrees(Cesium.Cartographic.fromCartesian(tagert).latitude), "longitude": Cesium.Math.toDegrees(Cesium.Cartographic.fromCartesian(tagert).longitude), - "p": 26.8, - "t": 351.3, - "z": 1, } + //濉旂殑璺濈鍜岃娴嬬偣鐨勮窛绂� const point1 = Cesium.Cartesian3.fromDegrees(0, 0, 50); const point2 = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(Cesium.Cartographic.fromCartesian(tagert).longitude), Cesium.Math.toDegrees(Cesium.Cartographic.fromCartesian(tagert).latitude), Cesium.Cartographic.fromCartesian(tagert).height); // 璁$畻璺濈锛堝崟浣嶏細绫筹級 - const distance1 = Cesium.Cartesian3.distance(point1, point2) - console.log(distance1) - data.distance = distance1 + const distanceCalculate = Cesium.Cartesian3.distance(point1, point2) + data.distance = distanceCalculate + //鍙抽敭缁撴潫鍚庢妸缂╂斁閲嶇疆涓�1 _this.zoomRatio = 1 _this.createVideoScope(data) setTimeout(() => { @@ -448,8 +426,6 @@ return result; }, changeCamera(position,heading){ - console.log(position) - console.log(heading) viewerC.camera.flyTo({ destination: position, orientation: { @@ -551,7 +527,6 @@ } else { groupEntity.position = position; } - console.log(groupEntity) } const key = event.key; const lower = key.toLowerCase(); @@ -718,12 +693,6 @@ // Fly back to the initial view (home) in 1 second viewerC.camera.flyHome(1.0); }, - move_measure_point(){ - CesiumSurvey.measureMovePoint(viewerC,'moveResultCon'); - }, - cammove_measure_point(){ - CesiumSurvey.cammeasureMovePoint(viewerC,'cammoveResultCon'); - }, mergePoint(){ let allEntities = viewerM.entities.values; // 鎵�鏈夊疄浣撳璞$粍鎴愮殑鏁扮粍 const grouped = {}; @@ -760,7 +729,6 @@ ] }; }); - console.log(result) this.$emit('mergePoint',result,this.mergeNumber,viewerM) }, genId() { @@ -791,7 +759,6 @@ }, handleKeydown(e) { const key = e.key; - console.log(key) const validKeys = ["a", "s", "d", "w",'q','e','ArrowUp','ArrowDown','ArrowLeft','ArrowRight','q','e']; if (validKeys.includes(key)) { this.triggerKey(key); @@ -800,8 +767,6 @@ }, // 鍒涘缓鍒濆鍖栫殑鍏夎酱 createVideoScope(data) { - console.log(data) - console.log(data.distance) if (data == undefined) { this.$message({ showClose: true, @@ -822,7 +787,6 @@ // Number(data.altitude) + Number(hight[1]) + 1.7 Number(data.altitude) ); - console.log(data) let inverseViewMatrix = this.hpr2m({ position: positionCt3, // 鐩告満鍧愭爣 // heading: Cesium.Math.toRadians(Number(120)), @@ -833,7 +797,7 @@ roll: Cesium.Math.toRadians(0), }); let frustum = new Cesium.PerspectiveFrustum({ - fov: Cesium.Math.toRadians(1), + fov: Cesium.Math.toRadians(56), aspectRatio: Number(1.77778), // 瀹介珮姣� near: Number(0.05), // 璁惧鐒﹁窛 far: Number(data.distance), // 鎷嶆憚璺濈 @@ -861,16 +825,11 @@ ); // viewer.scene.primitives.add(cameraVideo); let pmObj = {}; - console.log(data) pmObj.id = data.id; - console.log(pmObj) pmObj.primitive = cameraVideo; - // pmCollection.push(pmObj);//骞曞竷锛岃棰戣浆鎹娇鐢� viewerM.scene.primitives.add(cameraVideo); preVideoScopePrimitiveArrTie.push(pmObj); preVideoScopePrimitiveArrTie.map((item)=>{ - console.log(item) - console.log(chooseId) if(item.id != chooseId){ item.primitive.show = false } @@ -939,16 +898,34 @@ const roll = Cesium.Math.toDegrees(camera.roll); const point1 = Cesium.Cartesian3.fromDegrees(0, 0, 50); const point2 = Cesium.Cartesian3.fromDegrees(Cesium.Math.toDegrees(position.longitude),Cesium.Math.toDegrees(position.latitude),position.height) + + var camResult = + position.longitude.toFixed(4) + + '\u00B0' + + ',' + + position.latitude.toFixed(4) + + '\u00B0' + + ',' + + position.height.toFixed(1) + + '绫�,' + + heading.toFixed(2) + + '\u00B0' + + ',' + + pitch.toFixed(2) + + '\u00B0' + + ',' + + roll.toFixed(1) + + '\u00B0'; + document.getElementById('cammoveResultCon').innerHTML = camResult; // 璁$畻璺濈锛堝崟浣嶏細绫筹級 const distanceBetween = Cesium.Cartesian3.distance(point1, point2) - console.log(distanceBetween) console.log(preVideoScopePrimitiveArrTie) - console.log(chooseId) preVideoScopePrimitiveArrTie.map((item)=>{ if(item.id == chooseId){ let obj = this.updateSZScope(Cesium.Math.toDegrees(position.longitude),Cesium.Math.toDegrees(position.latitude),position.height,heading,pitch,roll,this.zoomRatio,distanceBetween) item.primitive.inverseViewMatrix = obj.M item.primitive.frustum = obj.F + item.primitive.zoomRatio = this.zoomRatio } }) }, @@ -959,22 +936,18 @@ Number(lat), Number(alt) ); - console.log(positionCt3) - console.log(distanceBetween) let frustum = new Cesium.PerspectiveFrustum({ - fov: Cesium.Math.toRadians(LightView), + fov: Cesium.Math.toRadians(56/LightView), aspectRatio: Number(1.77778), near: Number(0.05), far: Number(distanceBetween), }); - console.log(frustum) let inverseViewMatrixNew = this.hpr2m({ position: positionCt3, heading: Cesium.Math.toRadians(Number(camHeading)), pitch: Cesium.Math.toRadians(Number(camPitch)), roll: Cesium.Math.toRadians(Number(camRoll)), }); - console.log(inverseViewMatrixNew) return {M: inverseViewMatrixNew, F: frustum}; }, handleWheel(event) { @@ -1007,7 +980,7 @@ #cesiumContainer { margin: 0; padding: 0; - width: 73%; + width: 74%; height: calc(100vh - 205px); } #cesiumCamera { @@ -1032,7 +1005,7 @@ /* padding: 0 5px; */ margin-top: 10px; right: 0px; - width: 420px; + width: 410px; height: calc(100vh - 210px); bottom: 30px; margin: 0; -- Gitblit v1.9.3