mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-10 19:10:46 +00:00
222e593437
Using that higher precision, interpolate at a higher granularity. Further, truncate the target interpolation time to vertical blank boundaries to avoid producing temporal artifacts. Fix issues caused by interpolation calculations being handled differently in multiple places (and fix cases where smoothratios were being thrown away only to be redone without checking all proper conditions). Ensure ClockTicks changes do not break other targets (EKenBuild, VoidSW), but note any interpolation there is not similarly updated. git-svn-id: https://svn.eduke32.com/eduke32@8050 1a8010ca-5511-0410-912e-c29ae57300e0 # Conflicts: # source/build/src/build.cpp # source/build/src/sdlayer.cpp
63 lines
1.9 KiB
C++
63 lines
1.9 KiB
C++
|
|
#include "timer.h"
|
|
|
|
#include "build.h"
|
|
#include "compat.h"
|
|
|
|
#include <chrono>
|
|
|
|
using namespace std;
|
|
using namespace chrono;
|
|
|
|
EDUKE32_STATIC_ASSERT((steady_clock::period::den/steady_clock::period::num) >= 1000000000);
|
|
|
|
static time_point<steady_clock> timerlastsample;
|
|
static int timerticspersec;
|
|
static void(*usertimercallback)(void) = NULL;
|
|
|
|
int timerGetRate(void) { return timerticspersec; }
|
|
uint32_t timerGetTicks(void) { return duration_cast<milliseconds>(steady_clock::now().time_since_epoch()).count(); }
|
|
uint64_t timerGetTicksU64(void) { return steady_clock::now().time_since_epoch().count() * steady_clock::period::num; }
|
|
uint64_t timerGetFreqU64(void) { return steady_clock::period::den; }
|
|
|
|
// Returns the time since an unspecified starting time in milliseconds.
|
|
// (May be not monotonic for certain configurations.)
|
|
double timerGetHiTicks(void) { return duration<double, nano>(steady_clock::now().time_since_epoch()).count() / 1000000.0; }
|
|
|
|
int timerInit(int const tickspersecond)
|
|
{
|
|
timerticspersec = tickspersecond;
|
|
timerlastsample = steady_clock::now();
|
|
|
|
usertimercallback = NULL;
|
|
|
|
return 0;
|
|
}
|
|
|
|
ATTRIBUTE((flatten)) void timerUpdate(void)
|
|
{
|
|
auto time = steady_clock::now();
|
|
auto elapsedTime = time - timerlastsample;
|
|
|
|
uint64_t numerator = (elapsedTime.count() * (uint64_t) timerticspersec * steady_clock::period::num);
|
|
int n = numerator / timerGetFreqU64();
|
|
totalclock.setFraction(((numerator - n*timerGetFreqU64()) * 65536) / timerGetFreqU64());
|
|
|
|
if (n <= 0) return;
|
|
|
|
totalclock += n;
|
|
timerlastsample += n*nanoseconds(1000000000/timerticspersec);
|
|
|
|
if (usertimercallback)
|
|
for (; n > 0; n--) usertimercallback();
|
|
}
|
|
|
|
void(*timerSetCallback(void(*callback)(void)))(void)
|
|
{
|
|
void(*oldtimercallback)(void);
|
|
|
|
oldtimercallback = usertimercallback;
|
|
usertimercallback = callback;
|
|
|
|
return oldtimercallback;
|
|
}
|