hlsdk-portable/cl_dll/flashlight.cpp

176 lines
3.8 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.
*
****/
//
// flashlight.cpp
//
// implementation of CHudFlashlight class
//
#include "hud.h"
#include "cl_util.h"
#include "parsemsg.h"
#include <string.h>
#include <stdio.h>
2016-07-03 18:39:55 +05:00
DECLARE_MESSAGE( m_Flash, FlashBat )
DECLARE_MESSAGE( m_Flash, Flashlight )
2016-06-04 18:24:23 +05:00
#define BAT_NAME "sprites/%d_Flashlight.spr"
2016-07-03 18:39:55 +05:00
int CHudFlashlight::Init( void )
2016-06-04 18:24:23 +05:00
{
m_fFade = 0;
m_fOn = 0;
2016-07-03 18:39:55 +05:00
HOOK_MESSAGE( Flashlight );
HOOK_MESSAGE( FlashBat );
2016-06-04 18:24:23 +05:00
m_iFlags |= HUD_ACTIVE;
2016-07-03 18:39:55 +05:00
gHUD.AddHudElem( this );
2016-06-04 18:24:23 +05:00
return 1;
}
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
void CHudFlashlight::Reset( void )
2016-06-04 18:24:23 +05:00
{
m_fFade = 0;
m_fOn = 0;
m_iBat = 100;
2019-10-13 16:49:25 +05:00
m_flBat = 1.0f;
2016-06-04 18:24:23 +05:00
}
2016-07-03 18:39:55 +05:00
int CHudFlashlight::VidInit( void )
2016-06-04 18:24:23 +05:00
{
int HUD_flash_empty = gHUD.GetSpriteIndex( "flash_empty" );
int HUD_flash_full = gHUD.GetSpriteIndex( "flash_full" );
int HUD_flash_beam = gHUD.GetSpriteIndex( "flash_beam" );
2016-07-03 18:39:55 +05:00
m_hSprite1 = gHUD.GetSprite( HUD_flash_empty );
m_hSprite2 = gHUD.GetSprite( HUD_flash_full );
m_hBeam = gHUD.GetSprite( HUD_flash_beam );
m_prc1 = &gHUD.GetSpriteRect( HUD_flash_empty );
m_prc2 = &gHUD.GetSpriteRect( HUD_flash_full );
2016-06-04 18:24:23 +05:00
m_prcBeam = &gHUD.GetSpriteRect(HUD_flash_beam);
m_iWidth = m_prc2->right - m_prc2->left;
return 1;
}
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
int CHudFlashlight::MsgFunc_FlashBat( const char *pszName, int iSize, void *pbuf )
2016-06-04 18:24:23 +05:00
{
BEGIN_READ( pbuf, iSize );
int x = READ_BYTE();
m_iBat = x;
2019-10-13 16:49:25 +05:00
m_flBat = ( (float)x ) / 100.0f;
2016-06-04 18:24:23 +05:00
return 1;
}
2016-07-03 18:39:55 +05:00
int CHudFlashlight::MsgFunc_Flashlight( const char *pszName, int iSize, void *pbuf )
2016-06-04 18:24:23 +05:00
{
BEGIN_READ( pbuf, iSize );
m_fOn = READ_BYTE();
int x = READ_BYTE();
m_iBat = x;
2019-10-13 16:49:25 +05:00
m_flBat = ( (float)x ) / 100.0f;
2016-06-04 18:24:23 +05:00
return 1;
}
2016-07-03 18:39:55 +05:00
int CHudFlashlight::Draw( float flTime )
2016-06-04 18:24:23 +05:00
{
static bool show = ( gHUD.m_iHideHUDDisplay & ( HIDEHUD_FLASHLIGHT | HIDEHUD_ALL ) );
if( show != !( gHUD.m_iHideHUDDisplay & ( HIDEHUD_FLASHLIGHT | HIDEHUD_ALL ) ) )
{
show = !( gHUD.m_iHideHUDDisplay & ( HIDEHUD_FLASHLIGHT | HIDEHUD_ALL ) );
if( gMobileEngfuncs )
{
gMobileEngfuncs->pfnTouchHideButtons( "flashlight", !show );
}
}
2016-07-03 18:39:55 +05:00
if( !show )
2016-06-04 18:24:23 +05:00
return 1;
int r, g, b, x, y, a;
wrect_t rc;
if( gEngfuncs.IsSpectateOnly() )
return 1;
#ifdef MOBILE_HACKS
2019-12-01 17:23:00 +05:00
if( g_iModType == MOD_INDUCTION )
{
if( !( gHUD.m_iWeaponBits & ( 1 << ( WEAPON_FLASHLIGHT ) ) ) )
return 1;
}
else
{
if( !( gHUD.m_iWeaponBits & ( 1 << ( WEAPON_SUIT ) ) ) )
return 1;
}
#else // MOBILE_HACKS
if( !( gHUD.m_iWeaponBits & ( 1 << ( WEAPON_SUIT ) ) ) )
2016-06-04 18:24:23 +05:00
return 1;
2019-12-01 17:23:00 +05:00
#endif // MOBILE_HACKS
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
if( m_fOn )
2016-06-04 18:24:23 +05:00
a = 225;
else
a = MIN_ALPHA;
2019-10-13 16:49:25 +05:00
if( m_flBat < 0.20f )
2016-07-03 18:39:55 +05:00
UnpackRGB( r,g,b, RGB_REDISH );
2016-06-04 18:24:23 +05:00
else
2019-12-01 14:32:10 +05:00
#ifdef MOBILE_HACKS
UnpackRGB( r, g, b, g_iHudColor );
#else // MOBILE_HACKS
UnpackRGB( r, g, b, RGB_YELLOWISH );
#endif // MOBILE_HACKS
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
ScaleColors( r, g, b, a );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
y = ( m_prc1->bottom - m_prc2->top ) / 2;
x = ScreenWidth - m_iWidth - m_iWidth / 2 ;
2016-06-04 18:24:23 +05:00
// Draw the flashlight casing
2016-07-03 18:39:55 +05:00
SPR_Set( m_hSprite1, r, g, b );
SPR_DrawAdditive( 0, x, y, m_prc1 );
2016-06-04 18:24:23 +05:00
2016-07-03 18:39:55 +05:00
if( m_fOn )
{
// draw the flashlight beam
x = ScreenWidth - m_iWidth / 2;
2016-06-04 18:24:23 +05:00
SPR_Set( m_hBeam, r, g, b );
SPR_DrawAdditive( 0, x, y, m_prcBeam );
}
// draw the flashlight energy level
2016-07-03 18:39:55 +05:00
x = ScreenWidth - m_iWidth - m_iWidth / 2;
2019-10-13 16:49:25 +05:00
int iOffset = m_iWidth * ( 1.0f - m_flBat );
2016-07-03 18:39:55 +05:00
if( iOffset < m_iWidth )
2016-06-04 18:24:23 +05:00
{
rc = *m_prc2;
rc.left += iOffset;
2016-07-03 18:39:55 +05:00
SPR_Set( m_hSprite2, r, g, b );
SPR_DrawAdditive( 0, x + iOffset, y, &rc );
2016-06-04 18:24:23 +05:00
}
return 1;
}