[NetworkComponent] Now using server-side entity ID instead of an arbitrary one.
This commit is contained in:
parent
1d7782c54a
commit
bf7143efb3
@ -27,6 +27,8 @@
|
|||||||
#include <gk/core/Debug.hpp>
|
#include <gk/core/Debug.hpp>
|
||||||
#include <gk/gl/Camera.hpp>
|
#include <gk/gl/Camera.hpp>
|
||||||
|
|
||||||
|
#include <entt/entt.hpp>
|
||||||
|
|
||||||
#include "AnimationComponent.hpp"
|
#include "AnimationComponent.hpp"
|
||||||
#include "Client.hpp"
|
#include "Client.hpp"
|
||||||
#include "ClientPlayer.hpp"
|
#include "ClientPlayer.hpp"
|
||||||
@ -249,7 +251,7 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntitySpawn, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntitySpawn, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto ®istry = m_world.scene().registry();
|
auto ®istry = m_world.scene().registry();
|
||||||
@ -261,12 +263,12 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
registry.emplace<NetworkComponent>(entity, entityID);
|
registry.emplace<NetworkComponent>(entity, entityID);
|
||||||
}
|
}
|
||||||
else if (registry.get<NetworkComponent>(it->second).entityID != entityID) {
|
else if (registry.get<NetworkComponent>(it->second).entityID != entityID) {
|
||||||
gkError() << "EntitySpawn: Entity ID" << entityID << "is invalid";
|
gkError() << "EntitySpawn: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntityDespawn, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntityDespawn, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto it = m_entityMap.find(entityID);
|
auto it = m_entityMap.find(entityID);
|
||||||
@ -274,11 +276,11 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
m_world.scene().registry().destroy(it->second);
|
m_world.scene().registry().destroy(it->second);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gkError() << "EntityDespawn: Entity ID" << entityID << "is invalid";
|
gkError() << "EntityDespawn: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntityPosition, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntityPosition, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto it = m_entityMap.find(entityID);
|
auto it = m_entityMap.find(entityID);
|
||||||
@ -287,11 +289,11 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
packet >> position.x >> position.y >> position.z;
|
packet >> position.x >> position.y >> position.z;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gkError() << "EntityPosition: Entity ID" << entityID << "is invalid";
|
gkError() << "EntityPosition: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntityRotation, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntityRotation, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto it = m_entityMap.find(entityID);
|
auto it = m_entityMap.find(entityID);
|
||||||
@ -303,11 +305,11 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
rotation.quat = glm::quat(w, x, y, z);
|
rotation.quat = glm::quat(w, x, y, z);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gkError() << "EntityRotation: Entity ID" << entityID << "is invalid";
|
gkError() << "EntityRotation: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntityAnimation, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntityAnimation, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto it = m_entityMap.find(entityID);
|
auto it = m_entityMap.find(entityID);
|
||||||
@ -316,11 +318,11 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
animation.deserialize(packet);
|
animation.deserialize(packet);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gkError() << "EntityAnimation: Entity ID" << entityID << "is invalid";
|
gkError() << "EntityAnimation: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
});
|
});
|
||||||
|
|
||||||
m_client.setCommandCallback(Network::Command::EntityDrawableDef, [this](sf::Packet &packet) {
|
m_client.setCommandCallback(Network::Command::EntityDrawableDef, [this](sf::Packet &packet) {
|
||||||
u32 entityID;
|
entt::entity entityID;
|
||||||
packet >> entityID;
|
packet >> entityID;
|
||||||
|
|
||||||
auto it = m_entityMap.find(entityID);
|
auto it = m_entityMap.find(entityID);
|
||||||
@ -328,7 +330,7 @@ void ClientCommandHandler::setupCallbacks() {
|
|||||||
packet >> m_world.scene().registry().get_or_emplace<DrawableDef>(it->second);
|
packet >> m_world.scene().registry().get_or_emplace<DrawableDef>(it->second);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
gkError() << "EntityDrawableDef: Entity ID" << entityID << "is invalid";
|
gkError() << "EntityDrawableDef: Entity ID" << std::underlying_type_t<entt::entity>(entityID) << "is invalid";
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ class ClientCommandHandler {
|
|||||||
|
|
||||||
std::unordered_map<u16, PlayerBox> &m_playerBoxes;
|
std::unordered_map<u16, PlayerBox> &m_playerBoxes;
|
||||||
|
|
||||||
std::unordered_map<u32, entt::entity> m_entityMap;
|
std::unordered_map<entt::entity, entt::entity> m_entityMap;
|
||||||
|
|
||||||
bool m_isRegistryInitialized = false;
|
bool m_isRegistryInitialized = false;
|
||||||
|
|
||||||
|
@ -36,3 +36,15 @@ sf::Packet &operator>>(sf::Packet &packet, gk::Color &color) {
|
|||||||
return packet;
|
return packet;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sf::Packet &operator<<(sf::Packet &packet, const entt::entity &entity) {
|
||||||
|
packet << std::underlying_type_t<entt::entity>(entity);
|
||||||
|
return packet;
|
||||||
|
}
|
||||||
|
|
||||||
|
sf::Packet &operator>>(sf::Packet &packet, entt::entity &entity) {
|
||||||
|
std::underlying_type_t<entt::entity> id;
|
||||||
|
packet >> id;
|
||||||
|
entity = static_cast<entt::entity>(id);
|
||||||
|
return packet;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -143,4 +143,12 @@ sf::Packet &operator>>(sf::Packet &packet, gk::Vector3<T> &vec) {
|
|||||||
sf::Packet &operator<<(sf::Packet &packet, const gk::Color &color);
|
sf::Packet &operator<<(sf::Packet &packet, const gk::Color &color);
|
||||||
sf::Packet &operator>>(sf::Packet &packet, gk::Color &color);
|
sf::Packet &operator>>(sf::Packet &packet, gk::Color &color);
|
||||||
|
|
||||||
|
//======================================================================================
|
||||||
|
// entt::entity
|
||||||
|
//======================================================================================
|
||||||
|
#include <entt/entt.hpp>
|
||||||
|
|
||||||
|
sf::Packet &operator<<(sf::Packet &packet, const entt::entity &entity);
|
||||||
|
sf::Packet &operator>>(sf::Packet &packet, entt::entity &entity);
|
||||||
|
|
||||||
#endif // NETWORKUTILS_HPP_
|
#endif // NETWORKUTILS_HPP_
|
||||||
|
@ -27,10 +27,10 @@
|
|||||||
#ifndef NETWORKCOMPONENT_HPP_
|
#ifndef NETWORKCOMPONENT_HPP_
|
||||||
#define NETWORKCOMPONENT_HPP_
|
#define NETWORKCOMPONENT_HPP_
|
||||||
|
|
||||||
#include <gk/core/IntTypes.hpp>
|
#include <entt/entt.hpp>
|
||||||
|
|
||||||
struct NetworkComponent {
|
struct NetworkComponent {
|
||||||
u32 entityID = 0;
|
entt::entity entityID;
|
||||||
|
|
||||||
bool hasSpawned = false;
|
bool hasSpawned = false;
|
||||||
};
|
};
|
||||||
|
@ -112,7 +112,7 @@ void ServerCommandHandler::sendChatMessage(u16 clientID, const std::string &mess
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntitySpawn(u32 entityID, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntitySpawn(entt::entity entityID, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntitySpawn << entityID;
|
packet << Network::Command::EntitySpawn << entityID;
|
||||||
|
|
||||||
@ -122,7 +122,7 @@ void ServerCommandHandler::sendEntitySpawn(u32 entityID, const ClientInfo *clien
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntityDespawn(u32 entityID, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntityDespawn(entt::entity entityID, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntityDespawn << entityID;
|
packet << Network::Command::EntityDespawn << entityID;
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ void ServerCommandHandler::sendEntityDespawn(u32 entityID, const ClientInfo *cli
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntityPosition(u32 entityID, double x, double y, double z, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntityPosition(entt::entity entityID, double x, double y, double z, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntityPosition << entityID << x << y << z;
|
packet << Network::Command::EntityPosition << entityID << x << y << z;
|
||||||
|
|
||||||
@ -142,7 +142,7 @@ void ServerCommandHandler::sendEntityPosition(u32 entityID, double x, double y,
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntityRotation(u32 entityID, float w, float x, float y, float z, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntityRotation(entt::entity entityID, float w, float x, float y, float z, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntityRotation << entityID << w << x << y << z;
|
packet << Network::Command::EntityRotation << entityID << w << x << y << z;
|
||||||
|
|
||||||
@ -152,7 +152,7 @@ void ServerCommandHandler::sendEntityRotation(u32 entityID, float w, float x, fl
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntityAnimation(u32 entityID, const AnimationComponent &animation, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntityAnimation(entt::entity entityID, const AnimationComponent &animation, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntityAnimation << entityID << animation;
|
packet << Network::Command::EntityAnimation << entityID << animation;
|
||||||
|
|
||||||
@ -162,7 +162,7 @@ void ServerCommandHandler::sendEntityAnimation(u32 entityID, const AnimationComp
|
|||||||
client->tcpSocket->send(packet);
|
client->tcpSocket->send(packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerCommandHandler::sendEntityDrawableDef(u32 entityID, const DrawableDef &drawableDef, const ClientInfo *client) const {
|
void ServerCommandHandler::sendEntityDrawableDef(entt::entity entityID, const DrawableDef &drawableDef, const ClientInfo *client) const {
|
||||||
sf::Packet packet;
|
sf::Packet packet;
|
||||||
packet << Network::Command::EntityDrawableDef << entityID << drawableDef;
|
packet << Network::Command::EntityDrawableDef << entityID << drawableDef;
|
||||||
|
|
||||||
|
@ -31,6 +31,8 @@
|
|||||||
|
|
||||||
#include <gk/core/Vector3.hpp>
|
#include <gk/core/Vector3.hpp>
|
||||||
|
|
||||||
|
#include <entt/entt.hpp>
|
||||||
|
|
||||||
#include "ChatCommandHandler.hpp"
|
#include "ChatCommandHandler.hpp"
|
||||||
|
|
||||||
struct BlockData;
|
struct BlockData;
|
||||||
@ -58,12 +60,12 @@ class ServerCommandHandler {
|
|||||||
void sendPlayerInvUpdate(u16 clientID, const ClientInfo *client = nullptr) const;
|
void sendPlayerInvUpdate(u16 clientID, const ClientInfo *client = nullptr) const;
|
||||||
void sendPlayerChangeDimension(u16 clientID, s32 x, s32 y, s32 z, u16 dimension, const ClientInfo *client = nullptr) const;
|
void sendPlayerChangeDimension(u16 clientID, s32 x, s32 y, s32 z, u16 dimension, const ClientInfo *client = nullptr) const;
|
||||||
void sendChatMessage(u16 clientID, const std::string &message, const ClientInfo *client = nullptr) const;
|
void sendChatMessage(u16 clientID, const std::string &message, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntitySpawn(u32 entityID, const ClientInfo *client = nullptr) const;
|
void sendEntitySpawn(entt::entity entityID, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntityDespawn(u32 entityID, const ClientInfo *client = nullptr) const;
|
void sendEntityDespawn(entt::entity entityID, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntityPosition(u32 entityID, double x, double y, double z, const ClientInfo *client = nullptr) const;
|
void sendEntityPosition(entt::entity entityID, double x, double y, double z, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntityRotation(u32 entityID, float w, float x, float y, float z, const ClientInfo *client = nullptr) const;
|
void sendEntityRotation(entt::entity entityID, float w, float x, float y, float z, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntityAnimation(u32 entityID, const AnimationComponent &animation, const ClientInfo *client = nullptr) const;
|
void sendEntityAnimation(entt::entity entityID, const AnimationComponent &animation, const ClientInfo *client = nullptr) const;
|
||||||
void sendEntityDrawableDef(u32 entityID, const DrawableDef &drawableDef, const ClientInfo *client = nullptr) const;
|
void sendEntityDrawableDef(entt::entity entityID, const DrawableDef &drawableDef, const ClientInfo *client = nullptr) const;
|
||||||
|
|
||||||
void setupCallbacks();
|
void setupCallbacks();
|
||||||
|
|
||||||
|
@ -34,13 +34,11 @@
|
|||||||
#include "Registry.hpp"
|
#include "Registry.hpp"
|
||||||
#include "RotationComponent.hpp"
|
#include "RotationComponent.hpp"
|
||||||
|
|
||||||
static u32 counter = 0; // FIXME: TEMPORARY
|
|
||||||
|
|
||||||
void ItemDropFactory::create(entt::registry ®istry, double x, double y, double z, const std::string &itemID, u16 amount) {
|
void ItemDropFactory::create(entt::registry ®istry, double x, double y, double z, const std::string &itemID, u16 amount) {
|
||||||
auto entity = registry.create();
|
auto entity = registry.create();
|
||||||
registry.emplace<PositionComponent>(entity, x, y, z);
|
registry.emplace<PositionComponent>(entity, x, y, z);
|
||||||
registry.emplace<RotationComponent>(entity);
|
registry.emplace<RotationComponent>(entity);
|
||||||
registry.emplace<NetworkComponent>(entity, counter++);
|
registry.emplace<NetworkComponent>(entity, entity);
|
||||||
|
|
||||||
auto &drawableDef = registry.emplace<DrawableDef>(entity);
|
auto &drawableDef = registry.emplace<DrawableDef>(entity);
|
||||||
auto &cube = drawableDef.addInventoryCube();
|
auto &cube = drawableDef.addInventoryCube();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user