| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225 |
- // Copyright (c) 2008-2023 the Urho3D project
- // License: MIT
- #include "../Precompiled.h"
- #include "../Core/CoreEvents.h"
- #include "../Core/Profiler.h"
- #include <ctime>
- #ifdef _WIN32
- #include "../Engine/WinWrapped.h"
- #include <mmsystem.h>
- #elif __EMSCRIPTEN__
- #include <emscripten/emscripten.h>
- #else
- #include <sys/time.h>
- #include <unistd.h>
- #endif
- #include "../DebugNew.h"
- namespace Urho3D
- {
- bool HiresTimer::supported(false);
- long long HiresTimer::frequency(1000);
- Time::Time(Context* context) :
- Object(context),
- frameNumber_(0),
- timeStep_(0.0f),
- timerPeriod_(0)
- {
- #ifdef _WIN32
- LARGE_INTEGER frequency;
- if (QueryPerformanceFrequency(&frequency))
- {
- HiresTimer::frequency = frequency.QuadPart;
- HiresTimer::supported = true;
- }
- #else
- HiresTimer::frequency = 1000000;
- HiresTimer::supported = true;
- #endif
- }
- Time::~Time()
- {
- SetTimerPeriod(0);
- }
- static unsigned Tick()
- {
- #ifdef _WIN32
- return (unsigned)timeGetTime();
- #elif __EMSCRIPTEN__
- return (unsigned)emscripten_get_now();
- #else
- struct timeval time{};
- gettimeofday(&time, nullptr);
- return (unsigned)(time.tv_sec * 1000 + time.tv_usec / 1000);
- #endif
- }
- static long long HiresTick()
- {
- #ifdef _WIN32
- if (HiresTimer::IsSupported())
- {
- LARGE_INTEGER counter;
- QueryPerformanceCounter(&counter);
- return counter.QuadPart;
- }
- else
- return timeGetTime();
- #elif __EMSCRIPTEN__
- return (long long)(emscripten_get_now()*1000.0);
- #else
- struct timeval time{};
- gettimeofday(&time, nullptr);
- return time.tv_sec * 1000000LL + time.tv_usec;
- #endif
- }
- void Time::BeginFrame(float timeStep)
- {
- ++frameNumber_;
- if (!frameNumber_)
- ++frameNumber_;
- timeStep_ = timeStep;
- #ifdef URHO3D_PROFILING
- auto* profiler = GetSubsystem<Profiler>();
- if (profiler)
- profiler->BeginFrame();
- #endif
- {
- URHO3D_PROFILE(BeginFrame);
- // Frame begin event
- using namespace BeginFrame;
- VariantMap& eventData = GetEventDataMap();
- eventData[P_FRAMENUMBER] = frameNumber_;
- eventData[P_TIMESTEP] = timeStep_;
- SendEvent(E_BEGINFRAME, eventData);
- }
- }
- void Time::EndFrame()
- {
- {
- URHO3D_PROFILE(EndFrame);
- // Frame end event
- SendEvent(E_ENDFRAME);
- }
- #ifdef URHO3D_PROFILING
- auto* profiler = GetSubsystem<Profiler>();
- if (profiler)
- profiler->EndFrame();
- #endif
- }
- void Time::SetTimerPeriod(unsigned mSec)
- {
- #ifdef _WIN32
- if (timerPeriod_ > 0)
- timeEndPeriod(timerPeriod_);
- timerPeriod_ = mSec;
- if (timerPeriod_ > 0)
- timeBeginPeriod(timerPeriod_);
- #endif
- }
- float Time::GetElapsedTime()
- {
- return elapsedTime_.GetMSec(false) / 1000.0f;
- }
- unsigned Time::GetSystemTime()
- {
- return Tick();
- }
- unsigned Time::GetTimeSinceEpoch()
- {
- return (unsigned)time(nullptr);
- }
- String Time::GetTimeStamp()
- {
- time_t sysTime;
- time(&sysTime);
- const char* dateTime = ctime(&sysTime);
- return String(dateTime).Replaced("\n", "");
- }
- void Time::Sleep(unsigned mSec)
- {
- #ifdef _WIN32
- ::Sleep(mSec);
- #else
- timespec time{static_cast<time_t>(mSec / 1000), static_cast<long>((mSec % 1000) * 1000000)};
- nanosleep(&time, nullptr);
- #endif
- }
- float Time::GetFramesPerSecond() const
- {
- return 1.0f / timeStep_;
- }
- Timer::Timer()
- {
- Reset();
- }
- unsigned Timer::GetMSec(bool reset)
- {
- unsigned currentTime = Tick();
- unsigned elapsedTime = currentTime - startTime_;
- if (reset)
- startTime_ = currentTime;
- return elapsedTime;
- }
- void Timer::Reset()
- {
- startTime_ = Tick();
- }
- HiresTimer::HiresTimer()
- {
- Reset();
- }
- long long HiresTimer::GetUSec(bool reset)
- {
- long long currentTime = HiresTick();
- long long elapsedTime = currentTime - startTime_;
- // Correct for possible weirdness with changing internal frequency
- if (elapsedTime < 0)
- elapsedTime = 0;
- if (reset)
- startTime_ = currentTime;
- return (elapsedTime * 1000000LL) / frequency;
- }
- void HiresTimer::Reset()
- {
- startTime_ = HiresTick();
- }
- }
|