Browse Source

1.defineStore新增字段

2.earthMapUrl 抽离URL
3.  新增
      import { listenMouseHandlerSence } from '@/utils/earthMap/listenMouseHandlerSence';
        import  getLineInfo  from '@/utils/earthMap/getLineInfo';
        import  getCameraInfo  from '@/utils/earthMap/getCameraInfo';
master
DIAMOND 12 months ago
parent
commit
9bc895a3be
  1. 55
      src/api/earth/earthMap.ts
  2. 6
      src/store/modules/earthMap.ts
  3. 186
      src/utils/earthMap/getCameraInfo.ts
  4. 268
      src/utils/earthMap/getLineInfo.ts
  5. 124
      src/utils/earthMap/listenMouseHandlerSence.ts
  6. 614
      src/views/earthMap/edit/EarthComp.vue
  7. 827
      src/views/military/modules/earthMap/scene/model/mapModel/EarthMapModal copy.vue
  8. 12
      src/views/military/modules/earthMap/scene/model/mapModel/EarthMapModal.vue
  9. 85
      src/views/military/modules/earthMap/scene/model/sceneInfo/SenceInfo.vue

55
src/api/earth/earthMap.ts

@ -0,0 +1,55 @@
import { defHttp } from '/@/utils/http/axios';
import { message } from 'ant-design-vue';
import { useGlobSetting } from '/@/hooks/setting';
const globSetting = useGlobSetting();
export enum earthMapUrl{
queryLabelList= 'military/msMapLabel/queryLabelAndDeviceList',
queryLineList= 'military/msMapLine/list',
queryCameraInfo= 'military/camera/site/getCameraInfoForEarth',
queryAllModelInfo= 'military/msModelPosition/queryAllModelInfo',
queryPatrolRouteInfo= 'military/msPatrolLine/getLineDetail',
queryBayoneByParam= 'military/msBayonetStatistics/getBayoneByParam',
queryAisInfo= 'military/checkpoint/msAisInfo/list',
keepAlive= 'military/mapInfo/keepAlive',
//雷达扫描列表
radarList= '/military/RadarConfig/list',
// 删除模型
// 传感器
deleteSensor= '/military/msModelPosition/deleteByEventSerialNum',
// 站点
deleteSite= '/military/camera/site/delete',
// 标志点
deleteMapLabel= '/military/msMapLabel/delete',
updateMapLine= '/military/msMapLine/edit',
deleteMapLine= '/military/msMapLine/delete',
saveMapLine= '/military/msMapLine/add',
// 编辑 模型
// 传感器
updateSensor= '/military/msModelPosition/editByEventSerialNum',
// 站点
updateSite= '/military/camera/site/edit',
// 标志点
updateMapLabel= '/military/msMapLabel/edit',
// 模型 保存
// 传感器
SaveSensorModel= '/military/msModelPosition/add',
// 站点
saveCameraSiteModel= '/military/camera/site/add',
// 标志点
saveMapLabel= '/military/msMapLabel/addMapLabel',
// 通过 线路名称 查询 线路
queryMapLine= '/military/msMapLine/queryByName',
querySiteById= '/military/camera/site/queryById',
// 查询设备列表
queryDeviceInfoList= '/military/msDeviceInfo/list',
setDefenseArea= '/military/netty/microwaveDetector/defenceArea',
perimeterRegionList= '/third/api/perimeterRegionList',
perimeterControl= '/third/api/perimeterControl',
// 雷达重新发送报警信息
sendRadarAlarmByWebSocket= '/military/warn/sendRadarAlarmByWebSocket',
}

6
src/store/modules/earthMap.ts

@ -21,6 +21,12 @@ export const useEarthMapStore = defineStore({
keyAreaPos: <number[][]>[], //记录创建防区的点位,重点管控区域
shipDataList: <any>[], //船只数据列表
xbsjEarthUI: <any>null, //XbsjEarthUI
///////////////////////
cameraData: <any>{},//请求的电线杆数据
nodeConfigByRef: new Map(),// 区域节点By Ref划分
areaByNodeId: new Map(),
}),
getters: {
getCustomPrimitiveList(): any {

186
src/utils/earthMap/getCameraInfo.ts

@ -0,0 +1,186 @@
/**
*
* EarthComp.vue
*/
import { defHttp } from '/@/utils/http/axios';
import { addPin } from '@/utils/earthMap/earthObj';
import { useUserStore } from '/@/store/modules/user';
import { useEarthMapStore } from '/@/store/modules/earthMap';
import { earthMapUrl } from '@/api/earth/earthMap'
import { nextTick } from 'vue';
import $ from 'jquery';
let userStore = useUserStore();
let store = useEarthMapStore();
export default function getCameraInfo(models, type) {
console.log("加载站点");
return new Promise((resolve, reject) => {
//请求电线杆信息
defHttp.get({ url: earthMapUrl.queryCameraInfo }, { isTransformResponse: false }).then(async (res) => {
if (res.success) {
// console.log("res",res);
setCamera(res.result, models, type);
store.cameraData = res.result;
resolve(models);
}
});
});
}
async function setCamera(res, models, type) {
//根据经纬度算出该点地形高度
let posArr: any = [],
updatedPositions: any = [];
//地形是否开启
if (window.$earth.sceneTree.$refs.terrain.czmObject.show) {
res.forEach((data, index) => {
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
posArr.push(window.Cesium.Cartographic.fromDegrees(data.longitude, data.latitude));
});
}
});
var promise = window.Cesium.sampleTerrainMostDetailed(this._viewer.terrainProvider, posArr);
updatedPositions = await window.Cesium.when(promise);
} else {
res.forEach((data, index) => {
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
updatedPositions.push(window.Cesium.Cartographic.fromDegrees(data.longitude, data.latitude, 0));
});
}
});
}
// console.log("根据经纬度算出该点地形高度",res);
// console.log("根据经纬度算出该点地形高度",updatedPositions);
//设置电线杆
res.forEach((data, index) => {
// console.log("data",data);
let siteConfig: any = null;
const lineId = data.id;
let childs: any = null;
if (type == 2) {
childs = models.children;
for (const child of childs) {
if ('node_' + data.id == child.ref) {
siteConfig = child.children[0];
}
}
} else {
const parentNode = store.nodeConfigByRef.get('node_' + data.id);
if (!parentNode) {
return;
}
childs = parentNode.children;
siteConfig = childs[0];
// console.log("parentNode",parentNode);
}
if (!siteConfig) {
return;
}
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
// 判断电线杆状态
let num = 0;
if (data.msCameraSettingList != null) {
data.msCameraSettingList.forEach((data, index) => {
if (data.status == '3') {
//1-在线,2-离线,3-异常
num = num + 1;
}
});
}
let gltfStr;
if (!data.modelUrl) {
return;
}
let fileInfos = data.modelUrl.split('.');
if (num == 0) {
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + fileInfos[0] + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + fileInfos[0] + '.' + fileInfos[1];
} else if (num < data.msCameraSettingList.length) {
let newName = fileInfos[0].substring(0, fileInfos[0].length - 1) + 'R';
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + newName + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + newName + '.' + fileInfos[1];
} else if (num == data.msCameraSettingList.length) {
let newName = fileInfos[0].substring(0, fileInfos[0].length - 1) + 'Y';
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + newName + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + newName + '.' + fileInfos[1];
}
const modelConfig = {
ref: data.id,
name: lineId,
czmObject: {
name: data.sitename,
xbsjType: 'Model',
url: gltfStr,
// "color": [0.52, 0.6, 0.58, 1],
minimumPixelSize: data.minimumPixelSize,
// maximumScale: 0.02,
scale: data.scale,
xbsjScale: data.xyzScale ? data.xyzScale.split(',') : [1, 1, 1],
xbsjPosition: [window.Cesium.Math.toRadians(data.longitude), window.Cesium.Math.toRadians(data.latitude), data.height],
xbsjRotation: [
window.Cesium.Math.toRadians(data.yaw),
window.Cesium.Math.toRadians(data.pitch),
window.Cesium.Math.toRadians(data.roll),
],
viewDistance: 150,
distanceDisplayCondition: [1.0, 30000.0],
customProp: data.id,
},
};
window.$earth.sceneTree.root.children.push(modelConfig);
//鼠标事件
window.$earth.sceneTree.$refs[data.id].czmObject.onmouseover = () => {
window.$viewer._container.style.cursor = 'pointer';
};
window.$earth.sceneTree.$refs[data.id].czmObject.onmouseout = () => {
window.$viewer._container.style.cursor = 'default';
};
nextTick(() => {
const divs = $('#earthContainer>div>div>div:nth-child(5)')
.children('div')
.eq(1)
.children()
.eq(0)
.children()
.eq(0)
.children()
.each((index, element) => {
$(element).css('display', 'none');
});
});
//加载相机
let cameraList: any = [];
if (data.msCameraSettingList) {
for (let camera of data.msCameraSettingList) {
let name = camera.cameraName;
const obj = {
ref: 'camera_' + camera.id,
expand: false,
title: name,
czmObject: {
name: name,
xbsjType: 'Model',
},
};
// let id = camera.id
cameraList.push(obj);
// 默认设置为在线
}
}
// 杆
const node = {
ref: 'node_' + data.id,
title: data.sitename,
expand: false,
children: cameraList,
};
siteConfig.children.push(node);
});
}
});
}

