From 04e51bbcbf891d36e52e1fe8325c55d1a5ab32bd Mon Sep 17 00:00:00 2001 From: cc Date: Sun, 10 Dec 2023 02:11:35 +0000 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E4=BA=86=E9=80=89=E4=B8=AD?= =?UTF-8?q?=E7=9A=84=E9=80=BB=E8=BE=91=EF=BC=8C=E6=9B=B4=E5=AE=B9=E6=98=93?= =?UTF-8?q?=E7=82=B9=E5=87=BB=E4=BA=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bim/bimHome/components/ThreeView.vue | 56 +++++++++++-------- vite.config.js | 2 +- 2 files changed, 33 insertions(+), 25 deletions(-) diff --git a/src/views/bim/bimHome/components/ThreeView.vue b/src/views/bim/bimHome/components/ThreeView.vue index 9fea329..82ca6e3 100644 --- a/src/views/bim/bimHome/components/ThreeView.vue +++ b/src/views/bim/bimHome/components/ThreeView.vue @@ -125,7 +125,7 @@ onMounted(() => { // 启动动画 renderScene(); document.addEventListener("click", onMouseDown); - document.addEventListener("mousemove", onMouseDown); + document.addEventListener("mousemove", onMouseMove); }); @@ -291,28 +291,31 @@ const enableGroup = [ 'tanghua_room', 'touliao_room', ] -// const onMouseDown = (event) => { -// // 计算鼠标点击位置的归一化设备坐标 -// mouse.x = (event.clientX / window.innerWidth) * 2 - 1; -// mouse.y = -(event.clientY / window.innerHeight) * 2 + 1; +const onMouseMove = (event) => { + var raycaster = new THREE.Raycaster() + // 计算鼠标点击位置的归一化设备坐标 + mouse.x = (event.clientX / window.innerWidth) * 2 - 1; + mouse.y = -(event.clientY / window.innerHeight) * 2 + 1; -// var raycaster = new THREE.Raycaster() -// cleanColor(); -// // 更新射线的起点和方向 -// raycaster.setFromCamera(mouse, camera); -// // 计算射线和场景中所有可点击物体的相交情况 -// const intersects = raycaster.intersectObjects(scene.children, true); -// // 如果找到了模型,将其材质修改为绿色 -// if (intersects.length > 0) { -// const clickedObject = intersects[0].object; -// // 储存被选中的模型和材质 -// selectedObject = clickedObject; -// // // 修改材质为绿色 -// selectedObject.material = new THREE.MeshBasicMaterial({ color: 0x00ff00 }); -// nearCamera(intersects); -// } - -// } + // 更新射线的起点和方向 + raycaster.setFromCamera(mouse, camera); + // 计算射线和场景中所有可点击物体的相交情况 + const intersects = raycaster.intersectObjects(scene.children, true); + // 如果找到了模型,将其材质修改为绿色 + if (intersects.length > 0) { + const clickedObject = intersects[0].object; + // 储存被选中的模型和材质 + selectedObject = clickedObject; + if (enableGroup.indexOf(selectedObject.name) != -1) { + outlineObj([selectedObject]) + // nearCamera(intersects); + } + if (enableGroup.indexOf(selectedObject.parent.name) != -1) { + outlineObj([selectedObject.parent]) + // nearCamera(intersects); + } + } +} const onMouseDown = (event) => { var raycaster = new THREE.Raycaster() // 计算鼠标点击位置的归一化设备坐标 @@ -327,13 +330,18 @@ const onMouseDown = (event) => { if (intersects.length > 0) { const clickedObject = intersects[0].object; // 储存被选中的模型和材质 - selectedObject = clickedObject.parent; + selectedObject = clickedObject; if (enableGroup.indexOf(selectedObject.name) != -1) { outlineObj([selectedObject]) + alert("点击了",selectedObject.name) + // nearCamera(intersects); + } + if (enableGroup.indexOf(selectedObject.parent.name) != -1) { + outlineObj([selectedObject.parent]) + alert("点击了",selectedObject.parent.name) // nearCamera(intersects); } } - } let composer = null diff --git a/vite.config.js b/vite.config.js index 8f5ec55..af22aa5 100644 --- a/vite.config.js +++ b/vite.config.js @@ -25,7 +25,7 @@ export default defineConfig(({ mode, command }) => { }, // vite 相关配置 server: { - port: 80, + port: 8080, host: true, open: true, proxy: {