Compare commits

..

No commits in common. "03d75fd3ab18c8950aeb726ab16dc9321d896beb" and "285b0843030ce8b6f9ffd776e0f60128af43a212" have entirely different histories.

1 changed files with 85 additions and 17 deletions

View File

@ -78,7 +78,7 @@ let objM = [];
// //
let warnSets = []; let warnSets = [];
// //
let currentIndex = 1; let currentIndex = 0;
let romeObj = [] let romeObj = []
// //
let checkArr = []; let checkArr = [];
@ -173,6 +173,16 @@ const loadSence = () => {
yjobj.push(e); yjobj.push(e);
} }
}) })
//
const objname = ['start', 'middle1', 'middle2', 'end']
objname.forEach((item, index) => {
var targetModel = model.getObjectByName(item);
if (targetModel) romeObj.push(
targetModel
)
console.log('targetModel', targetModel)
})
//
// //
const checkname = [{ const checkname = [{
@ -415,6 +425,47 @@ const centerSelectedGroup = (obj) => {
tween.start(); tween.start();
} }
//
const roam = () => {
if (currentIndex < romeObj.length) {
console.log('照相机坐标', camera.position);
console.log('物体坐标', romeObj[currentIndex].getWorldPosition(new THREE.Vector3()));
var nextPosition = romeObj[currentIndex].getWorldPosition(new THREE.Vector3());
//
gsap.to(camera.position, {
x: nextPosition.x,
y: nextPosition.y + 2.2,
z: nextPosition.z,
duration: 10,
ease: 'power1.inOut',
onComplete: () => {
roam()
}
});
let lookObj;
if (currentIndex == romeObj.length - 1) {
lookObj = romeObj[0].getWorldPosition(new THREE.Vector3())
} else if (currentIndex < romeObj.length) {
lookObj = romeObj[currentIndex + 1].getWorldPosition(new THREE.Vector3())
}
gsap.to(controls.target, {
x: lookObj.x,
y: lookObj.y + 2.2,
z: lookObj.z,
duration: 10,
ease: "power1.inOut",
onComplete: () => { },
});
currentIndex++;
console.log('lookObj', currentIndex)
} else {
toHomeView();
}
}
// //
const toHomeView = () => { const toHomeView = () => {
// //
@ -572,7 +623,18 @@ const xfadd = (obj, state) => {
} }
// //
const removexf = () => { const removexf = () => {
console.log(xfobj.length); // model.traverse(e => {
// if (e.isMesh && e.children.length > 0) {
// e.remove(e.children[0])
// } else {
// e.traverse(o => {
// if (o.isMesh && o.children.length > 0) {
// o.remove(o.children[0])
// }
// })
// }
// })
xfobj.forEach((o) => { xfobj.forEach((o) => {
// //
let obj = o.children[o.children.length-1]; let obj = o.children[o.children.length-1];
@ -617,11 +679,11 @@ const changeMap = (img) => {
} }
// //
const check = () => { const check = () => {
console.log('照相机坐标', camera.position);
console.log('物体坐标', checkArr[checkindex].getWorldPosition(new THREE.Vector3()));
if (checkindex < checkArr.length ) { if (currentIndex < romeObj.length) {
// .getWorldPosition()
var checkPosition = checkArr[checkindex].getWorldPosition(new THREE.Vector3()); var checkPosition = checkArr[checkindex].getWorldPosition(new THREE.Vector3());
gsap.to(camera.position, { gsap.to(camera.position, {
x: checkPosition.x, x: checkPosition.x,
y: checkPosition.y + 5.2, y: checkPosition.y + 5.2,
@ -629,42 +691,48 @@ const check = () => {
duration: 10, duration: 10,
ease: 'power1.inOut', ease: 'power1.inOut',
onComplete: () => { onComplete: () => {
// if (checkindex == romeObj.length) { //
addLabel(checkArr[checkindex], checkArr[checkindex].isPass);
if (checkindex == checkArr.length - 1) { //
checkComplete(); checkComplete();
} else {
check()
} }
check()
} }
}); });
var pos1 = new THREE.Vector3( camera.position );
var pos2 = new THREE.Vector3( checkPosition );
var distance = pos1.distanceTo(pos2);
console.log(12354, distance);
let nextObj; let nextObj;
if (checkindex == checkArr.length - 1) { if (checkindex == checkArr.length - 1) {
nextObj = checkArr[0].getWorldPosition(new THREE.Vector3()) nextObj = checkArr[0].getWorldPosition(new THREE.Vector3())
} else if (checkindex < checkArr.length - 1) { return;
} else if (checkindex < checkArr.length) {
nextObj = checkArr[checkindex + 1].getWorldPosition(new THREE.Vector3()) nextObj = checkArr[checkindex + 1].getWorldPosition(new THREE.Vector3())
} }
gsap.to(controls.target, { gsap.to(controls.target, {
x: nextObj.x, x: nextObj.x,
y: nextObj.y + 5.2, y: nextObj.y + 5.2,
z: nextObj.z, z: nextObj.z,
duration: 10, duration: 10,
ease: "power1.inOut", ease: "power1.inOut",
onComplete: () => { onComplete: () => {
//
// addLabel(checkArr[checkindex], checkArr[checkindex].isPass);
}, },
}); });
checkindex++; checkindex++;
console.log('nextObj', checkindex)
} }
} }
// //
const checkComplete = () => { const checkComplete = () => {
toHomeView(); toHomeView();
bimStore().setCheckArr(checkArr); checkindex = 0;
emit('checkComplete', checkArr); bimStore().setCheckArr(romeObj);
emit('checkComplete', romeObj);
return; return;
} }