268
src/utils/earthMap/getLineInfo.ts

@ -0,0 +1,268 @@
/**
*
* EarthComp.vue
*/
import { defHttp } from '/@/utils/http/axios';
import { addPin } from '@/utils/earthMap/earthObj';
import { useUserStore } from '/@/store/modules/user';
import { useEarthMapStore } from '/@/store/modules/earthMap';
import { earthMapUrl } from '@/api/earth/earthMap'
import hidePng from '@/assets/earthMap/hide.png';
import { nextTick } from 'vue';
import $ from 'jquery';
let userStore = useUserStore();
let store = useEarthMapStore();
export default function getLineInfo(models, type) {
console.log("请求线路信息");
return new Promise((resolve, reject) => {
//请求线路信息
defHttp
.get(
{
url: earthMapUrl.queryLineList,
params: {
pageNo: 1,
pageSize: 99999,
sceneId: userStore.userInfo?.sceneId + '*',
},
},
{ isTransformResponse: false }
)
.then(async (res) => {
// console.log('加载区域',res);
if (res.success) {
//一级区域
let parentArea: any = [];
//二级区域
let childArea: any = [];
res.result.records.forEach((data) => {
if (data.parentCode) {
childArea.push(data);
} else {
parentArea.push(data);
}
});
parentArea.forEach((data) => {
// console.log(data);
// data.sceneId
let updatedPositions: any = [];
let positionsData = JSON.parse(data.positions);
if (!positionsData) {
positionsData = [];
}
updatedPositions = positionsData;
let lineOptions: any = {
maxShowHeight: 30000,
customProp: data.lineCode,
};
lineOptions.name = data.name;
lineOptions.xbsjType = 'Polyline';
lineOptions.width = data.width;
lineOptions.positions = updatedPositions;
lineOptions.loop = Boolean(data.isLoop);
lineOptions.depthTest = Boolean(data.isDepthCheck);
lineOptions.arcType = data.interpolation;
let material: any = {};
switch (data.materialType) {
// 实线
case 0:
material.type = 'XbsjColorMaterial';
material.XbsjColorMaterial = {};
if (!data.color || data.color.length <= 0) {
data.color = '[1,1,1,1]';
}
material.XbsjColorMaterial.color = JSON.parse(data.color);
break;
// 虚线
case 1:
material.type = 'XbsjPolylineDashMaterial';
material.XbsjPolylineDashMaterial = {};
material.XbsjPolylineDashMaterial.color = JSON.parse(data.color);
material.XbsjPolylineDashMaterial.gapColor = JSON.parse(data.intervalColor);
material.XbsjPolylineDashMaterial.dashLength = data.dashLength;
material.XbsjPolylineDashMaterial.dashPattern = data.dashStyle;
break;
// 箭头线
case 2:
material.type = 'XbsjPolylineArrowMaterial';
material.XbsjPolylineArrowMaterial = {};
material.XbsjPolylineArrowMaterial.color = JSON.parse(data.color);
break;
// 轨迹线
case 3:
material.type = 'XbsjODLineMaterial';
material.XbsjODLineMaterial = {};
material.XbsjODLineMaterial.color = JSON.parse(data.color);
material.XbsjODLineMaterial.totoalFrameCount = data.cycleFrame;
break;
}
lineOptions.material = material;
let currentChildArea: any = [];
if (childArea.length) {
childArea.forEach((element) => {
let obj = {};
if (data.id == element.parentCode) {
obj = {
expand: false,
title: element.name,
ref: 'nodeSecondary_' + element.id,
children: [],
};
let updatedPositions: any = [];
let positionsData = JSON.parse(element.positions);
if (!positionsData) {
positionsData = [];
}
updatedPositions = positionsData;
let lineOptions: any = {
maxShowHeight: 30000,
customProp: element.lineCode,
};
lineOptions.name = element.name;
lineOptions.xbsjType = 'Polyline';
lineOptions.width = element.width;
lineOptions.positions = updatedPositions;
lineOptions.loop = Boolean(element.isLoop);
lineOptions.depthTest = Boolean(element.isDepthCheck);
lineOptions.arcType = element.interpolation;
let material: any = {};
switch (element.materialType) {
// 实线
case 0:
material.type = 'XbsjColorMaterial';
material.XbsjColorMaterial = {};
if (!element.color || element.color.length <= 0) {
element.color = '[1,1,1,1]';
}
material.XbsjColorMaterial.color = JSON.parse(element.color);
break;
// 虚线
case 1:
material.type = 'XbsjPolylineDashMaterial';
material.XbsjPolylineDashMaterial = {};
material.XbsjPolylineDashMaterial.color = JSON.parse(element.color);
material.XbsjPolylineDashMaterial.gapColor = JSON.parse(element.intervalColor);
material.XbsjPolylineDashMaterial.dashLength = element.dashLength;
material.XbsjPolylineDashMaterial.dashPattern = element.dashStyle;
break;
// 箭头线
case 2:
material.type = 'XbsjPolylineArrowMaterial';
material.XbsjPolylineArrowMaterial = {};
material.XbsjPolylineArrowMaterial.color = JSON.parse(element.color);
break;
// 轨迹线
case 3:
material.type = 'XbsjODLineMaterial';
material.XbsjODLineMaterial = {};
material.XbsjODLineMaterial.color = JSON.parse(element.color);
material.XbsjODLineMaterial.totoalFrameCount = element.cycleFrame;
break;
}
let pos = [0, 0, 0];
positionsData.forEach((element) => {
pos[0] += element[0];
pos[1] += element[1];
pos[2] += element[2];
});
pos[0] = pos[0] / positionsData.length;
pos[1] = pos[1] / positionsData.length;
pos[2] = pos[2] / positionsData.length;
let pinBuilder = {
extTextFont: '30px 宋体',
extTextPixelOffset: [-40, 10],
fillColor: [0, 0.3450980392156863, 1, 0.9],
outlineColor: [1, 1, 1, 1],
extText: element.name,
};
let pin = addPin(element.name, hidePng, { position: pos, scale: 0.8, pinBuilder, far: 107374 });
lineOptions.pinXbsjGuid = pin.xbsjGuid;
lineOptions.material = material;
// that._earth.sceneTree.root.children.push({ czmObject: lineOptions, ref: element.id });
window.$earth.sceneTree.root.children.push({ czmObject: lineOptions, ref: element.id });
currentChildArea.push(obj);
// 如果是总部
if (type == 1) {
store.nodeConfigByRef.set('nodeSecondary_' + element.id, obj);
}
}
});
}
//配置信息
const node = {
ref: 'node_' + data.id,
expand: false,
title: '<防区>' + data.name,
children: [
{
expand: false,
title: '监控点位',
ref: 'monitor_' + window.guid(),
children: [],
},
{
expand: false,
title: '雷达点位',
ref: 'ldList_' + window.guid(),
children: currentChildArea,
},
{
expand: false,
title: '微波点位',
ref: 'wbList_' + window.guid(),
children: [],
},
],
};
if (data.sceneId == models.ref) {
// console.log("当前场景下");
//该防区为当前场景下
//压入树
models.children.push(node);
store.nodeConfigByRef.set(node.ref, node);
store.areaByNodeId.set(node.ref, data.sceneId);
// return
} else {
const childs = models.children;
for (const child of childs) {
if (child.ref == data.sceneId) {
//该防区为子场景下
// console.log("子场景下");
child.children.push(node);
store.nodeConfigByRef.set(node.ref, node);
store.areaByNodeId.set(node.ref, data.sceneId);
}
}
}
//放进世界场景树
window.$earth.sceneTree.root.children.push({ czmObject: lineOptions, ref: data.id });
});
//加载二级区域模型
childArea.forEach((data) => {});
nextTick(() => {
const divs = $('#earthContainer>div>div>div:nth-child(5)')
.children('div')
.eq(1)
.children()
.eq(0)
.children()
.eq(0)
.children()
.each((index, element) => {
// const paddingLeft = $(element).children().eq(0).css('padding-left')
$(element).css('display', 'none');
});
});
// console.log("models",models);
resolve(models);
}
});
});
}

124
src/utils/earthMap/listenMouseHandlerSence.ts

