mirror of
https://github.com/italicsjenga/valence.git
synced 2025-01-26 05:26:34 +11:00
Fix chunks loading multiple times
The default chunk view distance has also been lowered to 2 since that is the most conservative guess.
This commit is contained in:
parent
d61c3f1f6f
commit
b2310db7b7
4 changed files with 9 additions and 6 deletions
|
@ -12,10 +12,10 @@ use valence::config::{Config, ServerListPing};
|
||||||
use valence::dimension::{Dimension, DimensionId};
|
use valence::dimension::{Dimension, DimensionId};
|
||||||
use valence::entity::types::Pose;
|
use valence::entity::types::Pose;
|
||||||
use valence::entity::{Entity, EntityEvent, EntityId, EntityKind, TrackedData};
|
use valence::entity::{Entity, EntityEvent, EntityId, EntityKind, TrackedData};
|
||||||
|
use valence::player_list::PlayerListId;
|
||||||
use valence::server::{Server, SharedServer, ShutdownResult};
|
use valence::server::{Server, SharedServer, ShutdownResult};
|
||||||
use valence::text::{Color, TextFormat};
|
use valence::text::{Color, TextFormat};
|
||||||
use valence::{async_trait, ident};
|
use valence::{async_trait, ident};
|
||||||
use valence::player_list::PlayerListId;
|
|
||||||
|
|
||||||
pub fn main() -> ShutdownResult {
|
pub fn main() -> ShutdownResult {
|
||||||
env_logger::Builder::new()
|
env_logger::Builder::new()
|
||||||
|
@ -56,9 +56,9 @@ impl Config for Game {
|
||||||
type ChunkState = ();
|
type ChunkState = ();
|
||||||
type ClientState = EntityId;
|
type ClientState = EntityId;
|
||||||
type EntityState = ();
|
type EntityState = ();
|
||||||
|
type PlayerListState = ();
|
||||||
type ServerState = ServerState;
|
type ServerState = ServerState;
|
||||||
type WorldState = ();
|
type WorldState = ();
|
||||||
type PlayerListState = ();
|
|
||||||
|
|
||||||
fn max_connections(&self) -> usize {
|
fn max_connections(&self) -> usize {
|
||||||
// We want status pings to be successful even if the server is full.
|
// We want status pings to be successful even if the server is full.
|
||||||
|
|
|
@ -9,12 +9,12 @@ use valence::config::{Config, ServerListPing};
|
||||||
use valence::dimension::DimensionId;
|
use valence::dimension::DimensionId;
|
||||||
use valence::entity::types::Pose;
|
use valence::entity::types::Pose;
|
||||||
use valence::entity::{Entity, EntityEvent, EntityId, EntityKind, TrackedData};
|
use valence::entity::{Entity, EntityEvent, EntityId, EntityKind, TrackedData};
|
||||||
|
use valence::player_list::PlayerListId;
|
||||||
use valence::server::{Server, SharedServer, ShutdownResult};
|
use valence::server::{Server, SharedServer, ShutdownResult};
|
||||||
use valence::spatial_index::RaycastHit;
|
use valence::spatial_index::RaycastHit;
|
||||||
use valence::text::{Color, TextFormat};
|
use valence::text::{Color, TextFormat};
|
||||||
use valence::util::from_yaw_and_pitch;
|
use valence::util::from_yaw_and_pitch;
|
||||||
use vek::Vec3;
|
use vek::Vec3;
|
||||||
use valence::player_list::PlayerListId;
|
|
||||||
|
|
||||||
pub fn main() -> ShutdownResult {
|
pub fn main() -> ShutdownResult {
|
||||||
env_logger::Builder::new()
|
env_logger::Builder::new()
|
||||||
|
@ -46,9 +46,9 @@ impl Config for Game {
|
||||||
type ClientState = EntityId;
|
type ClientState = EntityId;
|
||||||
/// `true` for entities that have been intersected with.
|
/// `true` for entities that have been intersected with.
|
||||||
type EntityState = bool;
|
type EntityState = bool;
|
||||||
|
type PlayerListState = ();
|
||||||
type ServerState = Option<PlayerListId>;
|
type ServerState = Option<PlayerListId>;
|
||||||
type WorldState = ();
|
type WorldState = ();
|
||||||
type PlayerListState = ();
|
|
||||||
|
|
||||||
fn max_connections(&self) -> usize {
|
fn max_connections(&self) -> usize {
|
||||||
// We want status pings to be successful even if the server is full.
|
// We want status pings to be successful even if the server is full.
|
||||||
|
|
|
@ -266,7 +266,7 @@ impl<C: Config> Client<C> {
|
||||||
velocity: Vec3::default(),
|
velocity: Vec3::default(),
|
||||||
yaw: 0.0,
|
yaw: 0.0,
|
||||||
pitch: 0.0,
|
pitch: 0.0,
|
||||||
view_distance: 8,
|
view_distance: 2,
|
||||||
teleport_id_counter: 0,
|
teleport_id_counter: 0,
|
||||||
pending_teleports: 0,
|
pending_teleports: 0,
|
||||||
spawn_position: BlockPos::default(),
|
spawn_position: BlockPos::default(),
|
||||||
|
@ -879,6 +879,8 @@ impl<C: Config> Client<C> {
|
||||||
// Send the join game packet and other initial packets. We defer this until now
|
// Send the join game packet and other initial packets. We defer this until now
|
||||||
// so that the user can set the client's initial location, game mode, etc.
|
// so that the user can set the client's initial location, game mode, etc.
|
||||||
if self.created_this_tick() {
|
if self.created_this_tick() {
|
||||||
|
self.bits.set_spawn(false);
|
||||||
|
|
||||||
if let Some(id) = &self.new_player_list {
|
if let Some(id) = &self.new_player_list {
|
||||||
player_lists
|
player_lists
|
||||||
.get(id)
|
.get(id)
|
||||||
|
|
|
@ -31,7 +31,8 @@ pub trait Config: 'static + Sized + Send + Sync + UnwindSafe + RefUnwindSafe {
|
||||||
type WorldState: Send + Sync;
|
type WorldState: Send + Sync;
|
||||||
/// Custom state to store with every [`Chunk`](crate::chunk::Chunk).
|
/// Custom state to store with every [`Chunk`](crate::chunk::Chunk).
|
||||||
type ChunkState: Send + Sync;
|
type ChunkState: Send + Sync;
|
||||||
/// Custom state to store with every [`PlayerList`](crate::player_list::PlayerList).
|
/// Custom state to store with every
|
||||||
|
/// [`PlayerList`](crate::player_list::PlayerList).
|
||||||
type PlayerListState: Send + Sync;
|
type PlayerListState: Send + Sync;
|
||||||
|
|
||||||
/// Called once at startup to get the maximum number of simultaneous
|
/// Called once at startup to get the maximum number of simultaneous
|
||||||
|
|
Loading…
Add table
Reference in a new issue