From f3efebde7ada4e5ba2f2720f0318cb46b53d68da Mon Sep 17 00:00:00 2001 From: Jakob MG Date: Fri, 8 Apr 2011 05:56:09 +0200 Subject: [PATCH] Begin csqc vehicles framework (not functional or used yet). Add some comments. Spawn 3 not 4 shell fragments for raptor bomb on split (only function change in this commit) --- qcsrc/client/Main.qc | 2 +- qcsrc/client/damage.qc | 2 +- qcsrc/client/vehicles/vehicles.qc | 8 +- qcsrc/common/constants.qh | 2 +- qcsrc/server/vehicles/vehicles.qc | 183 ++++++++++++++++++++------ qcsrc/server/vehicles/vehicles_def.qh | 70 +++++----- 6 files changed, 194 insertions(+), 73 deletions(-) diff --git a/qcsrc/client/Main.qc b/qcsrc/client/Main.qc index db1b9b3a9e..3e9f73305f 100644 --- a/qcsrc/client/Main.qc +++ b/qcsrc/client/Main.qc @@ -970,7 +970,7 @@ void(float bIsNewEntity) CSQC_Ent_Update = case ENT_CLIENT_GAUNTLET: Ent_ReadHook(bIsNewEntity, ENT_CLIENT_GAUNTLET); break; case ENT_CLIENT_ACCURACY: Ent_ReadAccuracy(); break; case ENT_CLIENT_AUXILIARYXHAIR: Net_AuXair2(bIsNewEntity); break; - case ENT_CLIENT_VEHICLE_RACER: Net_VehicleRacer(bIsNewEntity); break; + case ENT_CLIENT_VEHICLE: Net_Vehicle(bIsNewEntity); break; default: error(strcat(_("unknown entity type in CSQC_Ent_Update: %d\n"), self.enttype)); break; diff --git a/qcsrc/client/damage.qc b/qcsrc/client/damage.qc index 6aad2e57fc..cd338553ad 100644 --- a/qcsrc/client/damage.qc +++ b/qcsrc/client/damage.qc @@ -120,7 +120,7 @@ void Ent_DamageInfo(float isNew) case DEATH_RAPTOR_BOMB_SPLIT: float i; vector ang, vel; - for(i = 1; i <= 4; ++i) + for(i = 1; i < 4; ++i) { vel = normalize(w_org - (w_org + normalize(force) * 16)) + randomvec() * 128; ang = vectoangles(vel); diff --git a/qcsrc/client/vehicles/vehicles.qc b/qcsrc/client/vehicles/vehicles.qc index 14949e9405..20d3fab75e 100644 --- a/qcsrc/client/vehicles/vehicles.qc +++ b/qcsrc/client/vehicles/vehicles.qc @@ -57,6 +57,10 @@ void AuxiliaryXhair_Draw2D() self.draw2d = Draw_Not; } +void Net_Vehicle(float IsNew) +{ + //entnum +} void Net_AuXair2(float bIsNew) { @@ -476,6 +480,7 @@ void RaptorCBShellfragDraw() self.move_avelocity += randomvec() * 15; self.renderflags = 0; + if(self.cnt < time) self.alpha = bound(0, self.nextthink - time, 1); if(self.alpha < ALPHA_MIN_VISIBLE) @@ -504,7 +509,8 @@ void RaptorCBShellfragToss(vector _org, vector _vel, vector _ang) sfrag.move_time = time; sfrag.damageforcescale = 4; - sfrag.nextthink = time + 2 * (1 + prandom() * 2); + sfrag.nextthink = time + 3; + sfrag.cnt = time + 2; sfrag.drawmask = MASK_NORMAL; diff --git a/qcsrc/common/constants.qh b/qcsrc/common/constants.qh index 93ace6f5f8..c56bda74ce 100644 --- a/qcsrc/common/constants.qh +++ b/qcsrc/common/constants.qh @@ -117,7 +117,7 @@ const float ENT_CLIENT_ACCURACY = 30; const float ENT_CLIENT_TURRET = 40; const float ENT_CLIENT_AUXILIARYXHAIR = 50; -const float ENT_CLIENT_VEHICLE_RACER = 60; +const float ENT_CLIENT_VEHICLE = 60; const float SPRITERULE_DEFAULT = 0; const float SPRITERULE_TEAMPLAY = 1; diff --git a/qcsrc/server/vehicles/vehicles.qc b/qcsrc/server/vehicles/vehicles.qc index ad5b006e3a..644411fc6f 100644 --- a/qcsrc/server/vehicles/vehicles.qc +++ b/qcsrc/server/vehicles/vehicles.qc @@ -10,7 +10,10 @@ void vehicles_clearrturn(); void vehicles_setreturn(); -#define MAX_AXH 4 +/** AuxiliaryXhair* + Send addictional points of interest to be drawn, to vehicle owner +**/ +float MAX_AXH = 4; .entity AuxiliaryXhair[MAX_AXH]; float SendAuxiliaryXhair(entity to, float sf) @@ -75,6 +78,7 @@ void SendAuxiliaryXhair2(entity own, vector loc, vector clr, float axh_id) } */ +// End AuxiliaryXhair void CSQCVehicleSetup(entity own, float vehicle_id) { @@ -85,6 +89,19 @@ void CSQCVehicleSetup(entity own, float vehicle_id) WriteByte(MSG_ONE, vehicle_id); } +/** vehicles_locktarget + + Generic target locking. + + Figure out if what target is "locked" (if any), for missile tracking as such. + + after calling, "if(self.lock_target != world && self.lock_strength == 1)" mean + you have a locked in target. + + Exspects a crosshair_trace() or equivalent to be + dont before calling. + +**/ .entity lock_target; .float lock_strength; .float lock_time; @@ -143,6 +160,7 @@ traceline(orig, orig + vel * dt, MOVE_NORMAL, self); \ if(trace_fraction != 1) \ acm += normalize(self.origin - trace_endpos) * (vlen(vel) * mult) +// Hover movement support float force_fromtag_power; float force_fromtag_normpower; vector force_fromtag_origin; @@ -158,6 +176,8 @@ vector vehicles_force_fromtag_hover(string tag_name, float spring_length, float return v_forward * force_fromtag_power; } +// Experimental hovermode wich uses attraction/repulstion from surface unsted of gravity/repulsion +// Can possibly be use to move abt any surface (inclusing walls/celings) vector vehicles_force_fromtag_maglev(string tag_name, float spring_length, float max_power) { @@ -165,6 +185,7 @@ vector vehicles_force_fromtag_maglev(string tag_name, float spring_length, float v_forward = normalize(v_forward) * -1; traceline(force_fromtag_origin, force_fromtag_origin - (v_forward * spring_length), MOVE_NORMAL, self); + // TODO - this may NOT be compatible with wall/celing movement, unhardcode 0.25 (engine count multiplier) if(trace_fraction == 1.0) { force_fromtag_normpower = -0.25; @@ -177,6 +198,7 @@ vector vehicles_force_fromtag_maglev(string tag_name, float spring_length, float return v_forward * force_fromtag_power; } +// Generic vehile projectile system void vehicles_projectile_damage(entity inflictor, entity attacker, float damage, float deathtype, vector hitloc, vector force) { self.health -= damage; @@ -262,7 +284,12 @@ entity vehicles_projectile(string _mzlfx, string _mzlsound, return proj; } +// End generic vehile projectile system +/** vehicles_spawn + Exetuted for all vehiles on (re)spawn. + Sets defaults for newly spawned units. +**/ void vehicles_spawn() { dprint("Spawning vehicle: ", self.netname, "\n"); @@ -663,42 +690,6 @@ void vehicles_reset_colors() self.effects = _effects; } -//#define VEHICLES_CSQC -#ifdef VEHICLES_CSQC -#define VSF_ORG 2 -#define VSF_VEL 4 -#define VSF_ANG 8 -#define VSF_COLORMAP 16 -#define VSF_STAT1 32 - -float SendVehicle(entity to, float sf) -{ - WriteByte(MSG_ENTITY, ENT_CLIENT_VEHICLE_RACER); - - WriteByte(MSG_ENTITY, self.cnt); - - WriteCoord(MSG_ENTITY, self.origin_x); - WriteCoord(MSG_ENTITY, self.origin_y); - WriteCoord(MSG_ENTITY, self.origin_z); - - WriteCoord(MSG_ENTITY, self.velocity_x); - WriteCoord(MSG_ENTITY, self.velocity_y); - WriteCoord(MSG_ENTITY, self.velocity_z); - - WriteAngle(MSG_ENTITY, self.angles_x); - WriteAngle(MSG_ENTITY, self.angles_y); - WriteAngle(MSG_ENTITY, self.angles_z); - - return TRUE; -} - -void NetLinkVehicle() -{ - self.SendFlags = 0xFFFFFF; - Net_LinkEntity(self, FALSE, 0, SendVehicle); -} -#endif - float vehicle_initialize(string net_name, string bodymodel, string topmodel, @@ -816,3 +807,121 @@ void bugmenot() self.vehicle_spawn = self.vehicle_exit; self.AuxiliaryXhair = self.AuxiliaryXhair; } + +#ifdef VEHICLES_CSQC +// SendFlags +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_FULL_UPDATE = 16777215 /// Send everything + + +#ifdef SVQC +float send_vehile(entity to, float sf) +{ + WriteByte(MSG_ENTITY, ENT_CLIENT_VEHICLE); + + WriteByte(MSG_ENTITY, sf); + + if(sf & VSF_SETUP) + { + WriteByte(MSG_ENTITY, self.hud); //vehicle type = hud + WriteByte(MSG_ENTITY, self.team); + WriteShort(MSG_ENTITY, self.colormap); + } + + if(sf & VSF_ORIGIN) + { + WriteCoord(MSG_ENTITY, self.origin_x); + WriteCoord(MSG_ENTITY, self.origin_y); + WriteCoord(MSG_ENTITY, self.origin_z); + } + + if(sf & VSF_MOVEMENT) + { + WriteCoord(MSG_ENTITY, self.velocity_x); + WriteCoord(MSG_ENTITY, self.velocity_y); + WriteCoord(MSG_ENTITY, self.velocity_z); + + WriteAngle(MSG_ENTITY, self.angles_x); + WriteAngle(MSG_ENTITY, self.angles_y); + WriteAngle(MSG_ENTITY, self.angles_z); + + WriteCoord(MSG_ENTITY, self.avelocity_x); + WriteCoord(MSG_ENTITY, self.avelocity_y); + WriteCoord(MSG_ENTITY, self.avelocity_z); + } + + if(sf & VSF_STATS) + { + WriteShort(MSG_ENTITY, self.vehicle_health); + WriteShort(MSG_ENTITY, self.vehicle_shield); + WriteShort(MSG_ENTITY, self.vehicle_energy); + WriteShort(MSG_ENTITY, self.vehicle_ammo1); + WriteShort(MSG_ENTITY, self.vehicle_reload1); + WriteShort(MSG_ENTITY, self.vehicle_ammo2); + WriteShort(MSG_ENTITY, self.vehicle_reload2); + } + + if(sf & VSF_EXTRA) + { + self.vehile_send_exta(to); + } + + return TRUE; +} + +void net_link_vehile() +{ + self.SendFlags = 0xFFFFFF; + Net_LinkEntity(self, FALSE, 0, send_vehile); +} +#endif // SVQC + +#ifdef CSQC +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"); + self.move_movetype = MOVETYPE_BOUNCE; + self.entremove = VehicleRacerRemove; + setsize(self, '-60 -60 -20', '60 60 20'); + self.draw = VehicleRacerDraw; + self.scale = 0.5; + } + + self.cnt = ReadByte(); + + self.origin_x = ReadCoord(); + self.origin_y = ReadCoord(); + self.origin_z = ReadCoord(); + + 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.move_origin = self.origin; + self.move_velocity = self.velocity; + self.move_angles = self.angles; +} +#endif // CSQC + +#endif // VEHICLES_CSQC diff --git a/qcsrc/server/vehicles/vehicles_def.qh b/qcsrc/server/vehicles/vehicles_def.qh index 570e8a8285..8c68fa04a1 100644 --- a/qcsrc/server/vehicles/vehicles_def.qh +++ b/qcsrc/server/vehicles/vehicles_def.qh @@ -1,62 +1,68 @@ +// #define VEHICLES_CSQC +// #define VEHICLES_USE_ODE #define VEHICLES_ENABLED #ifdef VEHICLES_ENABLED //#define VEHICLES_VIEWROTATE_CROSSHAIR - #message "with tZork vehicles (experimental)" -float SVC_SETVIEWPORT = 5; // Net.Protocol 0x05 -float SVC_SETVIEWANGLES = 10; // Net.Protocol 0x0A -float SVC_UPDATEENTITY = 128; // Net.Protocol 0x80 - .float vehicle_flags; -#define VHF_ISVEHICLE 2 -#define VHF_HASSHIELD 4 -#define VHF_SHIELDREGEN 8 -#define VHF_HEALTHREGEN 16 -#define VHF_ENERGYREGEN 32 -#define VHF_DEATHEJECT 64 -#define VHF_MOVE_GROUND 128 -#define VHF_MOVE_HOVER 256 -#define VHF_MOVE_FLY 512 +float VHF_ISVEHICLE = 2; /// Indicates vehicle +float VHF_HASSHIELD = 4; /// Vehicle has shileding +float VHF_SHIELDREGEN = 8; /// Vehicles shield regenerates +float VHF_HEALTHREGEN = 16; /// Vehicles health regenerates +float VHF_ENERGYREGEN = 32; /// Vehicles energy regenerates +float VHF_DEATHEJECT = 64; /// Vehicle ejects pilot upon fatal damage +float VHF_MOVE_GROUND = 128; /// Vehicle moves on gound +float VHF_MOVE_HOVER = 256; /// Vehicle hover close to gound +float VHF_MOVE_FLY = 512; /// Vehicle is airborn .float hud; .entity gun1; .entity gun2; -.entity vehicle_shieldent; - -.float vehicle_health; -.float vehicle_shield; -.float vehicle_energy; +.float vehicle_health; /// If self is player this is 0..1 indicating precentage of health left on vehicle. If self is vehile, this is the real health value. +.float vehicle_energy; /// If self is player this is 0..1 indicating precentage of energy left on vehicle. If self is vehile, this is the real energy value. +.float vehicle_shield; /// If self is player this is 0..1 indicating precentage of shield left on vehicle. If self is vehile, this is the real shield value. +.entity vehicle_shieldent; /// Entity to disply the shild effect on damage -.float vehicle_ammo1; -.float vehicle_reload1; - -.float vehicle_ammo2; -.float vehicle_reload2; +.float vehicle_ammo1; /// If self is player this field's use depends on the individual vehile. If self is vehile, this is the real ammo1 value. +.float vehicle_reload1; /// If self is player this field's use depends on the individual vehile. If self is vehile, this is the real reload1 value. +.float vehicle_ammo2; /// If self is player this field's use depends on the individual vehile. If self is vehile, this is the real ammo2 value. +.float vehicle_reload2; /// If self is player this field's use depends on the individual vehile. If self is vehile, this is the real reload2 value. .entity vehicle; .entity vehicle_viewport; .entity vehicle_hudmodel; +#ifdef SVQC .float dmg_time; - .float vehicle_respawntime; .void() vehicle_spawn; var .void(float exit_flags) vehicle_exit; -#define VHEF_NORMAL 0 -#define VHEF_EJECT 1 -#define VHEF_RELESE 2 +float VHEF_NORMAL = 0; /// User pressed exit key +float VHEF_EJECT = 1; /// User pressed exit key 3 times fast (not implemented) or vehile is dying +float VHEF_RELESE = 2; /// Release ownership, client possibly allready dissconnected / went spec / changed team / used "kill" (not implemented) + +float SVC_SETVIEWPORT = 5; // Net.Protocol 0x05 +float SVC_SETVIEWANGLES = 10; // Net.Protocol 0x0A +float SVC_UPDATEENTITY = 128; // Net.Protocol 0x80 -var .void() vehicle_enter; -var .void() vehicle_die; -var .void() vehicle_spawn; +var .void() vehicle_enter; /// Vehicles custom funciton to be executed when owner exit it +var .void() vehicle_die; /// Vehicles custom function to be executed when vehile die +var .void() vehicle_spawn; /// Vehicles custom fucntion to be efecuted when vehicle (re)spawns -#endif +#ifdef VEHICLES_CSQC +var .void(entity to) vehile_send_exta; /// Vehicles custom send code (for extra bits, stats and whatnot) +void net_link_vehile(); /// Initiates csqc networking for vehicle +#endif //VEHICLES_CSQC +#endif //SVQC +#ifdef VEHICLES_USE_ODE void(entity e, float physics_enabled) physics_enable = #540; // enable or disable physics on object void(entity e, vector force, vector force_pos) physics_addforce = #541; // apply a force from certain origin, length of force vector is power of force void(entity e, vector torque) physics_addtorque = #542; // add relative torque +#endif // VEHICLES_USE_ODE +#endif // VEHICLES_ENABLED \ No newline at end of file -- 2.39.5