diff options
Diffstat (limited to 'src/cgame')
-rw-r--r-- | src/cgame/cg_draw.c | 42 | ||||
-rw-r--r-- | src/cgame/cg_local.h | 1 | ||||
-rw-r--r-- | src/cgame/cg_weapons.c | 106 |
3 files changed, 87 insertions, 62 deletions
diff --git a/src/cgame/cg_draw.c b/src/cgame/cg_draw.c index 374c7a75..bc012338 100644 --- a/src/cgame/cg_draw.c +++ b/src/cgame/cg_draw.c @@ -899,15 +899,42 @@ CG_DrawPlayerHealthCross */ static void CG_DrawPlayerHealthCross( rectDef_t *rect, vec4_t color, qhandle_t shader ) { - playerState_t *ps = &cg.snap->ps; - int health = ps->stats[ STAT_HEALTH ]; - - if( health < 10 ) + if( ( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_2X ) || + ( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_3X ) ) + return; + if( cg.snap->ps.stats[ STAT_PTEAM ] == PTE_HUMANS && + cg.snap->ps.stats[ STAT_HEALTH ] < 10 ) { color[ 0 ] = 1.0f; color[ 1 ] = color[ 2 ] = 0.0f; } + if( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_ACTIVE ) + color[ 3 ] = 1.0f; + + trap_R_SetColor( color ); + CG_DrawPic( rect->x, rect->y, rect->w, rect->h, shader ); + trap_R_SetColor( NULL ); +} + +static void CG_DrawPlayerHealthCross2( rectDef_t *rect, vec4_t color, qhandle_t shader ) +{ + if( !( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_2X ) ) + return; + if( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_ACTIVE ) + color[ 3 ] = 1.0f; + + trap_R_SetColor( color ); + CG_DrawPic( rect->x, rect->y, rect->w, rect->h, shader ); + trap_R_SetColor( NULL ); +} +static void CG_DrawPlayerHealthCross3( rectDef_t *rect, vec4_t color, qhandle_t shader ) +{ + if( !( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_3X ) ) + return; + if( cg.snap->ps.stats[ STAT_STATE ] & SS_HEALING_ACTIVE ) + color[ 3 ] = 1.0f; + trap_R_SetColor( color ); CG_DrawPic( rect->x, rect->y, rect->w, rect->h, shader ); trap_R_SetColor( NULL ); @@ -2156,6 +2183,12 @@ void CG_OwnerDraw( float x, float y, float w, float h, float text_x, case CG_PLAYER_HEALTH_CROSS: CG_DrawPlayerHealthCross( &rect, color, shader ); break; + case CG_PLAYER_HEALTH_CROSS2: + CG_DrawPlayerHealthCross2( &rect, color, shader ); + break; + case CG_PLAYER_HEALTH_CROSS3: + CG_DrawPlayerHealthCross3( &rect, color, shader ); + break; case CG_PLAYER_CLIPS_RING: CG_DrawPlayerClipsRing( &rect, color, shader ); break; @@ -2872,7 +2905,6 @@ static void CG_PainBlend( void ) return; damage = cg.lastHealth - cg.snap->ps.stats[ STAT_HEALTH ]; - if( damage < 0 ) damage = 0; diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h index b47f7cc9..71e4a14c 100644 --- a/src/cgame/cg_local.h +++ b/src/cgame/cg_local.h @@ -1125,6 +1125,7 @@ typedef struct float painBlendValue; float painBlendTarget; + float healBlendValue; int lastHealth; int lastPredictedCommand; diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c index 45318cf8..f4c8fbf8 100644 --- a/src/cgame/cg_weapons.c +++ b/src/cgame/cg_weapons.c @@ -869,6 +869,12 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent trap_S_AddLoopingSound( cent->currentState.number, cent->lerpOrigin, vec3_origin, weapon->readySound ); } + // Lucifer cannon charge warning beep + if( weaponNum == WP_LUCIFER_CANNON && + ( cent->currentState.eFlags & EF_WARN_CHARGE ) ) + trap_S_AddLoopingSound( cent->currentState.number, cent->lerpOrigin, + vec3_origin, cgs.media.lCannonWarningSound ); + if( !noGunModel ) { CG_PositionEntityOnTag( &gun, parent, parent->hModel, "tag_weapon" ); @@ -1015,12 +1021,6 @@ void CG_AddViewWeapon( playerState_t *ps ) if( ( ps->stats[ STAT_BUILDABLE ] & ~SB_VALID_TOGGLEBIT ) > BA_NONE ) CG_GhostBuildable( ps->stats[ STAT_BUILDABLE ] & ~SB_VALID_TOGGLEBIT ); - // Lucifer cannon charge warning beep - if( weapon == WP_LUCIFER_CANNON && - ps->stats[ STAT_MISC ] > LCANNON_TOTAL_CHARGE * 2 / 3 ) - trap_S_AddLoopingSound( ps->clientNum, ps->origin, vec3_origin, - cgs.media.lCannonWarningSound ); - // no gun if in third person view if( cg.renderingThirdPerson ) return; @@ -1165,22 +1165,12 @@ CG_DrawItemSelect */ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color ) { - int i; - float x = rect->x; - float y = rect->y; - float width = rect->w; - float height = rect->h; - float iconWidth; - float iconHeight; - int items[ 64 ]; - int numItems = 0, selectedItem = 0; - int length; - int selectWindow; - qboolean vertical; - centity_t *cent; + centity_t *cent; playerState_t *ps; - - int colinfo[ 64 ]; + float x = rect->x, y = rect->y, width = rect->w, height = rect->h, + iconWidth, iconHeight; + int i, items[ 64 ], colinfo[ 64 ], numItems = 0, selectedItem = 0, length; + qboolean vertical; cent = &cg_entities[ cg.snap->ps.clientNum ]; ps = &cg.snap->ps; @@ -1201,23 +1191,7 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color ) // showing weapon select clears pickup item display, but not the blend blob cg.itemPickupTime = 0; - if( height > width ) - { - vertical = qtrue; - iconWidth = width * cgDC.aspectScale; - iconHeight = width; - length = height / ( width * cgDC.aspectScale ); - } - else if( height <= width ) - { - vertical = qfalse; - iconWidth = height * cgDC.aspectScale; - iconHeight = height; - length = width / ( height * cgDC.aspectScale ); - } - - selectWindow = length / 2; - + // put all weapons in the items list for( i = WP_NONE + 1; i < WP_NUM_WEAPONS; i++ ) { if( !BG_InventoryContainsWeapon( i, cg.snap->ps.stats ) ) @@ -1236,6 +1210,7 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color ) numItems++; } + // put all upgrades in the weapons list for( i = UP_NONE + 1; i < UP_NUM_UPGRADES; i++ ) { if( !BG_InventoryContainsUpgrade( i, cg.snap->ps.stats ) ) @@ -1244,7 +1219,6 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color ) if( !BG_FindUsableForUpgrade ( i ) ) colinfo[ numItems ] = 2; - if( i == cg.weaponSelect - 32 ) selectedItem = numItems; @@ -1253,42 +1227,60 @@ void CG_DrawItemSelect( rectDef_t *rect, vec4_t color ) numItems++; } + // compute the length of the display window and determine orientation + vertical = height > width; + if( vertical ) + { + iconWidth = width * cgDC.aspectScale; + iconHeight = width; + length = height / ( width * cgDC.aspectScale ); + } + else + { + iconWidth = height * cgDC.aspectScale; + iconHeight = height; + length = width / ( height * cgDC.aspectScale ); + } + + // render icon ring for( i = 0; i < length; i++ ) { - int displacement = i - selectWindow; - int item = displacement + selectedItem; + int item = i - length / 2 + selectedItem; - if( ( item >= 0 ) && ( item < numItems ) ) + if( item < 0 ) + item += length; + else if( item >= length ) + item -= length; + if( item >= 0 && item < numItems ) { switch( colinfo[ item ] ) { - case 0: - color = colorCyan; - break; - case 1: - color = colorRed; - break; - case 2: - color = colorMdGrey; - break; + case 0: + color = colorCyan; + break; + case 1: + color = colorRed; + break; + case 2: + color = colorMdGrey; + break; } color[3] = 0.5; - trap_R_SetColor( color ); if( items[ item ] <= 32 ) - CG_DrawPic( x, y, iconWidth, iconHeight, cg_weapons[ items[ item ] ].weaponIcon ); + CG_DrawPic( x, y, iconWidth, iconHeight, + cg_weapons[ items[ item ] ].weaponIcon ); else if( items[ item ] > 32 ) - CG_DrawPic( x, y, iconWidth, iconHeight, cg_upgrades[ items[ item ] - 32 ].upgradeIcon ); - - trap_R_SetColor( NULL ); + CG_DrawPic( x, y, iconWidth, iconHeight, + cg_upgrades[ items[ item ] - 32 ].upgradeIcon ); } - if( vertical ) y += iconHeight; else x += iconWidth; } + trap_R_SetColor( NULL ); } |