From: Jakob MG Date: Fri, 8 Apr 2011 14:00:22 +0000 (+0200) Subject: A little more work towards csqc vehicles X-Git-Tag: xonotic-v0.5.0~199^2~11^2~70 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=1b6e1b90abfe4713255f3829d25cdae3592962a2;p=xonotic%2Fxonotic-data.pk3dir.git A little more work towards csqc vehicles --- diff --git a/qcsrc/server/vehicles/vehicles.qc b/qcsrc/server/vehicles/vehicles.qc index 644411fc6f..fbb114bc62 100644 --- a/qcsrc/server/vehicles/vehicles.qc +++ b/qcsrc/server/vehicles/vehicles.qc @@ -814,15 +814,26 @@ float VSF_SETUP = 2; /// Send vehicle type etc float VSF_ORIGIN = 4; /// Send location float VSF_MOVEMENT = 8; /// Send movement update (and angle/avelocity) float VSF_STATS = 16; /// Send ammo, health etc -float VSF_EXTRA = 32; /// Send additional data (turret rotations and such) handeld per vehicle type. +float VSF_EXTRA = 32; /// Send additional data (turret rotations and such). Handeld per vehicle type. +float VSF_ANIMINFO = 64; /// Animation info float VSF_FULL_UPDATE = 16777215 /// Send everything #ifdef SVQC float send_vehile(entity to, float sf) { + float dist; + + // Always send a compleate update to owner, minus VSF_SETUP + if(to == self.owner && self.owner != world && sf != VSF_FULL_UPDATE) + sf |= (VSF_FULL_UPDATE &~= VSF_SETUP); + + dist = vlen(self.origin - to.origin); + // TODO: Distance based message filtering + WriteByte(MSG_ENTITY, ENT_CLIENT_VEHICLE); - + + // We need to know client-side what was sent WriteByte(MSG_ENTITY, sf); if(sf & VSF_SETUP) @@ -885,15 +896,6 @@ void Net_ReadVehicle(float bIsNew) { float sf; - sf = ReadByte(); - - if(sf & VSF_SETUP) - { - float vhtype; - vhtype = ReadByte(); - - } - if(bIsNew) { setmodel(self, "models/vehicles/wakizashi.dpm"); @@ -903,24 +905,38 @@ void Net_ReadVehicle(float bIsNew) self.draw = VehicleRacerDraw; self.scale = 0.5; } + + sf = ReadByte(); + if(sf & VSF_SETUP) + { + self.hud = ReadByte(); + self.team = ReadByte(); + self.colormap = ReadShort(); + } - self.cnt = ReadByte(); - - self.origin_x = ReadCoord(); - self.origin_y = ReadCoord(); - self.origin_z = ReadCoord(); + if(sf & if(sf & VSF_ORIGIN)) + { + self.origin_x = ReadCoord(); + self.origin_y = ReadCoord(); + self.origin_z = ReadCoord(); + self.move_origin = self.origin; + } - self.velocity_x = ReadCoord(); - self.velocity_y = ReadCoord(); - self.velocity_z = ReadCoord(); + if(sf & VSF_MOVEMENT) + { + self.velocity_x = ReadCoord(); + self.velocity_y = ReadCoord(); + self.velocity_z = ReadCoord(); - self.angles_x = ReadAngle(); - self.angles_y = ReadAngle(); - self.angles_z = ReadAngle(); + self.angles_x = ReadAngle(); + self.angles_y = ReadAngle(); + self.angles_z = ReadAngle(); + + self.move_velocity = self.velocity; + self.move_angles = self.angles; - self.move_origin = self.origin; - self.move_velocity = self.velocity; - self.move_angles = self.angles; + } + } #endif // CSQC