@ -0,0 +1,124 @@
/**
*
* EarthComp.vue
*
*/
import { toRefs, watch, nextTick, ref, reactive, onMounted } from 'vue';
import { message } from 'ant-design-vue';
import dwPng from '@/assets/images/rotationXYZ.png';
import rotationXYZ from '@/assets/images/rotationXYZ.png';
// 添加地图上的鼠标监听事件
let pin: any = undefined;
let viewer: any = undefined;
// 鼠标样式
const cursorCss = ref("grab");
let position: any = null;
let rotation: any = null;
let fov: any = null;
export function listenMouseHandlerSence(enablePointer = false, that) {
viewer = window.$earth.czm.viewer;
window.viewer = viewer;
window.$earth.interaction.picking.enabled = true;
window.$earth.interaction.picking.clickedColor = [1, 0, 0, 1];
const handler = new window.Cesium.ScreenSpaceEventHandler(
viewer.scene.canvas
);
window.CesiumGlobalHandler = handler;
// 取消双击旋转事件
viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(
window.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK
);
console.log("enablePointer", enablePointer);
if (enablePointer) {
viewer.cesiumWidget.screenSpaceEventHandler.setInputAction((event) => {
let cartesian = viewer.scene.globe.pick(viewer.camera.getPickRay(event.position), viewer.scene);
if (!cartesian) {
return;
}
// 世界坐标转换为弧度
let ellipsoid = viewer.scene.globe.ellipsoid;
let cartographic = ellipsoid.cartesianToCartographic(cartesian);
// 弧度转换为经纬度
let pointLon = window.Cesium.Math.toDegrees(cartographic.longitude); // 经度
let pointLat = window.Cesium.Math.toDegrees(cartographic.latitude); // 纬度
let pointAlt = cartographic.height; // 高度
console.log("点击的经纬度坐标是:", {
"经度:": pointLon,
"纬度:": pointLat
});
// debugger
//destroy方法有问题无法成功销毁,故选择trycatch
try {
pin && pin.destroy();
pin = undefined
} catch (error) {
console.error("销毁失败",error);
pin = undefined
}
pin = new window.XE.Obj.Pin(window.$earth);
pin.position = [cartographic.longitude, cartographic.latitude, pointAlt];
pin.imageUrl = dwPng;
let cposition = [window.$earth.camera.position[0], window.$earth.camera.position[1], window.$earth.camera.position[2]];
if (pin) {
position = [pin.position[0], pin.position[1], pin.position[2]];
}
rotation = [window.$earth.camera.rotation[0], window.$earth.camera.rotation[1], window.$earth.camera.rotation[2]];
fov = window.$earth.camera.fov;
that.$emit("checkPosition", position, cposition, rotation, fov);
},
window.Cesium.ScreenSpaceEventType.LEFT_CLICK
);
}
// /* 左键事件 */
handler.setInputAction((event) => {
handler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
// modelDw.value = false;
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grabbing`;
}, window.Cesium.ScreenSpaceEventType.LEFT_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grab`;
}, window.Cesium.ScreenSpaceEventType.LEFT_UP);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `url(${rotationXYZ}),grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_UP);
let clearId: any = null;
handler.setInputAction((event) => {
if (event > 0) {
cursorCss.value = `zoom-in`;
} else {
cursorCss.value = `zoom-out`;
}
clearId = setTimeout(() => {
clearTimeout(clearId);
cursorCss.value = `grab`
}, 2000);
}, window.Cesium.ScreenSpaceEventType.WHEEL);
}

614
src/views/earthMap/edit/EarthComp.vue

@ -107,7 +107,7 @@
import AISInfoWindow from '@/components/earthMap/AISInfoWindow.vue';
import { getRealTime } from '@/utils/date';
import $mitt from '@/utils/earthMap/mitt';
import { drawInit } from '@/utils/earthMap/earthDraw';
import { guid } from '@/utils/earthMap/guid';
import HandleNodeType from '@/utils/earthMap/handleNodeType';
import { keyControlInit } from '@/utils/earthMap/keyControlInit';
@ -120,7 +120,13 @@
import { useMessage } from '/@/hooks/web/useMessage';
import { CircleScan } from '@/utils/earthMap/radarEntity';
import { radianToDegreeInLngLatHeight } from '@/utils/earthMap/earth';
import { listenMouseHandlerSence } from '@/utils/earthMap/listenMouseHandlerSence';
import getLineInfo from '@/utils/earthMap/getLineInfo';
import getCameraInfo from '@/utils/earthMap/getCameraInfo';
import { drawInit } from '@/utils/earthMap/earthDraw';
import dwPng from '@/assets/images/rotationXYZ.png';
import rotationXYZ from '@/assets/images/rotationXYZ.png';
import circleDot2 from '@/assets/earthMap/circleDot2.png';
import circleDot1 from '@/assets/earthMap/circleDot1.png';
import circleDot3 from '@/assets/earthMap/circleDot3.png';
@ -269,6 +275,16 @@
type: Boolean,
default: false,
},
//
enablePointer: {
type: Boolean,
default: false
},
//
listenMouseHandlerSenceOpen: {
type: Boolean,
default: false
},
},
})
export default class EarthComp extends Vue {
@ -433,6 +449,16 @@
// ais
ship_aisData = {};
//
pin: any = undefined;
viewer: any = undefined;
//
cursorCss = "grab";
position: any = null;
rotation: any = null;
fov: any = null;
mounted() {
let that = this;
//
@ -570,6 +596,7 @@
//
window.$uia = earthUI;
window.$earth = earthUI.earth;
window.$viewer = earthUI.earth.czm.viewer;
earthUI.controls.mainBar.show = false; //
earthUI.controls.statusBar.show = true; //
//
@ -659,7 +686,7 @@
window._CONFIG['earthMapURL'] + window._CONFIG['vector'];
this.sceneTree.children[2].czmObject.xbsjTerrainProvider.XbsjCesiumTerrainProvider.url =
window._CONFIG['earthMapURL'] + window._CONFIG['terrain'];
// this.sceneTree.children.push(this.areaB)
this._earth.sceneTree.root = {
expand: true,
@ -676,6 +703,8 @@
//
if (this.PropsListenMouseHandlerOpen) this.listenMouseHandler(earthUI);
//
if (this.listenMouseHandlerSenceOpen) listenMouseHandlerSence(this.enablePointer,this);
//mitt
if (this.PropsListenMittHandlerOpen) this.listenMittHandler(earthUI);
@ -691,7 +720,12 @@
});
}
//
async fly() {
async fly() {
if(this.$attrs.onCustomFly){
// customFly
this.$emit('customFly');
return
}
let position, rotation, viewDistance, duration;
const sceneId = this.userStore.userInfo?.sceneId;
await defHttp
@ -791,7 +825,7 @@
/* 使用async/await 处理异步方法顺序执行。成功的操作放到try里,失败的放在catch里 */
async createBBHLine(earthUI = null) {
console.log('MyScene', this.userStore.userInfo?.sceneId);
// console.log('MyScene', this.userStore.userInfo?.sceneId);
let labelItems: any = undefined;
let type = 1; //**
@ -817,11 +851,11 @@
//
// console.log("");
if (this.PropsGetLineInfoShow) await this.getLineInfo(models, type);
if (this.PropsGetLineInfoShow) await getLineInfo(models, type);
//
// console.log("");
if (this.PropsGetCameraInfoShow) await this.getCameraInfo(models, type);
if (this.PropsGetCameraInfoShow) await getCameraInfo(models, type);
//
// console.log("");
@ -1070,432 +1104,8 @@
}
//
getLineInfo(models, type) {
const that = this;
return new Promise((resolve, reject) => {
//线
defHttp
.get(
{
url: this.url.queryLineList,
params: {
pageNo: 1,
pageSize: 99999,
sceneId: this.userStore.userInfo?.sceneId + '*',
},
},
{ isTransformResponse: false }
)
.then(async (res) => {
// console.log('',res);
if (res.success) {
//
let parentArea: any = [];
//
let childArea: any = [];
res.result.records.forEach((data) => {
if (data.parentCode) {
childArea.push(data);
} else {
parentArea.push(data);
}
});
parentArea.forEach((data) => {
// console.log(data);
// data.sceneId
let updatedPositions: any = [];
let positionsData = JSON.parse(data.positions);
if (!positionsData) {
positionsData = [];
}
updatedPositions = positionsData;
let lineOptions: any = {
maxShowHeight: 30000,
customProp: data.lineCode,
};
lineOptions.name = data.name;
lineOptions.xbsjType = 'Polyline';
lineOptions.width = data.width;
lineOptions.positions = updatedPositions;
lineOptions.loop = Boolean(data.isLoop);
lineOptions.depthTest = Boolean(data.isDepthCheck);
lineOptions.arcType = data.interpolation;
let material: any = {};
switch (data.materialType) {
// 线
case 0:
material.type = 'XbsjColorMaterial';
material.XbsjColorMaterial = {};
if (!data.color || data.color.length <= 0) {
data.color = '[1,1,1,1]';
}
material.XbsjColorMaterial.color = JSON.parse(data.color);
break;
// 线
case 1:
material.type = 'XbsjPolylineDashMaterial';
material.XbsjPolylineDashMaterial = {};
material.XbsjPolylineDashMaterial.color = JSON.parse(data.color);
material.XbsjPolylineDashMaterial.gapColor = JSON.parse(data.intervalColor);
material.XbsjPolylineDashMaterial.dashLength = data.dashLength;
material.XbsjPolylineDashMaterial.dashPattern = data.dashStyle;
break;
// 线
case 2:
material.type = 'XbsjPolylineArrowMaterial';
material.XbsjPolylineArrowMaterial = {};
material.XbsjPolylineArrowMaterial.color = JSON.parse(data.color);
break;
// 线
case 3:
material.type = 'XbsjODLineMaterial';
material.XbsjODLineMaterial = {};
material.XbsjODLineMaterial.color = JSON.parse(data.color);
material.XbsjODLineMaterial.totoalFrameCount = data.cycleFrame;
break;
}
lineOptions.material = material;
let currentChildArea: any = [];
if (childArea.length) {
childArea.forEach((element) => {
let obj = {};
if (data.id == element.parentCode) {
obj = {
expand: false,
title: element.name,
ref: 'nodeSecondary_' + element.id,
children: [],
};
let updatedPositions: any = [];
let positionsData = JSON.parse(element.positions);
if (!positionsData) {
positionsData = [];
}
updatedPositions = positionsData;
let lineOptions: any = {
maxShowHeight: 30000,
customProp: element.lineCode,
};
lineOptions.name = element.name;
lineOptions.xbsjType = 'Polyline';
lineOptions.width = element.width;
lineOptions.positions = updatedPositions;
lineOptions.loop = Boolean(element.isLoop);
lineOptions.depthTest = Boolean(element.isDepthCheck);
lineOptions.arcType = element.interpolation;
let material: any = {};
switch (element.materialType) {
// 线
case 0:
material.type = 'XbsjColorMaterial';
material.XbsjColorMaterial = {};
if (!element.color || element.color.length <= 0) {
element.color = '[1,1,1,1]';
}
material.XbsjColorMaterial.color = JSON.parse(element.color);
break;
// 线
case 1:
material.type = 'XbsjPolylineDashMaterial';
material.XbsjPolylineDashMaterial = {};
material.XbsjPolylineDashMaterial.color = JSON.parse(element.color);
material.XbsjPolylineDashMaterial.gapColor = JSON.parse(element.intervalColor);
material.XbsjPolylineDashMaterial.dashLength = element.dashLength;
material.XbsjPolylineDashMaterial.dashPattern = element.dashStyle;
break;
// 线
case 2:
material.type = 'XbsjPolylineArrowMaterial';
material.XbsjPolylineArrowMaterial = {};
material.XbsjPolylineArrowMaterial.color = JSON.parse(element.color);
break;
// 线
case 3:
material.type = 'XbsjODLineMaterial';
material.XbsjODLineMaterial = {};
material.XbsjODLineMaterial.color = JSON.parse(element.color);
material.XbsjODLineMaterial.totoalFrameCount = element.cycleFrame;
break;
}
let pos = [0, 0, 0];
positionsData.forEach((element) => {
pos[0] += element[0];
pos[1] += element[1];
pos[2] += element[2];
});
pos[0] = pos[0] / positionsData.length;
pos[1] = pos[1] / positionsData.length;
pos[2] = pos[2] / positionsData.length;
let pinBuilder = {
extTextFont: '30px 宋体',
extTextPixelOffset: [-40, 10],
fillColor: [0, 0.3450980392156863, 1, 0.9],
outlineColor: [1, 1, 1, 1],
extText: element.name,
};
let pin = addPin(element.name, hidePng, { position: pos, scale: 0.8, pinBuilder, far: 107374 });
lineOptions.pinXbsjGuid = pin.xbsjGuid;
lineOptions.material = material;
that._earth.sceneTree.root.children.push({ czmObject: lineOptions, ref: element.id });
currentChildArea.push(obj);
//
if (type == 1) {
this.nodeConfigByRef.set('nodeSecondary_' + element.id, obj);
}
}
});
}
//
const node = {
ref: 'node_' + data.id,
expand: false,
title: '<防区>' + data.name,
children: [
{
expand: false,
title: '监控点位',
ref: 'monitor_' + window.guid(),
children: [],
},
{
expand: false,
title: '雷达点位',
ref: 'ldList_' + window.guid(),
children: currentChildArea,
},
{
expand: false,
title: '微波点位',
ref: 'wbList_' + window.guid(),
children: [],
},
],
};
if (data.sceneId == models.ref) {
// console.log("");
//
//
models.children.push(node);
this.nodeConfigByRef.set(node.ref, node);
this.areaByNodeId.set(node.ref, data.sceneId);
// return
} else {
const childs = models.children;
for (const child of childs) {
if (child.ref == data.sceneId) {
//
// console.log("");
child.children.push(node);
this.nodeConfigByRef.set(node.ref, node);
this.areaByNodeId.set(node.ref, data.sceneId);
}
}
}
//
that._earth.sceneTree.root.children.push({ czmObject: lineOptions, ref: data.id });
});
//
childArea.forEach((data) => {});
this.$nextTick(() => {
const divs = $('#earthContainer>div>div>div:nth-child(5)')
.children('div')
.eq(1)
.children()
.eq(0)
.children()
.eq(0)
.children()
.each((index, element) => {
// const paddingLeft = $(element).children().eq(0).css('padding-left')
$(element).css('display', 'none');
});
});
// console.log("models",models);
resolve(models);
}
});
});
}
//
getCameraInfo(models, type) {
return new Promise((resolve, reject) => {
//线
defHttp.get({ url: this.url.queryCameraInfo }, { isTransformResponse: false }).then(async (res) => {
if (res.success) {
// console.log("res",res);
this.setCamera(res.result, models, type);
this.cameraData = res.result;
resolve(models);
}
});
});
}
async setCamera(res, models, type) {
//
let posArr: any = [],
updatedPositions: any = [];
const that = this;
//
if (window.$earth.sceneTree.$refs.terrain.czmObject.show) {
res.forEach((data, index) => {
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
posArr.push(window.Cesium.Cartographic.fromDegrees(data.longitude, data.latitude));
});
}
});
var promise = window.Cesium.sampleTerrainMostDetailed(this._viewer.terrainProvider, posArr);
updatedPositions = await window.Cesium.when(promise);
} else {
res.forEach((data, index) => {
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
updatedPositions.push(window.Cesium.Cartographic.fromDegrees(data.longitude, data.latitude, 0));
});
}
});
}
// console.log("",res);
// console.log("",updatedPositions);
//线
res.forEach((data, index) => {
// console.log("data",data);
let siteConfig: any = null;
const lineId = data.id;
let childs: any = null;
if (type == 2) {
childs = models.children;
for (const child of childs) {
if ('node_' + data.id == child.ref) {
siteConfig = child.children[0];
}
}
} else {
const parentNode = that.nodeConfigByRef.get('node_' + data.id);
if (!parentNode) {
return;
}
childs = parentNode.children;
siteConfig = childs[0];
// console.log("parentNode",parentNode);
}
if (!siteConfig) {
return;
}
if (data.msCameraSiteList != null) {
data.msCameraSiteList.forEach((data, index) => {
// 线
let num = 0;
if (data.msCameraSettingList != null) {
data.msCameraSettingList.forEach((data, index) => {
if (data.status == '3') {
//1-线2-线3-
num = num + 1;
}
});
}
let gltfStr;
if (!data.modelUrl) {
return;
}
let fileInfos = data.modelUrl.split('.');
if (num == 0) {
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + fileInfos[0] + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + fileInfos[0] + '.' + fileInfos[1];
} else if (num < data.msCameraSettingList.length) {
let newName = fileInfos[0].substring(0, fileInfos[0].length - 1) + 'R';
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + newName + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + newName + '.' + fileInfos[1];
} else if (num == data.msCameraSettingList.length) {
let newName = fileInfos[0].substring(0, fileInfos[0].length - 1) + 'Y';
// gltfStr = window._CONFIG['domianURL'] + '/sys/common/static/' + newName + '.' + fileInfos[1];
gltfStr = '/dt/sys/common/static/' + newName + '.' + fileInfos[1];
}
const modelConfig = {
ref: data.id,
name: lineId,
czmObject: {
name: data.sitename,
xbsjType: 'Model',
url: gltfStr,
// "color": [0.52, 0.6, 0.58, 1],
minimumPixelSize: data.minimumPixelSize,
// maximumScale: 0.02,
scale: data.scale,
xbsjScale: data.xyzScale ? data.xyzScale.split(',') : [1, 1, 1],
xbsjPosition: [window.Cesium.Math.toRadians(data.longitude), window.Cesium.Math.toRadians(data.latitude), data.height],
xbsjRotation: [
window.Cesium.Math.toRadians(data.yaw),
window.Cesium.Math.toRadians(data.pitch),
window.Cesium.Math.toRadians(data.roll),
],
viewDistance: 150,
distanceDisplayCondition: [1.0, 30000.0],
customProp: data.id,
},
};
window.$earth.sceneTree.root.children.push(modelConfig);
//
window.$earth.sceneTree.$refs[data.id].czmObject.onmouseover = () => {
this._viewer._container.style.cursor = 'pointer';
};
window.$earth.sceneTree.$refs[data.id].czmObject.onmouseout = () => {
this._viewer._container.style.cursor = 'default';
};
this.$nextTick(() => {
const divs = $('#earthContainer>div>div>div:nth-child(5)')
.children('div')
.eq(1)
.children()
.eq(0)
.children()
.eq(0)
.children()
.each((index, element) => {
$(element).css('display', 'none');
});
});
//
let cameraList: any = [];
if (data.msCameraSettingList) {
for (let camera of data.msCameraSettingList) {
let name = camera.cameraName;
const obj = {
ref: 'camera_' + camera.id,
expand: false,
title: name,
czmObject: {
name: name,
xbsjType: 'Model',
},
};
// let id = camera.id
cameraList.push(obj);
// 线
}
}
//
const node = {
ref: 'node_' + data.id,
title: data.sitename,
expand: false,
children: cameraList,
};
siteConfig.children.push(node);
});
}
});
}
//
async getLabelInfo(models, type) {
@ -1962,6 +1572,104 @@
});
}
// /* */
listenMouseHandlerSence(enablePointer,that){
this.viewer = window.$earth.czm.viewer;
window.viewer = this.viewer;
window.$earth.interaction.picking.enabled = true;
window.$earth.interaction.picking.clickedColor = [1, 0, 0, 1];
const handler = new window.Cesium.ScreenSpaceEventHandler(
this.viewer.scene.canvas
);
window.CesiumGlobalHandler = handler;
//
this.viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(
window.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK
);
if (enablePointer) {
this.viewer.cesiumWidget.screenSpaceEventHandler.setInputAction((event) => {
let cartesian = this.viewer.scene.globe.pick(this.viewer.camera.getPickRay(event.position), this.viewer.scene);
if (!cartesian) {
return;
}
//
let ellipsoid = this.viewer.scene.globe.ellipsoid;
let cartographic = ellipsoid.cartesianToCartographic(cartesian);
//
let pointLon = window.Cesium.Math.toDegrees(cartographic.longitude); //
let pointLat = window.Cesium.Math.toDegrees(cartographic.latitude); //
let pointAlt = cartographic.height; //
console.log("点击的的经纬度坐标是:", {
"经度:": pointLon,
"纬度:": pointLat
});
this.pin && this.pin.destroy();
this.pin = new window.XE.Obj.Pin(window.$earth);
this.pin.position = [cartographic.longitude, cartographic.latitude, pointAlt];
this.pin.imageUrl = dwPng;
let cposition = [window.$earth.camera.position[0], window.$earth.camera.position[1], window.$earth.camera.position[2]];
if (this.pin) {
this.position = [this.pin.position[0], this.pin.position[1], this.pin.position[2]];
}
this.rotation = [window.$earth.camera.rotation[0], window.$earth.camera.rotation[1], window.$earth.camera.rotation[2]];
this.fov = window.$earth.camera.fov;
this.$emit("checkPosition", this.position, cposition, this.rotation, this.fov);
},
window.Cesium.ScreenSpaceEventType.LEFT_CLICK
);
}
// /* */
handler.setInputAction((event) => {
handler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
// modelDw.value = false;
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
this.cursorCss = `grabbing`;
}, window.Cesium.ScreenSpaceEventType.LEFT_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
this.cursorCss = `grab`;
}, window.Cesium.ScreenSpaceEventType.LEFT_UP);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
this.cursorCss = `url(${rotationXYZ}),grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
this.cursorCss = `grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_UP);
let clearId: any = null;
handler.setInputAction((event) => {
if (event > 0) {
this.cursorCss = `zoom-in`;
} else {
this.cursorCss = `zoom-out`;
}
clearId = setTimeout(() => {
clearTimeout(clearId);
this.cursorCss = `grab`
}, 2000);
}, window.Cesium.ScreenSpaceEventType.WHEEL);
}
listenMouseHandler(earthUI = null) {
let that: any = this;
this._handler = new window.Cesium.ScreenSpaceEventHandler(this._viewer.scene.canvas);
@ -1979,7 +1687,7 @@
}
let pickedFeature = this._viewer.scene.pick(click.position);
// console.log(':', pickedFeature);
console.log('点击:', pickedFeature);
if (pickedFeature && pickedFeature.id) {
//
@ -2052,19 +1760,16 @@
JSON.parse(pickedFeature.id._xbsjOwner.customProp).labelAttr == '4'
) {
let labelCode = JSON.parse(pickedFeature.id._xbsjOwner.customProp).labelCode;
console.log('点击雷达:', pickedFeature.id._xbsjOwner);
console.log(pickedFeature.id._xbsjOwner);
if (pickedFeature.id._xbsjOwner.addViewShedReturn) {
///
// pickedFeature.id._xbsjOwner.addViewShedReturn.show = !pickedFeature.id._xbsjOwner.addViewShedReturn.show;
// console.log("pickedFeature.id._xbsjOwner.addViewShedReturn",pickedFeature.id._xbsjOwner.addViewShedReturn);
//undefined()
console.log('关闭扫描');
pickedFeature.id._xbsjOwner.addViewShedReturn.clear();
pickedFeature.id._xbsjOwner.addViewShedReturn = undefined;
} else {
console.log('打开扫描');
defHttp.get({ url: this.url.radarList, params: { radarCode: labelCode } }, { isTransformResponse: false }).then((res) => {
if (res.success) {
if (res.result.records.length > 0) {
@ -3673,22 +3378,7 @@
this.addModelWinShow = true;
});
//////////////////////////
// getBind
// this._earthUI.showPropertyWindow(
// {
// czmObject: sn.czmObject,
// node: item,
// type: 'jkd',
// lineId: lineId,
// areaCode: areaCode,
// areaByNodeId: that.areaByNodeId,
// },
// {
// // component: addModelModal,
// component: addModelWin,
// }
// )
return;
}
} else {
@ -3712,25 +3402,7 @@
this.addModelWinShow = true;
});
// getBind
// this._earthUI.showPropertyWindow(
// {
// czmObject: sn.czmObject,
// node: item,
// type: jsonObj.labelAttr == 4 ? 'ld' : 'wb',
// lineId: lineId,
// areaCode: areaCode,
// areaByNodeId: that.areaByNodeId,
// eidtId: sn.ref,
// setLabelStatus: that.setLabelStatus,
// setIconByRef: that.setIconByRef,
// el: el,
// },
// {
// // component: addModelModal,
// component: addModelWin,
// }
// )
return;
}
}

827
src/views/military/modules/earthMap/scene/model/mapModel/EarthMapModal copy.vue

@ -0,0 +1,827 @@
<template>
<a-modal :title="title" :visible="visible" @ok="handleOk" @cancel="handleCancel" width="60vw" :destroyOnClose="true"
wrapClassName="EarthMap">
<a-row>
<a-col :span="24">
<div id="earthContainer" :style="{ cursor: cursorCss }"></div>
<!-- <span class="mapManage" @click="() => { mapManageShow = !mapManageShow }">
<a-icon type="setting" theme="filled" />
</span> -->
<span :class="['scaleWin', 'iconSpan', scaleWin.status ? 'colorBlue' : '']" title="放大或缩小" @click="scaleWinFunc">
<ExpandOutlined v-if="!scaleWin.status" />
<CompressOutlined v-else />
</span>
<span :class="['mapModel', 'iconSpan']" @click="modelChange" title="地图维度切换">
{{ modelText == "2D" ? "3D" : "2D" }}
</span>
<template v-if="editTileModel != undefined && modelText == '3D'">
<span class="buildManage iconSpan" @click="enableTileChange" title="建筑加载">
<img src="../../../../../../../assets/images/build_close.png" class="iconSize" v-show="!enableTile" />
<img src="../../../../../../../assets/images/build_able.png" class="iconSize" v-show="enableTile" />
</span>
<span class="modelDw iconSpan" @click="modelDwFunc" title="模型跟随鼠标">
<img src="../../../../../../../assets/images/dw_close.png" class="iconSize" v-show="!modelDw" />
<img src="../../../../../../../assets/images/dw_able.png" class="iconSize" v-show="modelDw" />
</span>
<span class="modelMove iconSpan" @click="modelMoveFunc" title="模型移动">
<img src="../../../../../../../assets/images/move_close.png" class="iconSize" v-show="!modelMove" />
<img src="../../../../../../../assets/images/move_able.png" class="iconSize" v-show="modelMove" />
</span>
<span class="modelRotation iconSpan" @click="modelRotationFunc" title="模型旋转">
<img src="../../../../../../../assets/images/rotation_close.png" class="iconSize" v-show="!modelRotation" />
<img src="../../../../../../../assets/images/rotation_able.png" class="iconSize" v-show="modelRotation" />
</span>
<span class="modelScale iconSpan" title="缩放">
<a-tooltip placement="left" trigger="click"
:getPopupContainer="(triggerNode) => { return triggerNode.parentElement }">
<img src="../../../../../../../assets/images/scale_close.png" class="iconSize" v-show="!modelScaleStatus"
@click="modelScaleStatusChange" />
<img src="../../../../../../../assets/images/scale_able.png" class="iconSize" v-show="modelScaleStatus"
@click="modelScaleStatusChange" />
<template #title>
<div class="sliderContainer">
<a-row class="sliderRow">
<a-col :span="4">
X轴:
</a-col>
<a-col :span="11">
<a-slider v-model:value="scaleValues[0]" :min="scaleConfig.X.min" :max="scaleConfig.X.max"
:step="scaleConfig.X.step" />
</a-col>
<a-col :span="6">
<a-input-number v-model:value="scaleValues[0]" :min="scaleConfig.X.min" :max="scaleConfig.X.max"
:step="scaleConfig.X.step" style="width:100%"></a-input-number>
</a-col>
<a-col :span="2" :offset="1" @click="() => { scaleConfig.X.show = !scaleConfig.X.show }">
<SettingOutlined :style="{ color: scaleConfig.X.show ? '#1296db' : '#FFF' }" />
</a-col>
</a-row>
<a-row v-show="scaleConfig.X.show" type="flex" justify="space-around" align="middle" :gutter="[0, 12]">
<a-col :span="8">
最小值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.X.min" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
最大值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.X.max" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
步长:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.X.step" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="24" class="sliderRow">
<a-button type="primary" class="fill-9-row" @click="() => { allSetting('X') }">应用全部</a-button>
</a-col>
</a-row>
<a-row class="sliderRow">
<a-col :span="4">
Y轴:
</a-col>
<a-col :span="11">
<a-slider v-model:value="scaleValues[1]" :min="scaleConfig.Y.min" :max="scaleConfig.Y.max"
:step="scaleConfig.Y.step" />
</a-col>
<a-col :span="6">
<a-input-number v-model:value="scaleValues[1]" :min="scaleConfig.Y.min" :max="scaleConfig.Y.max"
:step="scaleConfig.Y.step" style="width:100%"></a-input-number>
</a-col>
<a-col :span="2" :offset="1" @click="() => { scaleConfig.Y.show = !scaleConfig.Y.show }">
<SettingOutlined :style="{ color: scaleConfig.X.show ? '#1296db' : '#FFF' }" />
</a-col>
</a-row>
<a-row v-show="scaleConfig.Y.show" type="flex" justify="space-around" align="middle" :gutter="[0, 12]">
<a-col :span="8">
最小值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Y.min" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
最大值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Y.max" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
步长:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Y.step" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="24" class="sliderRow">
<a-button type="primary" class="fill-9-row" @click="() => { allSetting('Y') }">应用全部</a-button>
</a-col>
</a-row>
<a-row class="sliderRow">
<a-col :span="4">
Z轴:
</a-col>
<a-col :span="11">
<a-slider v-model:value="scaleValues[2]" :min="scaleConfig.Z.min" :max="scaleConfig.Z.max"
:step="scaleConfig.Z.step" />
</a-col>
<a-col :span="6">
<a-input-number v-model:value="scaleValues[2]" :min="scaleConfig.Z.min" :max="scaleConfig.Z.max"
:step="scaleConfig.Z.step" style="width:100%"></a-input-number>
</a-col>
<a-col :span="2" :offset="1" @click="() => { scaleConfig.Z.show = !scaleConfig.Z.show }">
<SettingOutlined :style="{ color: scaleConfig.X.show ? '#1296db' : '#FFF' }" />
</a-col>
</a-row>
<a-row v-show="scaleConfig.Z.show" type="flex" justify="space-around" align="middle" :gutter="[0, 12]">
<a-col :span="8">
最小值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Z.min" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
最大值:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Z.max" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="8">
步长:
</a-col>
<a-col :span="16">
<a-input-number v-model:value="scaleConfig.Z.step" class="fill-9-row"></a-input-number>
</a-col>
<a-col :span="24" class="sliderRow">
<a-button type="primary" class="fill-9-row" @click="() => { allSetting('Z') }">应用全部</a-button>
</a-col>
</a-row>
</div>
</template>
</a-tooltip>
</span>
</template>
</a-col>
</a-row>
</a-modal>
</template>
<script setup>
import { toRefs, watch, nextTick, ref, reactive, onMounted, getCurrentInstance } from 'vue';
import { message } from 'ant-design-vue';
import { useEarthMapStore } from '/@/store/modules/earthMap';
import rotationXYZ from '@/assets/images/rotationXYZ.png';
import { defHttp } from '@/utils/http/axios';
import { FormatPainterOutlined, SettingOutlined, ExpandOutlined, GatewayOutlined, ZoomInOutlined, ZoomOutOutlined, CompressOutlined } from '@ant-design/icons-vue';
// import dwPng from '/@/assets/images/dwPng.png';
import dwPng from '@/assets/images/rotationXYZ.png';
import { drawPolygonSave, drawGeoSmoothPolygon } from "@/utils/earthMap/earthDraw";
const store = useEarthMapStore();
const { proxy } = getCurrentInstance();
//
const getMapPage = (params) => defHttp.get({ url: "/military/msMapManage/list/page", params: params }, { isTransformResponse: false });
//
const cursorCss = ref("grab");
const props = defineProps(['title', 'visible', 'hasMoveMethod', 'initModeType', 'editTileModel', 'enableTile', 'enablePointer']);
const { title, visible, hasMoveMethod, initModeType, editTileModel, enablePointer } = toRefs(props);
//
const enableTile = ref(props.enableTile);
const pointerXyz = ref([]);
const defaultPinUrl = "../";
const emit = defineEmits(["closeWin", "checkPosition", "moveChinaPosition"])
//
const handleOk = function () {
let position = null;
let rotation = null;
let fov = null;
if (CModel.value) {
position = [...CModel.value.czmObject.xbsjPosition];
rotation = [...CModel.value.czmObject.xbsjRotation];
emit("checkPosition", position, rotation, [...scaleValues.value]);
} else {
let cposition = [window.earth.camera.position[0], window.earth.camera.position[1], window.earth.camera.position[2]];
if (pin) {
position = [pin.position[0], pin.position[1], pin.position[2]];
}
rotation = [window.earth.camera.rotation[0], window.earth.camera.rotation[1], window.earth.camera.rotation[2]];
fov = window.earth.camera.fov;
emit("checkPosition", position, cposition, rotation, fov);
}
handleCancel();
}
const handleCancel = function () {
emit("closeWin");
}
//
let earth = undefined;
let _viewer = undefined;
watch(
visible, async (value, oldValue) => {
//
if (value) {
await nextTick()
//
window.XE.ready().then(() => {
//
return window.XE.HTML.loadJS('/earthsdk/XbsjEarth-Plugins/plottingSymbol/plottingSymbol.js');
}).then(async () => {
earth = new window.XE.Earth('earthContainer');
window.earth = window.$earth = earth
window.$viewer = _viewer = window.earth.czm.viewer;
initMode();
listenMouseHandler();
listenMouseHandlerSelect();
addContainerClickListen();
await getDataSource();
moveChinaPosition();
});
} else {
//
destroyCache();
}
}
)
const mapManageShow = ref(false);
const modelText = ref('2D');
const modelChange = function () {
const viewer = window.earth.czm.viewer;
if (modelText.value == '3D') {
// 2D
// const loyauts = window.earth.sceneTree.$refs["loyauts"].children;
// loyauts.forEach(loyaut => {
// loyaut.enabled = false;
// });
modelText.value = "2D";
enableTile.value = false;
if (CModel.value) {
// CModel.value.show = false;
if (modelDw.value) {
modelDwFunc();
}
if (modelMove.value) {
modelMoveFunc();
}
if (modelRotation.value) {
modelRotationFunc();
}
}
viewer.scene.morphTo2D(0)
} else {
viewer.scene.morphTo3D(0)
modelText.value = "3D";
}
}
const enableTileChange = function () {
if (modelText.value != "3D") {
message.info("2D切片。若要加载切片,请切换至3D模式!")
return;
}
enableTile.value = !enableTile.value;
}
const initMode = function () {
const viewer = window.earth.czm.viewer;
// initModeType2D
if (!initModeType.value) {
modelText.value = "3D"
viewer.scene.morphTo3D(0)
return;
}
// 2D
if (initModeType.value == "2D") {
modelText.value = "3D"
viewer.scene.morphTo2D(0)
} else if (initModeType.value == "3D") {
// 3D
modelText.value = "3D"
viewer.scene.morphTo3D(0)
}
}
const CModel = ref(null);
//
const editTileModelFunc = function (root) {
//
if (!editTileModel || !editTileModel.value) {
return;
}
//
const modelObj = {
ref: editTileModel.value.custom.id,
czmObject: editTileModel.value.czmObject,
enabled: true,
}
//
root.push(modelObj);
//
CModel.value = window.earth.sceneTree.$refs[editTileModel.value.custom.id];
//
CModel.value.enabled = true;
CModel.value.czmObject.enabled = true;
//
scaleValues.value = [...CModel.value.czmObject.xbsjScale];
}
const moveChinaPosition = function () {
// moveChinaPosition
if (hasMoveMethod.value) {
emit('moveChinaPosition');
} else {
//
window.earth.camera.fov = 1.0471975511965976;
window.earth.camera.position = [1.8833961240252113, 0.6131398723508994, 8921610.846366767];
window.earth.camera.rotation = [6.283185307179586, -1.5704896980852325, 0]
}
}
let viewer = undefined;
//
const cssGrab = function (e) {
const buttonNum = e.button;
if (buttonNum == 0) {
cursorCss.value = `grabbing`;
} else if (buttonNum == 1) {
cursorCss.value = `${rotationXYZ}`;
}
}
//
const addContainerClickListen = function () {
const dom = document.getElementById("earthContainer");
dom.addEventListener("mousedown", cssGrab, true)
// dom.addEventListener("mouseup", cssGrab)
}
//
const modelFollowMouse = (event) => {
if (CModel.value && modelText.value == "3D") {
if (CModel.value.enabled == false) {
CModel.value.enabled = true;
}
//
//
let cartesian = viewer.scene.globe.pick(viewer.camera.getPickRay(event.endPosition), viewer.scene);
if (!cartesian) {
return;
}
//
let ellipsoid = viewer.scene.globe.ellipsoid;
let cartographic = ellipsoid.cartesianToCartographic(cartesian);
let lon = cartographic.longitude; //
let lat = cartographic.latitude; //
// let alt = cartographic.height; //
let alt = 0; //
CModel.value.czmObject.xbsjPosition = [lon, lat, alt];
}
}
let pin = undefined;
//
const listenMouseHandler = function () {
viewer = window.earth.czm.viewer;
window.viewer = viewer;
window.earth.interaction.picking.enabled = true;
window.earth.interaction.picking.clickedColor = [1, 0, 0, 1];
const handler = new window.Cesium.ScreenSpaceEventHandler(
viewer.scene.canvas
);
window.CesiumGlobalHandler = handler;
//
viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(
window.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK
);
// handler.setInputAction(modelFollowMouse, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
if (enablePointer.value) {
viewer.cesiumWidget.screenSpaceEventHandler.setInputAction((event) => {
let cartesian = viewer.scene.globe.pick(viewer.camera.getPickRay(event.position), viewer.scene);
if (!cartesian) {
return;
}
//
let ellipsoid = viewer.scene.globe.ellipsoid;
let cartographic = ellipsoid.cartesianToCartographic(cartesian);
//
let pointLon = Cesium.Math.toDegrees(cartographic.longitude); //
let pointLat = Cesium.Math.toDegrees(cartographic.latitude); //
let pointAlt = cartographic.height; //
console.log("点击的的经纬度坐标是:", {
"经度:": pointLon,
"纬度:": pointLat
});
pin && pin.destroy();
pin = new window.XE.Obj.Pin(window.earth);
pin.position = [cartographic.longitude, cartographic.latitude, pointAlt];
pin.imageUrl = dwPng;
},
window.Cesium.ScreenSpaceEventType.LEFT_CLICK
);
}
// /* */
handler.setInputAction((event) => {
handler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
modelDw.value = false;
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grabbing`;
}, window.Cesium.ScreenSpaceEventType.LEFT_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grab`;
}, window.Cesium.ScreenSpaceEventType.LEFT_UP);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `url(${rotationXYZ}),grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_DOWN);
handler.setInputAction((event) => {
if (clearId != null) {
clearTimeout(clearId);
clearId = null;
}
cursorCss.value = `grab`;
}, window.Cesium.ScreenSpaceEventType.MIDDLE_UP);
let clearId = null;
handler.setInputAction((event) => {
if (event > 0) {
cursorCss.value = `zoom-in`;
} else {
cursorCss.value = `zoom-out`;
}
clearId = setTimeout(() => {
clearTimeout(clearId);
cursorCss.value = `grab`
}, 2000);
}, window.Cesium.ScreenSpaceEventType.WHEEL);
// window.earth.onclick = function () {
// console.log(1);
// }
}
//-
const listenMouseHandlerSelect = function () {
// window.$earth.interaction.picking.enabled = true;
// window.$earth.interaction.picking.clickedColor = [1, 0, 0, 1];
const _handler = new window.Cesium.ScreenSpaceEventHandler(
_viewer.scene.canvas
);
// window.CesiumGlobalHandler = handler;
//
_viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(
window.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK
);
_handler.setInputAction((click) => {
//
// `primitive`
let pickedFeature = _viewer.scene.pick(click.position);
// console.log("pick", pickedFeature);
let entity = pickedFeature && pickedFeature.id;
if (entity == undefined) { return; }
//
else if (typeof pickedFeature !== 'undefined' && entity.name == '区域选取') {
console.log("entity", entity);
//
entity.showProperty()
}
}, window.Cesium.ScreenSpaceEventType.RIGHT_CLICK); //
}
//
const getDataSource = async function () {
const params = {
pageNo: 1,
pageSize: 9999,
status: 1,
}
return getMapPage(params).then(
(res) => {
if (res.code == 200) {
const loyaut = {
ref: "loyauts",
expand: false,
title: "地图图层",
children: []
}
const records = res.result.records;
records.forEach(item => {
const czmObject = JSON.parse(item.czmObject);
const child = {
ref: item.id,
czmObject: czmObject,
enabled: true,
}
loyaut.children.push(child);
});
window.earth.sceneTree.root.children.push(loyaut);
const loyauts = window.earth.sceneTree.$refs["loyauts"].children;
editTileModelFunc(loyauts);
//
watch([modelText, enableTile], ([newVal, newVal1], [oldValue, oldValue1]) => {
// 3D
if (newVal == "3D" && newVal1) {
loyauts.forEach(loyaut => {
if (loyaut.czmObject.xbsjType == "Tileset") {
loyaut.enabled = true;
}
if (CModel.value) {
CModel.value.enabled = true;
}
});
} else if (newVal == "2D" || !newVal1) {
// 3D
loyauts.forEach(loyaut => {
if (loyaut.czmObject.xbsjType == "Tileset") {
loyaut.enabled = false;
}
if (CModel.value) {
CModel.value.enabled = false;
}
});
}
})
} else {
message.error("无法显示数据!");
}
}
).catch(
(e) => {
message.error("无法显示数据!");
}
)
}
//
const scaleWin = reactive({
status: false
})
const scaleWinFunc = function () {
const el = document.getElementsByClassName("EarthMap")[0].querySelector(".ant-modal-content");
if (!scaleWin.status) {
const width = window.innerWidth;
el.setAttribute("style", `width:${width}px;position:fixed;left:0;top:0;`);
scaleWin.status = true;
} else {
el.removeAttribute("style");
scaleWin.status = false;
}
}
//
const modelDw = ref(false);
const modelDwFunc = function (e) {
modelScaleStatus.value = false;
if (!modelDw.value) {
window.CesiumGlobalHandler.setInputAction(
modelFollowMouse, window.Cesium.ScreenSpaceEventType.MOUSE_MOVE
);
modelDw.value = true;
} else {
window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
modelDw.value = false
}
}
//
const modelMove = ref(false);
const modelMoveFunc = function (e) {
if (!CModel.value) {
return;
}
if (!modelMove.value) {
if (CModel.value.enabled == false) {
CModel.value.enabled = true;
}
CModel.value.czmObject.positionEditing = true;
modelRotation.value = false;
modelMove.value = true;
} else {
CModel.value.czmObject.positionEditing = false;
modelMove.value = false
}
}
//
const modelRotation = ref(false);
const modelRotationFunc = function (e) {
if (!CModel.value) {
return;
}
if (!modelRotation.value) {
if (CModel.value.enabled == false) {
CModel.value.enabled = true;
}
CModel.value.czmObject.rotationEditing = true;
modelMove.value = false;
modelRotation.value = true;
} else {
CModel.value.czmObject.rotationEditing = false;
modelRotation.value = false
}
}
//
const scaleValues = ref([1, 1, 1]);
const modelScaleStatus = ref(false);
//
const modelScaleStatusChange = function () {
modelScaleStatus.value = !modelScaleStatus.value;
}
//
const scaleConfigObj = {
X: {
min: -10,
max: 10,
step: 1,
show: false,
},
Y: {
min: -10,
max: 10,
step: 1,
show: false,
},
Z: {
min: -10,
max: 10,
step: 1,
show: false,
},
};
const scaleConfig = ref(
{
...scaleConfigObj
}
)
// xyz
const allSetting = function (propName) {
const keys = Object.keys(scaleConfig.value);
const beCopyObj = scaleConfig.value[propName];
keys.forEach(key => {
scaleConfig.value[key] = { ...beCopyObj, show: scaleConfig.value[key].show }
});
}
//
watch(scaleValues, (new_scale, scale) => {
if (!CModel.value || !CModel.value.czmObject) {
return;
}
CModel.value.czmObject.xbsjScale = new_scale;
}, {
deep: true
})
//
const destroyCache = function () {
scaleConfig.value = { ...scaleConfigObj };
scaleValues.value = [1, 1, 1];
modelRotation.value = false;
modelMove.value = false;
scaleWin.value = false;
modelScaleStatus.value = false;
modelDw.value = false;
enableTile.value = false;
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.LEFT_DOWN)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.LEFT_UP)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MIDDLE_DOWN)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MIDDLE_UP)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.WHEEL)
CModel.value && CModel.value.destroy();
earth && earth.destroy();
modelText.value = "2D";
scaleWin.status = false;
}
defineExpose(
{
CModel
}
);
</script>
<style scoped>
.fill-9-row {
width: 90%;
}
.sliderRow {
display: flex;
justify-content: center;
align-items: center;
min-height: 50px;
}
.sliderContainer {
width: 200px;
}
.iconSize {
width: 16px;
height: 16px;
}
.colorBlue {
color: #1296db !important;
}
.iconSpan {
color: #fff;
display: block;
width: 36px;
height: 36px;
font-size: 16px;
font-style: normal;
line-height: 36px;
text-align: center;
text-transform: none;
text-rendering: auto;
background-color: rgba(0, 0, 0, 0.4);
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
}
.selectIcon {
position: absolute;
top: 108px;
left: 0;
}
.clearIcon {
position: absolute;
top: 144px;
left: 0;
}
.modelScale {
position: absolute;
top: 252px;
left: 0;
}
.modelRotation {
position: absolute;
top: 216px;
left: 0;
}
.modelMove {
position: absolute;
top: 180px;
left: 0;
}
.modelDw {
position: absolute;
top: 144px;
left: 0;
}
.scaleWin {
position: absolute;
top: 36px;
left: 0;
}
.mapModel {
position: absolute;
top: 72px;
left: 0;
}
.buildManage {
position: absolute;
top: 108px;
left: 0;
}
:deep(.ant-modal-body) {
padding: 0px !important;
}
:deep(.ant-modal-close-x) {
color: #fff;
background-color: rgba(0, 0, 0, 0.4);
width: 36px;
height: 36px;
line-height: 36px;
}
</style>

