From 400f4d2ff4444e311713d762201274d8983b4621 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期四, 09 五月 2024 14:09:01 +0800
Subject: [PATCH] #
---
src/components/box.jsx | 83 ++++++++++++++++++++++++++++++-----------
1 files changed, 60 insertions(+), 23 deletions(-)
diff --git a/src/components/box.jsx b/src/components/box.jsx
index 5ca3bba..351575b 100644
--- a/src/components/box.jsx
+++ b/src/components/box.jsx
@@ -2,47 +2,84 @@
import { useFrame } from '@react-three/fiber';
import { useFBX, useAnimations } from '@react-three/drei';
import * as THREE from 'three';
+import {
+ MODEL_BOX_SCALE,
+ SHELF_BAY_GROUP_COUNT,
+ SHELF_BAY_UNIT_SEPARTE_DISTANCE,
+ SHELF_LEV_UNIT_SEPARTE_DISTANCE,
+ SHELF_HEIGHT_FROM_GROUND
+} from '@/config/setting'
+import * as Common from '../utils/common';
+import { useStore } from '@/store';
-const setShadow = (obj) => {
- obj.castShadow = true;
- obj.receiveShadow = true;
+const getShelfRow = (row) => {
+ return row;
+}
- if (obj.children) {
- obj.children.forEach((child) => {
- setShadow(child);
- });
- }
-};
+const getShelfBay = (bay) => {
+ return bay - (bay - 1) % SHELF_BAY_GROUP_COUNT;
+}
-const setColor = (obj) => {
- if (obj.material) {
- obj.material.color.set(0x4680BF);
- }
- if (obj.children) {
- obj.children.forEach((child) => {
- setColor(child);
- });
- }
-};
+const getShelfLev = (lev) => {
+ return 1;
+}
+
+const getShelfNo = (row, bay, lev) => {
+ return Common.generateLocNo(getShelfRow(row), getShelfBay(bay), getShelfLev(lev));
+}
const Box = (props) => {
- const { position = [0, 300, 0] } = props;
+ const { row, bay, lev, position = [0, 300, 0], rotationY = 0 } = props;
+ const state = useStore();
+
+ const [pos, setPos] = useState([]);
+ const [rotaY, setRotaY] = useState(0);
const boxModel = useMemo(() => {
const fbx = useFBX('/models/box/box.fbx');
if (!fbx.castShadow) {
- setShadow(fbx);
+ Common.setShadow(fbx);
}
+ fbx.scale.set(MODEL_BOX_SCALE, MODEL_BOX_SCALE, MODEL_BOX_SCALE);
return fbx.clone();
}, [])
useEffect(() => {
+ if (row && bay && lev) {
+ // from shelf
+ const shelfNo = getShelfNo(row, bay, lev);
+ const shelfPos = state.shelfList[shelfNo];
+ if (!shelfPos) { return }
+ const { row: shelfRow, bay: shelfBay, lev: shelfLev } = Common.parseLocNo(shelfNo);
- }, []);
+ // cal bay position
+ let posZByLev = shelfPos[2];
+ if (bay === shelfBay) {
+ posZByLev = shelfPos[2] + SHELF_BAY_UNIT_SEPARTE_DISTANCE;
+ }
+ if (bay === shelfBay + 1) {
+ posZByLev = shelfPos[2];
+ }
+ if (bay === shelfBay + 2) {
+ posZByLev = shelfPos[2] - SHELF_BAY_UNIT_SEPARTE_DISTANCE;
+ }
+
+ setPos([
+ shelfPos[0],
+ shelfPos[1] + SHELF_HEIGHT_FROM_GROUND + (lev - shelfLev) * SHELF_LEV_UNIT_SEPARTE_DISTANCE,
+ posZByLev
+ ]);
+ setRotaY(Math.PI / 2);
+ } else {
+ // from agv
+ setPos(position);
+ setRotaY(rotationY);
+ }
+ }, [props]);
return (
<>
- <group rotation={[0, 0, 0]} scale={0.5} position={position}>
+ <group rotation-y={rotaY} position={pos}>
<primitive object={boxModel} castShadow />
</group>
</>
--
Gitblit v1.9.1