2020-06-03 07:32:28 +00:00
|
|
|
#ifndef GAME_MWWORLD_DATETIMEMANAGER_H
|
|
|
|
#define GAME_MWWORLD_DATETIMEMANAGER_H
|
|
|
|
|
2023-08-06 14:09:41 +00:00
|
|
|
#include <set>
|
2022-08-27 11:07:59 +00:00
|
|
|
#include <string_view>
|
2020-06-03 07:32:28 +00:00
|
|
|
|
2023-02-06 23:37:55 +00:00
|
|
|
#include "globalvariablename.hpp"
|
|
|
|
|
2020-06-03 07:32:28 +00:00
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
struct EpochTimeStamp;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class Globals;
|
|
|
|
class TimeStamp;
|
2023-08-06 12:46:15 +00:00
|
|
|
class World;
|
2020-06-03 07:32:28 +00:00
|
|
|
|
|
|
|
class DateTimeManager
|
|
|
|
{
|
|
|
|
public:
|
2023-08-06 12:46:15 +00:00
|
|
|
// Game time.
|
|
|
|
// Note that game time generally goes faster than the simulation time.
|
|
|
|
std::string_view getMonthName(int month = -1) const; // -1: current month
|
2020-06-03 07:32:28 +00:00
|
|
|
TimeStamp getTimeStamp() const;
|
|
|
|
ESM::EpochTimeStamp getEpochTimeStamp() const;
|
2023-08-06 12:46:15 +00:00
|
|
|
double getGameTime() const { return (static_cast<double>(mDaysPassed) * 24 + mGameHour) * 3600.0; }
|
|
|
|
float getGameTimeScale() const { return mGameTimeScale; }
|
|
|
|
void setGameTimeScale(float scale); // game time to simulation time ratio
|
|
|
|
|
2023-09-26 10:39:38 +00:00
|
|
|
// Rendering simulation time (summary simulation time of rendering frames since application start).
|
|
|
|
double getRenderingSimulationTime() const { return mRenderingSimulationTime; }
|
|
|
|
void setRenderingSimulationTime(double t) { mRenderingSimulationTime = t; }
|
|
|
|
|
|
|
|
// World simulation time (the number of seconds passed from the beginning of the game).
|
2023-08-06 12:46:15 +00:00
|
|
|
double getSimulationTime() const { return mSimulationTime; }
|
|
|
|
void setSimulationTime(double t) { mSimulationTime = t; }
|
|
|
|
float getSimulationTimeScale() const { return mSimulationTimeScale; }
|
|
|
|
void setSimulationTimeScale(float scale); // simulation time to real time ratio
|
|
|
|
|
2023-08-06 14:09:41 +00:00
|
|
|
// Whether the game is paused in the current frame.
|
|
|
|
bool isPaused() const { return mPaused; }
|
|
|
|
|
|
|
|
// Pauses the game starting from the next frame until `unpause` is called with the same tag.
|
|
|
|
void pause(std::string_view tag) { mPausedTags.emplace(tag); }
|
|
|
|
void unpause(std::string_view tag);
|
|
|
|
const std::set<std::string, std::less<>>& getPausedTags() const { return mPausedTags; }
|
|
|
|
|
|
|
|
// Updates mPaused; should be called once a frame.
|
|
|
|
void updateIsPaused();
|
|
|
|
|
2023-08-06 12:46:15 +00:00
|
|
|
private:
|
|
|
|
friend class World;
|
2020-06-03 07:32:28 +00:00
|
|
|
void setup(Globals& globalVariables);
|
2023-02-06 23:37:55 +00:00
|
|
|
bool updateGlobalInt(GlobalVariableName name, int value);
|
|
|
|
bool updateGlobalFloat(GlobalVariableName name, float value);
|
2023-08-06 12:46:15 +00:00
|
|
|
void advanceTime(double hours, Globals& globalVariables);
|
|
|
|
|
|
|
|
void setHour(double hour);
|
|
|
|
void setDay(int day);
|
|
|
|
void setMonth(int month);
|
|
|
|
|
|
|
|
int mDaysPassed = 0;
|
|
|
|
int mDay = 0;
|
|
|
|
int mMonth = 0;
|
|
|
|
int mYear = 0;
|
|
|
|
float mGameHour = 0.f;
|
|
|
|
float mGameTimeScale = 0.f;
|
|
|
|
float mSimulationTimeScale = 1.0;
|
2023-09-26 10:39:38 +00:00
|
|
|
double mRenderingSimulationTime = 0.0;
|
2023-08-06 12:46:15 +00:00
|
|
|
double mSimulationTime = 0.0;
|
2023-08-06 14:09:41 +00:00
|
|
|
bool mPaused = false;
|
|
|
|
std::set<std::string, std::less<>> mPausedTags;
|
2020-06-03 07:32:28 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|