mirror of
https://github.com/halpz/re3.git
synced 2025-01-25 07:00:59 +00:00
Partial hud
This commit is contained in:
parent
d68ec362dd
commit
e79e8b30e0
|
@ -1237,11 +1237,12 @@ cMusicManager::DisplayRadioStationName()
|
||||||
case RADIO_ESPANTOSO: string = TheText.Get("FEA_FM6"); break;
|
case RADIO_ESPANTOSO: string = TheText.Get("FEA_FM6"); break;
|
||||||
case EMOTION: string = TheText.Get("FEA_FM7"); break;
|
case EMOTION: string = TheText.Get("FEA_FM7"); break;
|
||||||
case WAVE: string = TheText.Get("FEA_FM8"); break;
|
case WAVE: string = TheText.Get("FEA_FM8"); break;
|
||||||
case USERTRACK:
|
case 9: string = TheText.Get("FEA_FM9"); break;
|
||||||
|
case 10:
|
||||||
if (!SampleManager.IsMP3RadioChannelAvailable())
|
if (!SampleManager.IsMP3RadioChannelAvailable())
|
||||||
return;
|
return;
|
||||||
string = TheText.Get("FEA_MP3"); break;
|
string = TheText.Get("FEA_MP3"); break;
|
||||||
default: return;
|
default: string = TheText.Get("FEA_NON"); break;
|
||||||
};
|
};
|
||||||
|
|
||||||
if (pCurrentStation != string) {
|
if (pCurrentStation != string) {
|
||||||
|
@ -1255,21 +1256,22 @@ cMusicManager::DisplayRadioStationName()
|
||||||
|
|
||||||
CFont::SetJustifyOff();
|
CFont::SetJustifyOff();
|
||||||
CFont::SetBackgroundOff();
|
CFont::SetBackgroundOff();
|
||||||
CFont::SetScale(SCREEN_SCALE_X(0.8f), SCREEN_SCALE_Y(1.35f));
|
CFont::SetDropShadowPosition(2);
|
||||||
|
CFont::SetScale(PSP_SCREEN_SCALE_X(0.5f), PSP_SCREEN_SCALE_Y(0.88f));
|
||||||
CFont::SetPropOn();
|
CFont::SetPropOn();
|
||||||
CFont::SetFontStyle(FONT_STANDARD);
|
CFont::SetFontStyle(FONT_BANK);
|
||||||
CFont::SetCentreOn();
|
CFont::SetCentreOn();
|
||||||
CFont::SetCentreSize(SCREEN_STRETCH_X(DEFAULT_SCREEN_WIDTH));
|
CFont::SetCentreSize(PSP_SCREEN_SCALE_X(260.0f));
|
||||||
CFont::SetColor(CRGBA(0, 0, 0, 255));
|
CFont::SetDropColor(CRGBA(0, 0, 0, 255));
|
||||||
CFont::PrintString(SCREEN_WIDTH / 2 + SCREEN_SCALE_X(2.0f), SCREEN_SCALE_Y(22.0f) + SCREEN_SCALE_Y(2.0f), pCurrentStation);
|
|
||||||
|
|
||||||
if (gNumRetunePresses)
|
if (gNumRetunePresses)
|
||||||
CFont::SetColor(CRGBA(102, 133, 143, 255));
|
CFont::SetColor(CRGBA(77, 155, 210, 255));
|
||||||
else
|
else
|
||||||
CFont::SetColor(CRGBA(147, 196, 211, 255));
|
CFont::SetColor(CRGBA(77, 155, 210, 255));
|
||||||
|
|
||||||
CFont::PrintString(SCREEN_WIDTH / 2, SCREEN_SCALE_Y(22.0f), pCurrentStation);
|
CFont::PrintString(SCREEN_WIDTH / 2, PSP_SCREEN_SCALE_Y(7.0f), pCurrentStation);
|
||||||
CFont::DrawFonts();
|
CFont::DrawFonts();
|
||||||
|
CFont::SetCentreSize(SCREEN_STRETCH_X(DEFAULT_SCREEN_WIDTH));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -204,11 +204,11 @@ inline uint32 ldb(uint32 p, uint32 s, uint32 w)
|
||||||
#define PSP_DEFAULT_SCREEN_WIDTH (480)
|
#define PSP_DEFAULT_SCREEN_WIDTH (480)
|
||||||
#define PSP_DEFAULT_SCREEN_HEIGHT (272)
|
#define PSP_DEFAULT_SCREEN_HEIGHT (272)
|
||||||
|
|
||||||
#define PSP_SCALE_TO_PS2_X(a) (a * ((float)DEFAULT_SCREEN_WIDTH / PSP_DEFAULT_SCREEN_WIDTH))
|
#define PSP_SCALE_TO_PS2_X(a) ((float)a * ((float)DEFAULT_SCREEN_WIDTH / (float)PSP_DEFAULT_SCREEN_WIDTH))
|
||||||
#define PSP_SCALE_TO_PS2_Y(a) (a * ((float)DEFAULT_SCREEN_HEIGHT / PSP_DEFAULT_SCREEN_HEIGHT))
|
#define PSP_SCALE_TO_PS2_Y(a) ((float)a * ((float)DEFAULT_SCREEN_HEIGHT / (float)PSP_DEFAULT_SCREEN_HEIGHT))
|
||||||
|
|
||||||
#define PSP_SCREEN_SCALE_X(a) SCREEN_STRETCH_X(PSP_SCALE_TO_PS2_X(a))
|
#define PSP_SCREEN_SCALE_X(a) ((a) * (float) SCREEN_WIDTH / PSP_DEFAULT_SCREEN_WIDTH)
|
||||||
#define PSP_SCREEN_SCALE_Y(a) SCREEN_STRETCH_Y(PSP_SCALE_TO_PS2_Y(a))
|
#define PSP_SCREEN_SCALE_Y(a) ((a) * (float) SCREEN_WIDTH / PSP_DEFAULT_SCREEN_WIDTH)
|
||||||
#define PSP_SCREEN_SCALE_FROM_RIGHT(a) (SCREEN_WIDTH - PSP_SCREEN_SCALE_X(a))
|
#define PSP_SCREEN_SCALE_FROM_RIGHT(a) (SCREEN_WIDTH - PSP_SCREEN_SCALE_X(a))
|
||||||
#define PSP_SCREEN_SCALE_FROM_BOTTOM(a) (SCREEN_HEIGHT - PSP_SCREEN_SCALE_Y(a))
|
#define PSP_SCREEN_SCALE_FROM_BOTTOM(a) (SCREEN_HEIGHT - PSP_SCREEN_SCALE_Y(a))
|
||||||
|
|
||||||
|
|
|
@ -39,7 +39,7 @@
|
||||||
// Game has colors inlined in code.
|
// Game has colors inlined in code.
|
||||||
// For easier modification we collect them here:
|
// For easier modification we collect them here:
|
||||||
CRGBA MONEY_COLOR(0, 207, 133, 255);
|
CRGBA MONEY_COLOR(0, 207, 133, 255);
|
||||||
CRGBA AMMO_COLOR(255, 150, 225, 255);
|
CRGBA AMMO_COLOR(255, 255, 255, 255);
|
||||||
CRGBA HEALTH_COLOR(255, 150, 225, 255);
|
CRGBA HEALTH_COLOR(255, 150, 225, 255);
|
||||||
CRGBA ARMOUR_COLOR(185, 185, 185, 255);
|
CRGBA ARMOUR_COLOR(185, 185, 185, 255);
|
||||||
CRGBA NOTWANTED_COLOR(27, 89, 130, 255);
|
CRGBA NOTWANTED_COLOR(27, 89, 130, 255);
|
||||||
|
@ -130,6 +130,8 @@ CSprite2d CHud::Sprites[NUM_HUD_SPRITES];
|
||||||
|
|
||||||
wchar* CHud::gLastPrintForeverString;
|
wchar* CHud::gLastPrintForeverString;
|
||||||
|
|
||||||
|
uint8 CHud::m_HudAlpha = 209;
|
||||||
|
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -213,6 +215,7 @@ RwTexture *gpLaserSightTex;
|
||||||
RwTexture *gpLaserDotTex;
|
RwTexture *gpLaserDotTex;
|
||||||
RwTexture *gpViewFinderTex;
|
RwTexture *gpViewFinderTex;
|
||||||
|
|
||||||
|
// TODO(LCS): some things were reversed from LCS but not all
|
||||||
void CHud::Draw()
|
void CHud::Draw()
|
||||||
{
|
{
|
||||||
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERNEAREST);
|
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERNEAREST);
|
||||||
|
@ -405,6 +408,8 @@ void CHud::Draw()
|
||||||
DrawMoneyCounter
|
DrawMoneyCounter
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERLINEAR); // TODO(LCS): temp filtering fix for money counter, remove later
|
||||||
|
|
||||||
wchar sPrint[16];
|
wchar sPrint[16];
|
||||||
wchar sPrintIcon[16];
|
wchar sPrintIcon[16];
|
||||||
char sTemp[16];
|
char sTemp[16];
|
||||||
|
@ -417,25 +422,8 @@ void CHud::Draw()
|
||||||
m_LastDisplayScore = CWorld::Players[CWorld::PlayerInFocus].m_nVisibleMoney;
|
m_LastDisplayScore = CWorld::Players[CWorld::PlayerInFocus].m_nVisibleMoney;
|
||||||
}
|
}
|
||||||
if (m_DisplayScoreState != FADED_OUT) {
|
if (m_DisplayScoreState != FADED_OUT) {
|
||||||
sprintf(sTemp, "$%08d", CWorld::Players[CWorld::PlayerInFocus].m_nVisibleMoney);
|
|
||||||
AsciiToUnicode(sTemp, sPrint);
|
|
||||||
|
|
||||||
CFont::SetPropOff();
|
|
||||||
CFont::SetBackgroundOff();
|
|
||||||
CFont::SetScale(SCREEN_SCALE_X(HUD_TEXT_SCALE_X), SCREEN_SCALE_Y(HUD_TEXT_SCALE_Y));
|
|
||||||
CFont::SetCentreOff();
|
|
||||||
CFont::SetRightJustifyOn();
|
|
||||||
CFont::SetRightJustifyWrap(0.0f);
|
|
||||||
CFont::SetBackGroundOnlyTextOff();
|
|
||||||
CFont::SetFontStyle(FONT_HEADING);
|
|
||||||
CFont::SetPropOff();
|
|
||||||
CFont::SetDropShadowPosition(2);
|
|
||||||
CFont::SetDropColor(CRGBA(0, 0, 0, alpha));
|
|
||||||
MONEY_COLOR.a = alpha;
|
|
||||||
CFont::SetColor(MONEY_COLOR);
|
|
||||||
|
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud) {
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f), SCREEN_SCALE_Y(43.0f), sPrint);
|
DrawCash();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -448,46 +436,23 @@ void CHud::Draw()
|
||||||
alpha = CHud::DrawFadeState(HUD_WEAPON_FADING, 1);
|
alpha = CHud::DrawFadeState(HUD_WEAPON_FADING, 1);
|
||||||
m_LastWeapon = playerPed->GetWeapon()->m_eWeaponType;
|
m_LastWeapon = playerPed->GetWeapon()->m_eWeaponType;
|
||||||
}
|
}
|
||||||
|
alpha = Min(alpha, m_HudAlpha);
|
||||||
if (m_WeaponState != FADED_OUT) {
|
if (m_WeaponState != FADED_OUT) {
|
||||||
CWeapon *weapon = playerPed->GetWeapon();
|
CWeapon *weapon = playerPed->GetWeapon();
|
||||||
int32 AmmoAmount = CWeaponInfo::GetWeaponInfo((eWeaponType)WeaponType)->m_nAmountofAmmunition;
|
|
||||||
int32 AmmoInClip = weapon->m_nAmmoInClip;
|
|
||||||
int32 TotalAmmo = weapon->m_nAmmoTotal;
|
|
||||||
int32 Ammo, Clip;
|
|
||||||
|
|
||||||
if (AmmoAmount <= 1 || AmmoAmount >= 1000)
|
|
||||||
sprintf(sTemp, "%d", TotalAmmo);
|
|
||||||
else {
|
|
||||||
if (WeaponType == WEAPONTYPE_FLAMETHROWER) {
|
|
||||||
Clip = AmmoInClip / 10;
|
|
||||||
|
|
||||||
Ammo = Min((TotalAmmo - AmmoInClip) / 10, 9999);
|
|
||||||
} else {
|
|
||||||
Clip = AmmoInClip;
|
|
||||||
|
|
||||||
Ammo = Min(TotalAmmo - AmmoInClip, 9999);
|
|
||||||
}
|
|
||||||
|
|
||||||
sprintf(sTemp, "%d-%d", Ammo, Clip);
|
|
||||||
}
|
|
||||||
|
|
||||||
AsciiToUnicode(sTemp, sPrint);
|
|
||||||
CWeaponInfo *weaponInfo = CWeaponInfo::GetWeaponInfo((eWeaponType)WeaponType);
|
CWeaponInfo *weaponInfo = CWeaponInfo::GetWeaponInfo((eWeaponType)WeaponType);
|
||||||
/*
|
/*
|
||||||
DrawWeaponIcon
|
DrawWeaponIcon
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud) {
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
|
float right = FrontEndMenuManager.m_PrefsUseWideScreen ? 468.6f : 470.0f;
|
||||||
|
float left = right - (FrontEndMenuManager.m_PrefsUseWideScreen ? 48.6f : 54.0f);
|
||||||
if (weaponInfo->m_nModelId <= 0) {
|
if (weaponInfo->m_nModelId <= 0) {
|
||||||
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERLINEAR);
|
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERLINEAR);
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud)
|
if (FrontEndMenuManager.m_PrefsShowHud)
|
||||||
Sprites[WeaponType].Draw(
|
Sprites[WeaponType].Draw(
|
||||||
CRect(SCREEN_SCALE_FROM_RIGHT(99.0f), SCREEN_SCALE_Y(27.0f), SCREEN_SCALE_FROM_RIGHT(35.0f), SCREEN_SCALE_Y(91.0f)),
|
CRect(PSP_SCREEN_SCALE_X(left), PSP_SCREEN_SCALE_Y(16.0f), PSP_SCREEN_SCALE_X(right), PSP_SCREEN_SCALE_Y(60.0f)),
|
||||||
CRGBA(255, 255, 255, alpha),
|
CRGBA(255, 255, 255, alpha));
|
||||||
0.015f, 0.015f,
|
|
||||||
1.0f, 0.0f,
|
|
||||||
0.015f, 1.0f,
|
|
||||||
1.0f, 1.0f);
|
|
||||||
} else {
|
} else {
|
||||||
CBaseModelInfo *weaponModel = CModelInfo::GetModelInfo(weaponInfo->m_nModelId);
|
CBaseModelInfo *weaponModel = CModelInfo::GetModelInfo(weaponInfo->m_nModelId);
|
||||||
RwTexDictionary *weaponTxd = CTxdStore::GetSlot(weaponModel->GetTxdSlot())->texDict;
|
RwTexDictionary *weaponTxd = CTxdStore::GetSlot(weaponModel->GetTxdSlot())->texDict;
|
||||||
|
@ -507,12 +472,8 @@ void CHud::Draw()
|
||||||
static CSprite2d sprite;
|
static CSprite2d sprite;
|
||||||
sprite.m_pTexture = weaponIcon;
|
sprite.m_pTexture = weaponIcon;
|
||||||
sprite.Draw(
|
sprite.Draw(
|
||||||
CRect(SCREEN_SCALE_FROM_RIGHT(99.0f), SCREEN_SCALE_Y(27.0f), SCREEN_SCALE_FROM_RIGHT(35.0f), SCREEN_SCALE_Y(91.0f)),
|
CRect(PSP_SCREEN_SCALE_X(left), PSP_SCREEN_SCALE_Y(16.0f), PSP_SCREEN_SCALE_X(right), PSP_SCREEN_SCALE_Y(60.0f)),
|
||||||
CRGBA(255, 255, 255, alpha),
|
CRGBA(255, 255, 255, alpha));
|
||||||
0.015f, 0.015f,
|
|
||||||
1.0f, 0.0f,
|
|
||||||
0.015f, 1.0f,
|
|
||||||
1.0f, 1.0f);
|
|
||||||
sprite.m_pTexture = nil;
|
sprite.m_pTexture = nil;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -520,7 +481,7 @@ void CHud::Draw()
|
||||||
}
|
}
|
||||||
|
|
||||||
CFont::SetBackgroundOff();
|
CFont::SetBackgroundOff();
|
||||||
CFont::SetScale(SCREEN_SCALE_X(0.5f), SCREEN_SCALE_Y(0.8f));
|
CFont::SetScale(PSP_SCREEN_SCALE_X(FrontEndMenuManager.m_PrefsUseWideScreen ? 0.18f : 0.2f), PSP_SCREEN_SCALE_Y(0.44f));
|
||||||
CFont::SetJustifyOff();
|
CFont::SetJustifyOff();
|
||||||
CFont::SetCentreOn();
|
CFont::SetCentreOn();
|
||||||
CFont::SetCentreSize(SCREEN_STRETCH_X(DEFAULT_SCREEN_WIDTH));
|
CFont::SetCentreSize(SCREEN_STRETCH_X(DEFAULT_SCREEN_WIDTH));
|
||||||
|
@ -528,13 +489,65 @@ void CHud::Draw()
|
||||||
CFont::SetDropShadowPosition(0);
|
CFont::SetDropShadowPosition(0);
|
||||||
CFont::SetFontStyle(FONT_STANDARD);
|
CFont::SetFontStyle(FONT_STANDARD);
|
||||||
|
|
||||||
|
int32 AmmoAmount = CWeaponInfo::GetWeaponInfo((eWeaponType)WeaponType)->m_nAmountofAmmunition;
|
||||||
|
int32 AmmoInClip = weapon->m_nAmmoInClip;
|
||||||
|
int32 TotalAmmo = weapon->m_nAmmoTotal;
|
||||||
|
int32 Ammo, Clip;
|
||||||
|
|
||||||
if (Min(9999, TotalAmmo - AmmoInClip) != 9999 && !CDarkel::FrenzyOnGoing() && weaponInfo->m_nWeaponSlot > 1 && weapon->m_eWeaponType != WEAPONTYPE_DETONATOR) {
|
if (Min(9999, TotalAmmo - AmmoInClip) != 9999 && !CDarkel::FrenzyOnGoing() && weaponInfo->m_nWeaponSlot > 1 && weapon->m_eWeaponType != WEAPONTYPE_DETONATOR) {
|
||||||
CFont::SetDropShadowPosition(2);
|
CFont::SetDropShadowPosition(2);
|
||||||
CFont::SetDropColor(CRGBA(0, 0, 0, alpha));
|
CFont::SetDropColor(CRGBA(0, 0, 0, alpha));
|
||||||
AMMO_COLOR.a = alpha;
|
AMMO_COLOR.a = alpha;
|
||||||
CFont::SetColor(AMMO_COLOR);
|
CFont::SetColor(AMMO_COLOR);
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud)
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(66.0f), SCREEN_SCALE_Y(90.0f), sPrint);
|
|
||||||
|
|
||||||
|
if (AmmoAmount <= 1 || AmmoAmount >= 1000)
|
||||||
|
{
|
||||||
|
sprintf(sTemp, "%d", TotalAmmo);
|
||||||
|
AsciiToUnicode(sTemp, sPrint);
|
||||||
|
float pos = 435.0f;
|
||||||
|
#ifdef FIX_BUGS
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
pos = 438.0f;
|
||||||
|
#endif
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_FROM_RIGHT(PSP_DEFAULT_SCREEN_WIDTH - pos), PSP_SCREEN_SCALE_Y(42.0f), sPrint);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
if (WeaponType == WEAPONTYPE_FLAMETHROWER) {
|
||||||
|
Clip = AmmoInClip / 10;
|
||||||
|
|
||||||
|
Ammo = Min((TotalAmmo - AmmoInClip) / 10, 9999);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Clip = AmmoInClip;
|
||||||
|
|
||||||
|
Ammo = Min(TotalAmmo - AmmoInClip, 9999);
|
||||||
|
}
|
||||||
|
|
||||||
|
char sMinus[10];
|
||||||
|
char sAmmo[20];
|
||||||
|
char sClip[20];
|
||||||
|
|
||||||
|
sprintf(sMinus, "-");
|
||||||
|
sprintf(sAmmo, "%d", Ammo);
|
||||||
|
sprintf(sClip, "%d", Clip);
|
||||||
|
|
||||||
|
CFont::SetCentreOff();
|
||||||
|
CFont::SetRightJustifyOn();
|
||||||
|
AsciiToUnicode(sAmmo, sPrint);
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_FROM_RIGHT(PSP_DEFAULT_SCREEN_WIDTH - (FrontEndMenuManager.m_PrefsUseWideScreen ? 438.0f : 435.0f)), PSP_SCREEN_SCALE_Y(42.0f), sPrint);
|
||||||
|
|
||||||
|
CFont::SetRightJustifyOff();
|
||||||
|
AsciiToUnicode(sMinus, sPrint);
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_FROM_RIGHT(PSP_DEFAULT_SCREEN_WIDTH - (FrontEndMenuManager.m_PrefsUseWideScreen ? 439.0f : 436.0f)), PSP_SCREEN_SCALE_Y(42.0f), sPrint);
|
||||||
|
|
||||||
|
AsciiToUnicode(sClip, sPrint);
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_FROM_RIGHT(PSP_DEFAULT_SCREEN_WIDTH - (FrontEndMenuManager.m_PrefsUseWideScreen ? 441.0f : 439.0f)), PSP_SCREEN_SCALE_Y(42.0f), sPrint);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
CFont::SetDropShadowPosition(0);
|
CFont::SetDropShadowPosition(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -568,23 +581,8 @@ void CHud::Draw()
|
||||||
&& CTimer::GetFrameCounter() & 8) {
|
&& CTimer::GetFrameCounter() & 8) {
|
||||||
if (playerPed->m_fHealth >= 10
|
if (playerPed->m_fHealth >= 10
|
||||||
|| playerPed->m_fHealth < 10 && CTimer::GetFrameCounter() & 8) {
|
|| playerPed->m_fHealth < 10 && CTimer::GetFrameCounter() & 8) {
|
||||||
|
|
||||||
AsciiToUnicode("{", sPrintIcon);
|
|
||||||
#ifdef FIX_BUGS
|
|
||||||
sprintf(sTemp, "%03d", int32(playerPed->m_fHealth + 0.5f));
|
|
||||||
#else
|
|
||||||
sprintf(sTemp, "%03d", (int32)playerPed->m_fHealth);
|
|
||||||
#endif
|
|
||||||
AsciiToUnicode(sTemp, sPrint);
|
|
||||||
|
|
||||||
CFont::SetColor(HEALTH_COLOR);
|
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud) {
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f), SCREEN_SCALE_Y(65.0f), sPrint);
|
DrawHealthBar(playerPed->m_fHealth);
|
||||||
|
|
||||||
if (!CWorld::Players[CWorld::PlayerInFocus].m_nTimeLastHealthLoss || CTimer::GetTimeInMilliseconds() > CWorld::Players[CWorld::PlayerInFocus].m_nTimeLastHealthLoss + 2000 || CTimer::GetFrameCounter() & 4) {
|
|
||||||
// CFont::SetColor(HEALTH_COLOR);
|
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f + 54.0f), SCREEN_SCALE_Y(65.0f), sPrintIcon);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -605,13 +603,7 @@ void CHud::Draw()
|
||||||
|
|
||||||
CFont::SetColor(ARMOUR_COLOR);
|
CFont::SetColor(ARMOUR_COLOR);
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud) {
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
|
DrawArmourBar(playerPed->m_fArmour);
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(182.0f), SCREEN_SCALE_Y(65.0f), sPrint);
|
|
||||||
|
|
||||||
if (!CWorld::Players[CWorld::PlayerInFocus].m_nTimeLastArmourLoss || CTimer::GetTimeInMilliseconds() > CWorld::Players[CWorld::PlayerInFocus].m_nTimeLastArmourLoss + 2000 || CTimer::GetFrameCounter() & 4) {
|
|
||||||
// CFont::SetColor(ARMOUR_COLOR);
|
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(182.0f + 52.0f), SCREEN_SCALE_Y(65.0f), sPrintIcon);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -628,36 +620,23 @@ void CHud::Draw()
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_WantedState != FADED_OUT) {
|
if (m_WantedState != FADED_OUT) {
|
||||||
CFont::SetBackgroundOff();
|
char wantedStar[] = "\x16";
|
||||||
CFont::SetScale(SCREEN_SCALE_X(HUD_TEXT_SCALE_X), SCREEN_SCALE_Y(HUD_TEXT_SCALE_Y));
|
float starX = 441.0f;
|
||||||
CFont::SetJustifyOff();
|
|
||||||
CFont::SetCentreOff();
|
|
||||||
CFont::SetRightJustifyOn();
|
|
||||||
CFont::SetPropOn();
|
|
||||||
CFont::SetFontStyle(FONT_STANDARD);
|
|
||||||
|
|
||||||
AsciiToUnicode(">", sPrintIcon);
|
|
||||||
|
|
||||||
for (int i = 0; i < 6; i++) {
|
for (int i = 0; i < 6; i++) {
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud) {
|
if (FrontEndMenuManager.m_PrefsShowHud) {
|
||||||
if (playerPed->m_pWanted->GetWantedLevel() > i
|
if (playerPed->m_pWanted->GetWantedLevel() > i
|
||||||
&& (CTimer::GetTimeInMilliseconds() > playerPed->m_pWanted->m_nLastWantedLevelChange
|
&& (CTimer::GetTimeInMilliseconds() > playerPed->m_pWanted->m_nLastWantedLevelChange
|
||||||
+ 2000 || CTimer::GetFrameCounter() & 4)) {
|
+ 2000 || CTimer::GetFrameCounter() & 4)) {
|
||||||
|
|
||||||
WANTED_COLOR.a = alpha;
|
DrawTimeAndCashNumbers(wantedStar, starX, 63.0f, false);
|
||||||
CFont::SetColor(WANTED_COLOR);
|
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f + 23.0f * i), SCREEN_SCALE_Y(87.0f), sPrintIcon);
|
|
||||||
|
|
||||||
} else if (playerPed->m_pWanted->m_nMinWantedLevel > i && CTimer::GetFrameCounter() & 4) {
|
} else if (playerPed->m_pWanted->m_nMinWantedLevel > i && CTimer::GetFrameCounter() & 4) {
|
||||||
WANTED_COLOR_FLASH.a = alpha;
|
DrawTimeAndCashNumbers(wantedStar, starX, 63.0f, true);
|
||||||
CFont::SetColor(WANTED_COLOR_FLASH);
|
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f + 23.0f * i), SCREEN_SCALE_Y(87.0f), sPrintIcon);
|
|
||||||
|
|
||||||
} else if (playerPed->m_pWanted->GetWantedLevel() <= i) {
|
|
||||||
NOTWANTED_COLOR.a = alpha;
|
|
||||||
CFont::SetColor(NOTWANTED_COLOR);
|
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(110.0f + 23.0f * i), SCREEN_SCALE_Y(87.0f), sPrintIcon);
|
|
||||||
}
|
}
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
starX -= 11.0f;
|
||||||
|
else
|
||||||
|
starX -= 13.5f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -919,24 +898,8 @@ void CHud::Draw()
|
||||||
DrawClock
|
DrawClock
|
||||||
*/
|
*/
|
||||||
if (m_ClockState) {
|
if (m_ClockState) {
|
||||||
CFont::SetJustifyOff();
|
|
||||||
CFont::SetCentreOff();
|
|
||||||
CFont::SetBackgroundOff();
|
|
||||||
CFont::SetScale(SCREEN_SCALE_X(HUD_TEXT_SCALE_X), SCREEN_SCALE_Y(HUD_TEXT_SCALE_Y));
|
|
||||||
CFont::SetBackGroundOnlyTextOff();
|
|
||||||
CFont::SetPropOff();
|
|
||||||
CFont::SetFontStyle(FONT_HEADING);
|
|
||||||
CFont::SetRightJustifyOn();
|
|
||||||
CFont::SetRightJustifyWrap(0.0f);
|
|
||||||
CFont::SetDropShadowPosition(2);
|
|
||||||
CFont::SetDropColor(CRGBA(0, 0, 0, 255));
|
|
||||||
|
|
||||||
sprintf(sTemp, "%02d:%02d", CClock::GetHours(), CClock::GetMinutes());
|
|
||||||
AsciiToUnicode(sTemp, sPrint);
|
|
||||||
|
|
||||||
CFont::SetColor(CLOCK_COLOR);
|
|
||||||
if (FrontEndMenuManager.m_PrefsShowHud)
|
if (FrontEndMenuManager.m_PrefsShowHud)
|
||||||
CFont::PrintString(SCREEN_SCALE_FROM_RIGHT(111.0f), SCREEN_SCALE_Y(22.0f), sPrint);
|
DrawTime();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1188,7 +1151,7 @@ void CHud::Draw()
|
||||||
if (FrontEndMenuManager.m_PrefsShowSubtitles || !CCutsceneMgr::IsRunning()) {
|
if (FrontEndMenuManager.m_PrefsShowSubtitles || !CCutsceneMgr::IsRunning()) {
|
||||||
#ifdef CUTSCENE_BORDERS_SWITCH
|
#ifdef CUTSCENE_BORDERS_SWITCH
|
||||||
if (!FrontEndMenuManager.m_PrefsCutsceneBorders)
|
if (!FrontEndMenuManager.m_PrefsCutsceneBorders)
|
||||||
CFont::SetDropShadowPosition(2);
|
CFont::SetDropShadowPosition(0);
|
||||||
#endif
|
#endif
|
||||||
CFont::SetCentreSize(SCREEN_WIDTH - SCREEN_SCALE_X(60.0f));
|
CFont::SetCentreSize(SCREEN_WIDTH - SCREEN_SCALE_X(60.0f));
|
||||||
CFont::SetScale(SCREEN_SCALE_X(0.58f), SCREEN_SCALE_Y(1.2f));
|
CFont::SetScale(SCREEN_SCALE_X(0.58f), SCREEN_SCALE_Y(1.2f));
|
||||||
|
@ -1200,7 +1163,7 @@ void CHud::Draw()
|
||||||
|
|
||||||
onceItWasWidescreen = false;
|
onceItWasWidescreen = false;
|
||||||
CFont::DrawFonts();
|
CFont::DrawFonts();
|
||||||
CFont::SetDropShadowPosition(2);
|
CFont::SetDropShadowPosition(0);
|
||||||
CFont::SetDropColor(CRGBA(0, 0, 0, 255));
|
CFont::SetDropColor(CRGBA(0, 0, 0, 255));
|
||||||
CFont::SetScale(SCREEN_SCALE_X(0.58f), SCREEN_SCALE_Y(1.22f));
|
CFont::SetScale(SCREEN_SCALE_X(0.58f), SCREEN_SCALE_Y(1.22f));
|
||||||
|
|
||||||
|
@ -1426,6 +1389,221 @@ void CHud::Draw()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int HealthFlashTimer = 50;
|
||||||
|
|
||||||
|
void
|
||||||
|
CHud::DrawHealthBar(int16 value)
|
||||||
|
{
|
||||||
|
if (m_ItemToFlash == ITEM_HEALTH) {
|
||||||
|
if (CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_fHealth > 10.0f) {
|
||||||
|
if (HealthFlashTimer-- == 0) {
|
||||||
|
m_ItemToFlash = -1;
|
||||||
|
HealthFlashTimer = 50;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
float fHealth = value;
|
||||||
|
float fMaxHealth = CWorld::Players[CWorld::PlayerInFocus].m_nMaxHealth;
|
||||||
|
fHealth = clamp(fHealth, 0.0f, fMaxHealth);
|
||||||
|
float fWidth = (fHealth / fMaxHealth) * 40.0f + 16.0f + 4.0f;
|
||||||
|
float u = fWidth / 64.0f;
|
||||||
|
if (value == 0) {
|
||||||
|
fWidth = 0.0f;
|
||||||
|
u = 0.0f;
|
||||||
|
} else if (value == fMaxHealth) {
|
||||||
|
fWidth = 64.0f;
|
||||||
|
u = 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
fWidth *= 0.68f;
|
||||||
|
else
|
||||||
|
fWidth *= 0.85f;
|
||||||
|
|
||||||
|
float fX1 = FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f;
|
||||||
|
float fX2 = fWidth + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect1(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(40.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(50.0f));
|
||||||
|
CRGBA color1(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_INSIDE2].Draw(rect1, color1, 0.0f, 0.0f, u, 0.0f, 0.0f, 1.0f, u, 1.0f);
|
||||||
|
|
||||||
|
fX1 = fWidth + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
fX2 = (FrontEndMenuManager.m_PrefsUseWideScreen ? 43.52f : 54.4f) + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect2(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(40.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(50.0f));
|
||||||
|
CRGBA color2(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_INSIDE2DARK].Draw(rect2, color2, u, 0.0f, 1.0f, 0.0f, u, 1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
fX1 = FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f;
|
||||||
|
fX2 = (FrontEndMenuManager.m_PrefsUseWideScreen ? 43.52f : 54.4f) + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect3(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(40.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(50.0f));
|
||||||
|
CRGBA color3(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_OUTLINE].Draw(rect3, color3, 0.01f, 0.0f, 1.0f, 0.0f, 0.01f, 1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
if (fMaxHealth > 100.0f)
|
||||||
|
{
|
||||||
|
CFont::SetFontStyle(FONT_STANDARD);
|
||||||
|
CFont::SetDropShadowPosition(0);
|
||||||
|
CFont::SetDropColor(CRGBA(0, 0, 0, m_HudAlpha));
|
||||||
|
CFont::SetColor(CRGBA(255, 255, 255, m_HudAlpha));
|
||||||
|
CFont::SetCentreOn();
|
||||||
|
if (fMaxHealth > 125.0f)
|
||||||
|
CFont::SetScale(FrontEndMenuManager.StretchX(PSP_SCALE_TO_PS2_X(FrontEndMenuManager.m_PrefsUseWideScreen ? 0.3375f : 0.45f)), FrontEndMenuManager.StretchY(PSP_SCALE_TO_PS2_Y(0.75f)));
|
||||||
|
else
|
||||||
|
CFont::SetScale(FrontEndMenuManager.StretchX(PSP_SCALE_TO_PS2_X(FrontEndMenuManager.m_PrefsUseWideScreen ? 0.2625f : 0.35f)), FrontEndMenuManager.StretchY(PSP_SCALE_TO_PS2_Y(0.6f)));
|
||||||
|
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
fX1 = 375.0f + 12.0f;
|
||||||
|
else
|
||||||
|
fX1 = 360.0f + 15.0f;
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(36.0f), (wchar*)L"+");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int ArmourFlashTimer = 50;
|
||||||
|
|
||||||
|
void
|
||||||
|
CHud::DrawArmourBar(int16 value)
|
||||||
|
{
|
||||||
|
if (m_ItemToFlash == ITEM_ARMOUR) {
|
||||||
|
if (CWorld::Players[CWorld::PlayerInFocus].m_pPed->m_fArmour > 10.0f) {
|
||||||
|
if (ArmourFlashTimer-- == 0) {
|
||||||
|
m_ItemToFlash = -1;
|
||||||
|
ArmourFlashTimer = 50;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
float fArmour = value;
|
||||||
|
float fMaxArmour = CWorld::Players[CWorld::PlayerInFocus].m_nMaxArmour;
|
||||||
|
fArmour = clamp(fArmour, 0.0f, fMaxArmour);
|
||||||
|
float fWidth = (fArmour / fMaxArmour) * 40.0f + 16.0f + 4.0f;
|
||||||
|
float u = fWidth / 64.0f;
|
||||||
|
if (value == 0) {
|
||||||
|
fWidth = 0.0f;
|
||||||
|
u = 0.0f;
|
||||||
|
} else if (value == fMaxArmour) {
|
||||||
|
fWidth = 64.0f;
|
||||||
|
u = 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
fWidth *= 0.68f;
|
||||||
|
else
|
||||||
|
fWidth *= 0.85f;
|
||||||
|
|
||||||
|
float fX1 = FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f;
|
||||||
|
float fX2 = fWidth + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect1(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(28.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(38.0f));
|
||||||
|
CRGBA color1(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_INSIDE1].Draw(rect1, color1, 0.0f, 0.0f, u, 0.0f, 0.0f, 1.0f, u, 1.0f);
|
||||||
|
|
||||||
|
fX1 = fWidth + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
fX2 = (FrontEndMenuManager.m_PrefsUseWideScreen ? 43.52f : 54.4f) + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect2(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(28.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(38.0f));
|
||||||
|
CRGBA color2(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_INSIDE1DARK].Draw(rect2, color2, u, 0.0f, 1.0f, 0.0f, u, 1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
fX1 = FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f;
|
||||||
|
fX2 = (FrontEndMenuManager.m_PrefsUseWideScreen ? 43.52f : 54.4f) + (FrontEndMenuManager.m_PrefsUseWideScreen ? 375.0f : 360.0f);
|
||||||
|
CRect rect3(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(28.0f), PSP_SCREEN_SCALE_X(fX2), PSP_SCREEN_SCALE_Y(38.0f));
|
||||||
|
CRGBA color3(255, 255, 255, m_HudAlpha);
|
||||||
|
Sprites[HUD_BAR_OUTLINE].Draw(rect3, color3, 0.01f, 0.0f, 1.0f, 0.0f, 0.01f, 1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
if (fMaxArmour > 100.0f) {
|
||||||
|
CFont::SetFontStyle(FONT_STANDARD);
|
||||||
|
CFont::SetDropShadowPosition(0);
|
||||||
|
CFont::SetDropColor(CRGBA(0, 0, 0, m_HudAlpha));
|
||||||
|
CFont::SetColor(CRGBA(255, 255, 255, m_HudAlpha));
|
||||||
|
CFont::SetCentreOn();
|
||||||
|
if (fMaxArmour > 125.0f)
|
||||||
|
CFont::SetScale(FrontEndMenuManager.StretchX(PSP_SCALE_TO_PS2_X(FrontEndMenuManager.m_PrefsUseWideScreen ? 0.3375f : 0.45f)), FrontEndMenuManager.StretchY(PSP_SCALE_TO_PS2_Y(0.75f)));
|
||||||
|
else
|
||||||
|
CFont::SetScale(FrontEndMenuManager.StretchX(PSP_SCALE_TO_PS2_X(FrontEndMenuManager.m_PrefsUseWideScreen ? 0.2625f : 0.35f)), FrontEndMenuManager.StretchY(PSP_SCALE_TO_PS2_Y(0.6f)));
|
||||||
|
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
fX1 = 375.0f + 12.0f;
|
||||||
|
else
|
||||||
|
fX1 = 360.0f + 15.0f;
|
||||||
|
CFont::PrintString(PSP_SCREEN_SCALE_X(fX1), PSP_SCREEN_SCALE_Y(24.0f), (wchar*)L"+");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
CHud::DrawTimeAndCashNumbers(char *str, float x, float y, bool secondSet)
|
||||||
|
{
|
||||||
|
CRGBA color(255, 255, 255, m_HudAlpha);
|
||||||
|
|
||||||
|
float width = 11.0f;
|
||||||
|
if (FrontEndMenuManager.m_PrefsUseWideScreen)
|
||||||
|
width = 9.0f;
|
||||||
|
|
||||||
|
float height = 10.0f;
|
||||||
|
while (*str) {
|
||||||
|
uint8 c = *str;
|
||||||
|
if (c >= '0' && c <= ':')
|
||||||
|
{
|
||||||
|
if (secondSet) c -= '%';
|
||||||
|
else c -= '0';
|
||||||
|
} else {
|
||||||
|
if (c == 22) {
|
||||||
|
if (secondSet)
|
||||||
|
color = CRGBA(62, 141, 188, m_HudAlpha);
|
||||||
|
else
|
||||||
|
color = CRGBA(192, 155, 54, m_HudAlpha);
|
||||||
|
} else if (!secondSet)
|
||||||
|
c = 10;
|
||||||
|
else
|
||||||
|
c = 21;
|
||||||
|
}
|
||||||
|
|
||||||
|
int row = c / 8;
|
||||||
|
int col = c - row * 8;
|
||||||
|
float width2 = width;
|
||||||
|
if (c == 22)
|
||||||
|
width2 += 3.0f;
|
||||||
|
CRect rect(PSP_SCREEN_SCALE_X(x), PSP_SCREEN_SCALE_Y(y), PSP_SCREEN_SCALE_X(x+ width2), PSP_SCREEN_SCALE_Y(y) + PSP_SCREEN_SCALE_Y(height));
|
||||||
|
|
||||||
|
float u = col * 0.125f;
|
||||||
|
// TODO(LCS): some odd calculation with u going on in here if it's < 0, it might be fabs, but maybe not
|
||||||
|
|
||||||
|
float v = row * 0.265625f;
|
||||||
|
// TODO(LCS): same odd calculation with v as above
|
||||||
|
|
||||||
|
str++;
|
||||||
|
Sprites[HUD_HUDNUMBERS].Draw(rect, color, u, v, u + 0.125f, v, u, v + 0.265625f, u + 0.125f, v + 0.265625f);
|
||||||
|
|
||||||
|
x += (width - 2.0f);
|
||||||
|
if (c == 10)
|
||||||
|
x -= 4.0f;
|
||||||
|
|
||||||
|
#ifdef GTA_PSP
|
||||||
|
x = Ceil(PSP_SCREEN_SCALE_X(x)) * ((float)PSP_DEFAULT_SCREEN_WIDTH / (float)SCREEN_WIDTH);
|
||||||
|
#else
|
||||||
|
// BUG: actually above wasn't PSP only but on higher resolutions things don't look like they were meant to, so we stick with PS2 version here
|
||||||
|
x = Ceil(PSP_SCALE_TO_PS2_X(x)) * ((float)PSP_DEFAULT_SCREEN_WIDTH / (float)DEFAULT_SCREEN_WIDTH);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
CHud::DrawCash()
|
||||||
|
{
|
||||||
|
char str[200];
|
||||||
|
sprintf(str, "$%08d", CWorld::Players[CWorld::PlayerInFocus].m_nMoney);
|
||||||
|
DrawTimeAndCashNumbers(str, FrontEndMenuManager.m_PrefsUseWideScreen ? 386.0f : 373.0f, 53.0f, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
CHud::DrawTime()
|
||||||
|
{
|
||||||
|
// TODO(LCS): a lot more code should be here
|
||||||
|
|
||||||
|
char str[24];
|
||||||
|
sprintf(str, "%02d:%02d", CClock::ms_nGameClockHours, CClock::ms_nGameClockMinutes);
|
||||||
|
DrawTimeAndCashNumbers(str, FrontEndMenuManager.m_PrefsUseWideScreen ? 386.0f : 373.0f, 17.0f, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void CHud::DrawAfterFade()
|
void CHud::DrawAfterFade()
|
||||||
{
|
{
|
||||||
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERNEAREST);
|
RwRenderStateSet(rwRENDERSTATETEXTUREFILTER, (void*)rwFILTERNEAREST);
|
||||||
|
|
|
@ -38,7 +38,13 @@ enum eSprites
|
||||||
HUD_FIST,
|
HUD_FIST,
|
||||||
HUD_SITEROCKET = 41,
|
HUD_SITEROCKET = 41,
|
||||||
HUD_RADARDISC = 50,
|
HUD_RADARDISC = 50,
|
||||||
HUD_SITESNIPER = 63,
|
HUD_BAR_INSIDE1DARK = 57,
|
||||||
|
HUD_BAR_INSIDE2DARK,
|
||||||
|
HUD_HUDNUMBERS,
|
||||||
|
HUD_BAR_INSIDE1,
|
||||||
|
HUD_BAR_INSIDE2,
|
||||||
|
HUD_BAR_OUTLINE,
|
||||||
|
HUD_SITESNIPER,
|
||||||
HUD_SITEM16,
|
HUD_SITEM16,
|
||||||
HUD_SITELASER,
|
HUD_SITELASER,
|
||||||
HUD_LASERDOT,
|
HUD_LASERDOT,
|
||||||
|
@ -119,6 +125,7 @@ public:
|
||||||
static uint32 m_LastTimeEnergyLost;
|
static uint32 m_LastTimeEnergyLost;
|
||||||
|
|
||||||
static wchar* gLastPrintForeverString;
|
static wchar* gLastPrintForeverString;
|
||||||
|
static uint8 m_HudAlpha;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static void Draw();
|
static void Draw();
|
||||||
|
@ -139,4 +146,9 @@ public:
|
||||||
static void Shutdown();
|
static void Shutdown();
|
||||||
static float DrawFadeState(DRAW_FADE_STATE, int);
|
static float DrawFadeState(DRAW_FADE_STATE, int);
|
||||||
static void ResetWastedText(void);
|
static void ResetWastedText(void);
|
||||||
|
static void DrawHealthBar(int16 value);
|
||||||
|
static void DrawArmourBar(int16 value);
|
||||||
|
static void DrawTimeAndCashNumbers(char *str, float x, float y, bool secondSet);
|
||||||
|
static void DrawCash();
|
||||||
|
static void DrawTime();
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue