diff options
author | Lizzy Fleckenstein <eliasfleckenstein@web.de> | 2023-02-12 23:49:03 +0100 |
---|---|---|
committer | Lizzy Fleckenstein <eliasfleckenstein@web.de> | 2023-02-12 23:49:03 +0100 |
commit | 19365cf9e27731e02431adb1e52447cddabb7a11 (patch) | |
tree | a6d7f00b8e13bcf024e93794e8b506e9560bda46 /src/to_clt | |
parent | 6847ec6672757dec3b8ae58e0a77994c2344f9e0 (diff) | |
download | mt_net-19365cf9e27731e02431adb1e52447cddabb7a11.tar.xz |
Implement objects
Diffstat (limited to 'src/to_clt')
-rw-r--r-- | src/to_clt/env.rs | 154 | ||||
-rw-r--r-- | src/to_clt/hud.rs | 6 |
2 files changed, 155 insertions, 5 deletions
diff --git a/src/to_clt/env.rs b/src/to_clt/env.rs index f242298..4b035e2 100644 --- a/src/to_clt/env.rs +++ b/src/to_clt/env.rs @@ -1,10 +1,160 @@ use super::*; #[mt_derive(to = "clt")] -pub struct ObjAdd; // TODO +pub struct ObjProps { + #[mt(const8 = 4)] // version + pub max_hp: u16, // player only + pub collide_with_nodes: bool, + pub weight: f32, // deprecated + pub collision_box: ([f32; 3], [f32; 3]), + pub selection_box: ([f32; 3], [f32; 3]), + pub pointable: bool, + pub visual: String, + pub visual_size: [f32; 3], + pub textures: Vec<String>, + pub sprite_sheet_size: [i16; 2], // in sprites + pub sprite_pos: [i16; 2], // in sprite sheet + pub visible: bool, + pub make_footstep_sounds: bool, + pub rotate_speed: f32, // in radians per second + pub mesh: String, + pub colors: Vec<Color>, + pub collide_with_objs: bool, + pub step_height: f32, + pub face_rotate_dir: bool, + pub face_rotate_dir_off: f32, // in degrees + pub backface_cull: bool, + pub nametag: String, + pub nametag_color: Color, + pub face_rotate_speed: f32, // in degrees per second + pub infotext: String, + pub itemstring: String, + pub glow: i8, + pub max_breath: u16, // player only + pub eye_height: f32, // player only + pub zoom_fov: f32, // in degrees. player only + pub use_texture_alpha: bool, + pub dmg_texture_mod: String, // suffix + pub shaded: bool, + pub show_on_minimap: bool, + pub nametag_bg: Color, +} + +#[mt_derive(to = "clt")] +pub struct ObjPos { + pub pos: [f32; 3], + pub vel: [f32; 3], + pub acc: [f32; 3], + pub rot: [f32; 3], + pub interpolate: bool, + pub end: bool, + pub update_interval: f32, +} + +#[mt_derive(to = "clt")] +pub struct ObjSprite { + pub frame0: [i16; 2], + pub frames: u16, + pub frame_duration: f32, + pub view_angle_frames: bool, +} + +#[mt_derive(to = "clt")] +pub struct ObjAnim { + pub frames: [i32; 2], + pub speed: f32, + pub blend: f32, + pub no_loop: bool, +} + +#[mt_derive(to = "clt")] +pub struct ObjBonePos { + pub pos: [f32; 3], + pub rot: [f32; 3], +} + +#[mt_derive(to = "clt")] +pub struct ObjAttach { + pub parent_id: u16, + pub bone: String, + pub pos: [f32; 3], + pub rot: [f32; 3], + pub force_visible: bool, +} + +#[mt_derive(to = "clt")] +pub struct ObjPhysicsOverride { + pub walk: f32, + pub jump: f32, + pub gravity: f32, + // the following are player only + pub no_sneak: bool, + pub no_sneak_glitch: bool, + pub old_sneak: bool, +} + +#[mt_derive(to = "clt", repr = "u8", tag = "type", content = "data")] +pub enum ObjMsg { + Props(ObjProps) = 0, + Pos(ObjPos), + TextureMod { + #[serde(rename = "mod")] + texture_mod: String, + }, + Sprite(ObjSprite), + Hp { + hp: u16, + }, + ArmorGroups { + armor: HashMap<String, u16>, + }, + Anim(ObjAnim), + BonePos { + bone: String, + pos: ObjBonePos, + }, + Attach(ObjAttach), + PhysicsOverride(ObjPhysicsOverride), + SpawnInfant { + id: u16, + #[mt(const8 = 101)] // GenericCAO + infant_type: (), + } = 11, + AnimSpeed { + speed: f32, + }, +} #[mt_derive(to = "clt")] -pub struct ObjMsg; // TODO +pub struct ObjIdMsg { + pub id: u16, + #[mt(size16)] + pub msg: ObjMsg, +} + +#[mt_derive(to = "clt")] +pub struct ObjInitMsg(#[mt(size32)] ObjMsg); + +#[mt_derive(to = "clt")] +pub struct ObjInitData { + #[mt(const8 = 1)] // version + pub name: String, + pub is_player: bool, + pub id: u16, + pub pos: [f32; 3], + pub rot: [f32; 3], + pub hp: u16, + #[mt(len8)] + pub msgs: Vec<ObjInitMsg>, +} + +#[mt_derive(to = "clt")] +pub struct ObjAdd { + pub id: u16, + #[mt(const8 = 101)] // GenericCAO + #[mt(size32)] + pub init_data: ObjInitData, +} #[mt_derive(to = "clt", repr = "u8", enumset)] pub enum MapBlockFlag { diff --git a/src/to_clt/hud.rs b/src/to_clt/hud.rs index f45d735..cf9e337 100644 --- a/src/to_clt/hud.rs +++ b/src/to_clt/hud.rs @@ -110,13 +110,13 @@ pub struct MinimapMode { } #[mt_derive(to = "clt", custom)] -pub struct MinimapModePkt { +pub struct MinimapModesPkt { current: u16, modes: Vec<MinimapMode>, } #[cfg(feature = "server")] -impl MtSerialize for MinimapModePkt { +impl MtSerialize for MinimapModesPkt { fn mt_serialize<C: MtCfg>( &self, writer: &mut impl std::io::Write, @@ -130,7 +130,7 @@ impl MtSerialize for MinimapModePkt { } #[cfg(feature = "client")] -impl MtDeserialize for MinimapModePkt { +impl MtDeserialize for MinimapModesPkt { fn mt_deserialize<C: MtCfg>(reader: &mut impl std::io::Read) -> Result<Self, DeserializeError> { let len = DefCfg::read_len(reader)?; let current = MtDeserialize::mt_deserialize::<DefCfg>(reader)?; |