From f57db66f7c1ead69b0772132330edb30411e6373 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期二, 23 四月 2024 15:30:32 +0800
Subject: [PATCH] #
---
src/components/agv.jsx | 36 +++++++++++++++++++++++++++++++-----
1 files changed, 31 insertions(+), 5 deletions(-)
diff --git a/src/components/agv.jsx b/src/components/agv.jsx
index dfd5ea8..bb7e222 100644
--- a/src/components/agv.jsx
+++ b/src/components/agv.jsx
@@ -13,12 +13,14 @@
const [groupPos, setGroupPos] = useState({ x: 0, y: 0, z: 0 });
const [groupTheta, setGroupTheta] = useState(0);
const [loaderHeight, setLoaderHeight] = useState(0);
+ const [integrateTheta, setIntegrateTheta] = useState(0);
const [forkDis, setForkDis] = useState(0);
useEffect(() => {
if (!props || Object.keys(props).length === 0) {
return;
}
+
// group position
const pos = {
x: position?.[0],
@@ -64,6 +66,20 @@
}).start();
}
+ // loader theta
+ if (integrateTheta !== loaderTheta) {
+ const minTheta = Common.minDiffTheta(integrateTheta, loaderTheta);
+ new TWEEN.Tween({ value: integrateTheta })
+ .to({ value: minTheta }, INTERVAL_TIME)
+ .easing(TWEEN.Easing.Linear.None)
+ .onUpdate((e) => {
+ setIntegrateTheta(e.value)
+ })
+ .onComplete((e) => {
+ setIntegrateTheta(e.value)
+ }).start();
+ }
+
// fork lenght
if (forkDis !== forkLength) {
new TWEEN.Tween({ value: forkDis })
@@ -74,7 +90,6 @@
})
.onComplete((e) => {
setForkDis(e.value)
- console.log(e.value);
}).start();
}
@@ -118,13 +133,24 @@
position={[groupPos.x, groupPos.y, groupPos.z]}
>
<primitive object={bodyModel} castShadow />
- <group position-y={loaderHeight}>
- <primitive object={loaderModel} castShadow position={[0, 30, 0]} />
+ <group
+ position-y={loaderHeight}
+ rotation-y={Common.rotationParseNum(integrateTheta)}
+ >
+ <primitive object={loaderModel} castShadow position={[0, 20, 0]} />
<group position-z={forkDis}>
- <primitive object={forkModel} castShadow position={[0, 35, 0]} />
- {hasBox && <Box position={[0, 34, 0]} />}
+ <primitive object={forkModel} castShadow position={[0, 25, 0]} />
+ {hasBox && <Box position={[0, 24, 0]} />}
</group>
</group>
+ <group>
+ {trayList?.[0]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 25, 0]} />}
+ {trayList?.[1]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 48, 0]} />}
+ {trayList?.[2]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 71, 0]} />}
+ {trayList?.[3]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 94, 0]} />}
+ {trayList?.[4]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 117, 0]} />}
+ {trayList?.[5]?.hasBox && <Box rotationY={Math.PI / 2} position={[-43, 140, 0]} />}
+ </group>
</group>
</>
)
--
Gitblit v1.9.1