2021-12-15 19:23:49 +00:00
|
|
|
#include "LegoDieRoll.h"
|
|
|
|
#include "Entity.h"
|
2021-12-15 20:33:16 +00:00
|
|
|
#include "dLogger.h"
|
2021-12-15 19:23:49 +00:00
|
|
|
#include "GameMessages.h"
|
|
|
|
|
|
|
|
void LegoDieRoll::OnStartup(Entity* self) {
|
|
|
|
self->AddTimer("DoneRolling", 10.0f);
|
|
|
|
self->AddTimer("ThrowDice", LegoDieRoll::animTime);
|
|
|
|
}
|
|
|
|
|
|
|
|
void LegoDieRoll::OnTimerDone(Entity* self, std::string timerName) {
|
|
|
|
if (timerName == "DoneRolling") {
|
|
|
|
self->Smash(self->GetObjectID(), SILENT);
|
|
|
|
}
|
|
|
|
else if (timerName == "ThrowDice") {
|
|
|
|
int dieRoll = GeneralUtils::GenerateRandomNumber<int>(1, 6);
|
|
|
|
|
|
|
|
switch (dieRoll)
|
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-1");
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-2");
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-3");
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-4");
|
|
|
|
break;
|
|
|
|
case 5:
|
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-5");
|
|
|
|
break;
|
|
|
|
case 6:
|
2021-12-15 23:30:46 +00:00
|
|
|
{
|
2021-12-15 19:23:49 +00:00
|
|
|
GameMessages::SendPlayAnimation(self, u"roll-die-6");
|
2021-12-15 23:30:46 +00:00
|
|
|
// tracking the It's Truly Random Achievement
|
|
|
|
auto* owner = self->GetOwner();
|
|
|
|
auto* missionComponent = owner->GetComponent<MissionComponent>();
|
|
|
|
|
2021-12-15 23:36:10 +00:00
|
|
|
if (missionComponent != nullptr) {
|
2021-12-15 23:30:46 +00:00
|
|
|
const auto rollMissionState = missionComponent->GetMissionState(756);
|
2021-12-15 23:36:10 +00:00
|
|
|
if (rollMissionState == MissionState::MISSION_STATE_ACTIVE) {
|
2021-12-15 23:30:46 +00:00
|
|
|
missionComponent->ForceProgress(756, 1103, 1);
|
|
|
|
}
|
|
|
|
}
|
2021-12-15 19:23:49 +00:00
|
|
|
break;
|
2021-12-15 23:30:46 +00:00
|
|
|
}
|
2021-12-15 19:23:49 +00:00
|
|
|
default:
|
2021-12-15 20:44:10 +00:00
|
|
|
Game::logger->LogDebug("LegoDieRoll", "Invalid animation: roll-die-%i\n", dieRoll);
|
2021-12-15 19:23:49 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|