summaryrefslogtreecommitdiff
path: root/src/game
diff options
context:
space:
mode:
authorTim Angus <tim@ngus.net>2002-12-02 02:32:49 +0000
committerTim Angus <tim@ngus.net>2002-12-02 02:32:49 +0000
commit5056c7733069093f7c9263e861512c4e7bc27990 (patch)
tree4502a65edbbb28c9a07c85be244f5cc5536aa91a /src/game
parent99f454e46275215412247564878896806a772ed0 (diff)
* Bounding box fiddles
* Added a small radius search to the use action * Fixed a couple of crash bugs
Diffstat (limited to 'src/game')
-rw-r--r--src/game/bg_misc.c44
-rw-r--r--src/game/g_active.c26
-rw-r--r--src/game/g_client.c2
-rw-r--r--src/game/g_cmds.c2
4 files changed, 52 insertions, 22 deletions
diff --git a/src/game/bg_misc.c b/src/game/bg_misc.c
index 4422d29c..4300cfa1 100644
--- a/src/game/bg_misc.c
+++ b/src/game/bg_misc.c
@@ -1273,12 +1273,12 @@ classAttributes_t bg_classList[ ] =
"default", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -15, -15, -15 }, //vec3_t mins;
- { 15, 15, 15 }, //vec3_t maxs;
- { 15, 15, 15 }, //vec3_t crouchmaxs;
+ { -15, -15, -6 }, //vec3_t mins;
+ { 15, 15, 6 }, //vec3_t maxs;
+ { 15, 15, 6 }, //vec3_t crouchmaxs;
{ -15, -15, -4 }, //vec3_t deadmins;
{ 15, 15, 4 }, //vec3_t deadmaxs;
- 0, 0, //int viewheight, crouchviewheight;
+ 6, 6, //int viewheight, crouchviewheight;
SOLDIER_HEALTH, //int health;
SOLDIER_REGEN, //int regenRate;
SCA_WALLCLIMBER|SCA_CANJUMP|SCA_NOWEAPONDRIFT|
@@ -1303,9 +1303,9 @@ classAttributes_t bg_classList[ ] =
"red", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -24, -24, -24 }, //vec3_t mins;
- { 24, 24, 24 }, //vec3_t maxs;
- { 24, 24, 24 }, //vec3_t crouchmaxs;
+ { -24, -24, -9 }, //vec3_t mins;
+ { 24, 24, 9 }, //vec3_t maxs;
+ { 24, 24, 9 }, //vec3_t crouchmaxs;
{ -24, -24, -4 }, //vec3_t deadmins;
{ 24, 24, 4 }, //vec3_t deadmaxs;
6, 6, //int viewheight, crouchviewheight;
@@ -1332,9 +1332,9 @@ classAttributes_t bg_classList[ ] =
"blue", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -24, -24, -24 }, //vec3_t mins;
- { 24, 24, 24 }, //vec3_t maxs;
- { 24, 24, 24 }, //vec3_t crouchmaxs;
+ { -24, -24, -11 }, //vec3_t mins;
+ { 24, 24, 11 }, //vec3_t maxs;
+ { 24, 24, 11 }, //vec3_t crouchmaxs;
{ -24, -24, -4 }, //vec3_t deadmins;
{ 24, 24, 4 }, //vec3_t deadmaxs;
6, 6, //int viewheight, crouchviewheight;
@@ -1361,9 +1361,9 @@ classAttributes_t bg_classList[ ] =
"default", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -24, -24, -24 }, //vec3_t mins;
- { 24, 24, 24 }, //vec3_t maxs;
- { 24, 24, 24 }, //vec3_t crouchmaxs;
+ { -24, -24, -12 }, //vec3_t mins;
+ { 24, 24, 12 }, //vec3_t maxs;
+ { 24, 24, 12 }, //vec3_t crouchmaxs;
{ -24, -24, -4 }, //vec3_t deadmins;
{ 24, 24, 4 }, //vec3_t deadmaxs;
6, 6, //int viewheight, crouchviewheight;
@@ -1391,9 +1391,9 @@ classAttributes_t bg_classList[ ] =
"blue", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -24, -24, -24 }, //vec3_t mins;
- { 24, 24, 24 }, //vec3_t maxs;
- { 24, 24, 24 }, //vec3_t crouchmaxs;
+ { -24, -24, -14 }, //vec3_t mins;
+ { 24, 24, 14 }, //vec3_t maxs;
+ { 24, 24, 14 }, //vec3_t crouchmaxs;
{ -24, -24, -4 }, //vec3_t deadmins;
{ 24, 24, 4 }, //vec3_t deadmaxs;
6, 6, //int viewheight, crouchviewheight;
@@ -1450,9 +1450,9 @@ classAttributes_t bg_classList[ ] =
"red", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -15, -15, -15 }, //vec3_t mins;
- { 15, 15, 15 }, //vec3_t maxs;
- { 15, 15, 15 }, //vec3_t crouchmaxs;
+ { -15, -15, -16 }, //vec3_t mins;
+ { 15, 15, 16 }, //vec3_t maxs;
+ { 15, 15, 16 }, //vec3_t crouchmaxs;
{ -15, -15, -4 }, //vec3_t deadmins;
{ 15, 15, 4 }, //vec3_t deadmaxs;
4, 4, //int viewheight, crouchviewheight;
@@ -1479,9 +1479,9 @@ classAttributes_t bg_classList[ ] =
"default", //char *skinname;
"alien_hud", //char *hudname;
( 1 << S1 )|( 1 << S2 )|( 1 << S3 ), //int stages
- { -30, -30, -35 }, //vec3_t mins;
- { 30, 30, 15 }, //vec3_t maxs;
- { 30, 30, 15 }, //vec3_t crouchmaxs;
+ { -30, -30, -36 }, //vec3_t mins;
+ { 30, 30, 36 }, //vec3_t maxs;
+ { 30, 30, 36 }, //vec3_t crouchmaxs;
{ -15, -15, -4 }, //vec3_t deadmins;
{ 15, 15, 4 }, //vec3_t deadmaxs;
4, 4, //int viewheight, crouchviewheight;
diff --git a/src/game/g_active.c b/src/game/g_active.c
index 463868db..7c643014 100644
--- a/src/game/g_active.c
+++ b/src/game/g_active.c
@@ -1114,6 +1114,13 @@ void ClientThink_real( gentity_t *ent )
}
else
{
+#define USE_OBJECT_RANGE 64
+
+ int entityList[ MAX_GENTITIES ];
+ vec3_t range = { USE_OBJECT_RANGE, USE_OBJECT_RANGE, USE_OBJECT_RANGE };
+ vec3_t mins, maxs, dir;
+ int i, num;
+
//TA: look for object infront of player
AngleVectors( client->ps.viewangles, view, NULL, NULL );
VectorMA( client->ps.origin, 200, view, point );
@@ -1123,6 +1130,25 @@ void ClientThink_real( gentity_t *ent )
if( traceEnt->use )
traceEnt->use( traceEnt, ent, ent ); //other and activator are the same in this context
+ else
+ {
+ //no entity in front of player - do a small area search
+
+ VectorAdd( client->ps.origin, range, maxs );
+ VectorSubtract( client->ps.origin, range, mins );
+
+ num = trap_EntitiesInBox( mins, maxs, entityList, MAX_GENTITIES );
+ for( i = 0; i < num; i++ )
+ {
+ traceEnt = &g_entities[ entityList[ i ] ];
+
+ if( traceEnt->use )
+ {
+ traceEnt->use( traceEnt, ent, ent ); //other and activator are the same in this context
+ break;
+ }
+ }
+ }
}
}
diff --git a/src/game/g_client.c b/src/game/g_client.c
index 0935c84a..b6bb58f8 100644
--- a/src/game/g_client.c
+++ b/src/game/g_client.c
@@ -1281,6 +1281,8 @@ void ClientSpawn( gentity_t *ent, gentity_t *spawn )
spawn_origin[ 2 ] += bodyMaxs[ 2 ] + fabs( classMins[ 2 ] ) + 1;
G_AddEvent( spawn, EV_GIB_ALIEN, DirToByte( up ) );
spawn->freeAfterEvent = qtrue;
+
+ spawnPoint = spawn;
}
else
{
diff --git a/src/game/g_cmds.c b/src/game/g_cmds.c
index 6b8664ec..32c3c6ee 100644
--- a/src/game/g_cmds.c
+++ b/src/game/g_cmds.c
@@ -1836,6 +1836,8 @@ void Cmd_Spawnbody_f( gentity_t *ent )
VectorMA( ent->client->ps.origin, 128.0f, forward, dummy->r.currentOrigin );
dummy->r.currentOrigin[ 2 ] += 64.0f;
+ dummy->client = level.clients + MAX_CLIENTS;
+
dummy->client->ps.stats[ STAT_PTEAM ] = PTE_HUMANS;
dummy->client->ps.stats[ STAT_PCLASS ] = PCL_H_BASE;