26 using namespace std::chrono_literals;
33 , last_render_(
clock::time_point::max())
57 return utils::nullopt;
60 using std::chrono::milliseconds;
61 const auto [min_time, avg_time, max_time] =
get_times();
64 std::chrono::duration_cast<milliseconds>(min_time),
65 std::chrono::duration_cast<milliseconds>(avg_time),
66 std::chrono::duration_cast<milliseconds>(max_time),
69 static_cast<unsigned>(1
s / max_time),
70 static_cast<unsigned>(1
s / avg_time),
71 static_cast<unsigned>(1
s / min_time),
78 const auto [min_time, max_time]
84 return { *min_time, total_time /
frametimes_.size(), *max_time };
89 auto now = clock::now();
92 if(elapsed > clock::duration{0}) {
void process() override
Inherited from events::pump_monitor.
clock::time_point last_render_
std::tuple< clock::duration, clock::duration, clock::duration > times
auto get_times() const -> times
Get min, average, and max frametimes in steady_clock resolution.
boost::circular_buffer< clock::duration > frametimes_
clock::time_point last_lap_
auto get_info() const -> utils::optional< frame_info >
Returns the current frame time and info, or nullopt if no times have been recorded.
void update_count()
Records time since last invocation.
std::chrono::steady_clock clock
void show(const gui2::tracked_drawable &target)
Displays the fps report popup for the given tracked_drawable.
void hide()
Hides the fps report popup.
static map_location::direction s