From f4413207a03658c719987d02fdbb87443843f43b Mon Sep 17 00:00:00 2001 From: enneract Date: Sun, 23 Nov 2014 22:29:30 +0100 Subject: Remove Smoke Grenade. --- assets/icons/iconw_smoke.tga | Bin 40044 -> 0 bytes assets/models/weapons/smoke/smoke.jpg | Bin 99790 -> 0 bytes assets/models/weapons/smoke/smoke.md3 | Bin 2652 -> 0 bytes assets/models/weapons/smoke/smoke.wav | Bin 52974 -> 0 bytes assets/models/weapons/smoke/smokegfx.tga | Bin 262188 -> 0 bytes assets/models/weapons/smoke/weapon.cfg | 11 --------- src/cgame/cg_event.c | 10 +------- src/cgame/cg_weapons.c | 2 -- src/game/bg_misc.c | 25 -------------------- src/game/bg_mod.h | 1 - src/game/bg_public.h | 1 - src/game/g_active.c | 15 ------------ src/game/g_missile.c | 38 ------------------------------- src/game/g_weapon.c | 15 ------------ 14 files changed, 1 insertion(+), 117 deletions(-) delete mode 100644 assets/icons/iconw_smoke.tga delete mode 100644 assets/models/weapons/smoke/smoke.jpg delete mode 100644 assets/models/weapons/smoke/smoke.md3 delete mode 100644 assets/models/weapons/smoke/smoke.wav delete mode 100644 assets/models/weapons/smoke/smokegfx.tga delete mode 100644 assets/models/weapons/smoke/weapon.cfg diff --git a/assets/icons/iconw_smoke.tga b/assets/icons/iconw_smoke.tga deleted file mode 100644 index 0dd72b1..0000000 Binary files a/assets/icons/iconw_smoke.tga and /dev/null differ diff --git a/assets/models/weapons/smoke/smoke.jpg b/assets/models/weapons/smoke/smoke.jpg deleted file mode 100644 index a001de3..0000000 Binary files a/assets/models/weapons/smoke/smoke.jpg and /dev/null differ diff --git a/assets/models/weapons/smoke/smoke.md3 b/assets/models/weapons/smoke/smoke.md3 deleted file mode 100644 index 53fed50..0000000 Binary files a/assets/models/weapons/smoke/smoke.md3 and /dev/null differ diff --git a/assets/models/weapons/smoke/smoke.wav b/assets/models/weapons/smoke/smoke.wav deleted file mode 100644 index 6c2d7ea..0000000 Binary files a/assets/models/weapons/smoke/smoke.wav and /dev/null differ diff --git a/assets/models/weapons/smoke/smokegfx.tga b/assets/models/weapons/smoke/smokegfx.tga deleted file mode 100644 index f028d75..0000000 Binary files a/assets/models/weapons/smoke/smokegfx.tga and /dev/null differ diff --git a/assets/models/weapons/smoke/weapon.cfg b/assets/models/weapons/smoke/weapon.cfg deleted file mode 100644 index 93fd03a..0000000 --- a/assets/models/weapons/smoke/weapon.cfg +++ /dev/null @@ -1,11 +0,0 @@ -icon icons/iconw_smoke -idleSound models/weapons/smoke/smoke.wav -primary -{ - - missileParticleSystem models/weapons/smoke/impactPS - - missileModel models/weapons/smoke/smoke.md3 - missileAnimates 0 20 20 0 - -} diff --git a/src/cgame/cg_event.c b/src/cgame/cg_event.c index 794b8a4..d9e2f77 100644 --- a/src/cgame/cg_event.c +++ b/src/cgame/cg_event.c @@ -244,10 +244,7 @@ static void CG_Obituary( entityState_t *ent ) else message = "^5was terminated by own flames"; break; - - case MOD_SMOKE: - message = "^5smoked himself up"; - break; + case MOD_ABOMB: message = "^5bombed himself up"; break; @@ -357,11 +354,6 @@ static void CG_Obituary( entityState_t *ent ) message2 = "^5's ^5flames"; break; - case MOD_SMOKE: - message = "^5tasted^7"; - message2 = "^5's ^5smoke"; - break; - case MOD_ABUILDER_CLAW: message = "^5should leave^7"; message2 = "^5's ^5buildings alone"; diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c index 2b41d13..04f6495 100644 --- a/src/cgame/cg_weapons.c +++ b/src/cgame/cg_weapons.c @@ -65,8 +65,6 @@ void CG_RegisterUpgrade( int upgradeNum ) upgradeInfo->upgradeIcon = cg_weapons[ WP_GRENADE ].weaponIcon; else if( upgradeNum == UP_MINE ) upgradeInfo->upgradeIcon = cg_weapons[ WP_MINE ].weaponIcon; - else if( upgradeNum == UP_SMOKE ) - upgradeInfo->upgradeIcon = cg_weapons[ WP_SMOKE ].weaponIcon; else if( ( icon = BG_Upgrade( upgradeNum )->icon ) ) upgradeInfo->upgradeIcon = trap_R_RegisterShader( icon ); } diff --git a/src/game/bg_misc.c b/src/game/bg_misc.c index 92f3826..742363d 100644 --- a/src/game/bg_misc.c +++ b/src/game/bg_misc.c @@ -3651,31 +3651,6 @@ static const weaponAttributes_t bg_weapons[ ] = qfalse, //qboolean longRanged; TEAM_HUMANS //team_t team; }, - { - WP_SMOKE, //int weaponNum; - SMOKE_PRICE, //int price; - STAGE_GE_5, //int stages - SLOT_NONE, //int slots; - "smoke", //char *weaponName; - "Smoke", //char *weaponHumanName; - "", - 1, //int maxAmmo; - 0, //int maxClips; - qfalse, //int infiniteAmmo; - qfalse, //int usesEnergy; - SMOKE_REPEAT, //int repeatRate1; - 0, //int repeatRate2; - 0, //int repeatRate3; - 0, //int reloadTime; - SMOKE_K_SCALE, //float knockbackScale; - qfalse, //qboolean hasAltMode; - qfalse, //qboolean hasThirdMode; - qfalse, //qboolean canZoom; - 90.0f, //float zoomFov; - qfalse, //qboolean purchasable; - qfalse, //qboolean longRanged; - TEAM_HUMANS //WUTeam_t team; - }, { WP_MINE, //int weaponNum; MINE_PRICE, //int price; diff --git a/src/game/bg_mod.h b/src/game/bg_mod.h index 5e4245b..4929b32 100644 --- a/src/game/bg_mod.h +++ b/src/game/bg_mod.h @@ -18,7 +18,6 @@ MOD( MOD_GRENADE ), MOD( MOD_PSAWBLADE ), MOD( MOD_MINE ), MOD( MOD_FLAMES ), -MOD( MOD_SMOKE ), MOD( MOD_SPITEFUL_ABCESS ), MOD( MOD_WATER ), MOD( MOD_SLIME ), diff --git a/src/game/bg_public.h b/src/game/bg_public.h index 2ca9e32..c0b6381 100644 --- a/src/game/bg_public.h +++ b/src/game/bg_public.h @@ -359,7 +359,6 @@ typedef enum WP_LUCIFER_CANNON, WP_ROCKET_LAUNCHER, WP_GRENADE, - WP_SMOKE, WP_MINE, WP_LOCKBLOB_LAUNCHER, WP_HIVE, diff --git a/src/game/g_active.c b/src/game/g_active.c index c7a8977..951a3a9 100644 --- a/src/game/g_active.c +++ b/src/game/g_active.c @@ -1941,21 +1941,6 @@ void ClientThink_real( gentity_t *ent ) ent->s.weapon = lastWeapon; } - if( BG_InventoryContainsUpgrade( UP_SMOKE, client->ps.stats ) && - BG_UpgradeIsActive( UP_SMOKE, client->ps.stats ) ) - { - int lastWeapon = ent->s.weapon; - - //remove SMOKE - BG_DeactivateUpgrade( UP_SMOKE, client->ps.stats ); - BG_RemoveUpgradeFromInventory( UP_SMOKE, client->ps.stats ); - - //M-M-M-M-MONSTER HACK - ent->s.weapon = WP_SMOKE; - FireWeapon( ent ); - ent->s.weapon = lastWeapon; - } - // set speed if( client->ps.pm_type == PM_NOCLIP ) client->ps.speed = client->pers.flySpeed; diff --git a/src/game/g_missile.c b/src/game/g_missile.c index 830d72a..2056f79 100644 --- a/src/game/g_missile.c +++ b/src/game/g_missile.c @@ -1241,44 +1241,6 @@ gentity_t *launch_saw( gentity_t *self, vec3_t start, vec3_t dir ) return bolt; } - -gentity_t *launch_smoke( gentity_t *self, vec3_t start, vec3_t dir ) -{ - gentity_t *bolt; - - VectorNormalize( dir ); - bolt = G_Spawn( ); - bolt->classname = "smoke"; - bolt->nextthink = level.time + 200; - bolt->think = G_ProcessSmoke; - bolt->s.eType = ET_MISSILE; - bolt->r.svFlags = SVF_USE_CURRENT_ORIGIN; - bolt->s.weapon = WP_SMOKE; - bolt->s.eFlags = EF_BOUNCE_HALF; - bolt->s.generic1 = WPM_PRIMARY; //weaponMode - bolt->r.ownerNum = self->s.number; - bolt->parent = self; - bolt->damage = SMOKE_DAMAGE; - bolt->splashDamage = 0; - bolt->splashRadius = 0; - bolt->methodOfDeath = MOD_SMOKE; - bolt->splashMethodOfDeath = MOD_SMOKE; - bolt->clipmask = MASK_SHOT; - bolt->target_ent = NULL; - bolt->r.mins[ 0 ] = bolt->r.mins[ 1 ] = bolt->r.mins[ 2 ] = -3.0f; - bolt->r.maxs[ 0 ] = bolt->r.maxs[ 1 ] = bolt->r.maxs[ 2 ] = 3.0f; - bolt->s.time = level.time; - bolt->s.pos.trType = TR_GRAVITY; - bolt->s.pos.trTime = level.time - MISSILE_PRESTEP_TIME; // move a bit on the very first frame - VectorCopy( start, bolt->s.pos.trBase ); - VectorScale( dir, SMOKE_SPEED, bolt->s.pos.trDelta ); - SnapVector( bolt->s.pos.trDelta ); // save net bandwidth - - VectorCopy( start, bolt->r.currentOrigin ); - - return bolt; -} - /* ================ AHive_SearchAndDestroy diff --git a/src/game/g_weapon.c b/src/game/g_weapon.c index 5453913..d869fb1 100644 --- a/src/game/g_weapon.c +++ b/src/game/g_weapon.c @@ -696,18 +696,6 @@ void acidBombFire2x( gentity_t *ent, int wp ) m = fire_acidBomb2( ent, muzzle, forward, wp ); } -/* -====================================================================== -SMOKE -====================================================================== -*/ - -void throwSmoke( gentity_t *ent ) -{ - gentity_t *m; - m = launch_smoke( ent, muzzle, forward ); -} - /* ====================================================================== LAS GUN @@ -1994,9 +1982,6 @@ void FireWeapon( gentity_t *ent ) case WP_MINE: throwMine( ent ); break; - case WP_SMOKE: - throwSmoke( ent ); - break; case WP_LOCKBLOB_LAUNCHER: lockBlobLauncherFire( ent ); break; -- cgit From b0a9981e09bbc7c30769f680a4e0ff17c9ea8239 Mon Sep 17 00:00:00 2001 From: enneract Date: Mon, 24 Nov 2014 02:20:51 +0100 Subject: Implement the Lightning Gun. --- assets/gfx/lightning/beam.jpg | Bin 0 -> 6750 bytes assets/models/weapons/lightning/weapon.cfg | 14 ++++ assets/scripts/hw_lightning.particle | 35 ++++++++++ assets/scripts/hw_lightning.shader | 9 +++ src/cgame/cg_local.h | 2 + src/cgame/cg_main.c | 3 +- src/cgame/cg_weapons.c | 101 +++++++++++++++++++++++++++++ src/game/bg_misc.c | 25 +++++++ src/game/bg_mod.h | 1 + src/game/bg_public.h | 1 + src/game/g_weapon.c | 49 +++++++++++++- src/game/tremulous.h | 8 +++ 12 files changed, 244 insertions(+), 4 deletions(-) create mode 100644 assets/gfx/lightning/beam.jpg create mode 100644 assets/models/weapons/lightning/weapon.cfg create mode 100644 assets/scripts/hw_lightning.particle create mode 100644 assets/scripts/hw_lightning.shader diff --git a/assets/gfx/lightning/beam.jpg b/assets/gfx/lightning/beam.jpg new file mode 100644 index 0000000..d3b2b30 Binary files /dev/null and b/assets/gfx/lightning/beam.jpg differ diff --git a/assets/models/weapons/lightning/weapon.cfg b/assets/models/weapons/lightning/weapon.cfg new file mode 100644 index 0000000..59133e2 --- /dev/null +++ b/assets/models/weapons/lightning/weapon.cfg @@ -0,0 +1,14 @@ +weaponModel models/weapons/lcannon/lcannon.md3 +icon icons/iconw_lucifer +crosshair 48 gfx/2d/crosshair-lcannon_s + +primary +{ + continuousFlash + + flashDlightColor 1.0 1.0 1.0 + + impactMark 8 gfx/marks/bullet_mrk + impactParticleSystem models/weapons/lightning/impactPS +} + diff --git a/assets/scripts/hw_lightning.particle b/assets/scripts/hw_lightning.particle new file mode 100644 index 0000000..afcba47 --- /dev/null +++ b/assets/scripts/hw_lightning.particle @@ -0,0 +1,35 @@ + +models/weapons/lightning/impactPS +{ + ejector + { + particle + { + shader sync gfx/psaw/blue_particle + + displacement 0 0 0 ~2.0 + + velocityType normal + velocityDir linear + velocityMagnitude 100 + velocity 0 0 -1 ~90 + + accelerationType static + accelerationDir linear + accelerationMagnitude 800 + acceleration 0 0 -1 ~10 + + radius 0 1.0~2.0 3.0~2.0 + alpha 0 1.0 1.0 + rotation 0 ~360 - + bounce 0.5 + + lifeTime 1000 + } + + count 3 + delay 0 + period 0 - ~0% + } +} + diff --git a/assets/scripts/hw_lightning.shader b/assets/scripts/hw_lightning.shader new file mode 100644 index 0000000..2fa0c0c --- /dev/null +++ b/assets/scripts/hw_lightning.shader @@ -0,0 +1,9 @@ +gfx/lightning/beam +{ + nomipmaps + { + map gfx/lightning/beam + blendFunc add + tcMod scroll -5 0 + } +} diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h index a477336..72b5a96 100644 --- a/src/cgame/cg_local.h +++ b/src/cgame/cg_local.h @@ -1336,6 +1336,8 @@ typedef struct qhandle_t headShotPS; qhandle_t humanWoundsBleedPS; qhandle_t alienWoundsBleedPS; + + qhandle_t lightningBeam; } cgMedia_t; typedef struct diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c index b7885ec..9abdc7e 100644 --- a/src/cgame/cg_main.c +++ b/src/cgame/cg_main.c @@ -821,7 +821,8 @@ static void CG_RegisterGraphics( void ) cgs.media.healthCrossPoisoned = trap_R_RegisterShader( "ui/assets/neutral/cross_poison.tga" ); cgs.media.upgradeClassIconShader = trap_R_RegisterShader( "icons/icona_upgrade.tga" ); - + + cgs.media.lightningBeam = trap_R_RegisterShader( "gfx/lightning/beam" ); cgs.media.disconnectPS = CG_RegisterParticleSystem( "disconnectPS" ); diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c index 04f6495..86306e1 100644 --- a/src/cgame/cg_weapons.c +++ b/src/cgame/cg_weapons.c @@ -866,6 +866,60 @@ static float CG_MachinegunSpinAngle( centity_t *cent, qboolean firing ) return angle; } +/* +============= +CG_RenderBeam +============= +*/ + +void CG_RenderGenericBeam( const vec3_t start, const vec3_t end, qhandle_t shader, float radius ) +{ + vec3_t delta, viewdelta, side; + float length; + polyVert_t quad[ 4 ]; + + VectorSubtract( end, start, delta ); + length = VectorLength( delta ); + VectorSubtract( start, cg.refdef.vieworg, viewdelta ); + CrossProduct( delta, viewdelta, side ); + VectorNormalize( side ); + + VectorMA( start, radius, side, quad[ 3 ].xyz ); + VectorMA( start, -radius, side, quad[ 2 ].xyz ); + VectorMA( end, -radius, side, quad[ 1 ].xyz ); + VectorMA( end, radius, side, quad[ 0 ].xyz ); + + quad[ 0 ].st[ 0 ] = length / radius * 0.1; + quad[ 0 ].st[ 1 ] = 0; + quad[ 0 ].modulate[ 0 ] = 255; + quad[ 0 ].modulate[ 1 ] = 255; + quad[ 0 ].modulate[ 2 ] = 255; + quad[ 0 ].modulate[ 3 ] = 255; + + quad[ 1 ].st[ 0 ] = length / radius * 0.1; + quad[ 1 ].st[ 1 ] = 1; + quad[ 1 ].modulate[ 0 ] = 255; + quad[ 1 ].modulate[ 1 ] = 255; + quad[ 1 ].modulate[ 2 ] = 255; + quad[ 1 ].modulate[ 3 ] = 255; + + quad[ 2 ].st[ 0 ] = 0; + quad[ 2 ].st[ 1 ] = 1; + quad[ 2 ].modulate[ 0 ] = 255; + quad[ 2 ].modulate[ 1 ] = 255; + quad[ 2 ].modulate[ 2 ] = 255; + quad[ 2 ].modulate[ 3 ] = 255; + + quad[ 3 ].st[ 0 ] = 0; + quad[ 3 ].st[ 1 ] = 0; + quad[ 3 ].modulate[ 0 ] = 255; + quad[ 3 ].modulate[ 1 ] = 255; + quad[ 3 ].modulate[ 2 ] = 255; + quad[ 3 ].modulate[ 3 ] = 255; + + trap_R_AddPolyToScene( shader, 4, quad ); +} + /* ============= @@ -876,6 +930,7 @@ The main player will have this called for BOTH cases, so effects like light and sound should only be done on the world model case. ============= */ + void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent ) { refEntity_t gun; @@ -1114,6 +1169,52 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent cent->muzzlePsTrigger = qfalse; } + if( weaponNum == WP_LIGHTNING_GUN ) + { + attachment_t attachment; + vec3_t muzzle, forward, end, beam_start; + trace_t tr; + + if( ps ) + { + BG_GetClientViewOrigin( ps, muzzle ); + AngleVectors( ps->viewangles, forward, NULL, NULL ); + } + else + { + // NOTE: this code assumes that the player's normal is (0,0,1) + // it will break when humans start walking on walls + class_t class = ( cent->currentState.misc >> 8 ) & 0xFF; + + VectorCopy( cent->lerpOrigin, muzzle ); + + // the only way to tell if a human is crouching is to check its bbox + // which is transmitted in a weird, encoded form (hence the magic number) + if( class == PCL_HUMAN && cent->currentState.solid == 3151887 ) + muzzle[ 2 ] += BG_ClassConfig( class )->crouchViewheight; + else + muzzle[ 2 ] += BG_ClassConfig( class )->viewheight; + + AngleVectors( cent->lerpAngles, forward, NULL, NULL ); + } + + VectorMA( muzzle, LIGHTNING_RANGE, forward, end ); + + CG_Trace( &tr, muzzle, NULL, NULL, end, cg.predictedPlayerState.clientNum, MASK_SHOT ); + + memset( &attachment, 0, sizeof( attachment ) ); + + if( noGunModel ) + CG_SetAttachmentTag( &attachment, *parent, parent->hModel, "tag_weapon" ); + else + CG_SetAttachmentTag( &attachment, gun, gun.hModel, "tag_flash" ); + + CG_AttachToTag( &attachment ); + + if( CG_AttachmentPoint( &attachment, beam_start ) ) + CG_RenderGenericBeam( beam_start, tr.endpos, cgs.media.lightningBeam, 3 ); + } + // make a dlight for the flash if( weapon->wim[ weaponMode ].flashDlightColor[ 0 ] || weapon->wim[ weaponMode ].flashDlightColor[ 1 ] || diff --git a/src/game/bg_misc.c b/src/game/bg_misc.c index 742363d..efdc300 100644 --- a/src/game/bg_misc.c +++ b/src/game/bg_misc.c @@ -3574,6 +3574,31 @@ static const weaponAttributes_t bg_weapons[ ] = qtrue, //qboolean longRanged; TEAM_HUMANS //team_t team; }, + { + WP_LIGHTNING_GUN, //int weaponNum; + LIGHTNING_PRICE, //int price; + STAGE_GE_5, //int stages + SLOT_WEAPON, //int slots; + "lightning", //char *weaponName; + "[yefarms]Lightning Gun", //char *humanName; + "This is a lightning gun. It guns lightning.", + LIGHTNING_AMMO, //int maxAmmo; + 0, //int maxClips; + qfalse, //int infiniteAmmo; + qtrue, //int usesEnergy; + LIGHTNING_REPEAT, //int repeatRate1; + 0, //int repeatRate2; + 0, //int repeatRate3; + 0, //int reloadTime; + LIGHTNING_K_SCALE, //float knockbackScale; + qfalse, //qboolean hasAltMode; + qfalse, //qboolean hasThirdMode; + qfalse, //qboolean canZoom; + 90.0f, //float zoomFov; + qtrue, //qboolean purchasable; + qtrue, //qboolean longRanged; + TEAM_HUMANS //team_t team; + }, { WP_LUCIFER_CANNON, //int weaponNum; LCANNON_PRICE, //int price; diff --git a/src/game/bg_mod.h b/src/game/bg_mod.h index 4929b32..6f09037 100644 --- a/src/game/bg_mod.h +++ b/src/game/bg_mod.h @@ -8,6 +8,7 @@ MOD( MOD_CHAINGUN ), MOD( MOD_PRIFLE ), MOD( MOD_MDRIVER ), MOD( MOD_LASGUN ), +MOD( MOD_LIGHTNING ), MOD( MOD_LCANNON ), MOD( MOD_LCANNON_SPLASH ), MOD( MOD_FLAMER ), diff --git a/src/game/bg_public.h b/src/game/bg_public.h index c0b6381..18b0d2e 100644 --- a/src/game/bg_public.h +++ b/src/game/bg_public.h @@ -356,6 +356,7 @@ typedef enum WP_CHAINGUN, WP_FLAMER, WP_PULSE_RIFLE, + WP_LIGHTNING_GUN, WP_LUCIFER_CANNON, WP_ROCKET_LAUNCHER, WP_GRENADE, diff --git a/src/game/g_weapon.c b/src/game/g_weapon.c index d869fb1..1c333ab 100644 --- a/src/game/g_weapon.c +++ b/src/game/g_weapon.c @@ -819,9 +819,7 @@ void LCChargeFire( gentity_t *ent, qboolean secondary ) /* ====================================================================== - -PULSE RIFLE - +ROCKET LAUNCHER ====================================================================== */ @@ -830,6 +828,48 @@ void rocketLauncherFire( gentity_t *ent ) fire_rocket( ent, muzzle, forward ); } + +/* +====================================================================== +LIGHTNING GUN +====================================================================== +*/ + +void lightningGunFire( gentity_t *ent ) +{ + vec3_t start, end; + trace_t tr; + gentity_t *target; + + VectorMA( muzzle, LIGHTNING_RANGE, forward, end ); + + G_UnlaggedOn( ent, muzzle, LIGHTNING_RANGE ); + trap_Trace( &tr, muzzle, NULL, NULL, end, ent->s.number, MASK_SHOT ); + G_UnlaggedOff( ); + + if( tr.fraction == 1.0f || + tr.entityNum == ENTITYNUM_NONE || + ( tr.surfaceFlags & SURF_NOIMPACT ) ) + return; + + target = g_entities + tr.entityNum; + + if( target->s.eType == ET_PLAYER || target->s.eType == ET_BUILDABLE ) + BloodSpurt( ent, target, &tr ); + else + { + gentity_t *tent; + + tent = G_TempEntity( tr.endpos, EV_MISSILE_MISS ); + tent->s.eventParm = DirToByte( tr.plane.normal ); + tent->s.weapon = ent->s.weapon; + tent->s.generic1 = ent->s.generic1; + } + + G_Damage( target, ent, ent, forward, tr.endpos, LIGHTNING_DAMAGE, 0, MOD_LIGHTNING ); +} + + /* ====================================================================== TESLA GENERATOR @@ -1976,6 +2016,9 @@ void FireWeapon( gentity_t *ent ) case WP_ROCKET_LAUNCHER: rocketLauncherFire( ent ); break; + case WP_LIGHTNING_GUN: + lightningGunFire( ent ); + break; case WP_GRENADE: throwGrenade( ent ); break; diff --git a/src/game/tremulous.h b/src/game/tremulous.h index e7512d5..b42a7b4 100644 --- a/src/game/tremulous.h +++ b/src/game/tremulous.h @@ -514,6 +514,14 @@ TREMULOUS EDGE MOD SRC FILE #define PRIFLE_SECONDARY_SPEED 800 #define PRIFLE_SECONDARY_REPEAT 400 +#define LIGHTNING_PRICE 500 +#define LIGHTNING_AMMO 500 +#define LIGHTNING_K_SCALE 500 +#define LIGHTNING_DPS 100 // damage per second +#define LIGHTNING_REPEAT 50 // keep it as low as possible +#define LIGHTNING_DAMAGE ( LIGHTNING_DPS * LIGHTNING_REPEAT / 1000 ) +#define LIGHTNING_RANGE 450 + #define LCANNON_PRICE 600 #define LCANNON_AMMO 80 #define LCANNON_K_SCALE 1.0f -- cgit From 0aa94f6b6b7b49972a839aadaee4dbb42a3a53de Mon Sep 17 00:00:00 2001 From: enneract Date: Tue, 25 Nov 2014 01:45:57 +0100 Subject: Lightning Gun assets. --- assets/gfx/lightning/beam.jpg | Bin 6750 -> 0 bytes assets/icons/iconw_lightning.tga | Bin 0 -> 6814 bytes assets/models/weapons/lightning/CREDITS | 8 + assets/models/weapons/lightning/bolt.jpg | Bin 0 -> 4820 bytes assets/models/weapons/lightning/firing.wav | Bin 0 -> 138938 bytes assets/models/weapons/lightning/flash.jpg | Bin 0 -> 7860 bytes assets/models/weapons/lightning/flash0.wav | Bin 0 -> 70028 bytes assets/models/weapons/lightning/impact0.wav | Bin 0 -> 23760 bytes assets/models/weapons/lightning/impact1.wav | Bin 0 -> 29234 bytes assets/models/weapons/lightning/impact2.wav | Bin 0 -> 23370 bytes assets/models/weapons/lightning/lightning.jpg | Bin 0 -> 50840 bytes assets/models/weapons/lightning/lightning.md3 | Bin 0 -> 20692 bytes .../models/weapons/lightning/lightning_flash.md3 | Bin 0 -> 868 bytes assets/models/weapons/lightning/lightning_hand.md3 | Bin 0 -> 2628 bytes .../models/weapons/lightning/sidrial license.txt | 245 +++++++++++++++++++++ assets/models/weapons/lightning/weapon.cfg | 17 +- assets/models/weapons/rocketl/flash0.wav | Bin 99924 -> 99924 bytes assets/scripts/hw_lightning.particle | 10 +- assets/scripts/hw_lightning.shader | 29 ++- src/cgame/cg_event.c | 3 + src/cgame/cg_local.h | 1 + src/cgame/cg_main.c | 2 + src/cgame/cg_weapons.c | 33 ++- src/game/tremulous.h | 6 +- 24 files changed, 338 insertions(+), 16 deletions(-) delete mode 100644 assets/gfx/lightning/beam.jpg create mode 100644 assets/icons/iconw_lightning.tga create mode 100644 assets/models/weapons/lightning/CREDITS create mode 100644 assets/models/weapons/lightning/bolt.jpg create mode 100644 assets/models/weapons/lightning/firing.wav create mode 100644 assets/models/weapons/lightning/flash.jpg create mode 100644 assets/models/weapons/lightning/flash0.wav create mode 100644 assets/models/weapons/lightning/impact0.wav create mode 100644 assets/models/weapons/lightning/impact1.wav create mode 100644 assets/models/weapons/lightning/impact2.wav create mode 100644 assets/models/weapons/lightning/lightning.jpg create mode 100644 assets/models/weapons/lightning/lightning.md3 create mode 100644 assets/models/weapons/lightning/lightning_flash.md3 create mode 100644 assets/models/weapons/lightning/lightning_hand.md3 create mode 100644 assets/models/weapons/lightning/sidrial license.txt diff --git a/assets/gfx/lightning/beam.jpg b/assets/gfx/lightning/beam.jpg deleted file mode 100644 index d3b2b30..0000000 Binary files a/assets/gfx/lightning/beam.jpg and /dev/null differ diff --git a/assets/icons/iconw_lightning.tga b/assets/icons/iconw_lightning.tga new file mode 100644 index 0000000..280e83d Binary files /dev/null and b/assets/icons/iconw_lightning.tga differ diff --git a/assets/models/weapons/lightning/CREDITS b/assets/models/weapons/lightning/CREDITS new file mode 100644 index 0000000..c45a8d2 --- /dev/null +++ b/assets/models/weapons/lightning/CREDITS @@ -0,0 +1,8 @@ +firing.wav: +flash0.wav: + http://freesound.org/people/roper1911/sounds/152322/ + +impact0.wav: +impact1.wav: +impact2.wav: + http://freesound.org/people/FreqMan/sounds/24726/ diff --git a/assets/models/weapons/lightning/bolt.jpg b/assets/models/weapons/lightning/bolt.jpg new file mode 100644 index 0000000..29818cc Binary files /dev/null and b/assets/models/weapons/lightning/bolt.jpg differ diff --git a/assets/models/weapons/lightning/firing.wav b/assets/models/weapons/lightning/firing.wav new file mode 100644 index 0000000..668860a Binary files /dev/null and b/assets/models/weapons/lightning/firing.wav differ diff --git a/assets/models/weapons/lightning/flash.jpg b/assets/models/weapons/lightning/flash.jpg new file mode 100644 index 0000000..56cdcd9 Binary files /dev/null and b/assets/models/weapons/lightning/flash.jpg differ diff --git a/assets/models/weapons/lightning/flash0.wav b/assets/models/weapons/lightning/flash0.wav new file mode 100644 index 0000000..39747a7 Binary files /dev/null and b/assets/models/weapons/lightning/flash0.wav differ diff --git a/assets/models/weapons/lightning/impact0.wav b/assets/models/weapons/lightning/impact0.wav new file mode 100644 index 0000000..8f70050 Binary files /dev/null and b/assets/models/weapons/lightning/impact0.wav differ diff --git a/assets/models/weapons/lightning/impact1.wav b/assets/models/weapons/lightning/impact1.wav new file mode 100644 index 0000000..530d28b Binary files /dev/null and b/assets/models/weapons/lightning/impact1.wav differ diff --git a/assets/models/weapons/lightning/impact2.wav b/assets/models/weapons/lightning/impact2.wav new file mode 100644 index 0000000..ffff0d2 Binary files /dev/null and b/assets/models/weapons/lightning/impact2.wav differ diff --git a/assets/models/weapons/lightning/lightning.jpg b/assets/models/weapons/lightning/lightning.jpg new file mode 100644 index 0000000..1e2db36 Binary files /dev/null and b/assets/models/weapons/lightning/lightning.jpg differ diff --git a/assets/models/weapons/lightning/lightning.md3 b/assets/models/weapons/lightning/lightning.md3 new file mode 100644 index 0000000..c96197b Binary files /dev/null and b/assets/models/weapons/lightning/lightning.md3 differ diff --git a/assets/models/weapons/lightning/lightning_flash.md3 b/assets/models/weapons/lightning/lightning_flash.md3 new file mode 100644 index 0000000..2f6ceb0 Binary files /dev/null and b/assets/models/weapons/lightning/lightning_flash.md3 differ diff --git a/assets/models/weapons/lightning/lightning_hand.md3 b/assets/models/weapons/lightning/lightning_hand.md3 new file mode 100644 index 0000000..edda546 Binary files /dev/null and b/assets/models/weapons/lightning/lightning_hand.md3 differ diff --git a/assets/models/weapons/lightning/sidrial license.txt b/assets/models/weapons/lightning/sidrial license.txt new file mode 100644 index 0000000..14ac66d --- /dev/null +++ b/assets/models/weapons/lightning/sidrial license.txt @@ -0,0 +1,245 @@ +The weapons (blaster, gat, grenner) their effects and +icons as well as the powerup-models are taken from +Sidrial Quake3-MOD by Fountainhead Entertainment +---------------------------------------------------------- + + +LIMITED USE SOFTWARE LICENSE AGREEMENT + +This Limited Use Software License Agreement (this +"Agreement") is a legal agreement between you, the +end-user, and Fountainhead Entertainment, Inc. +("Fountainhead"). BY CONTINUING THE INSTALLATION +OF THE TOTAL CONVERSION TITLED SIDRIAL (THE +"SOFTWARE"), BY LOADING OR RUNNING THE SOFTWARE, +OR BY PLACING OR COPYING THE SOFTWARE ONTO YOUR +COMPUTER HARD DRIVE, COMPUTER RAM OR OTHER +STORAGE, YOU ARE AGREEING TO BE BOUND BY THE TERMS +OF THIS AGREEMENT. + +1. Grant of License. Subject to the terms +and provisions of this Agreement and so long as +you fully comply at all times with this Agreement, +Fountainhead grants to you the non-exclusive and +limited right to use the Software only in +executable or object code form. The term +"Software" includes all elements of the Software, +including, without limitation, data files and +screen displays. You are not receiving any +ownership or proprietary right, title or interest +in or to the Software or the copyrights, +trademarks, or other rights related thereto. For +purposes of the first sentence of this section, +"use" means loading the Software into RAM and/or +onto computer hard drive, as well as installation +of the Software on a hard disk or other storage +device, and means the uses permitted in sections +2. and 4. herein below. You agree that the +Software will not be downloaded, shipped, +transferred, exported or re-exported into any +country in violation of the U.S. Export +Administration Act (or any other law governing +such matters) by you or anyone at your direction +and that you will not utilize and will not +authorize anyone to utilize, in any other manner, +the Software in violation of any applicable law. +The Software shall not be downloaded or otherwise +exported or re-exported into (or to a national or +resident of) any country to which the U.S. has +embargoed goods or to anyone or into any country +who/which are prohibited, by applicable law, from +receiving such property. In exercising your +limited rights hereunder, you shall comply, at all +times, with all applicable laws, regulations, +ordinances and statutes. Fountainhead reserves +all rights not granted in this Agreement, +including, without limitation, all rights to +Fountainhead's trademarks. All other trademarks +and trade names are properties of their respective +owners. + +2. Permitted New Creations. Subject to the +terms and provisions of this Agreement and so long +as you fully comply at all times with this +Agreement, Fountainhead grants to you the +non-exclusive and limited right to create for the +Software (except any Software code) your own +modifications (the "New Creations") which shall +operate only with the Software (but not any demo, +test or other version of the Software). You may +include within the New Creations certain textures +and other images (the "Software Images") from the +Software. You shall not create any New Creations +which infringe against any third party right or +which are libelous, defamatory, obscene, false, +misleading, or otherwise illegal or unlawful. You +agree that the New Creations will not be +downloaded, shipped, transferred, exported or +re-exported into any country in violation of the +U.S. Export Administration Act (or any other law +governing such matters) by you or anyone at your +direction and that you will not utilize and will +not authorize anyone to utilize, in any other +manner, the New Creations in violation of any +applicable law. The New Creations shall not be +downloaded or otherwise exported or re-exported +into (or to a national or resident of) any country +to which the U.S. has embargoed goods or to anyone +or into any country who/which are prohibited, by +applicable law, from receiving such property. You +shall not rent, sell, lease, lend, offer on a +pay-per-play basis or otherwise commercially +exploit or commercially distribute the New +Creations. You are only permitted to distribute, +without any cost or charge, the New Creations to +other end-users so long as such distribution is +not infringing against any third party right and +is not otherwise illegal or unlawful. As noted +below, in the event you commit any breach of this +Agreement, your license and this Agreement shall +automatically terminate, without notice. + +3. Intellectual Property Rights. Certain + +printed materials (the "Printed Materials") may +accompany the Software. The Software, the Printed +Materials and all copyrights, trademarks and all +other conceivable intellectual property rights +related to the Software and the Printed Materials +are owned by Fountainhead and are protected by +United States copyright laws, international treaty +provisions and all applicable law, such as the +Lanham Act. You must treat the Software and the +Printed Materials like any other copyrighted +material, as required by 17 U.S.C., §101 et seq. +and other applicable law. You agree to use your +best efforts to see that any user of the Software +licensed hereunder, the Printed Materials or the +New Creations complies with this Agreement. You +agree that you are receiving a copy of the +Software and the Printed Materials by limited +license only and not by sale and that the "first +sale" doctrine of 17 U.S.C. §109 does not apply to +your receipt or use of the Software or the Printed +Materials. This section shall survive the +cancellation or termination of this Agreement. + +4. NO FOUNTAINHEAD WARRANTIES. FOUNTAINHEAD +DISCLAIMS ALL WARRANTIES, WHETHER EXPRESS OR +IMPLIED, INCLUDING, BUT NOT LIMITED TO, IMPLIED +WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A +PARTICULAR PURPOSE AND ANY WARRANTY OF +NON-INFRINGEMENT, WITH RESPECT TO THE SOFTWARE, +THE PRINTED MATERIALS, THE SOFTWARE IMAGES AND +OTHERWISE. THE SOFTWARE IS PROVIDED "AS IS" AND +WITHOUT WARRANTY. FOUNTAINHEAD DOES NOT WARRANT +THAT THE SOFTWARE OR THE OPERATION OF THE SOFTWARE +WILL BE UNINTERRUPTED OR ERROR FREE OR THAT THE +SOFTWARE WILL MEET YOUR SPECIFIC OR SPECIAL +REQUIREMENTS. ADDITIONAL STATEMENTS, WHETHER ORAL +OR WRITTEN, DO NOT CONSTITUTE WARRANTIES BY +FOUNTAINHEAD AND SHOULD NOT BE RELIED UPON. This +section shall survive the cancellation or +termination of this Agreement. + +5. Governing Law, Venue, Indemnity and +Liability Limitation. This Agreement shall be +construed in accordance with and governed by the +applicable laws of the State of Texas and +applicable United States federal law. Except as +set forth below, exclusive venue for all +litigation regarding this Agreement shall be in +Dallas County, Texas and you agree to submit to +the jurisdiction of the federal and state courts +in Dallas County, Texas for any such litigation. +You hereby agree to indemnify, defend and hold +harmless Fountainhead and Fountainhead's +respective officers, employees, directors, agents, +licensees (excluding you), sub-licensees +(excluding you), successors and assigns from and +against all losses, lawsuits, damages, causes of +action and claims relating to and/or arising from +the New Creations or the distribution or other use +of the New Creations or relating to and/or arising +from your breach of this Agreement. You agree +that your unauthorized use of the Software Images, +the Printed Materials, or the Software, or any +part thereof, may immediately and irreparably +damage Fountainhead such that Fountainhead could +not be adequately compensated solely by a monetary +award, and in such event, Fountainhead's option, +that Fountainhead shall be entitled to an +injunctive order, in addition to all other +available remedies including a monetary award, to +prohibit such unauthorized use without the +necessity of Fountainhead posting bond or other +security. IN ANY CASE, FOUNTAINHEAD AND +FOUNTAINHEAD'S RESPECTIVE OFFICERS, EMPLOYEES, +DIRECTORS, SHAREHOLDERS, REPRESENTATIVES, AGENTS, +LICENSEES (EXCLUDING YOU), SUBLICENSEES (EXCLUSING +YOU), SUCCESSORS AND ASSIGNS SHALL NOT BE LIABLE +FOR LOSS OF DATA, LOSS OF PROFITS, LOST SAVINGS, +SPECIAL, INCIDENTAL, CONSEQUENTIAL, INDIRECT OR +PUNITIVE DAMAGES OR ANY OTHER DAMAGES ARISING FROM +ANY ALLEGED CLAIM FOR BREACH OF WARRANTY, BREACH +OF CONTRACT, NEGLIGENCE, STRICT PRODUCT LIABILITY, +OR OTHER LEGAL THEORY EVEN IF FOUNTAINHEAD OR +THEIR RESPECTIVE AGENT(S) HAVE BEEN ADVISED OF THE +POSSIBILITY OF ANY SUCH DAMAGES, OR EVEN IF SUCH +DAMAGES ARE FORESEEABLE, OR LIABLE FOR ANY CLAIM +BY ANY OTHER PARTY. This section shall survive +the cancellation or termination of this Agreement. + +6. General Provisions. Neither this +Agreement nor any part or portion hereof shall be +assigned or sublicensed by you. Fountainhead may +assign its respective rights under this Agreement +in the assigning party's sole discretion. Should +any provision of this Agreement be held to be +void, invalid, unenforceable or illegal by a court +of competent jurisdiction, the validity and +enforceability of the other provisions shall not +be affected thereby. If any provision is +determined to be unenforceable by a court of +competent jurisdiction, you agree to a +modification of such provision to provide for +enforcement of the provision's intent, to the +extent permitted by applicable law. Failure of +Fountainhead to enforce any provision of this +Agreement shall not constitute or be construed as +a waiver of such provision or of the right to +enforce such provision. IMMEDIATELY UPON YOUR +FAILURE TO COMPLY WITH OR BREACH OF ANY TERM OR +PROVISION OF THIS AGREEMENT, YOUR LICENSE GRANTED +HEREIN AND THIS AGREEMENT SHALL AUTOMATICALLY +TERMINATE, WITHOUT NOTICE, AND FOUNTAINHEAD MAY +PURSUE ALL RELIEF AND REMEDIES AGAINST YOU, WHICH +ARE AVAILABLE UNDER APPLICABLE LAW AND/OR THIS +AGREEMENT. Immediately upon termination of this +Agreement, any and all rights you are granted +hereunder shall terminate, you shall have no right +to use the Software, the Printed Materials or the +New Creations, in any manner, and you shall +immediately destroy all copies of the Software, +the Printed Materials and the New Creations in +your possession, custody or control, and all +rights granted hereunder shall revert, without +notice, to and be vested in Fountainhead. + +YOU ACKNOWLEDGE THAT YOU HAVE READ THIS AGREEMENT, +YOU UNDERSTAND THIS AGREEMENT, AND UNDERSTAND THAT +BY CONTINUING THE INSTALLATION OF THE SOFTWARE, BY +LOADING OR RUNNING THE SOFTWARE, OR BY PLACING OR +COPYING THE SOFTWARE ONTO YOUR COMPUTER HARD DRIVE +OR RAM, YOU AGREE TO BE BOUND BY THE TERMS AND +CONDITIONS OF THIS AGREEMENT. YOU FURTHER AGREE +THAT, EXCEPT FOR WRITTEN SEPARATE AGREEMENTS, IF +ANY, BETWEEN FOUNTAINHEAD AND YOU, THIS AGREEMENT +IS A COMPLETE AND EXCLUSIVE STATEMENT OF THE +RIGHTS AND LIABILITIES OF THE PARTIES HERETO, +RELATING TO THE SUBJECT MATTER HEREOF. THIS +AGREEMENT SUPERSEDES ALL PRIOR ORAL AGREEMENTS, +PROPOSALS OR UNDERSTANDINGS, AND ANY OTHER +COMMUNICATIONS, IF ANY, BETWEEN FOUNTAINHEAD AND +YOU RELATING TO THE SUBJECT MATTER OF THIS +AGREEMENT. diff --git a/assets/models/weapons/lightning/weapon.cfg b/assets/models/weapons/lightning/weapon.cfg index 59133e2..4d48e0f 100644 --- a/assets/models/weapons/lightning/weapon.cfg +++ b/assets/models/weapons/lightning/weapon.cfg @@ -1,14 +1,19 @@ -weaponModel models/weapons/lcannon/lcannon.md3 -icon icons/iconw_lucifer -crosshair 48 gfx/2d/crosshair-lcannon_s +weaponModel models/weapons/lightning/lightning.md3 +icon icons/iconw_lightning +crosshair 24 gfx/2d/crosshair-lgun_s primary { continuousFlash - flashDlightColor 1.0 1.0 1.0 + flashDlightColor 0.8 0.9 1.0 - impactMark 8 gfx/marks/bullet_mrk - impactParticleSystem models/weapons/lightning/impactPS + flashSound 0 models/weapons/lightning/flash0.wav + firingSound models/weapons/lightning/firing.wav + + impactMark 6 gfx/marks/bullet_mrk + impactSound 0 models/weapons/lightning/impact0.wav + impactSound 1 models/weapons/lightning/impact1.wav + impactSound 2 models/weapons/lightning/impact2.wav } diff --git a/assets/models/weapons/rocketl/flash0.wav b/assets/models/weapons/rocketl/flash0.wav index 009febe..89e78b7 100644 Binary files a/assets/models/weapons/rocketl/flash0.wav and b/assets/models/weapons/rocketl/flash0.wav differ diff --git a/assets/scripts/hw_lightning.particle b/assets/scripts/hw_lightning.particle index afcba47..f9370d5 100644 --- a/assets/scripts/hw_lightning.particle +++ b/assets/scripts/hw_lightning.particle @@ -5,29 +5,29 @@ models/weapons/lightning/impactPS { particle { - shader sync gfx/psaw/blue_particle + shader sync gfx/lightning/particle displacement 0 0 0 ~2.0 velocityType normal velocityDir linear velocityMagnitude 100 - velocity 0 0 -1 ~90 + velocity 0 0 -1 ~10 accelerationType static accelerationDir linear accelerationMagnitude 800 acceleration 0 0 -1 ~10 - radius 0 1.0~2.0 3.0~2.0 + radius 0 9 0 alpha 0 1.0 1.0 rotation 0 ~360 - bounce 0.5 - lifeTime 1000 + lifeTime 100 } - count 3 + count 1 delay 0 period 0 - ~0% } diff --git a/assets/scripts/hw_lightning.shader b/assets/scripts/hw_lightning.shader index 2fa0c0c..c42612b 100644 --- a/assets/scripts/hw_lightning.shader +++ b/assets/scripts/hw_lightning.shader @@ -1,9 +1,36 @@ +gfx/lightning/particle +{ + { + map models/weapons/lightning/flash.jpg + blendFunc add + } +} + gfx/lightning/beam { nomipmaps { - map gfx/lightning/beam + map models/weapons/lightning/bolt.jpg blendFunc add tcMod scroll -5 0 + tcMod scale 5 1 + } +} + +models/weapons/lightning/flash +{ + cull none + { + map models/weapons/lightning/flash.jpg + blendFunc add + } +} + +models/weapons/lightning/bolt +{ + cull none + { + map models/weapons/lightning/bolt.jpg + blendFunc add } } diff --git a/src/cgame/cg_event.c b/src/cgame/cg_event.c index d9e2f77..4c756ad 100644 --- a/src/cgame/cg_event.c +++ b/src/cgame/cg_event.c @@ -335,6 +335,9 @@ static void CG_Obituary( entityState_t *ent ) message = "^5almost dodged^7"; message2 = "^5's ^5rocket"; break; + case MOD_LIGHTNING: + message = "^5was electrocuted by^7"; + break; case MOD_GRENADE: message = "^5couldn't escape^7"; message2 = "^5's ^5grenade"; diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h index 72b5a96..d979046 100644 --- a/src/cgame/cg_local.h +++ b/src/cgame/cg_local.h @@ -1338,6 +1338,7 @@ typedef struct qhandle_t alienWoundsBleedPS; qhandle_t lightningBeam; + qhandle_t lightningImpactPS; } cgMedia_t; typedef struct diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c index 9abdc7e..6be1d50 100644 --- a/src/cgame/cg_main.c +++ b/src/cgame/cg_main.c @@ -867,6 +867,8 @@ static void CG_RegisterGraphics( void ) cgs.media.humanWoundsBleedPS = CG_RegisterParticleSystem( "humanWoundBleedPS" ); cgs.media.headShotPS = CG_RegisterParticleSystem( "headShotPS" ); + cgs.media.lightningImpactPS = CG_RegisterParticleSystem( "models/weapons/lightning/impactPS" ); + CG_BuildableStatusParse( "ui/assets/human/buildstat.cfg", &cgs.humanBuildStat ); CG_BuildableStatusParse( "ui/assets/alien/buildstat.cfg", &cgs.alienBuildStat ); diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c index 86306e1..21d0352 100644 --- a/src/cgame/cg_weapons.c +++ b/src/cgame/cg_weapons.c @@ -868,7 +868,7 @@ static float CG_MachinegunSpinAngle( centity_t *cent, qboolean firing ) /* ============= -CG_RenderBeam +CG_RenderGenericBeam ============= */ @@ -1169,6 +1169,7 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent cent->muzzlePsTrigger = qfalse; } + // Lightning Gun's beam if( weaponNum == WP_LIGHTNING_GUN ) { attachment_t attachment; @@ -1213,6 +1214,19 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent if( CG_AttachmentPoint( &attachment, beam_start ) ) CG_RenderGenericBeam( beam_start, tr.endpos, cgs.media.lightningBeam, 3 ); + + if( tr.entityNum != ENTITYNUM_NONE && + !( tr.surfaceFlags & SURF_NOIMPACT ) ) + { + particleSystem_t *ps = CG_SpawnNewParticleSystem( cgs.media.lightningImpactPS ); + + if( CG_IsParticleSystemValid( &ps ) ) + { + CG_SetAttachmentPoint( &ps->attachment, tr.endpos ); + CG_SetParticleSystemNormal( ps, tr.plane.normal ); + CG_AttachToPoint( &ps->attachment ); + } + } } // make a dlight for the flash @@ -1353,6 +1367,15 @@ void CG_AddViewWeapon( playerState_t *ps ) } + // Lightning Gun vibration effect + if( ( weapon == WP_LIGHTNING_GUN ) && ps->eFlags & EF_FIRING ) + { + VectorMA( hand.origin, random( ) * 0.1, cg.refdef.viewaxis[ 0 ], + hand.origin ); + VectorMA( hand.origin, random( ) * 0.1, cg.refdef.viewaxis[ 1 ], + hand.origin ); + } + AnglesToAxis( angles, hand.axis ); // map torso animations to weapon animations @@ -1753,6 +1776,7 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode ) int c; weaponInfo_t *wi; weapon_t weaponNum; + qboolean skipSound = qfalse; es = ¢->currentState; @@ -1772,6 +1796,10 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode ) wi = &cg_weapons[ weaponNum ]; + if( wi->wim[ weaponMode ].continuousFlash && + cent->muzzleFlashTime >= cg.time - 100 ) + skipSound = qtrue; + // mark the entity as muzzle flashing, so when it is added it will // append the flash to the weapon model cent->muzzleFlashTime = cg.time; @@ -1783,6 +1811,9 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode ) cent->muzzlePsTrigger = qtrue; } + if( skipSound ) + return; + // play a sound for( c = 0; c < 4; c++ ) { diff --git a/src/game/tremulous.h b/src/game/tremulous.h index b42a7b4..ad4a688 100644 --- a/src/game/tremulous.h +++ b/src/game/tremulous.h @@ -515,9 +515,9 @@ TREMULOUS EDGE MOD SRC FILE #define PRIFLE_SECONDARY_REPEAT 400 #define LIGHTNING_PRICE 500 -#define LIGHTNING_AMMO 500 -#define LIGHTNING_K_SCALE 500 -#define LIGHTNING_DPS 100 // damage per second +#define LIGHTNING_AMMO 300 +#define LIGHTNING_K_SCALE 1 +#define LIGHTNING_DPS 60 // damage per second #define LIGHTNING_REPEAT 50 // keep it as low as possible #define LIGHTNING_DAMAGE ( LIGHTNING_DPS * LIGHTNING_REPEAT / 1000 ) #define LIGHTNING_RANGE 450 -- cgit From 3a91da2c493ae1885feea07c7cf53e1999f970d7 Mon Sep 17 00:00:00 2001 From: enneract Date: Sat, 13 Dec 2014 01:57:53 +0100 Subject: Get rid of progressive JPEGs. --- assets/models/weapons/lightning/bolt.jpg | Bin 4820 -> 4775 bytes assets/models/weapons/lightning/flash.jpg | Bin 7860 -> 7842 bytes assets/models/weapons/lightning/lightning.jpg | Bin 50840 -> 51257 bytes 3 files changed, 0 insertions(+), 0 deletions(-) diff --git a/assets/models/weapons/lightning/bolt.jpg b/assets/models/weapons/lightning/bolt.jpg index 29818cc..07d7ef1 100644 Binary files a/assets/models/weapons/lightning/bolt.jpg and b/assets/models/weapons/lightning/bolt.jpg differ diff --git a/assets/models/weapons/lightning/flash.jpg b/assets/models/weapons/lightning/flash.jpg index 56cdcd9..070d8fa 100644 Binary files a/assets/models/weapons/lightning/flash.jpg and b/assets/models/weapons/lightning/flash.jpg differ diff --git a/assets/models/weapons/lightning/lightning.jpg b/assets/models/weapons/lightning/lightning.jpg index 1e2db36..f7955d6 100644 Binary files a/assets/models/weapons/lightning/lightning.jpg and b/assets/models/weapons/lightning/lightning.jpg differ -- cgit From 2fde9f3481239b2b2226ee812dd34ed4d8d5d6d6 Mon Sep 17 00:00:00 2001 From: enneract Date: Sat, 13 Dec 2014 13:10:44 +0100 Subject: Improve Lightning Gun sounds. --- assets/models/weapons/lightning/CREDITS | 7 +++++++ assets/models/weapons/lightning/firing.wav | Bin 138938 -> 653456 bytes assets/models/weapons/lightning/flash0.wav | Bin 70028 -> 138302 bytes 3 files changed, 7 insertions(+) diff --git a/assets/models/weapons/lightning/CREDITS b/assets/models/weapons/lightning/CREDITS index c45a8d2..9ce05bb 100644 --- a/assets/models/weapons/lightning/CREDITS +++ b/assets/models/weapons/lightning/CREDITS @@ -1,4 +1,6 @@ firing.wav: + http://freesound.org/people/HerbertBoland/sounds/114595/ + flash0.wav: http://freesound.org/people/roper1911/sounds/152322/ @@ -6,3 +8,8 @@ impact0.wav: impact1.wav: impact2.wav: http://freesound.org/people/FreqMan/sounds/24726/ + +lightning.md3: +lightning.jpg: + see "sidrial license.txt" + diff --git a/assets/models/weapons/lightning/firing.wav b/assets/models/weapons/lightning/firing.wav index 668860a..3ba7722 100644 Binary files a/assets/models/weapons/lightning/firing.wav and b/assets/models/weapons/lightning/firing.wav differ diff --git a/assets/models/weapons/lightning/flash0.wav b/assets/models/weapons/lightning/flash0.wav index 39747a7..5895c02 100644 Binary files a/assets/models/weapons/lightning/flash0.wav and b/assets/models/weapons/lightning/flash0.wav differ -- cgit From d1853e239ae258e394a516f0eeda80f430a1a328 Mon Sep 17 00:00:00 2001 From: enneract Date: Sat, 13 Dec 2014 16:06:15 +0100 Subject: View quake, improved Rocket Launcher assets. (FIXME: Rocket explosion doesn't fade out) --- assets/gfx/rocketx/0002.jpg | Bin 0 -> 4605 bytes assets/gfx/rocketx/0003.jpg | Bin 0 -> 6454 bytes assets/gfx/rocketx/0004.jpg | Bin 0 -> 7373 bytes assets/gfx/rocketx/0005.jpg | Bin 0 -> 7978 bytes assets/gfx/rocketx/0006.jpg | Bin 0 -> 8260 bytes assets/gfx/rocketx/0007.jpg | Bin 0 -> 8351 bytes assets/gfx/rocketx/0008.jpg | Bin 0 -> 8448 bytes assets/gfx/rocketx/0009.jpg | Bin 0 -> 8560 bytes assets/gfx/rocketx/0010.jpg | Bin 0 -> 8660 bytes assets/gfx/rocketx/0011.jpg | Bin 0 -> 8827 bytes assets/gfx/rocketx/0012.jpg | Bin 0 -> 8947 bytes assets/gfx/rocketx/0013.jpg | Bin 0 -> 9079 bytes assets/gfx/rocketx/0014.jpg | Bin 0 -> 9090 bytes assets/gfx/rocketx/0015.jpg | Bin 0 -> 9029 bytes assets/gfx/rocketx/0016.jpg | Bin 0 -> 9019 bytes assets/gfx/rocketx/0017.jpg | Bin 0 -> 8935 bytes assets/gfx/rocketx/0018.jpg | Bin 0 -> 8850 bytes assets/gfx/rocketx/0019.jpg | Bin 0 -> 8662 bytes assets/gfx/rocketx/0020.jpg | Bin 0 -> 8450 bytes assets/gfx/rocketx/0021.jpg | Bin 0 -> 8249 bytes assets/gfx/rocketx/0022.jpg | Bin 0 -> 8022 bytes assets/gfx/rocketx/0023.jpg | Bin 0 -> 7930 bytes assets/gfx/rocketx/0024.jpg | Bin 0 -> 7733 bytes assets/gfx/rocketx/0025.jpg | Bin 0 -> 7581 bytes assets/gfx/rocketx/0026.jpg | Bin 0 -> 7346 bytes assets/gfx/rocketx/0027.jpg | Bin 0 -> 7060 bytes assets/gfx/rocketx/0028.jpg | Bin 0 -> 6750 bytes assets/gfx/rocketx/0029.jpg | Bin 0 -> 6433 bytes assets/gfx/rocketx/0030.jpg | Bin 0 -> 6090 bytes assets/models/weapons/lcannon/weapon.cfg | 2 + assets/models/weapons/lightning/weapon.cfg | 1 + assets/models/weapons/rocketl/rocketl.md3 | Bin 5796 -> 6004 bytes assets/models/weapons/rocketl/rocketl_flash.md3 | Bin 0 -> 868 bytes assets/models/weapons/rocketl/weapon.cfg | 2 + assets/scripts/hw_rocketl.particle | 41 +--- assets/scripts/hw_rocketl.shader | 302 ++++++++++++++++++++++++ src/cgame/cg_local.h | 8 + src/cgame/cg_main.c | 10 +- src/cgame/cg_view.c | 34 +++ src/cgame/cg_weapons.c | 42 +++- 40 files changed, 402 insertions(+), 40 deletions(-) create mode 100644 assets/gfx/rocketx/0002.jpg create mode 100644 assets/gfx/rocketx/0003.jpg create mode 100644 assets/gfx/rocketx/0004.jpg create mode 100644 assets/gfx/rocketx/0005.jpg create mode 100644 assets/gfx/rocketx/0006.jpg create mode 100644 assets/gfx/rocketx/0007.jpg create mode 100644 assets/gfx/rocketx/0008.jpg create mode 100644 assets/gfx/rocketx/0009.jpg create mode 100644 assets/gfx/rocketx/0010.jpg create mode 100644 assets/gfx/rocketx/0011.jpg create mode 100644 assets/gfx/rocketx/0012.jpg create mode 100644 assets/gfx/rocketx/0013.jpg create mode 100644 assets/gfx/rocketx/0014.jpg create mode 100644 assets/gfx/rocketx/0015.jpg create mode 100644 assets/gfx/rocketx/0016.jpg create mode 100644 assets/gfx/rocketx/0017.jpg create mode 100644 assets/gfx/rocketx/0018.jpg create mode 100644 assets/gfx/rocketx/0019.jpg create mode 100644 assets/gfx/rocketx/0020.jpg create mode 100644 assets/gfx/rocketx/0021.jpg create mode 100644 assets/gfx/rocketx/0022.jpg create mode 100644 assets/gfx/rocketx/0023.jpg create mode 100644 assets/gfx/rocketx/0024.jpg create mode 100644 assets/gfx/rocketx/0025.jpg create mode 100644 assets/gfx/rocketx/0026.jpg create mode 100644 assets/gfx/rocketx/0027.jpg create mode 100644 assets/gfx/rocketx/0028.jpg create mode 100644 assets/gfx/rocketx/0029.jpg create mode 100644 assets/gfx/rocketx/0030.jpg create mode 100644 assets/models/weapons/rocketl/rocketl_flash.md3 diff --git a/assets/gfx/rocketx/0002.jpg b/assets/gfx/rocketx/0002.jpg new file mode 100644 index 0000000..776768b Binary files /dev/null and b/assets/gfx/rocketx/0002.jpg differ diff --git a/assets/gfx/rocketx/0003.jpg b/assets/gfx/rocketx/0003.jpg new file mode 100644 index 0000000..91313e7 Binary files /dev/null and b/assets/gfx/rocketx/0003.jpg differ diff --git a/assets/gfx/rocketx/0004.jpg b/assets/gfx/rocketx/0004.jpg new file mode 100644 index 0000000..a1848ed Binary files /dev/null and b/assets/gfx/rocketx/0004.jpg differ diff --git a/assets/gfx/rocketx/0005.jpg b/assets/gfx/rocketx/0005.jpg new file mode 100644 index 0000000..da5e255 Binary files /dev/null and b/assets/gfx/rocketx/0005.jpg differ diff --git a/assets/gfx/rocketx/0006.jpg b/assets/gfx/rocketx/0006.jpg new file mode 100644 index 0000000..6d026ba Binary files /dev/null and b/assets/gfx/rocketx/0006.jpg differ diff --git a/assets/gfx/rocketx/0007.jpg b/assets/gfx/rocketx/0007.jpg new file mode 100644 index 0000000..c18ce0d Binary files /dev/null and b/assets/gfx/rocketx/0007.jpg differ diff --git a/assets/gfx/rocketx/0008.jpg b/assets/gfx/rocketx/0008.jpg new file mode 100644 index 0000000..06a2d74 Binary files /dev/null and b/assets/gfx/rocketx/0008.jpg differ diff --git a/assets/gfx/rocketx/0009.jpg b/assets/gfx/rocketx/0009.jpg new file mode 100644 index 0000000..6e7bc69 Binary files /dev/null and b/assets/gfx/rocketx/0009.jpg differ diff --git a/assets/gfx/rocketx/0010.jpg b/assets/gfx/rocketx/0010.jpg new file mode 100644 index 0000000..400d603 Binary files /dev/null and b/assets/gfx/rocketx/0010.jpg differ diff --git a/assets/gfx/rocketx/0011.jpg b/assets/gfx/rocketx/0011.jpg new file mode 100644 index 0000000..17e0220 Binary files /dev/null and b/assets/gfx/rocketx/0011.jpg differ diff --git a/assets/gfx/rocketx/0012.jpg b/assets/gfx/rocketx/0012.jpg new file mode 100644 index 0000000..6765bf9 Binary files /dev/null and b/assets/gfx/rocketx/0012.jpg differ diff --git a/assets/gfx/rocketx/0013.jpg b/assets/gfx/rocketx/0013.jpg new file mode 100644 index 0000000..a543aba Binary files /dev/null and b/assets/gfx/rocketx/0013.jpg differ diff --git a/assets/gfx/rocketx/0014.jpg b/assets/gfx/rocketx/0014.jpg new file mode 100644 index 0000000..5ed10d8 Binary files /dev/null and b/assets/gfx/rocketx/0014.jpg differ diff --git a/assets/gfx/rocketx/0015.jpg b/assets/gfx/rocketx/0015.jpg new file mode 100644 index 0000000..5fe6015 Binary files /dev/null and b/assets/gfx/rocketx/0015.jpg differ diff --git a/assets/gfx/rocketx/0016.jpg b/assets/gfx/rocketx/0016.jpg new file mode 100644 index 0000000..24f0d16 Binary files /dev/null and b/assets/gfx/rocketx/0016.jpg differ diff --git a/assets/gfx/rocketx/0017.jpg b/assets/gfx/rocketx/0017.jpg new file mode 100644 index 0000000..3b037f5 Binary files /dev/null and b/assets/gfx/rocketx/0017.jpg differ diff --git a/assets/gfx/rocketx/0018.jpg b/assets/gfx/rocketx/0018.jpg new file mode 100644 index 0000000..b479532 Binary files /dev/null and b/assets/gfx/rocketx/0018.jpg differ diff --git a/assets/gfx/rocketx/0019.jpg b/assets/gfx/rocketx/0019.jpg new file mode 100644 index 0000000..288bd52 Binary files /dev/null and b/assets/gfx/rocketx/0019.jpg differ diff --git a/assets/gfx/rocketx/0020.jpg b/assets/gfx/rocketx/0020.jpg new file mode 100644 index 0000000..97f2d10 Binary files /dev/null and b/assets/gfx/rocketx/0020.jpg differ diff --git a/assets/gfx/rocketx/0021.jpg b/assets/gfx/rocketx/0021.jpg new file mode 100644 index 0000000..3443b96 Binary files /dev/null and b/assets/gfx/rocketx/0021.jpg differ diff --git a/assets/gfx/rocketx/0022.jpg b/assets/gfx/rocketx/0022.jpg new file mode 100644 index 0000000..b14747d Binary files /dev/null and b/assets/gfx/rocketx/0022.jpg differ diff --git a/assets/gfx/rocketx/0023.jpg b/assets/gfx/rocketx/0023.jpg new file mode 100644 index 0000000..da23eb0 Binary files /dev/null and b/assets/gfx/rocketx/0023.jpg differ diff --git a/assets/gfx/rocketx/0024.jpg b/assets/gfx/rocketx/0024.jpg new file mode 100644 index 0000000..bfe4476 Binary files /dev/null and b/assets/gfx/rocketx/0024.jpg differ diff --git a/assets/gfx/rocketx/0025.jpg b/assets/gfx/rocketx/0025.jpg new file mode 100644 index 0000000..3c95e8b Binary files /dev/null and b/assets/gfx/rocketx/0025.jpg differ diff --git a/assets/gfx/rocketx/0026.jpg b/assets/gfx/rocketx/0026.jpg new file mode 100644 index 0000000..31590ea Binary files /dev/null and b/assets/gfx/rocketx/0026.jpg differ diff --git a/assets/gfx/rocketx/0027.jpg b/assets/gfx/rocketx/0027.jpg new file mode 100644 index 0000000..004d27f Binary files /dev/null and b/assets/gfx/rocketx/0027.jpg differ diff --git a/assets/gfx/rocketx/0028.jpg b/assets/gfx/rocketx/0028.jpg new file mode 100644 index 0000000..96405cb Binary files /dev/null and b/assets/gfx/rocketx/0028.jpg differ diff --git a/assets/gfx/rocketx/0029.jpg b/assets/gfx/rocketx/0029.jpg new file mode 100644 index 0000000..c344ab9 Binary files /dev/null and b/assets/gfx/rocketx/0029.jpg differ diff --git a/assets/gfx/rocketx/0030.jpg b/assets/gfx/rocketx/0030.jpg new file mode 100644 index 0000000..779691b Binary files /dev/null and b/assets/gfx/rocketx/0030.jpg differ diff --git a/assets/models/weapons/lcannon/weapon.cfg b/assets/models/weapons/lcannon/weapon.cfg index e6f1ab4..5719fdc 100644 --- a/assets/models/weapons/lcannon/weapon.cfg +++ b/assets/models/weapons/lcannon/weapon.cfg @@ -16,6 +16,7 @@ primary impactMark 32 gfx/marks/bullet_mrk impactSound 0 models/weapons/lcannon/impact0.wav impactParticleSystem models/weapons/lcannon/impactPS2 + impactQuake 1 } secondary @@ -30,4 +31,5 @@ secondary impactMark 8 gfx/marks/bullet_mrk impactSound 0 models/weapons/lcannon/impact0.wav impactParticleSystem models/weapons/lcannon/secondaryImpactPS2 + impactQuake 5 } diff --git a/assets/models/weapons/lightning/weapon.cfg b/assets/models/weapons/lightning/weapon.cfg index 4d48e0f..9b33568 100644 --- a/assets/models/weapons/lightning/weapon.cfg +++ b/assets/models/weapons/lightning/weapon.cfg @@ -10,6 +10,7 @@ primary flashSound 0 models/weapons/lightning/flash0.wav firingSound models/weapons/lightning/firing.wav + flashQuake 0.6 impactMark 6 gfx/marks/bullet_mrk impactSound 0 models/weapons/lightning/impact0.wav diff --git a/assets/models/weapons/rocketl/rocketl.md3 b/assets/models/weapons/rocketl/rocketl.md3 index 4119209..d515cf4 100644 Binary files a/assets/models/weapons/rocketl/rocketl.md3 and b/assets/models/weapons/rocketl/rocketl.md3 differ diff --git a/assets/models/weapons/rocketl/rocketl_flash.md3 b/assets/models/weapons/rocketl/rocketl_flash.md3 new file mode 100644 index 0000000..c1acf35 Binary files /dev/null and b/assets/models/weapons/rocketl/rocketl_flash.md3 differ diff --git a/assets/models/weapons/rocketl/weapon.cfg b/assets/models/weapons/rocketl/weapon.cfg index e5dafc6..5c6b70b 100644 --- a/assets/models/weapons/rocketl/weapon.cfg +++ b/assets/models/weapons/rocketl/weapon.cfg @@ -11,9 +11,11 @@ primary flashDlightColor 1.0 0.7 0.0 flashSound 0 models/weapons/rocketl/flash0.wav + flashQuake 1 impactMark 32 gfx/marks/bullet_mrk impactSound 0 models/weapons/rocketl/impact0.wav impactParticleSystem models/weapons/rocketl/impactPS + impactQuake 50 } diff --git a/assets/scripts/hw_rocketl.particle b/assets/scripts/hw_rocketl.particle index 891ac18..289fced 100644 --- a/assets/scripts/hw_rocketl.particle +++ b/assets/scripts/hw_rocketl.particle @@ -34,44 +34,11 @@ models/weapons/rocketl/missilePS models/weapons/rocketl/impactPS { - ejector - { - particle - { - shader sync rocketFlareParticle - displacement 0 0 0 0 - - velocityType normal - - velocityDir linear - - velocityMagnitude 0 - velocity 0 0 0 ~0 - - accelerationType static - accelerationDir linear - acceleration 0 0 0 ~0 - accelerationMagnitude 0 - - radius 0 50 100 - alpha 250 1 0 - rotation 0 ~-15 ~15 - bounce 0.0 - - lifeTime 40 - } - - count 1 - delay 0 - period 0 - 0 - } - ejector { particle { shader sync gfx/sprites/smoke - //shader sync flame3 flame4 flame5 flame6 flame7 flame8 flame9 flame10 flame11 flame12 flame13 flame14 flame15 flame16 flame17 flame18 flame19 flame20 flame21 flame22 flame23 flame24 flame25 displacement 0 0 0 0 velocityType normal @@ -103,7 +70,7 @@ models/weapons/rocketl/impactPS { particle { - shader sync flame3 flame4 flame5 flame6 flame7 flame8 flame9 flame10 flame11 flame12 flame13 flame14 flame15 flame16 flame17 flame18 flame19 flame20 flame21 flame22 flame23 flame24 flame25 + shader sync rocketx1 rocketx2 rocketx3 rocketx4 rocketx5 rocketx6 rocketx7 rocketx8 rocketx9 rocketx10 rocketx11 rocketx12 rocketx13 rocketx14 rocketx15 rocketx16 rocketx17 rocketx18 rocketx19 rocketx20 rocketx21 rocketx22 rocketx23 rocketx24 rocketx25 rocketx26 rocketx27 rocketx28 rocketx29 displacement 0 0 0 0 velocityType normal @@ -118,9 +85,9 @@ models/weapons/rocketl/impactPS acceleration 0 0 -1 ~5 accelerationMagnitude 25 - radius 0 0 100 - alpha 250 .75 0 - rotation 0 ~-15 ~15 + radius 0 30 70 + alpha 250 1 0 + rotation ~360 0 0 bounce 0.0 color 0 { 0.8 0.2 0.2 } - diff --git a/assets/scripts/hw_rocketl.shader b/assets/scripts/hw_rocketl.shader index 28c56cb..45abbb8 100644 --- a/assets/scripts/hw_rocketl.shader +++ b/assets/scripts/hw_rocketl.shader @@ -56,3 +56,305 @@ rocketThrust } } +models/weapons/rocketl/flash +{ + nopicmip + cull disable + { + map gfx/rocketx/0006.jpg + blendFunc GL_ONE GL_ONE + } +} + +// BEST ROCKET EPXLSION EVAR! +rocketx1 +{ + nopicmip + cull disable + { + map gfx/rocketx/0002.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx2 +{ + nopicmip + cull disable + { + map gfx/rocketx/0003.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx3 +{ + nopicmip + cull disable + { + map gfx/rocketx/0004.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx4 +{ + nopicmip + cull disable + { + map gfx/rocketx/0005.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx5 +{ + nopicmip + cull disable + { + map gfx/rocketx/0006.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx6 +{ + nopicmip + cull disable + { + map gfx/rocketx/0007.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx7 +{ + nopicmip + cull disable + { + map gfx/rocketx/0008.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx8 +{ + nopicmip + cull disable + { + map gfx/rocketx/0009.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx9 +{ + nopicmip + cull disable + { + map gfx/rocketx/0010.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx10 +{ + nopicmip + cull disable + { + map gfx/rocketx/0011.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx11 +{ + nopicmip + cull disable + { + map gfx/rocketx/0012.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx12 +{ + nopicmip + cull disable + { + map gfx/rocketx/0013.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx13 +{ + nopicmip + cull disable + { + map gfx/rocketx/0014.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx14 +{ + nopicmip + cull disable + { + map gfx/rocketx/0015.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx15 +{ + nopicmip + cull disable + { + map gfx/rocketx/0016.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx16 +{ + nopicmip + cull disable + { + map gfx/rocketx/0017.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx17 +{ + nopicmip + cull disable + { + map gfx/rocketx/0018.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx18 +{ + nopicmip + cull disable + { + map gfx/rocketx/0019.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx19 +{ + nopicmip + cull disable + { + map gfx/rocketx/0020.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx20 +{ + nopicmip + cull disable + { + map gfx/rocketx/0021.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx21 +{ + nopicmip + cull disable + { + map gfx/rocketx/0022.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx22 +{ + nopicmip + cull disable + { + map gfx/rocketx/0023.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx23 +{ + nopicmip + cull disable + { + map gfx/rocketx/0024.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx24 +{ + nopicmip + cull disable + { + map gfx/rocketx/0025.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx25 +{ + nopicmip + cull disable + { + map gfx/rocketx/0026.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx26 +{ + nopicmip + cull disable + { + map gfx/rocketx/0027.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx27 +{ + nopicmip + cull disable + { + map gfx/rocketx/0028.jpg + blendFunc GL_ONE GL_ONE + } +} + + +rocketx28 +{ + nopicmip + cull disable + { + map gfx/rocketx/0029.jpg + blendFunc GL_ONE GL_ONE + } +} + +rocketx29 +{ + nopicmip + cull disable + { + map gfx/rocketx/0030.jpg + blendFunc GL_ONE GL_ONE + } +} + diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h index d979046..97a21d9 100644 --- a/src/cgame/cg_local.h +++ b/src/cgame/cg_local.h @@ -787,6 +787,7 @@ typedef struct weaponInfoMode_s vec3_t flashDlightColor; sfxHandle_t flashSound[ 4 ]; // fast firing weapons randomly choose qboolean continuousFlash; + float flashQuake; qhandle_t missileModel; sfxHandle_t missileSound; @@ -816,6 +817,7 @@ typedef struct weaponInfoMode_s qhandle_t impactMarkSize; sfxHandle_t impactSound[ 4 ]; //random impact sound sfxHandle_t impactFleshSound[ 4 ]; //random impact sound + float impactQuake; } weaponInfoMode_t; // each WP_* weapon enum has an associated weaponInfo_t @@ -1159,6 +1161,8 @@ typedef struct int nearUsableBuildable; int nextWeaponClickTime; + + float viewQuake; } cg_t; @@ -1586,6 +1590,9 @@ extern vmCvar_t cg_chatTeamPrefix; extern vmCvar_t cg_drawBubble; extern vmCvar_t cg_BubbleZoom; +extern vmCvar_t cg_viewQuake; +extern vmCvar_t cg_viewQuakeLambda; + // // cg_main.c // @@ -1627,6 +1634,7 @@ void CG_TestModelNextSkin_f( void ); void CG_TestModelPrevSkin_f( void ); void CG_AddBufferedSound( sfxHandle_t sfx ); void CG_DrawActiveFrame( int serverTime, stereoFrame_t stereoView, qboolean demoPlayback ); +void CG_InduceViewQuake( vec3_t src, float mag ); void CG_OffsetFirstPersonView( void ); void CG_OffsetThirdPersonView( void ); void CG_OffsetShoulderView( void ); diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c index 6be1d50..c5ad444 100644 --- a/src/cgame/cg_main.c +++ b/src/cgame/cg_main.c @@ -226,7 +226,10 @@ vmCvar_t cg_chatTeamPrefix; vmCvar_t cg_drawBubble; vmCvar_t cg_BubbleZoom; -vmCvar_t cg_EDGEFPSFIX; +vmCvar_t cg_EDGEFPSFIX; + +vmCvar_t cg_viewQuake; +vmCvar_t cg_viewQuakeLambda; typedef struct { @@ -371,7 +374,10 @@ static cvarTable_t cvarTable[ ] = // { &cg_chatTeamPrefix, "cg_chatTeamPrefix", "1", CVAR_ARCHIVE} { &cg_chatTeamPrefix, "cg_chatTeamPrefix", "1", CVAR_ARCHIVE}, - { &cg_EDGEFPSFIX, "cg_EDGEFPSFIX", "0", CVAR_ARCHIVE|CVAR_USERINFO } + { &cg_EDGEFPSFIX, "cg_EDGEFPSFIX", "0", CVAR_ARCHIVE|CVAR_USERINFO }, + + { &cg_viewQuake, "cg_viewQuake", "1", CVAR_ARCHIVE }, + { &cg_viewQuakeLambda, "cg_viewQuakeLambda", "-10", CVAR_ARCHIVE } }; static int cvarTableSize = sizeof( cvarTable ) / sizeof( cvarTable[0] ); diff --git a/src/cgame/cg_view.c b/src/cgame/cg_view.c index a0142d0..68f9287 100644 --- a/src/cgame/cg_view.c +++ b/src/cgame/cg_view.c @@ -537,6 +537,26 @@ static void CG_StepOffset( void ) #define PCLOUD_ZOOM_FREQUENCY 0.625f // 2.5s / 4 #define PCLOUD_DISORIENT_DURATION 2500 +/* +=============== +CG_InduceViewQuake +=============== +*/ + +void CG_InduceViewQuake( vec3_t src, float mag ) +{ + if( !src ) + { + cg.viewQuake += mag; + } + else + { + float dist; + + dist = Distance( src, cg.refdef.vieworg ); + cg.viewQuake += mag / dist / dist * 1000.0f; + } +} /* =============== @@ -838,6 +858,20 @@ void CG_OffsetFirstPersonView( void ) // add step offset CG_StepOffset( ); + + + // view quake + if( cg.thisFrameTeleport ) + { + cg.viewQuake = 0; + } + else + { + angles[ PITCH ] += crandom( ) * cg.viewQuake * cg_viewQuake.value; + angles[ YAW ] += crandom( ) * cg.viewQuake * cg_viewQuake.value; + + cg.viewQuake *= pow( 2, (float)cg.frametime * 1.0e-3 * cg_viewQuakeLambda.value ); + } } //====================================================================== diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c index 21d0352..8e3b438 100644 --- a/src/cgame/cg_weapons.c +++ b/src/cgame/cg_weapons.c @@ -416,6 +416,26 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p continue; } + else if( !Q_stricmp( token, "impactQuake" ) ) + { + token = COM_Parse( text_p ); + if( !token ) + break; + + wim->impactQuake = atof( token ); + + continue; + } + else if( !Q_stricmp( token, "flashQuake" ) ) + { + token = COM_Parse( text_p ); + if( !token ) + break; + + wim->flashQuake = atof( token ); + + continue; + } else if( !Q_stricmp( token, "}" ) ) return qtrue; //reached the end of this weapon section else @@ -1827,6 +1847,14 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode ) if( wi->wim[ weaponMode ].flashSound[ c ] ) trap_S_StartSound( NULL, es->number, CHAN_WEAPON, wi->wim[ weaponMode ].flashSound[ c ] ); } + + if( cent == &cg.predictedPlayerEntity ) + { + float quake; + + quake = wi->wim[ weaponMode ].flashQuake; + CG_InduceViewQuake( NULL, quake ); + } } @@ -1843,7 +1871,7 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN qhandle_t mark = 0; qhandle_t ps = 0; int c; - float radius = 1.0f; + float radius = 1.0f, quake; weaponInfo_t *weapon = &cg_weapons[ weaponNum ]; if( weaponMode <= WPM_NONE || weaponMode >= WPM_NUM_WEAPONMODES ) @@ -1852,6 +1880,7 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN mark = weapon->wim[ weaponMode ].impactMark; radius = weapon->wim[ weaponMode ].impactMarkSize; ps = weapon->wim[ weaponMode ].impactParticleSystem; + quake = weapon->wim[ weaponMode ].impactQuake; if( soundType == IMPACTSOUND_FLESH ) { @@ -1905,6 +1934,11 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN // if( radius > 0.0f ) CG_ImpactMark( mark, origin, dir, random( ) * 360, 1, 1, 1, 1, qfalse, radius, qfalse ); + + if( weaponNum == WP_LUCIFER_CANNON ) + quake *= charge; + + CG_InduceViewQuake( origin, quake ); } @@ -1918,6 +1952,7 @@ void CG_MissileHitEntity( weapon_t weaponNum, weaponMode_t weaponMode, { vec3_t normal; weaponInfo_t *weapon = &cg_weapons[ weaponNum ]; + float quake = weapon->wim[ weaponMode ].impactQuake; VectorCopy( dir, normal ); VectorInverse( normal ); @@ -1947,6 +1982,11 @@ void CG_MissileHitEntity( weapon_t weaponNum, weaponMode_t weaponMode, CG_MissileHitWall( weaponNum, weaponMode, 0, origin, dir, sound, charge ); } + + if( weaponNum == WP_LUCIFER_CANNON ) + quake *= charge; + + CG_InduceViewQuake( origin, quake ); } -- cgit From cf0eb59c5407fd959410035532120a52a11b109e Mon Sep 17 00:00:00 2001 From: enneract Date: Sun, 14 Dec 2014 12:38:45 +0100 Subject: Fix rocket explosion not fading out properly. --- assets/gfx/rocketx/0025.jpg | Bin 7581 -> 6127 bytes assets/gfx/rocketx/0026.jpg | Bin 7346 -> 5150 bytes assets/gfx/rocketx/0027.jpg | Bin 7060 -> 3942 bytes assets/gfx/rocketx/0028.jpg | Bin 6750 -> 2777 bytes assets/gfx/rocketx/0029.jpg | Bin 6433 -> 1718 bytes assets/gfx/rocketx/0030.jpg | Bin 6090 -> 1193 bytes assets/scripts/hw_rocketl.particle | 2 +- 7 files changed, 1 insertion(+), 1 deletion(-) diff --git a/assets/gfx/rocketx/0025.jpg b/assets/gfx/rocketx/0025.jpg index 3c95e8b..e6a7923 100644 Binary files a/assets/gfx/rocketx/0025.jpg and b/assets/gfx/rocketx/0025.jpg differ diff --git a/assets/gfx/rocketx/0026.jpg b/assets/gfx/rocketx/0026.jpg index 31590ea..99ef757 100644 Binary files a/assets/gfx/rocketx/0026.jpg and b/assets/gfx/rocketx/0026.jpg differ diff --git a/assets/gfx/rocketx/0027.jpg b/assets/gfx/rocketx/0027.jpg index 004d27f..220234b 100644 Binary files a/assets/gfx/rocketx/0027.jpg and b/assets/gfx/rocketx/0027.jpg differ diff --git a/assets/gfx/rocketx/0028.jpg b/assets/gfx/rocketx/0028.jpg index 96405cb..5b2b4e6 100644 Binary files a/assets/gfx/rocketx/0028.jpg and b/assets/gfx/rocketx/0028.jpg differ diff --git a/assets/gfx/rocketx/0029.jpg b/assets/gfx/rocketx/0029.jpg index c344ab9..585257e 100644 Binary files a/assets/gfx/rocketx/0029.jpg and b/assets/gfx/rocketx/0029.jpg differ diff --git a/assets/gfx/rocketx/0030.jpg b/assets/gfx/rocketx/0030.jpg index 779691b..09721ca 100644 Binary files a/assets/gfx/rocketx/0030.jpg and b/assets/gfx/rocketx/0030.jpg differ diff --git a/assets/scripts/hw_rocketl.particle b/assets/scripts/hw_rocketl.particle index 289fced..5fbf798 100644 --- a/assets/scripts/hw_rocketl.particle +++ b/assets/scripts/hw_rocketl.particle @@ -86,7 +86,7 @@ models/weapons/rocketl/impactPS accelerationMagnitude 25 radius 0 30 70 - alpha 250 1 0 + alpha 250 1 1 rotation ~360 0 0 bounce 0.0 color 0 { 0.8 0.2 0.2 } - -- cgit From bb6121f265d70282aeba57a252996f130e5d6df8 Mon Sep 17 00:00:00 2001 From: enneract Date: Sun, 14 Dec 2014 13:17:33 +0100 Subject: Add view quake to more events. --- assets/models/weapons/grenade/weapon.cfg | 1 + src/cgame/cg_event.c | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/assets/models/weapons/grenade/weapon.cfg b/assets/models/weapons/grenade/weapon.cfg index a0d2f1b..9d0811c 100644 --- a/assets/models/weapons/grenade/weapon.cfg +++ b/assets/models/weapons/grenade/weapon.cfg @@ -9,4 +9,5 @@ primary impactParticleSystem models/weapons/grenade/impactPS2 impactSound 0 models/weapons/grenade/impact0.wav + impactQuake 120 } diff --git a/src/cgame/cg_event.c b/src/cgame/cg_event.c index 4c756ad..e5002cd 100644 --- a/src/cgame/cg_event.c +++ b/src/cgame/cg_event.c @@ -1009,9 +1009,12 @@ void CG_EntityEvent( centity_t *cent, vec3_t position ) CG_MissileHitWall( es->weapon, es->generic1, 0, position, dir, IMPACTSOUND_METAL, es->torsoAnim ); break; +#define BUILDABLE_EXPLOSION_QUAKE 50 + case EV_HUMAN_BUILDABLE_EXPLOSION: ByteToDir( es->eventParm, dir ); CG_HumanBuildableExplosion( position, dir, es->modelindex ); + CG_InduceViewQuake( position, BUILDABLE_EXPLOSION_QUAKE ); break; case EV_ALIEN_BUILDABLE_EXPLOSION: @@ -1020,6 +1023,8 @@ void CG_EntityEvent( centity_t *cent, vec3_t position ) if ( es->modelindex == BA_A_SPITEFUL_ABCESS ) CG_AlienSPITEFUL_ABCESSExplosion( position, dir ); + + CG_InduceViewQuake( position, BUILDABLE_EXPLOSION_QUAKE ); break; //Scleim greifer schwanz f\FCr slime -- cgit From 5130cdd357c5b3b442d39ee05052739419456e77 Mon Sep 17 00:00:00 2001 From: enneract Date: Sun, 14 Dec 2014 14:47:51 +0100 Subject: Limit view quake's mangitude. --- src/cgame/cg_local.h | 1 + src/cgame/cg_main.c | 4 +++- src/cgame/cg_view.c | 3 +++ 3 files changed, 7 insertions(+), 1 deletion(-) diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h index 97a21d9..7d4bd3d 100644 --- a/src/cgame/cg_local.h +++ b/src/cgame/cg_local.h @@ -1592,6 +1592,7 @@ extern vmCvar_t cg_BubbleZoom; extern vmCvar_t cg_viewQuake; extern vmCvar_t cg_viewQuakeLambda; +extern vmCvar_t cg_viewQuakeLimit; // // cg_main.c diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c index c5ad444..366a6a3 100644 --- a/src/cgame/cg_main.c +++ b/src/cgame/cg_main.c @@ -230,6 +230,7 @@ vmCvar_t cg_EDGEFPSFIX; vmCvar_t cg_viewQuake; vmCvar_t cg_viewQuakeLambda; +vmCvar_t cg_viewQuakeLimit; typedef struct { @@ -377,7 +378,8 @@ static cvarTable_t cvarTable[ ] = { &cg_EDGEFPSFIX, "cg_EDGEFPSFIX", "0", CVAR_ARCHIVE|CVAR_USERINFO }, { &cg_viewQuake, "cg_viewQuake", "1", CVAR_ARCHIVE }, - { &cg_viewQuakeLambda, "cg_viewQuakeLambda", "-10", CVAR_ARCHIVE } + { &cg_viewQuakeLambda, "cg_viewQuakeLambda", "-10", CVAR_ARCHIVE }, + { &cg_viewQuakeLimit, "cg_viewQuakeLimit", "5", CVAR_ARCHIVE } }; static int cvarTableSize = sizeof( cvarTable ) / sizeof( cvarTable[0] ); diff --git a/src/cgame/cg_view.c b/src/cgame/cg_view.c index 68f9287..eb6e88d 100644 --- a/src/cgame/cg_view.c +++ b/src/cgame/cg_view.c @@ -556,6 +556,9 @@ void CG_InduceViewQuake( vec3_t src, float mag ) dist = Distance( src, cg.refdef.vieworg ); cg.viewQuake += mag / dist / dist * 1000.0f; } + + if( cg.viewQuake > cg_viewQuakeLimit.value ) + cg.viewQuake = cg_viewQuakeLimit.value; } /* -- cgit