2020-01-07 18:59:03 +02:00
|
|
|
#include "common.h"
|
2020-04-17 16:31:11 +03:00
|
|
|
|
2020-01-07 18:59:03 +02:00
|
|
|
|
|
|
|
#include "DMAudio.h"
|
|
|
|
#include "Hud.h"
|
|
|
|
#include "Replay.h"
|
|
|
|
#include "Timer.h"
|
|
|
|
#include "Script.h"
|
|
|
|
#include "OnscreenTimer.h"
|
|
|
|
|
|
|
|
void COnscreenTimer::Init() {
|
|
|
|
m_bDisabled = false;
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
m_sEntries[i].m_nTimerOffset = 0;
|
|
|
|
m_sEntries[i].m_nCounterOffset = 0;
|
|
|
|
|
|
|
|
for(uint32 j = 0; j < 10; j++) {
|
|
|
|
m_sEntries[i].m_aTimerText[j] = 0;
|
|
|
|
m_sEntries[i].m_aCounterText[j] = 0;
|
|
|
|
}
|
|
|
|
|
2020-02-01 18:40:54 +02:00
|
|
|
m_sEntries[i].m_nType = COUNTER_DISPLAY_NUMBER;
|
2020-05-20 20:40:04 +03:00
|
|
|
m_sEntries[i].m_bTimerProcessed = false;
|
|
|
|
m_sEntries[i].m_bCounterProcessed = false;
|
|
|
|
m_sEntries[i].m_bTimerGoingDown = true;
|
2020-01-07 18:59:03 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimer::Process() {
|
|
|
|
if(!CReplay::IsPlayingBack() && !m_bDisabled) {
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
m_sEntries[i].Process();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimer::ProcessForDisplay() {
|
|
|
|
if(CHud::m_Wants_To_Draw_Hud) {
|
|
|
|
m_bProcessed = false;
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
if(m_sEntries[i].ProcessForDisplay()) {
|
|
|
|
m_bProcessed = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimer::ClearCounter(uint32 offset) {
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
if(offset == m_sEntries[i].m_nCounterOffset) {
|
|
|
|
m_sEntries[i].m_nCounterOffset = 0;
|
|
|
|
m_sEntries[i].m_aCounterText[0] = 0;
|
2020-02-01 18:40:54 +02:00
|
|
|
m_sEntries[i].m_nType = COUNTER_DISPLAY_NUMBER;
|
2020-01-07 18:59:03 +02:00
|
|
|
m_sEntries[i].m_bCounterProcessed = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimer::ClearClock(uint32 offset) {
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
if(offset == m_sEntries[i].m_nTimerOffset) {
|
|
|
|
m_sEntries[i].m_nTimerOffset = 0;
|
|
|
|
m_sEntries[i].m_aTimerText[0] = 0;
|
|
|
|
m_sEntries[i].m_bTimerProcessed = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-20 20:40:04 +03:00
|
|
|
void COnscreenTimer::AddCounter(uint32 offset, uint16 type, char* text, uint16 pos) {
|
2020-01-07 18:59:03 +02:00
|
|
|
|
2020-05-20 20:40:04 +03:00
|
|
|
m_sEntries[pos].m_nCounterOffset = offset;
|
|
|
|
if (m_sEntries[pos].m_aCounterText[0] != '\0')
|
|
|
|
return;
|
2020-01-07 18:59:03 +02:00
|
|
|
if(text) {
|
2020-05-20 20:40:04 +03:00
|
|
|
strncpy(m_sEntries[pos].m_aCounterText, text, 10);
|
2020-01-07 18:59:03 +02:00
|
|
|
} else {
|
2020-05-20 20:40:04 +03:00
|
|
|
m_sEntries[pos].m_aCounterText[0] = 0;
|
2020-01-07 18:59:03 +02:00
|
|
|
}
|
|
|
|
|
2020-05-20 20:40:04 +03:00
|
|
|
m_sEntries[pos].m_nType = type;
|
2020-01-07 18:59:03 +02:00
|
|
|
}
|
|
|
|
|
2020-05-20 20:40:04 +03:00
|
|
|
void COnscreenTimer::AddClock(uint32 offset, char* text, bool bGoingDown) {
|
2020-01-07 18:59:03 +02:00
|
|
|
uint32 i = 0;
|
|
|
|
for(uint32 i = 0; i < NUMONSCREENTIMERENTRIES; i++) {
|
|
|
|
if(m_sEntries[i].m_nTimerOffset == 0) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
m_sEntries[i].m_nTimerOffset = offset;
|
2020-05-20 20:40:04 +03:00
|
|
|
m_sEntries[i].m_bTimerGoingDown = bGoingDown;
|
2020-01-07 18:59:03 +02:00
|
|
|
if(text) {
|
|
|
|
strncpy(m_sEntries[i].m_aTimerText, text, 10);
|
|
|
|
} else {
|
|
|
|
m_sEntries[i].m_aTimerText[0] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimerEntry::Process() {
|
|
|
|
if(m_nTimerOffset == 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-02-23 13:12:44 +03:00
|
|
|
int32* timerPtr = CTheScripts::GetPointerToScriptVariable(m_nTimerOffset);
|
|
|
|
int32 oldTime = *timerPtr;
|
2020-05-20 20:40:04 +03:00
|
|
|
if (m_bTimerGoingDown) {
|
|
|
|
int32 newTime = oldTime - int32(CTimer::GetTimeStepInMilliseconds());
|
|
|
|
if (newTime < 0) {
|
|
|
|
*timerPtr = 0;
|
|
|
|
m_bTimerProcessed = 0;
|
|
|
|
m_nTimerOffset = 0;
|
|
|
|
m_aTimerText[0] = 0;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
*timerPtr = newTime;
|
|
|
|
int32 oldTimeSeconds = oldTime / 1000;
|
|
|
|
if (oldTimeSeconds < 12 && newTime / 1000 != oldTimeSeconds) {
|
|
|
|
DMAudio.PlayFrontEndSound(SOUND_CLOCK_TICK, newTime / 1000);
|
|
|
|
}
|
2020-01-07 18:59:03 +02:00
|
|
|
}
|
|
|
|
}
|
2020-05-20 20:40:04 +03:00
|
|
|
else
|
|
|
|
*timerPtr = oldTime + int32(CTimer::GetTimeStepInMilliseconds());
|
2020-01-07 18:59:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool COnscreenTimerEntry::ProcessForDisplay() {
|
|
|
|
m_bTimerProcessed = false;
|
|
|
|
m_bCounterProcessed = false;
|
|
|
|
|
|
|
|
if(m_nTimerOffset == 0 && m_nCounterOffset == 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(m_nTimerOffset != 0) {
|
|
|
|
m_bTimerProcessed = true;
|
|
|
|
ProcessForDisplayClock();
|
|
|
|
}
|
|
|
|
|
|
|
|
if(m_nCounterOffset != 0) {
|
|
|
|
m_bCounterProcessed = true;
|
|
|
|
ProcessForDisplayCounter();
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimerEntry::ProcessForDisplayClock() {
|
2020-02-23 13:12:44 +03:00
|
|
|
uint32 time = *CTheScripts::GetPointerToScriptVariable(m_nTimerOffset);
|
2020-01-07 18:59:03 +02:00
|
|
|
sprintf(m_bTimerBuffer, "%02d:%02d", time / 1000 / 60,
|
|
|
|
time / 1000 % 60);
|
|
|
|
}
|
|
|
|
|
|
|
|
void COnscreenTimerEntry::ProcessForDisplayCounter() {
|
2020-02-23 13:12:44 +03:00
|
|
|
uint32 counter = *CTheScripts::GetPointerToScriptVariable(m_nCounterOffset);
|
2020-01-07 18:59:03 +02:00
|
|
|
sprintf(m_bCounterBuffer, "%d", counter);
|
|
|
|
}
|