2024-06-10 22:42:30 -05:00
|
|
|
import {Sprite} from '@pixi/react';
|
|
|
|
import {useState} from 'react';
|
|
|
|
|
2024-06-11 01:41:19 -05:00
|
|
|
import {RESOLUTION} from '@/constants.js'
|
2024-06-10 23:55:06 -05:00
|
|
|
import Ecs from '@/engine/ecs.js';
|
2024-06-10 22:42:30 -05:00
|
|
|
import usePacket from '@/hooks/use-packet';
|
|
|
|
|
|
|
|
export default function EcsComponent() {
|
|
|
|
const [ecs] = useState(new Ecs());
|
|
|
|
const [entities, setEntities] = useState({});
|
2024-06-11 01:41:19 -05:00
|
|
|
const [mainEntity, setMainEntity] = useState();
|
2024-06-10 22:42:30 -05:00
|
|
|
usePacket('Tick', (payload) => {
|
|
|
|
if (0 === Object.keys(payload.ecs).length) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
ecs.apply(payload.ecs);
|
|
|
|
const updatedEntities = {...entities};
|
|
|
|
for (const id in payload.ecs) {
|
|
|
|
if (false === payload.ecs[id]) {
|
|
|
|
delete updatedEntities[id];
|
|
|
|
}
|
|
|
|
else {
|
2024-06-11 02:52:23 -05:00
|
|
|
updatedEntities[id] = ecs.get(id);
|
2024-06-11 01:41:19 -05:00
|
|
|
if (updatedEntities[id].MainEntity) {
|
2024-06-11 02:52:23 -05:00
|
|
|
setMainEntity(ecs.get(id));
|
2024-06-11 01:41:19 -05:00
|
|
|
}
|
2024-06-10 22:42:30 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
setEntities(updatedEntities);
|
|
|
|
}, [entities]);
|
2024-06-11 01:41:19 -05:00
|
|
|
if (!mainEntity) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
const {Camera} = mainEntity;
|
2024-06-11 02:24:45 -05:00
|
|
|
const [cx, cy] = [Camera.x - RESOLUTION.x / 2, Camera.y - RESOLUTION.y / 2];
|
2024-06-10 22:42:30 -05:00
|
|
|
const sprites = [];
|
|
|
|
for (const id in entities) {
|
|
|
|
const entity = entities[id];
|
|
|
|
sprites.push(
|
|
|
|
<Sprite
|
|
|
|
image={entity.Sprite.image}
|
|
|
|
key={id}
|
2024-06-11 01:41:19 -05:00
|
|
|
x={entity.Position.x - cx}
|
|
|
|
y={entity.Position.y - cy}
|
2024-06-10 22:42:30 -05:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{sprites}
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|