Revert "自定义,实例右键点击菜单,sdk右键菜单默认关闭,二维影像的渲染"
This reverts commit bf0b2c0633.
This commit is contained in:
@ -1,7 +1,7 @@
|
||||
server:
|
||||
host: 127.0.0.1
|
||||
port: 8848
|
||||
path: C:\Users\Administrator\AppData\Roaming\dzsp_shijingjun_offline_Y_save
|
||||
path: C:\Users\MSI\AppData\Roaming\dzsp_shijingjun_offline_Y_save
|
||||
poi:
|
||||
global:
|
||||
enabled: false
|
||||
|
||||
Binary file not shown.
@ -39,12 +39,6 @@ export const TsApi = {
|
||||
data
|
||||
})
|
||||
},
|
||||
updateTsSource: async (data: any) => {
|
||||
return await request.post({
|
||||
url: '/tsSource/update',
|
||||
data
|
||||
})
|
||||
},
|
||||
///tsSource/addModelSource
|
||||
addTsModelSource: async (data: any) => {
|
||||
return await request.post({
|
||||
|
||||
@ -1 +0,0 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="12" height="12" viewBox="0 0 12 12" fill="none"><path d="M5.25 0L5.25 2.25L4.5 2.25L4.5 3.75L10.5 3.75L10.5 9.75001L4.5 9.75001L4.5 12L3.75 12L3.75 9.75001L1.5 9.75001L1.5 3.75L3.75 3.75L3.75 2.25L3 2.25L3 0L5.25 0ZM3.75 4.5L2.25 4.5L2.25 9.00001L3.75 9.00001L3.75 4.5ZM9.75 4.5L4.5 4.5L4.5 9.00001L9.75 9.00001L9.75 4.5ZM0.75 4.5L0.75 9.00001L0 9.00001L0 4.5L0.75 4.5ZM12 4.5L12 9.00001L11.25 9.00001L11.25 4.5L12 4.5ZM5.625 5.5965L7.125 6.7215L5.625 7.8465L5.625 5.5965ZM4.5 0.75L3.75 0.75L3.75 1.5L4.5 1.5L4.5 0.75Z" fill="#00FFFF" ></path></svg>
|
||||
|
Before Width: | Height: | Size: 641 B |
@ -186,7 +186,7 @@ const initTreeCallBack = () => {
|
||||
});
|
||||
if ((window as any).earth_ts) {
|
||||
for (let i = 0; i < layers.length; i++) {
|
||||
initMapData(layers[i].sourceType, layers[i].detail, null)
|
||||
// initMapData(layers[i].sourceType, layers[i].detail, null)
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
@ -1,112 +0,0 @@
|
||||
<template>
|
||||
<div class="MouseRight">
|
||||
<div v-for="item in menus" class="item" @click="item.fun">
|
||||
<svg-icon :name="item.icon||item.key" :size="14"></svg-icon>
|
||||
{{ item.name }}
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
import {ref} from 'vue'
|
||||
import {TsApi} from "../../../api/ts";
|
||||
import {ElMessage} from "element-plus";
|
||||
import {useRightOperate} from './rightOperate'
|
||||
|
||||
let {delNode, addEvent} = useRightOperate()
|
||||
|
||||
const eventBus = inject("bus");
|
||||
let setOrReset = ref(1)
|
||||
let setView = (flag) => {
|
||||
// let cusView = window['YJ'].Global.getCurrentView(window['earth_ts'])
|
||||
let node = window['treeObj'].getNodeByParam("id", window['selectedIdTs'], null);
|
||||
let {
|
||||
id,
|
||||
sourceName,
|
||||
sourceType,
|
||||
sourcePath,
|
||||
parentId,
|
||||
isShow,
|
||||
detail,
|
||||
params,
|
||||
planId,
|
||||
} = node
|
||||
let entity = window['_entityMap'].get(id)
|
||||
if (flag)
|
||||
entity.setCustomView()
|
||||
|
||||
else
|
||||
entity.resetCustomView()
|
||||
const detailobj = {...JSON.parse(detail ?? '{}'), customView: flag ? entity.customView : null};
|
||||
let obj = {
|
||||
id,
|
||||
sourceName,
|
||||
sourceType,
|
||||
sourcePath,
|
||||
parentId,
|
||||
treeIndex: node.getIndex(),
|
||||
isShow: isShow ? 1 : 0,
|
||||
detail: JSON.stringify(detailobj),
|
||||
params,
|
||||
planId
|
||||
}
|
||||
TsApi.updateTsSource(obj).then(res => {
|
||||
if (res.code == 200) {
|
||||
ElMessage({type: "success", message: "操作成功"})
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
let deleteNode = () => {
|
||||
let node = window['treeObj'].getNodeByParam("id", window['selectedIdTs'], null);
|
||||
delNode(node, eventBus)
|
||||
}
|
||||
let addEventTs = () => {
|
||||
let node = window['treeObj'].getNodeByParam("id", window['selectedIdTs'], null);
|
||||
addEvent(node, eventBus)
|
||||
}
|
||||
let menus = ref([
|
||||
{name: "添加态势事件", key: "addEventTs", fun: addEventTs},
|
||||
{},
|
||||
{
|
||||
name: '删除', key: "delModel", fun: deleteNode
|
||||
}
|
||||
])
|
||||
|
||||
eventBus.on("initMenus", () => {
|
||||
let customView = null
|
||||
let entity = window['_entityMap'].get(window['selectedIdTs'])
|
||||
customView = Boolean(entity.customView && entity.customView.orientation)
|
||||
setOrReset.value = customView ? 0 : 1
|
||||
menus.value[1] =
|
||||
{
|
||||
name: setOrReset.value ? "视角设定" : "重置视角", key: setOrReset.value ? "setView" : "resetView", fun: () => {
|
||||
setView(setOrReset.value)
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
.MouseRight {
|
||||
position: absolute;
|
||||
z-index: 999;
|
||||
top: 0;
|
||||
left: 0;
|
||||
background: rgba(0, 0, 0, 0.6);
|
||||
//width: 110px;
|
||||
padding: 5px;
|
||||
display: none;
|
||||
|
||||
.item {
|
||||
padding: 0 5px;
|
||||
font-size: 15px;
|
||||
|
||||
&:hover {
|
||||
color: #0ff;
|
||||
cursor: pointer;
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
@ -137,10 +137,7 @@ onMounted(() => {
|
||||
for (let i = 0; i < doms.length; i++) {
|
||||
doms[i].style.lineHeight = "19px"
|
||||
}*/
|
||||
let panel = window['tsObj']._Store.getDomElement(".chart", 0)
|
||||
if (!panel)
|
||||
return
|
||||
let panelHeight = panel.getBoundingClientRect().height
|
||||
let panelHeight = window['tsObj']._Store.getDomElement(".chart", 0).getBoundingClientRect().height
|
||||
|
||||
// 转为字符串并按 "." 分割
|
||||
const [whole, decimalStr] = String(panelHeight).split('.');
|
||||
|
||||
@ -10,7 +10,7 @@
|
||||
@click="itemClicks(item)"
|
||||
>
|
||||
<div class="itemIcon">
|
||||
<svg-icon :name="item.icon||item.key" :size="14"></svg-icon>
|
||||
<svg-icon :name="item.key" :size="14"></svg-icon>
|
||||
</div>
|
||||
<div class="itemText">
|
||||
{{ t(`rightMenu.${item.key}`) }}
|
||||
|
||||
@ -128,8 +128,6 @@ export const useRightOperate = () => {
|
||||
}
|
||||
let detail = JSON.parse(res.data.detail)
|
||||
let mapParams = {...detail, ...res.data.params}
|
||||
if (res.data.sourceType)
|
||||
sourceType = res.data.sourceType
|
||||
initMapData(sourceType, mapParams, entity => {
|
||||
entity.flyTo()
|
||||
|
||||
@ -207,12 +205,11 @@ export const useRightOperate = () => {
|
||||
},
|
||||
addEvent: {
|
||||
key: 'addEvent',
|
||||
icon: 'addEventTs',
|
||||
callback: addEvent
|
||||
}
|
||||
|
||||
})
|
||||
return {
|
||||
rightMenus, delNode, addEvent
|
||||
rightMenus
|
||||
}
|
||||
}
|
||||
|
||||
@ -39,7 +39,6 @@
|
||||
<deduction :TSOBJ="tsOBJ"></deduction>
|
||||
<newEvent></newEvent>
|
||||
<addDirectory class="adddirectoryBox absolute zIndex999"></addDirectory>
|
||||
<mouseRight></mouseRight>
|
||||
|
||||
<!-- 方案描述编辑框 -->
|
||||
<!--<div class="dialogBox">-->
|
||||
@ -111,14 +110,13 @@
|
||||
|
||||
<script setup lang="ts">
|
||||
//@ts-nocheck
|
||||
import {ref, reactive, onMounted, nextTick, onUnmounted,} from "vue";
|
||||
import {ref, reactive, onMounted, nextTick, onUnmounted} from "vue";
|
||||
import {useRouter, useRoute} from "vue-router";
|
||||
import Cabin from "./cabin.vue"
|
||||
import Element from "./element.vue"
|
||||
import NewEvent from "./newEvent.vue"
|
||||
import Deduction from "./deduction.vue";
|
||||
import AddDirectory from './components/tsdirectory.vue'
|
||||
import MouseRight from './components/MouseRight.vue'
|
||||
import {TS} from "./sdk";
|
||||
import * as domain from "domain";
|
||||
import {TsApi} from "../../api/ts";
|
||||
@ -248,8 +246,6 @@ onMounted(async () => {
|
||||
// getAuthInfo()
|
||||
await YJ.on({host: baseURL})
|
||||
createEarth()
|
||||
window.addEventListener('click', handleClick)
|
||||
// window.addEventListener('contextmenu', handleClick)
|
||||
})
|
||||
const createEarth = async () => {
|
||||
(window as any).earth_ts = await new YJ.YJEarth('earthContainer', {navigationHelpButton: false})
|
||||
@ -300,20 +296,10 @@ const timer = setInterval(() => {
|
||||
}).replace(/\//g, '-');
|
||||
stamp.value = formattedDate
|
||||
}, 1000)
|
||||
|
||||
onUnmounted(() => {
|
||||
clearInterval(timer)
|
||||
window.removeEventListener('click', handleClick)
|
||||
// window.removeEventListener('contextmenu', handleClick)
|
||||
})
|
||||
|
||||
// 定义可复用的回调函数
|
||||
const handleClick = (e) => {
|
||||
console.log('点击事件触发', e)
|
||||
let dom = $('.MouseRight')[0]
|
||||
if (dom) dom.style.display = "none"
|
||||
}
|
||||
|
||||
</script>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
|
||||
@ -1,6 +1,6 @@
|
||||
import {TsApi} from "../../api/ts";
|
||||
import {useTreeNode} from '@/views/components/tree/hooks/treeNode'
|
||||
import {bus} from "../../utils/bus"
|
||||
import {rightClick} from "../components/tree/entityClick";
|
||||
|
||||
const {cusAddNodes, getSelectedNode} = useTreeNode()
|
||||
|
||||
@ -40,11 +40,6 @@ export function initMapData(type, data, cb: any = null) {
|
||||
cb && cb(entityObject)
|
||||
})
|
||||
|
||||
break
|
||||
case 'layer':
|
||||
data.host = baseURL
|
||||
entityObject = new YJ.Obj.Layer(window['earth_ts'], data)
|
||||
cb && cb(entityObject)
|
||||
break
|
||||
case "guiji":
|
||||
entityObject = new YJ.Obj.TrajectoryMotionObject(
|
||||
@ -74,20 +69,13 @@ export function initMapData(type, data, cb: any = null) {
|
||||
|
||||
}
|
||||
//鼠标右键点击事件
|
||||
entityObject.onRightClick = (event) => {
|
||||
entityObject.onRightClick = () => {
|
||||
// rightClick(getOptions());
|
||||
console.log("鼠标右键点击事件", options.id, event)
|
||||
console.log("鼠标右键点击事件")
|
||||
let id = options.id;
|
||||
|
||||
let node = window.treeObj.getNodeByParam("id", id, null);
|
||||
if (node) window.treeObj.selectNode(node);
|
||||
window['selectedIdTs'] = id
|
||||
// YJ.Global.splitScreen.setActiveId([id]);
|
||||
$('.MouseRight')[0].style.display = "block"
|
||||
$('.MouseRight')[0].style.top = event.position.y + "px"
|
||||
$('.MouseRight')[0].style.left = event.position.x + "px"
|
||||
|
||||
bus.emit("initMenus")
|
||||
YJ.Global.splitScreen.setActiveId([id]);
|
||||
};
|
||||
return options
|
||||
|
||||
|
||||
@ -41,7 +41,6 @@ export const showRightMenuTs = (event: any, treeObj: any, selectedNodes, nodeTyp
|
||||
try {
|
||||
arr = [...nodeType[selectedNodes[0].sourceType].rightMenus]
|
||||
console.log("rightMenus", nodeType[selectedNodes[0].sourceType].rightMenus)
|
||||
if (!['tileset', 'directory', 'layer', 'terrain',].includes(selectedNodes[0].sourceType))
|
||||
arr.push('addEvent')
|
||||
} catch (e) {
|
||||
console.log('e', e, selectedNodes[0].sourceType)
|
||||
|
||||
@ -192,7 +192,8 @@ function leftClick(options) {
|
||||
}
|
||||
}
|
||||
);
|
||||
} else {
|
||||
}
|
||||
else {
|
||||
isExistent = true
|
||||
}
|
||||
}
|
||||
@ -219,7 +220,7 @@ function rightClick(options) {
|
||||
let node = window.treeObj.getNodeByParam("id", id, null);
|
||||
if (node) window.treeObj.selectNode(node);
|
||||
// 自定义,实例右键点击菜单
|
||||
YJ.Global.splitScreen.setActiveId([id]);
|
||||
// YJ.Global.splitScreen.setActiveId([id]);
|
||||
}
|
||||
|
||||
let a = new Map()
|
||||
|
||||
@ -455,30 +455,30 @@ const createEarth = async () => {
|
||||
window.earth = await new YJ.YJEarth('earthContainer')
|
||||
let openLeftClick = await new YJ.Global.openLeftClick(window.earth)
|
||||
let openRightClick = await new YJ.Global.openRightClick(window.earth)
|
||||
/* YJ.Global.MouseRightMenu(window.earth, true, (text, object) => {
|
||||
switch (text) {
|
||||
case 'rotateAround':
|
||||
YJ.Global.rotateAround(window.earth, object.position)
|
||||
break
|
||||
case 'textBox':
|
||||
let id = new YJ.Tools().randomString()
|
||||
let name = '文本框'
|
||||
addMapSource({
|
||||
type: 'textBox',
|
||||
id: id,
|
||||
sourceName: name,
|
||||
opt: {
|
||||
id: id,
|
||||
position: object.position
|
||||
}
|
||||
})
|
||||
break
|
||||
case 'attribute':
|
||||
let node = window.treeObj.getNodeByParam('id', object.id, null)
|
||||
rightMenus.edit.callback(eventBus, node)
|
||||
break
|
||||
}
|
||||
})*/
|
||||
// YJ.Global.MouseRightMenu(window.earth, true, (text, object) => {
|
||||
// switch (text) {
|
||||
// case 'rotateAround':
|
||||
// YJ.Global.rotateAround(window.earth, object.position)
|
||||
// break
|
||||
// case 'textBox':
|
||||
// let id = new YJ.Tools().randomString()
|
||||
// let name = '文本框'
|
||||
// addMapSource({
|
||||
// type: 'textBox',
|
||||
// id: id,
|
||||
// sourceName: name,
|
||||
// opt: {
|
||||
// id: id,
|
||||
// position: object.position
|
||||
// }
|
||||
// })
|
||||
// break
|
||||
// case 'attribute':
|
||||
// let node = window.treeObj.getNodeByParam('id', object.id, null)
|
||||
// rightMenus.edit.callback(eventBus, node)
|
||||
// break
|
||||
// }
|
||||
// })
|
||||
|
||||
tree.value.initTreeCallBack()
|
||||
utilsSysChange(eventBus)
|
||||
|
||||
Reference in New Issue
Block a user