hlsdk-portable/cl_dll/ammohistory.cpp

192 lines
5.5 KiB
C++
Raw Normal View History

2016-06-04 18:24:23 +05:00
/***
*
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
*
* This product contains software technology licensed from Id
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
* All Rights Reserved.
*
* Use, distribution, and modification of this source code and/or resulting
* object code is restricted to non-commercial enhancements to products from
* Valve LLC. All other use, distribution, or modification is prohibited
* without written permission from Valve LLC.
*
****/
//
// ammohistory.cpp
//
#include "hud.h"
#include "cl_util.h"
#include "parsemsg.h"
#include <string.h>
#include <stdio.h>
#include "ammohistory.h"
HistoryResource gHR;
2016-07-03 18:39:55 +05:00
#define AMMO_PICKUP_GAP ( gHR.iHistoryGap + 5 )
#define AMMO_PICKUP_PICK_HEIGHT ( 32 + ( gHR.iHistoryGap * 2 ) )
#define AMMO_PICKUP_HEIGHT_MAX ( ScreenHeight - 100 )
2016-06-04 18:24:23 +05:00
#define MAX_ITEM_NAME 32
int HISTORY_DRAW_TIME = 5;
// keep a list of items
struct ITEM_INFO
{
char szName[MAX_ITEM_NAME];
HSPRITE spr;
wrect_t rect;
};
2016-07-03 18:39:55 +05:00
void HistoryResource::AddToHistory( int iType, int iId, int iCount )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
if( iType == HISTSLOT_AMMO && !iCount )
2016-06-04 18:24:23 +05:00
return; // no amount, so don't add
2016-07-03 18:39:55 +05:00
if( ( ( ( AMMO_PICKUP_GAP * iCurrentHistorySlot ) + AMMO_PICKUP_PICK_HEIGHT ) > AMMO_PICKUP_HEIGHT_MAX ) || ( iCurrentHistorySlot >= MAX_HISTORY ) )
{
// the pic would have to be drawn too high
2016-06-04 18:24:23 +05:00
// so start from the bottom
iCurrentHistorySlot = 0;
}
HIST_ITEM *freeslot = &rgAmmoHistory[iCurrentHistorySlot++]; // default to just writing to the first slot
HISTORY_DRAW_TIME = CVAR_GET_FLOAT( "hud_drawhistory_time" );
freeslot->type = iType;
freeslot->iId = iId;
freeslot->iCount = iCount;
freeslot->DisplayTime = gHUD.m_flTime + HISTORY_DRAW_TIME;
}
2016-07-03 18:39:55 +05:00
void HistoryResource::AddToHistory( int iType, const char *szName, int iCount )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
if( iType != HISTSLOT_ITEM )
2016-06-04 18:24:23 +05:00
return;
2016-07-03 18:39:55 +05:00
if( ( ( ( AMMO_PICKUP_GAP * iCurrentHistorySlot ) + AMMO_PICKUP_PICK_HEIGHT ) > AMMO_PICKUP_HEIGHT_MAX ) || ( iCurrentHistorySlot >= MAX_HISTORY ) )
{
// the pic would have to be drawn too high
2016-06-04 18:24:23 +05:00
// so start from the bottom
iCurrentHistorySlot = 0;
}
HIST_ITEM *freeslot = &rgAmmoHistory[iCurrentHistorySlot++]; // default to just writing to the first slot
// I am really unhappy with all the code in this file
int i = gHUD.GetSpriteIndex( szName );
2016-07-03 18:39:55 +05:00
if( i == -1 )
2016-06-04 18:24:23 +05:00
return; // unknown sprite name, don't add it to history
freeslot->iId = i;
freeslot->type = iType;
freeslot->iCount = iCount;
HISTORY_DRAW_TIME = CVAR_GET_FLOAT( "hud_drawhistory_time" );
freeslot->DisplayTime = gHUD.m_flTime + HISTORY_DRAW_TIME;
}
2016-07-03 18:39:55 +05:00
void HistoryResource::CheckClearHistory( void )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
for( int i = 0; i < MAX_HISTORY; i++ )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
if( rgAmmoHistory[i].type )
2016-06-04 18:24:23 +05:00
return;
}
iCurrentHistorySlot = 0;
}
//
// Draw Ammo pickup history
//
2016-07-03 18:39:55 +05:00
int HistoryResource::DrawAmmoHistory( float flTime )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
for( int i = 0; i < MAX_HISTORY; i++ )
2016-06-04 18:24:23 +05:00
{
2016-07-03 18:39:55 +05:00
if( rgAmmoHistory[i].type )
2016-06-04 18:24:23 +05:00
{
2019-08-12 02:25:50 +05:00
rgAmmoHistory[i].DisplayTime = Q_min( rgAmmoHistory[i].DisplayTime, gHUD.m_flTime + HISTORY_DRAW_TIME );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
if( rgAmmoHistory[i].DisplayTime <= flTime )
{
// pic drawing time has expired
2016-06-04 18:24:23 +05:00
memset( &rgAmmoHistory[i], 0, sizeof(HIST_ITEM) );
CheckClearHistory();
}
2016-07-03 18:39:55 +05:00
else if( rgAmmoHistory[i].type == HISTSLOT_AMMO )
2016-06-04 18:24:23 +05:00
{
wrect_t rcPic;
HSPRITE *spr = gWR.GetAmmoPicFromWeapon( rgAmmoHistory[i].iId, rcPic );
int r, g, b;
2016-07-03 18:39:55 +05:00
UnpackRGB( r, g, b, RGB_YELLOWISH );
float scale = ( rgAmmoHistory[i].DisplayTime - flTime ) * 80;
2019-08-12 02:25:50 +05:00
ScaleColors( r, g, b, Q_min( scale, 255 ) );
2016-06-04 18:24:23 +05:00
// Draw the pic
int ypos = ScreenHeight - (AMMO_PICKUP_PICK_HEIGHT + (AMMO_PICKUP_GAP * i));
int xpos = ScreenWidth - 24;
2016-07-03 18:39:55 +05:00
if( spr && *spr ) // weapon isn't loaded yet so just don't draw the pic
{
// the dll has to make sure it has sent info the weapons you need
2016-06-04 18:24:23 +05:00
SPR_Set( *spr, r, g, b );
SPR_DrawAdditive( 0, xpos, ypos, &rcPic );
}
2016-03-02 08:00:09 +00:00
// do not draw black console string
2016-07-03 18:39:55 +05:00
if( !( ( hud_textmode->value == 2 ) && ( scale < 200 ) ) )
2016-03-02 08:00:09 +00:00
// Draw the number
2016-06-04 18:24:23 +05:00
gHUD.DrawHudNumberString( xpos - 10, ypos, xpos - 100, rgAmmoHistory[i].iCount, r, g, b );
}
2016-07-03 18:39:55 +05:00
else if( rgAmmoHistory[i].type == HISTSLOT_WEAP )
2016-06-04 18:24:23 +05:00
{
WEAPON *weap = gWR.GetWeapon( rgAmmoHistory[i].iId );
2016-07-03 18:39:55 +05:00
if( !weap )
2016-06-04 18:24:23 +05:00
return 1; // we don't know about the weapon yet, so don't draw anything
int r, g, b;
2016-07-03 18:39:55 +05:00
UnpackRGB( r,g,b, RGB_YELLOWISH );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
if( !gWR.HasAmmo( weap ) )
UnpackRGB( r, g, b, RGB_REDISH ); // if the weapon doesn't have ammo, display it as red
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
float scale = ( rgAmmoHistory[i].DisplayTime - flTime ) * 80;
2019-08-12 02:25:50 +05:00
ScaleColors( r, g, b, Q_min( scale, 255 ) );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
int ypos = ScreenHeight - ( AMMO_PICKUP_PICK_HEIGHT + ( AMMO_PICKUP_GAP * i ) );
int xpos = ScreenWidth - ( weap->rcInactive.right - weap->rcInactive.left );
2016-06-04 18:24:23 +05:00
SPR_Set( weap->hInactive, r, g, b );
SPR_DrawAdditive( 0, xpos, ypos, &weap->rcInactive );
}
2016-07-03 18:39:55 +05:00
else if( rgAmmoHistory[i].type == HISTSLOT_ITEM )
2016-06-04 18:24:23 +05:00
{
int r, g, b;
2016-07-03 18:39:55 +05:00
if( !rgAmmoHistory[i].iId )
2016-06-04 18:24:23 +05:00
continue; // sprite not loaded
wrect_t rect = gHUD.GetSpriteRect( rgAmmoHistory[i].iId );
2016-07-03 18:39:55 +05:00
UnpackRGB( r, g, b, RGB_YELLOWISH );
float scale = ( rgAmmoHistory[i].DisplayTime - flTime ) * 80;
2019-08-12 02:25:50 +05:00
ScaleColors( r, g, b, Q_min( scale, 255 ) );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
int ypos = ScreenHeight - ( AMMO_PICKUP_PICK_HEIGHT + ( AMMO_PICKUP_GAP * i ) );
int xpos = ScreenWidth - ( rect.right - rect.left ) - 10;
2016-06-04 18:24:23 +05:00
SPR_Set( gHUD.GetSprite( rgAmmoHistory[i].iId ), r, g, b );
SPR_DrawAdditive( 0, xpos, ypos, &rect );
}
}
}
return 1;
}