1 REGISTER_NET_LINKED(ENT_CLIENT_CONVEYOR)
6 // TODO: check if this is what is causing the glitchiness when switching between them
7 float dt = time - self.move_time;
9 if(dt <= 0) { return; }
13 // set myself as current conveyor where possible
14 for(e = world; (e = findentity(e, conveyor, self)); )
19 for(e = findradius((self.absmin + self.absmax) * 0.5, vlen(self.absmax - self.absmin) * 0.5 + 1); e; e = e.chain)
23 vector emin = e.absmin;
24 vector emax = e.absmax;
25 if(self.solid == SOLID_BSP)
30 if(boxesoverlap(emin, emax, self.absmin, self.absmax)) // quick
31 if(WarpZoneLib_BoxTouchesBrush(emin, emax, self, e)) // accurate
35 for(e = world; (e = findentity(e, conveyor, self)); )
37 if(IS_CLIENT(e)) // doing it via velocity has quite some advantages
38 continue; // done in SV_PlayerPhysics continue;
40 setorigin(e, e.origin + self.movedir * PHYS_INPUT_FRAMETIME);
43 UpdateCSQCProjectile(e);
46 // stupid conveyor code
47 tracebox(e.origin, e.mins, e.maxs, e.origin + self.movedir * sys_frametime, MOVE_NORMAL, e);
48 if(trace_fraction > 0)
49 setorigin(e, trace_endpos);
55 self.nextthink = time;
63 self.state = !self.state;
70 self.state = (self.spawnflags & 1);
75 bool conveyor_send(entity this, entity to, int sf)
77 WriteHeader(MSG_ENTITY, ENT_CLIENT_CONVEYOR);
78 WriteByte(MSG_ENTITY, sf);
82 WriteByte(MSG_ENTITY, self.warpzone_isboxy);
83 WriteCoord(MSG_ENTITY, self.origin_x);
84 WriteCoord(MSG_ENTITY, self.origin_y);
85 WriteCoord(MSG_ENTITY, self.origin_z);
87 WriteCoord(MSG_ENTITY, self.mins_x);
88 WriteCoord(MSG_ENTITY, self.mins_y);
89 WriteCoord(MSG_ENTITY, self.mins_z);
90 WriteCoord(MSG_ENTITY, self.maxs_x);
91 WriteCoord(MSG_ENTITY, self.maxs_y);
92 WriteCoord(MSG_ENTITY, self.maxs_z);
94 WriteCoord(MSG_ENTITY, self.movedir_x);
95 WriteCoord(MSG_ENTITY, self.movedir_y);
96 WriteCoord(MSG_ENTITY, self.movedir_z);
98 WriteByte(MSG_ENTITY, self.speed);
99 WriteByte(MSG_ENTITY, self.state);
101 WriteString(MSG_ENTITY, self.targetname);
102 WriteString(MSG_ENTITY, self.target);
106 WriteByte(MSG_ENTITY, self.state);
115 self.movedir = self.movedir * self.speed;
116 self.think = conveyor_think;
117 self.nextthink = time;
120 self.use = conveyor_use;
121 self.reset = conveyor_reset;
129 Net_LinkEntity(self, 0, false, conveyor_send);
134 spawnfunc(trigger_conveyor)
141 spawnfunc(func_conveyor)
144 InitMovingBrushTrigger();
145 self.movetype = MOVETYPE_NONE;
151 void conveyor_draw(entity this) { WITH(entity, self, this, conveyor_think()); }
155 self.draw = conveyor_draw;
156 self.drawmask = MASK_NORMAL;
158 self.movetype = MOVETYPE_NONE;
160 self.solid = SOLID_TRIGGER;
161 self.move_origin = self.origin;
162 self.move_time = time;
165 NET_HANDLE(ENT_CLIENT_CONVEYOR, bool isnew)
167 float sf = ReadByte();
171 self.warpzone_isboxy = ReadByte();
172 self.origin_x = ReadCoord();
173 self.origin_y = ReadCoord();
174 self.origin_z = ReadCoord();
175 setorigin(self, self.origin);
177 self.mins_x = ReadCoord();
178 self.mins_y = ReadCoord();
179 self.mins_z = ReadCoord();
180 self.maxs_x = ReadCoord();
181 self.maxs_y = ReadCoord();
182 self.maxs_z = ReadCoord();
183 setsize(self, self.mins, self.maxs);
185 self.movedir_x = ReadCoord();
186 self.movedir_y = ReadCoord();
187 self.movedir_z = ReadCoord();
189 self.speed = ReadByte();
190 self.state = ReadByte();
192 self.targetname = strzone(ReadString());
193 self.target = strzone(ReadString());
199 self.state = ReadByte();