UFO: Alien Invasion
Loading...
Searching...
No Matches
e_event_particleappear.cpp
Go to the documentation of this file.
1
4
5/*
6Copyright (C) 2002-2025 UFO: Alien Invasion.
7
8This program is free software; you can redistribute it and/or
9modify it under the terms of the GNU General Public License
10as published by the Free Software Foundation; either version 2
11of the License, or (at your option) any later version.
12
13This program is distributed in the hope that it will be useful,
14but WITHOUT ANY WARRANTY; without even the implied warranty of
15MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
16
17See the GNU General Public License for more details.
18
19You should have received a copy of the GNU General Public License
20along with this program; if not, write to the Free Software
21Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22
23*/
24
25#include "../../../../client.h"
29
30int CL_ParticleAppearTime (const struct eventRegister_s* self, dbuffer* msg, eventTiming_t* eventTiming)
31{
32 if (eventTiming->parsedShot) {
33 if (eventTiming->parsedDeath) { /* drop items after death (caused by impact) */
34 return eventTiming->impactTime + 1400;
35 } else if (eventTiming->impactTime > cl.time) { /* item thrown on the ground */
36 return eventTiming->impactTime + 75;
37 }
38 }
39
40 return eventTiming->nextTime;
41}
42
51{
52 char particle[MAX_VAR];
53 int entnum, levelflags;
55
56 /* read data */
57 NET_ReadFormat(msg, self->formatString, &entnum, &levelflags, origin, particle, sizeof(particle));
58
59 le_t* le = LE_Get(entnum);
60 if (!le)
61 LE_NotFoundError(entnum);
62
63 /* particles don't have a model to add to the scene - we mark them as invisible and
64 * only render the particle */
66 le->levelflags = levelflags;
67 le->particleID = Mem_PoolStrDup(particle, cl_genericPool, 0);
69 if (!le->ptl)
70 Com_Printf("Could not spawn particle: '%s'\n", le->particleID);
71}
clientBattleScape_t cl
le_t * LE_Get(int entnum)
Searches all local entities for the one with the searched entnum.
#define LE_SetInvisible(le)
#define LE_NotFoundError(entnum)
memPool_t * cl_genericPool
Definition cl_main.cpp:86
ptl_t * CL_ParticleSpawn(const char *name, int levelFlags, const vec3_t s, const vec3_t v, const vec3_t a)
Spawn a new particle to the map.
Primary header for client.
void Com_Printf(const char *const fmt,...)
Definition common.cpp:428
int CL_ParticleAppearTime(const struct eventRegister_s *self, dbuffer *msg, eventTiming_t *eventTiming)
void CL_ParticleAppear(const eventRegister_t *self, dbuffer *msg)
Let a particle appear for the client.
voidpf uLong int origin
Definition ioapi.h:45
#define Mem_PoolStrDup(in, pool, tagNum)
Definition mem.h:50
void NET_ReadFormat(dbuffer *buf, const char *format,...)
The user-friendly version of NET_ReadFormat that reads variable arguments from a buffer according to ...
Definition netpack.cpp:533
#define MAX_VAR
Definition shared.h:36
Struct that defines one particular event with all its callbacks and data.
Definition e_main.h:42
const char * formatString
The format string that is used to write and parse this event.
Definition e_main.h:54
CL_ParseEvent timers and vars.
Definition e_main.h:30
int nextTime
Definition e_main.h:31
int impactTime
Definition e_main.h:33
bool parsedDeath
Definition e_main.h:35
bool parsedShot
Definition e_main.h:36
a local entity
ptl_t * ptl
const char * particleID
int levelflags
vec_t vec3_t[3]
Definition ufotypes.h:39