generated from Persson-dev/Godot-Xmake
fixed client player going crazy on spawn
All checks were successful
Linux arm64 / Build (pull_request) Successful in 1m35s
All checks were successful
Linux arm64 / Build (pull_request) Successful in 1m35s
This commit is contained in:
@@ -32,9 +32,9 @@ class World : public godot::Node3D, public protocol::PacketHandler {
|
|||||||
float m_PassedTime;
|
float m_PassedTime;
|
||||||
|
|
||||||
|
|
||||||
void AddPlayer(PlayerID a_PlayerId, godot::String a_PlayerName);
|
virtual void AddPlayer(PlayerID a_PlayerId, godot::String a_PlayerName);
|
||||||
void RemovePlayer(PlayerID a_PlayerId);
|
virtual void RemovePlayer(PlayerID a_PlayerId);
|
||||||
void SetPlayerPositionAndRotation(
|
virtual void SetPlayerPositionAndRotation(
|
||||||
PlayerID a_PlayerId, const godot::Vector3& a_Position, const godot::Vector3& a_Rotation, const godot::Vector3& a_Velocity);
|
PlayerID a_PlayerId, const godot::Vector3& a_Position, const godot::Vector3& a_Rotation, const godot::Vector3& a_Velocity);
|
||||||
};
|
};
|
||||||
} // namespace blitz
|
} // namespace blitz
|
||||||
@@ -20,7 +20,7 @@ class Player : public godot::CharacterBody3D {
|
|||||||
Player();
|
Player();
|
||||||
~Player();
|
~Player();
|
||||||
|
|
||||||
void _ready();
|
void _ready() override;
|
||||||
virtual void _physics_process(float delta);
|
virtual void _physics_process(float delta);
|
||||||
void animate(float delta);
|
void animate(float delta);
|
||||||
|
|
||||||
|
|||||||
@@ -15,6 +15,9 @@ class ServerWorld : public World {
|
|||||||
void HandlePacket(const protocol::packets::PlayerPositionAndRotation&) override;
|
void HandlePacket(const protocol::packets::PlayerPositionAndRotation&) override;
|
||||||
|
|
||||||
void SyncPlayersPos();
|
void SyncPlayersPos();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void AddPlayer(PlayerID a_PlayerId, godot::String a_PlayerName);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace blitz
|
} // namespace blitz
|
||||||
@@ -20,7 +20,10 @@ using namespace godot;
|
|||||||
|
|
||||||
void Player::_bind_methods() {}
|
void Player::_bind_methods() {}
|
||||||
|
|
||||||
Player::Player() : m_PeerId(0) {}
|
Player::Player() : m_PeerId(0) {
|
||||||
|
// we set the player to an invalid position
|
||||||
|
set_position({-99999, -999999, -999999});
|
||||||
|
}
|
||||||
|
|
||||||
Player::~Player() {}
|
Player::~Player() {}
|
||||||
|
|
||||||
@@ -31,9 +34,6 @@ void Player::_ready() {
|
|||||||
DEV_ASSERT(m_Mesh);
|
DEV_ASSERT(m_Mesh);
|
||||||
DEV_ASSERT(m_AnimationTree);
|
DEV_ASSERT(m_AnimationTree);
|
||||||
|
|
||||||
set_position({0, 0, 0});
|
|
||||||
set_velocity({0, 0, 0});
|
|
||||||
|
|
||||||
animate(0);
|
animate(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -55,4 +55,10 @@ void ServerWorld::HandlePacket(const protocol::packets::PlayerPositionAndRotatio
|
|||||||
SetPlayerPositionAndRotation(data.m_Player, data.m_Position, data.m_Rotation, data.m_Velocity);
|
SetPlayerPositionAndRotation(data.m_Player, data.m_Position, data.m_Rotation, data.m_Velocity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ServerWorld::AddPlayer(PlayerID a_PlayerId, godot::String a_PlayerName) {
|
||||||
|
World::AddPlayer(a_PlayerId, a_PlayerName);
|
||||||
|
Player* player = GetPlayerById(a_PlayerId);
|
||||||
|
player->set_position({0, 0, 0});
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace blitz
|
} // namespace blitz
|
||||||
Reference in New Issue
Block a user