From 2d3990bfa64fd7ab5ac14d2efcf68b6b465166de Mon Sep 17 00:00:00 2001 From: lukas0008 Date: Wed, 14 Aug 2024 01:07:20 +0200 Subject: [PATCH] Fix rotation - The rotation was previously not taking the modulus of the degree (which is incorrect). - `head_yaw` is currently not used, since the server only receives the yaw and pitch packet, it can be assumed that head yaw can be identical to yaw. --- pumpkin/src/client/player_packet.rs | 20 ++++++++++++-------- pumpkin/src/server.rs | 2 +- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index da5edb2d..d5d60120 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -24,6 +24,10 @@ use crate::{ use super::{Client, PlayerConfig}; +fn modulus(a: f32, b: f32) -> f32 { + ((a % b) + b) % b +} + /// Handles all Play Packets send by a real Player impl Client { pub fn handle_confirm_teleport( @@ -119,9 +123,9 @@ impl Client { let (x, lastx) = (entity.x, entity.lastx); let (y, lasty) = (entity.y, entity.lasty); let (z, lastz) = (entity.z, entity.lastz); - let yaw = (entity.yaw * 256.0 / 360.0).floor(); - let pitch = (entity.pitch * 256.0 / 360.0).floor(); - let head_yaw = (entity.head_yaw * 256.0 / 360.0).floor(); + let yaw = modulus(entity.yaw * 256.0 / 360.0, 256.0); + let pitch = modulus(entity.pitch * 256.0 / 360.0, 256.0); + // let head_yaw = (entity.head_yaw * 256.0 / 360.0).floor(); server.broadcast_packet( self, @@ -135,7 +139,7 @@ impl Client { on_ground, ), ); - server.broadcast_packet(self, &CHeadRot::new(entity_id.into(), head_yaw as u8)); + server.broadcast_packet(self, &CHeadRot::new(entity_id.into(), yaw as u8)); } pub fn handle_rotation(&mut self, server: &mut Server, rotation: SPlayerRotation) { @@ -150,15 +154,15 @@ impl Client { // send new position to all other players let on_ground = player.on_ground; let entity_id = entity.entity_id; - let yaw = (entity.yaw * 256.0 / 360.0).floor(); - let pitch = (entity.pitch * 256.0 / 360.0).floor(); - let head_yaw = (entity.head_yaw * 256.0 / 360.0).floor(); + let yaw = modulus(entity.yaw * 256.0 / 360.0, 256.0); + let pitch = modulus(entity.pitch * 256.0 / 360.0, 256.0); + // let head_yaw = modulus(entity.head_yaw * 256.0 / 360.0, 256.0); server.broadcast_packet( self, &CUpdateEntityRot::new(entity_id.into(), yaw as u8, pitch as u8, on_ground), ); - server.broadcast_packet(self, &CHeadRot::new(entity_id.into(), head_yaw as u8)); + server.broadcast_packet(self, &CHeadRot::new(entity_id.into(), yaw as u8)); } pub fn handle_chat_command(&mut self, _server: &mut Server, command: SChatCommand) { diff --git a/pumpkin/src/server.rs b/pumpkin/src/server.rs index 3b885882..fabd9357 100644 --- a/pumpkin/src/server.rs +++ b/pumpkin/src/server.rs @@ -339,7 +339,7 @@ impl Server { "./world".parse().unwrap(), ); level - .read_chunks(RadialIterator::new(32).collect(), sender) + .read_chunks(RadialIterator::new(2).collect(), sender) .await; });