详情标签

main
wangqiujuan0808 2023-12-15 20:09:13 +08:00
parent c7b62bef1c
commit babcf2d5a2
1 changed files with 43 additions and 36 deletions

View File

@ -81,6 +81,7 @@ Bus.on('clickDevice', (isParent) => {
if (!isParent) {// if (!isParent) {//
var clickName = bimStore().activateDevice.clickName; var clickName = bimStore().activateDevice.clickName;
var Floor = scene.getObjectByName(clickName); var Floor = scene.getObjectByName(clickName);
removeLabel();
boxLight(Floor); boxLight(Floor);
// //
// nearCamera(Floor); // nearCamera(Floor);
@ -91,10 +92,10 @@ Bus.on('clickDevice', (isParent) => {
// //
Bus.on('clickApplication', (isParent) => { Bus.on('clickApplication', (isParent) => {
// Todo // Todo
if(!isParent) { if (!isParent) {
xiaof(); xiaof();
} }
}) })
watch(() => bimStore().activateMenu, value => { watch(() => bimStore().activateMenu, value => {
@ -129,8 +130,8 @@ const loadSence = () => {
gltfLoader.load('/jzc/scene.gltf', (gltf) => { gltfLoader.load('/jzc/scene.gltf', (gltf) => {
var model = gltf.scene; var model = gltf.scene;
roamdObjects = model.children[0].children; roamdObjects = model.children[0].children;
model.traverse((obj)=>{ model.traverse((obj) => {
if (enableGroup.indexOf(obj.name) != -1){ if (enableGroup.indexOf(obj.name) != -1) {
xfobj.push(obj); xfobj.push(obj);
} }
}); });
@ -182,7 +183,7 @@ const isSelent = (obj) => {
} }
let selectedObjects = ref([]); let selectedObjects = ref([]);
let selectBoxByClick, selectBoxByMouseon, pointLabel; let selectBoxByClick, selectBoxByMouseon, pointLabel, selectedObject;
var marginLeft = 0; var marginLeft = 0;
var marginTop = 70; var marginTop = 70;
// //
@ -194,7 +195,7 @@ const onMouseMove = (event) => {
const intersects = raycaster.intersectObjects(scene.children, true); const intersects = raycaster.intersectObjects(scene.children, true);
if (intersects.length > 0) { if (intersects.length > 0) {
const clickedObject = intersects[0].object; const clickedObject = intersects[0].object;
var selectedObject = isSelent(clickedObject); selectedObject = isSelent(clickedObject);
if (selectedObject) { if (selectedObject) {
selectedObjects[0] = selectedObject; selectedObjects[0] = selectedObject;
if (selectBoxByMouseon) { if (selectBoxByMouseon) {
@ -218,9 +219,8 @@ const onMouseDownRight = (event) => {
if (intersects.length > 0) { if (intersects.length > 0) {
const clickedObject = intersects[0].object; const clickedObject = intersects[0].object;
console.log('这是我选中的模型', clickedObject); console.log('这是我选中的模型', clickedObject);
var selectedObject = isSelent(clickedObject); selectedObject = isSelent(clickedObject);
// addLabel(selectedObject, true); addLabel(selectedObject, true);
emit('handleRightClick', selectedObject);
} }
} }
// //
@ -235,20 +235,20 @@ const onMouseDown = (event) => {
if (intersects.length > 0) { if (intersects.length > 0) {
const clickedObject = intersects[0].object; const clickedObject = intersects[0].object;
console.log('这是我选中的模型', clickedObject); console.log('这是我选中的模型', clickedObject);
var selectedObject = isSelent(clickedObject); selectedObject = isSelent(clickedObject);
// //
boxLight(selectedObject); boxLight(selectedObject);
if(bimStore().activateIndex == '0') { if (bimStore().activateIndex == '0') {
// //
Bus.emit('handleTreeClick', clickedObject); Bus.emit('handleTreeClick', clickedObject);
return; return;
} }
if(bimStore().activateIndex == '1') { if (bimStore().activateIndex == '1') {
// //
Bus.emit('handleTreeClick1', clickedObject); Bus.emit('handleTreeClick1', clickedObject);
return; return;
} }
} }
} }
@ -377,10 +377,8 @@ const toHomeView = () => {
scene.remove(selectBoxByClick); scene.remove(selectBoxByClick);
} }
// //
if(!isAddLabel.value) { removeLabel();
removeLabel(); isAddLabel.value = true;
isAddLabel.value = !isAddLabel.value;
}
// //
controls.reset(); controls.reset();
} }
@ -402,44 +400,52 @@ const nearCamera = (floor) => {
// //
const setLabel = () => { const setLabel = () => {
if (isAddLabel.value) { if (isAddLabel.value) {
let obj = scene.getObjectByName('set2'); let obj = scene.getObjectByName('set2');
addLabel(obj, false); addLabel(obj, false);
} else { } else {
removeLabel(); removeLabel();
} }
isAddLabel.value = !isAddLabel.value; isAddLabel.value = !isAddLabel.value;
} }
// //
const addLabel = (obj,isShowDetail) => { const addLabel = (obj, isShowDetail) => {
removeLabel();
// console.log(123, obj); // console.log(123, obj);
centerSelectedGroup(obj); centerSelectedGroup(obj);
let text = "设备二"; let text = "设备二";
pointLabel = createLableObj(text,isShowDetail); pointLabel = createLableObj(text, isShowDetail);
obj.add(pointLabel); obj.add(pointLabel);
labelRenderer.setSize(window.innerWidth, window.innerHeight); labelRenderer.setSize(window.innerWidth, window.innerHeight);
labelRenderer.domElement.style.position = "absolute"; labelRenderer.domElement.style.position = "absolute";
labelRenderer.domElement.style.top = 0; labelRenderer.domElement.style.top = 0;
labelRenderer.domElement.style.pointerEvents = 'none';// labelRenderer.domElement.style.pointerEvents = 'none';//
document.body.appendChild(labelRenderer.domElement); document.body.appendChild(labelRenderer.domElement);
// HTML // HTML
document.getElementById("dom").appendChild(renderer.domElement); document.getElementById("dom").appendChild(renderer.domElement);
}; };
const createLableObj = (text,isShowDetail) => { const createLableObj = (text, isShowDetail) => {
let laberDiv = document.createElement("div"); //div let laberDiv = document.createElement("div"); //div
if(!isShowDetail) { if (!isShowDetail) {
laberDiv.className = "laber_name"; laberDiv.className = "laber_name";
laberDiv.innerHTML = `<div class="arrow_outer"></div><span>设备名称:${text}</span><span>状态:启用</span><span>压力50 Pa</span>` laberDiv.innerHTML = `<div class="arrow_outer"></div><span>设备名称:${text}</span><span>状态:启用</span><span>压力50 Pa</span>`
} else { } else {
laberDiv.style.pointerEvents = 'auto';//
laberDiv.className = "laber_name1"; laberDiv.className = "laber_name1";
laberDiv.innerHTML = `<div class="detail-btn">详情</div>` laberDiv.innerHTML = `<div class="detail-btn">详情</div>`;
laberDiv.addEventListener('click', function (event) {
emit('handleRightClick', selectedObject);
console.log(labelRenderer.domElement);
})
} }
let pointLabel = new CSS2DObject(laberDiv); let pointLabel = new CSS2DObject(laberDiv);
return pointLabel; return pointLabel;
}; };
const removeLabel = () => { const removeLabel = () => {
document.body.removeChild(labelRenderer.domElement); if(pointLabel) {
pointLabel.visible = false;
}
// document.body.removeChild(labelRenderer.domElement);
} }
// //
@ -456,18 +462,18 @@ const setBottom = () => {
// //
const xiaof = () => { const xiaof = () => {
xfobj.forEach((o)=>{ xfobj.forEach((o) => {
xfadd(o,Math.random() < 0.3); xfadd(o, Math.random() < 0.3);
}) })
} }
let xfobj = []; let xfobj = [];
// //
const xfadd = (obj,state)=> { const xfadd = (obj, state) => {
const texLoader= new THREE.TextureLoader(); const texLoader = new THREE.TextureLoader();
let texture = null; let texture = null;
if(state){ if (state) {
texture= texLoader.load("/ygr.png"); texture = texLoader.load("/ygr.png");
}else{ } else {
texture = texLoader.load("/yg.png"); texture = texLoader.load("/yg.png");
} }
const spriteMaterial = new THREE.SpriteMaterial({ const spriteMaterial = new THREE.SpriteMaterial({
@ -526,8 +532,9 @@ const xfadd = (obj,state)=> {
line-height: 24px; line-height: 24px;
} }
} }
.laber_name1 { .laber_name1 {
width:100px; width: 100px;
height: 50px; height: 50px;
border-radius: 5px; border-radius: 5px;
cursor: pointer; cursor: pointer;
@ -536,6 +543,6 @@ const xfadd = (obj,state)=> {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
z-index:999; z-index: 999;
} }
</style> </style>