12
src/views/military/modules/earthMap/scene/model/mapModel/EarthMapModal.vue

@ -358,7 +358,6 @@ const cssGrab = function (e) {
const addContainerClickListen = function () {
const dom = document.getElementById("earthContainer");
dom.addEventListener("mousedown", cssGrab, true)
// dom.addEventListener("mouseup", cssGrab)
}
//
const modelFollowMouse = (event) => {
@ -399,7 +398,6 @@ const listenMouseHandler = function () {
viewer.cesiumWidget.screenSpaceEventHandler.removeInputAction(
window.Cesium.ScreenSpaceEventType.LEFT_DOUBLE_CLICK
);
// handler.setInputAction(modelFollowMouse, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
if (enablePointer.value) {
viewer.cesiumWidget.screenSpaceEventHandler.setInputAction((event) => {
@ -472,9 +470,7 @@ const listenMouseHandler = function () {
cursorCss.value = `grab`
}, 2000);
}, window.Cesium.ScreenSpaceEventType.WHEEL);
// window.earth.onclick = function () {
// console.log(1);
// }
}
//-
const listenMouseHandlerSelect = function () {
@ -696,12 +692,6 @@ const destroyCache = function () {
modelDw.value = false;
enableTile.value = false;
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MOUSE_MOVE)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.LEFT_DOWN)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.LEFT_UP)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MIDDLE_DOWN)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.MIDDLE_UP)
// window.CesiumGlobalHandler.removeInputAction(window.Cesium.ScreenSpaceEventType.WHEEL)
CModel.value && CModel.value.destroy();
earth && earth.destroy();

