v2-ui #68
@@ -1,56 +1,66 @@
|
|||||||
import React, { useEffect } from 'react'
|
import React, { useCallback, useEffect, useState } from 'react'
|
||||||
import VehicleAnimator from '../animator/vehicleAnimator'
|
import VehicleAnimator from '../animator/vehicleAnimator'
|
||||||
|
import * as THREE from "three";
|
||||||
import { NavMeshQuery } from '@recast-navigation/core';
|
import { NavMeshQuery } from '@recast-navigation/core';
|
||||||
|
import { useNavMesh } from '../../../../../store/store';
|
||||||
|
import { usePlayButtonStore } from '../../../../../store/usePlayButtonStore';
|
||||||
|
import { useVehicleStore } from '../../../../../store/simulation/useVehicleStore';
|
||||||
|
|
||||||
function VehicleInstance() {
|
function VehicleInstance({ agvDetails }: any) {
|
||||||
|
const { navMesh } = useNavMesh();
|
||||||
|
const { isPlaying } = usePlayButtonStore();
|
||||||
|
const { setVehicleActive, setVehicleState } = useVehicleStore();
|
||||||
|
const [currentPhase, setCurrentPhase] = useState<(string)>("stationed");
|
||||||
|
const [path, setPath] = useState<[number, number, number][]>([]);
|
||||||
|
|
||||||
useEffect(() => {
|
const computePath = useCallback((start: any, end: any) => {
|
||||||
try {
|
|
||||||
const navMeshQuery = new NavMeshQuery(navMesh);
|
|
||||||
const { path: segmentPath } = navMeshQuery.computePath(start, end);
|
try {
|
||||||
return (
|
const navMeshQuery = new NavMeshQuery(navMesh);
|
||||||
segmentPath?.map(
|
const { path: segmentPath } = navMeshQuery.computePath(start, end);
|
||||||
({ x, y, z }) => [x, y + 0.1, z] as [number, number, number]
|
return (
|
||||||
) || []
|
segmentPath?.map(
|
||||||
);
|
({ x, y, z }) => [x, y + 0.1, z] as [number, number, number]
|
||||||
} catch {
|
) || []
|
||||||
return [];
|
);
|
||||||
|
} catch {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
}, [navMesh]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
|
||||||
|
|
||||||
|
if (isPlaying) {
|
||||||
|
if (!agvDetails.isActive && agvDetails.state == "idle" && currentPhase == "stationed") {
|
||||||
|
const toPickupPath = computePath(new THREE.Vector3(agvDetails.position[0], agvDetails.position[1], agvDetails.position[2]), agvDetails.point.action.pickUpPoint);
|
||||||
|
setPath(toPickupPath)
|
||||||
|
setVehicleActive(agvDetails.modelUuid, true)
|
||||||
|
setVehicleState(agvDetails.modelUuid, "running")
|
||||||
|
setCurrentPhase("stationed-pickup")
|
||||||
|
//
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [agvDetails, currentPhase, path, isPlaying])
|
||||||
|
|
||||||
|
function handleCallBack() {
|
||||||
|
if (currentPhase === "stationed-pickup") {
|
||||||
|
setVehicleActive(agvDetails.modelUuid, false)
|
||||||
|
setVehicleState(agvDetails.modelUuid, "idle")
|
||||||
|
setCurrentPhase("picking")
|
||||||
|
setPath([])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}, [navMesh]);
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
// const pickupToDropPath = computePath(pickup, drop);
|
|
||||||
// const dropToPickupPath = computePath(drop, pickup);
|
|
||||||
|
|
||||||
if (isPlaying) {
|
|
||||||
if (!agvDetails.isActive && agvDetails.state == "idle" && currentPhase == "stationed") {
|
|
||||||
const toPickupPath = computePath(new THREE.Vector3(agvDetails.position[0], agvDetails.position[1], agvDetails.position[2]), agvDetails.point.action.pickUpPoint);
|
|
||||||
setPath(toPickupPath)
|
|
||||||
setVehicleActive(agvDetails.modelUuid, true)
|
|
||||||
setVehicleState(agvDetails.modelUuid, "running")
|
|
||||||
setCurrentPhase("stationed-pickup")
|
|
||||||
//
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, [agvDetails, currentPhase, path, isPlaying])
|
|
||||||
|
|
||||||
function handleCallBack() {
|
|
||||||
if (currentPhase === "stationed-pickup") {
|
|
||||||
setVehicleActive(agvDetails.modelUuid, false)
|
|
||||||
setVehicleState(agvDetails.modelUuid, "idle")
|
|
||||||
setCurrentPhase("picking")
|
|
||||||
setPath([])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
|
||||||
<VehicleAnimator path={path} handleCallBack={handleCallBack} currentPhase={currentPhase} agvUuid={agvDetails?.modelUuid} />
|
<VehicleAnimator path={path} handleCallBack={handleCallBack} currentPhase={currentPhase} agvUuid={agvDetails?.modelUuid} />
|
||||||
|
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default VehicleInstance
|
export default VehicleInstance
|
||||||
Reference in New Issue
Block a user