From b910a573fc4cac3af346d1d01a025760fc90f683 Mon Sep 17 00:00:00 2001 From: Samual Lenks Date: Thu, 2 Jan 2014 19:52:29 -0500 Subject: [PATCH] Start fixing up weaponsystem.qc to handle new model settings --- qcsrc/common/weapons/weapons.qh | 5 +++++ qcsrc/server/weapons/weaponsystem.qc | 29 ++++++++++++++++------------ 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/qcsrc/common/weapons/weapons.qh b/qcsrc/common/weapons/weapons.qh index 4987793ba8..fff453f9e6 100644 --- a/qcsrc/common/weapons/weapons.qh +++ b/qcsrc/common/weapons/weapons.qh @@ -168,6 +168,11 @@ void register_weapons_done(); .string netname; // M: refname // reference name name .string message; // M: wepname // human readable name +#define WEP_MODEL_FIRSTPERSON model +#define WEP_MODEL_THIRDPERSON model2 +#define WEP_MODEL_PICKUP model3 +#define WEP_MODEL_SIMPLE mdl + // note: the fabs call is just there to hide "if result is constant" warning #define REGISTER_WEAPON_2(id,bit,function,ammotype,impulse,flags,rating,color,firstpmdl,thirdpmdl,pickupmdl,simplemdl,crosshair,refname,wepname) \ diff --git a/qcsrc/server/weapons/weaponsystem.qc b/qcsrc/server/weapons/weaponsystem.qc index b4c46ca6f0..833d04ef1a 100644 --- a/qcsrc/server/weapons/weaponsystem.qc +++ b/qcsrc/server/weapons/weaponsystem.qc @@ -87,20 +87,25 @@ float CL_Weaponentity_CustomizeEntityForClient() // to free: // call again with "" // remove the ent -void CL_WeaponEntity_SetModel(string name) + +#define WEP_MODEL_FIRSTPERSON model // h_ // wep.WEP_MODEL_FIRSTPERSON +#define WEP_MODEL_THIRDPERSON model2 // v_ // wep.WEP_MODEL_THIRDPERSON +#define WEP_MODEL_PICKUP model3 // g_ // wep.WEP_MODEL_PICKUP +#define WEP_MODEL_SIMPLE mdl +void CL_WeaponEntity_SetModel(entity wep) { float v_shot_idx; - if (name != "") + if(wep) { // if there is a child entity, hide it until we're sure we use it if (self.weaponentity) self.weaponentity.model = ""; - setmodel(self, strcat("models/weapons/v_", name, ".md3")); // precision set below + setmodel(self, wep.WEP_MODEL_THIRDPERSON); // precision set below v_shot_idx = gettagindex(self, "shot"); // used later if(!v_shot_idx) v_shot_idx = gettagindex(self, "tag_shot"); - setmodel(self, strcat("models/weapons/h_", name, ".iqm")); // precision set below + setmodel(self, wep.WEP_MODEL_FIRSTPERSON); // precision set below // preset some defaults that work great for renamed zym files (which don't need an animinfo) self.anim_fire1 = animfixfps(self, '0 1 0.01', '0 0 0'); self.anim_fire2 = animfixfps(self, '1 1 0.01', '0 0 0'); @@ -113,14 +118,14 @@ void CL_WeaponEntity_SetModel(string name) { if (!self.weaponentity) self.weaponentity = spawn(); - setmodel(self.weaponentity, strcat("models/weapons/v_", name, ".md3")); // precision does not matter + setmodel(self.weaponentity, wep.WEP_MODEL_THIRDPERSON); // precision does not matter setattachment(self.weaponentity, self, "weapon"); } else if(gettagindex(self, "tag_weapon")) { if (!self.weaponentity) self.weaponentity = spawn(); - setmodel(self.weaponentity, strcat("models/weapons/v_", name, ".md3")); // precision does not matter + setmodel(self.weaponentity, wep.WEP_MODEL_THIRDPERSON); // precision does not matter setattachment(self.weaponentity, self, "tag_weapon"); } else @@ -248,14 +253,13 @@ void CL_WeaponEntity_SetModel(string name) vector CL_Weapon_GetShotOrg(float wpn) { - entity wi, oldself; + entity oldself; vector ret; - wi = get_weaponinfo(wpn); oldself = self; self = spawn(); - CL_WeaponEntity_SetModel(wi.mdl); + CL_WeaponEntity_SetModel(get_weaponinfo(wpn)); ret = self.movedir; - CL_WeaponEntity_SetModel(""); + CL_WeaponEntity_SetModel(world); remove(self); self = oldself; return ret; @@ -281,13 +285,14 @@ void CL_Weaponentity_Think() self.weaponentity.model = ""; return; } - if (self.weaponname != self.owner.weaponname || self.dmg != self.owner.modelindex || self.deadflag != self.owner.deadflag) + if (self.weaponname != self.owner.weaponname || self.dmg != self.owner.modelindex || self.deadflag != self.owner.deadflag) // WEAPONTODO: get rid of .weaponname, handle model directly { self.weaponname = self.owner.weaponname; self.dmg = self.owner.modelindex; self.deadflag = self.owner.deadflag; - CL_WeaponEntity_SetModel(self.owner.weaponname); + // WEAPONTODO: get weapon entity from here! + //CL_WeaponEntity_SetModel(self.owner.weaponname); } tb = (self.effects & (EF_TELEPORT_BIT | EF_RESTARTANIM_BIT)); -- 2.39.5