silphius/app/react-components/ecs.jsx

54 lines
1.3 KiB
React
Raw Normal View History

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}
</>
)
}