85
src/views/military/modules/earthMap/scene/model/sceneInfo/SenceInfo.vue

@ -115,20 +115,20 @@
:hasMoveMethod="subObject && subObject.id ? true : false"
@moveChinaPosition="moveChinaPosition"
></EarthMapModal> -->
<a-modal
title="拾取中心坐标和相机数据"
:visible="mapVisible"
@ok="handleOk"
@cancel="destroyed"
width="60vw"
destroyOnClose
<a-modal title="拾取中心坐标和相机数据" :visible="mapVisible" @ok="earthMapOk" @cancel="destroyed" width="60vw" destroyOnClose
wrapClassName="EarthMap">
<a-row style="height: 60vh;">
<a-col :span="24">
<EarthComp ref="earth"/>
</a-col>
</a-row>
<a-row style="height: 60vh;">
<a-col :span="24">
<EarthComp
ref="earth"
@customFly="moveChinaPosition"
:hasMoveMethod="subObject && subObject.id ? true : false"
:enablePointer="true"
:listenMouseHandlerSenceOpen="true"
@checkPosition="checkPositionCache"
/>
</a-col>
</a-row>
</a-modal>
@ -142,16 +142,17 @@ import { defHttp } from '@/utils/http/axios';
import { message } from 'ant-design-vue';
import { EditOutlined } from '@ant-design/icons-vue';
import EarthComp from '@/views/earthMap/edit/EarthComp.vue';
// import EarthComp from '@/views/earthMap/edit/EarthCompTest.vue';
//subObjectok checkPosition
let subObjectCache= ref({});
const earth = ref()
function destroyed() {
console.log("earth",earth.value);
// console.log("earth", earth.value);
earth.value.destroy();
nextTick(()=>{
nextTick(() => {
mapVisible.value = false
})
}
@ -232,22 +233,20 @@ onMounted(async () => {
});
//
const moveChinaPosition = function () {
// console.log('moveChinaPosition',subObject.value);
window.earth.camera.fov = subObject.value.viewDistance;
// window.earth.camera.position = [subObject.value.lon, subObject.value.lat, subObject.value.altitude];
//
window.earth.camera.position = [subObject.value.cameraLon, subObject.value.cameraLat, subObject.value.cameraAltitude];
window.earth.camera.rotation = [subObject.value.rotationX, subObject.value.rotationY, subObject.value.rotationZ];
// console.log('movePosition', subObject.value);
if (subObject.value.id) {
window.$earth.camera.fov = subObject.value.viewDistance;
//
window.$earth.camera.position = [subObject.value.cameraLon, subObject.value.cameraLat, subObject.value.cameraAltitude];
window.$earth.camera.rotation = [subObject.value.rotationX, subObject.value.rotationY, subObject.value.rotationZ];
return
}
//
window.$earth.camera.fov = 1.0471975511965976;
window.$earth.camera.position = [1.8833961240252113, 0.6131398723508994, 8921610.846366767];
window.$earth.camera.rotation = [6.283185307179586, -1.5704896980852325, 0]
};
// const stop = watch(
// visible, (value, oldValue) => {
// if (value) {
// initMap()
// stop();
// }
// }
// )
//
const mapVisible = ref(false);
@ -270,6 +269,27 @@ const checkPosition = function (position, cameraPosition, rotation, fov) {
subObject.value.viewDistance = fov;
};
function checkPositionCache(position, cameraPosition, rotation, fov){
console.log("接收到了",position);
subObjectCache.value.position = position
subObjectCache.value.cameraPosition = cameraPosition;
subObjectCache.value.rotation = rotation;
subObjectCache.value.fov = fov;
}
function earthMapOk(){
checkPosition(
subObjectCache.value.position,
subObjectCache.value.cameraPosition,
subObjectCache.value.rotation,
subObjectCache.value.fov
)
destroyed()
}
//
const preViewUrl = computed({
get: () => {
@ -360,4 +380,5 @@ defineExpose({
:deep(.ant-select) {
width: 90%;
}</style>
}
</style>

Loading…
Cancel
Save