wangqiujuan0808 2023-12-14 11:57:13 +08:00
commit 41e2b90ea8
4 changed files with 205 additions and 47 deletions

BIN
dist.7z

Binary file not shown.

View File

@ -9,7 +9,7 @@
<div class="button" @click="setLabel"> <div class="button" @click="setLabel">
{{ isAddLabel ? '添加标签' : '移除标签' }} {{ isAddLabel ? '添加标签' : '移除标签' }}
</div> </div>
<div class="button" @click="roam({x: -1.6464157104492188, y: 2.9064807891845703, z: -11.564851760864258})"> <div class="button" @click="roam()">
漫游 漫游
</div> </div>
</div> </div>
@ -19,7 +19,7 @@
import { onMounted, ref,watch } from 'vue'; import { onMounted, ref,watch } from 'vue';
import * as THREE from 'three'; import * as THREE from 'three';
import { GLTFLoader } from "three/examples/jsm/loaders/GLTFLoader.js"; import { GLTFLoader } from "three/examples/jsm/loaders/GLTFLoader.js";
import { DRACOLoader} from "three/examples/jsm/loaders/DRACOLoader.js"; import { DRACOLoader } from "three/examples/jsm/loaders/DRACOLoader.js";
import { RoomEnvironment } from "three/examples/jsm/environments/RoomEnvironment.js"; import { RoomEnvironment } from "three/examples/jsm/environments/RoomEnvironment.js";
import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js"; import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";
import TWEEN from "@tweenjs/tween.js"; import TWEEN from "@tweenjs/tween.js";
@ -37,7 +37,8 @@ onMounted(() => {
document.addEventListener("click", onMouseDown); document.addEventListener("click", onMouseDown);
// document.addEventListener("mousemove", onMouseMove); // document.addEventListener("mousemove", onMouseMove);
}); });
let scene, renderer, camera, controls = true; let scene, renderer, camera, controls, pointsArr = true;
let i = 1;
let mouse = new THREE.Vector2(); let mouse = new THREE.Vector2();
let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer
const data = reactive({ const data = reactive({
@ -51,7 +52,7 @@ Bus.on('clickBuild', (isParent) => {
if (!isParent) {// if (!isParent) {//
var clickName = bimStore().activateTree.clickName; var clickName = bimStore().activateTree.clickName;
var Floor = scene.getObjectByName(clickName); var Floor = scene.getObjectByName(clickName);
console.log(123, Floor.position);
// x: 42.6454163 y: 5.36651754 z: -95.03277 // x: 42.6454163 y: 5.36651754 z: -95.03277
// x: 27.127655 y: 8.55 z: -6.132766 // x: 27.127655 y: 8.55 z: -6.132766
// x: 27.6954441 y: 10.7530384 z: -37.73485 // x: 27.6954441 y: 10.7530384 z: -37.73485
@ -99,7 +100,7 @@ const init = () => {
// //
renderer = new THREE.WebGLRenderer({ antialias: true }); renderer = new THREE.WebGLRenderer({ antialias: true });
renderer.setPixelRatio(window.devicePixelRatio); renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight); renderer.setSize(window.innerWidth, window.innerHeight);
renderer.outputEncoding = THREE.sRGBEncoding; renderer.outputEncoding = THREE.sRGBEncoding;
document.getElementById('gltf').appendChild(renderer.domElement); document.getElementById('gltf').appendChild(renderer.domElement);
@ -169,7 +170,7 @@ const isSelent = (obj) => {
} }
} }
} }
let selectedObjects = ref([]); let selectedObjects = ref([]);
let selectBoxByClick, selectBoxByMouseon; let selectBoxByClick, selectBoxByMouseon;
var marginLeft = 0; var marginLeft = 0;
@ -201,28 +202,26 @@ const onMouseDown = (event) => {
mouse.y = -((event.clientY - marginTop) / window.innerHeight) * 2 + 1; mouse.y = -((event.clientY - marginTop) / window.innerHeight) * 2 + 1;
raycaster.setFromCamera(mouse, camera); raycaster.setFromCamera(mouse, camera);
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;
// {x: -1.6464157104492188, y: 2.9064807891845703, z: -11.564851760864258}
// {x: -1.7519302368164062, y: 6.542750358581543, z: 11.509664535522461}
var selectedObject = isSelent(clickedObject); var selectedObject = isSelent(clickedObject);
console.log(selectedObject); console.log(123, selectedObject);
// boxLight(selectedObject); boxLight(selectedObject);
nearCamera(selectedObject) // nearCamera(selectedObject)
} }
} }
const boxLight = (selectedObject) => { const boxLight = (selectedObject) => {
if (selectedObject) { if (selectedObject) {
selectedObjects[0] = selectedObject; selectedObjects[0] = selectedObject;
if (selectBoxByClick) { if (selectBoxByClick) {
scene.remove(selectBoxByClick); scene.remove(selectBoxByClick);
}
selectBoxByClick = new THREE.BoxHelper(selectedObjects[0], '#00ffff');
scene.add(selectBoxByClick);
centerSelectedGroup(selectedObject);
} }
selectBoxByClick = new THREE.BoxHelper(selectedObjects[0], '#00ffff');
scene.add(selectBoxByClick);
centerSelectedGroup(selectedObject);
}
} }
// //
const centerSelectedGroup = (obj) => { const centerSelectedGroup = (obj) => {
@ -252,24 +251,68 @@ const centerSelectedGroup = (obj) => {
// tween1.start() // tween1.start()
} }
// //
const i = 0; const roam = () => {
const roam = (obj) => { //
gsap.to(camera.position, { controls.enableDamping = false; //
x: obj.x, controls.dampingFactor = 0.05; // 0 1 default = 0.25
y: obj.y, controls.screenSpacePanning = false; // 使default = false
z: obj.z, controls.minDistance = 100;
duration: 2, controls.maxDistance = 200;
ease: "power1.inOut", controls.maxPolarAngle = Math.PI / 2; // atorbit
onComplete: () => { //
// if (i < 1) { controls.enablePan = false; // pan
// // controls.enableKeys = true;
// roam( {x: -1.7519302368164062, y: 6.542750358581543, z: 11.509664535522461}) controls.keyPanSpeed = 30; // 7 WSAD
// } controls.enableZoom = false; //
// i++; controls.keyRotateSpeed = 90; // 30QE
}, controls.spaceingFactor = 0.4; //0.4
});
//
const path = new THREE.CatmullRomCurve3([
new THREE.Vector3(-50, 20, 90), //
new THREE.Vector3(-10, 40, 40), //
new THREE.Vector3(0, 0, 0), //
new THREE.Vector3(60, -60, 0), //
new THREE.Vector3(90, -40, 60), //
new THREE.Vector3(120, 30, 30), //
// //
// new THREE.Vector3(-10, 0, 10),
// //
// new THREE.Vector3(-5,10,-10),
// new THREE.Vector3(2, 5, -5),
// //
// new THREE.Vector3(10, 0, 10),
]);
pointsArr = path.getSpacedPoints(500);
// console.log(pointsArr);
i = 100;
// 线pointsArr[i]
camera.position.copy(pointsArr[i]);
// pointsArr[i + 1]
camera.lookAt(pointsArr[i + 1]);
renders();
} }
let num = 0;
const renders = () => {
/* angle += 0.01;
// yXOZ
camera.position.x = R * Math.sin(angle);
camera.lookAt(0, 0, 0); */
if (num < pointsArr.length - 1) {
//
camera.position.copy(pointsArr[num]);
// 线pointsArr[num]pointsArr[num+1]线线
// 线线线
camera.lookAt(pointsArr[num + 1]);
num += 1; //
} else {
num = 0
}
requestAnimationFrame(renders);
};
let roamdObjects = ref([]); let roamdObjects = ref([]);
// //
const toHomeView = () => { const toHomeView = () => {
@ -278,21 +321,21 @@ const toHomeView = () => {
// //
const nearCamera = (floor) => { const nearCamera = (floor) => {
controls.reset(); controls.reset();
// gsap.to(camera.position, { gsap.to(camera.position, {
// x: floor.position.x, x: floor.position.x,
// y: floor.position.y, y: floor.position.y,
// z: floor.position.z, z: floor.position.z,
// duration: 2, duration: 2,
// ease: "power1.inOut", ease: "power1.inOut",
// onComplete: () => { onComplete: () => {
// }, },
// }); });
} }
// //
const setLabel = () => { const setLabel = () => {
if(isAddLabel.value) { if (isAddLabel.value) {
addLabel(); addLabel();
} else { } else {
removeLabel(); removeLabel();
@ -334,6 +377,7 @@ const removeLabel = () => {
height: 100%; height: 100%;
width: 100%; width: 100%;
} }
.btnGroup { .btnGroup {
width: 180px; width: 180px;
position: absolute; position: absolute;
@ -356,6 +400,7 @@ const removeLabel = () => {
margin-top: 10px; margin-top: 10px;
} }
} }
.laber_name { .laber_name {
width: 120px; width: 120px;
height: 90px; height: 90px;

View File

@ -0,0 +1,112 @@
<template>
<div class="box4"></div>
</template>
<script>
import * as THREE from 'three';
import Stats from 'three/examples/jsm/libs/stats.module';
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls';
export default{
data(){
return{
scene:null,
camera:null,
renderer:null,
stats:null,
pointLight:null,
pos:0,
curve:null,
sphereLightMesh:null,
}
},
methods:{
init(){
this.scene=new THREE.Scene();//
this.camera=new THREE.PerspectiveCamera(40,window.innerWidth/window.innerHeight,1,1000);//
this.camera.position.set(0,70,70);//
this.camera.lookAt(new THREE.Vector3(0,0,0));//
this.scene.add(new THREE.AxesHelper(20));//
this.pointLight=new THREE.PointLight(0xffffff);
this.pointLight.position.set(0,5,5);
this.pointLight.name="pointLight";//
this.scene.add(this.pointLight);
//
let sphereLight=new THREE.SphereGeometry(0.5,50,50);
let spLightMaterial=new THREE.MeshLambertMaterial({
color:0xffffff,
emissive:0xffffff
})
this.sphereLightMesh=new THREE.Mesh(sphereLight,spLightMaterial);
this.sphereLightMesh.position.copy(this.pointLight.position);
this.scene.add(this.sphereLightMesh);
//
let spheregeo=new THREE.SphereGeometry(5,100,100);
let sphereMaterial=new THREE.MeshLambertMaterial({
color:new THREE.Color().setHSL(Math.random(),0.5,0.5),
})
this.scene.add(new THREE.Mesh(spheregeo,sphereMaterial));
this.curve = new THREE.CatmullRomCurve3( [
//
new THREE.Vector3(-10, 0, 10),
//
new THREE.Vector3(-5,10,-10),
new THREE.Vector3(2, 5, -5),
//
new THREE.Vector3(10, 0, 10),
],
true,
);
console.log(this.curve.getPoint( 0.1 ));
// 线
let geometry = new THREE.Geometry();
// 线()
geometry.vertices = this.curve.getSpacedPoints(100);
let material = new THREE.LineBasicMaterial({ color:new THREE.Color().setHSL(Math.random(),0.5,0.5) });
let curveObject = new THREE.Line(geometry, material);
this.scene.add(curveObject);
this.renderer=new THREE.WebGLRenderer({antialias:true});//,齿
this.renderer.setSize(window.innerWidth,window.innerHeight);//
this.renderer.setClearColor(0x000000);//
this.renderer.setPixelRatio(window.devicePixelRatio);
this.stats=new Stats();
let control=new OrbitControls(this.camera,this.renderer.domElement);
//
document.getElementsByClassName("box4")[0].appendChild(this.stats.domElement);
document.getElementsByClassName("box4")[0].appendChild(this.renderer.domElement);
window.addEventListener("resize",this.onSize,false);//
},
run(){
requestAnimationFrame(this.run);
let pointLight=this.scene.getObjectByName("pointLight");
if(this.pos<1){
pointLight.position=this.curve.getPointAt(this.pos);//
this.sphereLightMesh.position.copy(pointLight.position);//
this.pos+=0.001;
}else{
this.pos=0;
}
this.renderer.render(this.scene,this.camera);
this.stats.update();
},
onSize(){
this.camera.aspect=window.innerWidth/window.innerHeight;
this.renderer.setSize(window.innerWidth,window.innerHeight);
this.camera.updateProjectionMatrix();
}
},
mounted() {
this.init();
this.run();
}
}
</script>
<style>
</style>

View File

@ -49,6 +49,7 @@ import ApplicationTree from './components/ApplicationTree.vue';
import EquipmentInfo from './components/EquipmentInfo.vue'; import EquipmentInfo from './components/EquipmentInfo.vue';
import RealData from './components/RealData.vue'; import RealData from './components/RealData.vue';
import ThreeView from './components/ThreeView2.vue'; import ThreeView from './components/ThreeView2.vue';
// import ThreeView from './components/qqq.vue';
import DeviceInfoDialog from './components/DeviceInfoDialog.vue'; import DeviceInfoDialog from './components/DeviceInfoDialog.vue';
import RealInfoDialog from './components/RealInfoDialog.vue'; import RealInfoDialog from './components/RealInfoDialog.vue';
import DeviceDetial from './components/DeviceDetial.vue'; import DeviceDetial from './components/DeviceDetial.vue';