2020-12-13 17:11:55 +00:00
|
|
|
use common_net::msg::PresenceKind;
|
2020-10-30 16:39:53 +00:00
|
|
|
use hashbrown::HashSet;
|
|
|
|
use serde::{Deserialize, Serialize};
|
2022-08-08 04:38:20 +00:00
|
|
|
use specs::{Component, DenseVecStorage, DerefFlaggedStorage, NullStorage, VecStorage};
|
2020-10-30 16:39:53 +00:00
|
|
|
use vek::*;
|
|
|
|
|
|
|
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
|
|
pub struct Presence {
|
|
|
|
pub view_distance: u32,
|
|
|
|
pub kind: PresenceKind,
|
2021-05-01 18:28:20 +00:00
|
|
|
pub lossy_terrain_compression: bool,
|
2020-10-30 16:39:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Presence {
|
|
|
|
pub fn new(view_distance: u32, kind: PresenceKind) -> Self {
|
|
|
|
Self {
|
|
|
|
view_distance,
|
|
|
|
kind,
|
2021-05-01 18:28:20 +00:00
|
|
|
lossy_terrain_compression: false,
|
2020-10-30 16:39:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Component for Presence {
|
2022-08-08 04:38:20 +00:00
|
|
|
// Presence seems <= 64 bits, so it isn't worth using DenseVecStorage.
|
|
|
|
type Storage = DerefFlaggedStorage<Self, VecStorage<Self>>;
|
2020-10-30 16:39:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Distance from fuzzy_chunk before snapping to current chunk
|
|
|
|
pub const CHUNK_FUZZ: u32 = 2;
|
|
|
|
// Distance out of the range of a region before removing it from subscriptions
|
|
|
|
pub const REGION_FUZZ: u32 = 16;
|
|
|
|
|
|
|
|
#[derive(Clone, Debug)]
|
|
|
|
pub struct RegionSubscription {
|
|
|
|
pub fuzzy_chunk: Vec2<i32>,
|
|
|
|
pub regions: HashSet<Vec2<i32>>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Component for RegionSubscription {
|
2022-08-08 04:38:20 +00:00
|
|
|
type Storage = DerefFlaggedStorage<Self, DenseVecStorage<Self>>;
|
2020-10-30 16:39:53 +00:00
|
|
|
}
|
2021-07-16 21:33:31 +00:00
|
|
|
|
|
|
|
#[derive(Copy, Clone, Debug, Default, Serialize, Deserialize)]
|
|
|
|
pub struct RepositionOnChunkLoad;
|
|
|
|
|
|
|
|
impl Component for RepositionOnChunkLoad {
|
|
|
|
type Storage = NullStorage<Self>;
|
|
|
|
}
|