X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fserver%2Fg_models.qc;h=6c4f16b54e519a50986d79fc9ca410175c1b9328;hb=4012c96a19ebf6e582e1ff4f34913f3895fcb19c;hp=0214b9ed36b802156688eb1f98582e2b9c82b0af;hpb=1a65f7bb6bae1bb6d1a40d3e2eda30c822052313;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/g_models.qc b/qcsrc/server/g_models.qc index 0214b9ed3..6c4f16b54 100644 --- a/qcsrc/server/g_models.qc +++ b/qcsrc/server/g_models.qc @@ -1,14 +1,10 @@ -#if defined(CSQC) -#elif defined(MENUQC) -#elif defined(SVQC) - #include "../dpdefs/progsdefs.qh" - #include "../dpdefs/dpextensions.qh" - #include "../common/constants.qh" - #include "autocvars.qh" - #include "constants.qh" - #include "defs.qh" - #include "../csqcmodellib/sv_model.qh" -#endif +#include "_all.qh" + +#include "g_subs.qh" +#include "g_triggers.qh" + +#include "../common/constants.qh" +#include "../csqcmodellib/sv_model.qh" .float modelscale; @@ -29,7 +25,22 @@ void g_model_setcolormaptoactivator (void) void g_clientmodel_setcolormaptoactivator (void) { g_model_setcolormaptoactivator(); - self.SendFlags |= 1; + self.SendFlags |= (8 | 1); +} + +void g_clientmodel_use(void) +{ + if (self.antiwall_flag == 1) + { + self.inactive = 1; + self.solid = SOLID_NOT; + } + else if (self.antiwall_flag == 2) + { + self.inactive = 0; + self.solid = self.default_solid; + } + g_clientmodel_setcolormaptoactivator(); } void g_model_dropbyspawnflags() @@ -65,7 +76,7 @@ float g_clientmodel_genericsendentity (entity to, int sf) sf = sf & 0x0F; if(self.angles != '0 0 0') sf |= 0x10; - if(self.solid && (self.mins != '0 0 0' || self.maxs != '0 0 0')) + if(self.mins != '0 0 0' || self.maxs != '0 0 0') sf |= 0x20; if(self.colormap != 0) sf |= 0x40; @@ -133,6 +144,12 @@ float g_clientmodel_genericsendentity (entity to, int sf) WriteCoord(MSG_ENTITY, self.movedir.z); WriteByte(MSG_ENTITY, floor(self.lip * 255)); } + WriteShort(MSG_ENTITY, self.fade_start); + WriteShort(MSG_ENTITY, self.fade_end); + WriteShort(MSG_ENTITY, self.alpha_max); + WriteShort(MSG_ENTITY, self.alpha_min); + WriteShort(MSG_ENTITY, self.inactive); + WriteShort(MSG_ENTITY, self.fade_vertical_offset); } return true; @@ -151,11 +168,12 @@ float g_clientmodel_genericsendentity (entity to, int sf) if(self.geomtype) if(autocvar_physics_ode && checkextension("DP_PHYSICS_ODE")) self.movetype = MOVETYPE_PHYSICS; \ if(!self.scale) self.scale = self.modelscale; \ SetBrushEntityModel(); \ - self.use = g_clientmodel_setcolormaptoactivator; \ + self.use = g_clientmodel_use; \ InitializeEntity(self, g_clientmodel_dropbyspawnflags, INITPRIO_DROPTOFLOOR); \ if(!self.solid) self.solid = (sol); else if(self.solid < 0) self.solid = SOLID_NOT; \ if(!self.bgmscriptsustain) self.bgmscriptsustain = 1; else if(self.bgmscriptsustain < 0) self.bgmscriptsustain = 0; \ - Net_LinkEntity(self, true, 0, g_clientmodel_genericsendentity); + Net_LinkEntity(self, true, 0, g_clientmodel_genericsendentity); \ + self.default_solid = sol; // non-solid model entities: void spawnfunc_misc_gamemodel() { self.angles_x = -self.angles.x; G_MODEL_INIT (SOLID_NOT) } // model entity