Qt: Fix FPS counter on Windows

This commit is contained in:
Vicki Pfau 2018-09-30 16:14:17 -07:00
parent 1247dec1ba
commit da80c5a971
3 changed files with 12 additions and 24 deletions

View File

@ -113,6 +113,7 @@ Bugfixes:
- Switch: Fix incorrect mapping for fast forward cap - Switch: Fix incorrect mapping for fast forward cap
- GB, GBA: Fix broken opposing button filter (fixes mgba.io/i/1191) - GB, GBA: Fix broken opposing button filter (fixes mgba.io/i/1191)
- Qt: Fix jumbled background when paused - Qt: Fix jumbled background when paused
- Qt: Fix FPS counter on Windows
Misc: Misc:
- mGUI: Add SGB border configuration option - mGUI: Add SGB border configuration option
- mGUI: Add support for different settings types - mGUI: Add support for different settings types

View File

@ -138,13 +138,11 @@ Window::Window(CoreManager* manager, ConfigController* config, int playerId, QWi
connect(this, &Window::shutdown, m_logView, &QWidget::hide); connect(this, &Window::shutdown, m_logView, &QWidget::hide);
connect(&m_fpsTimer, &QTimer::timeout, this, &Window::showFPS); connect(&m_fpsTimer, &QTimer::timeout, this, &Window::showFPS);
connect(&m_frameTimer, &QTimer::timeout, this, &Window::delimitFrames);
connect(&m_focusCheck, &QTimer::timeout, this, &Window::focusCheck); connect(&m_focusCheck, &QTimer::timeout, this, &Window::focusCheck);
connect(&m_inputController, &InputController::profileLoaded, m_shortcutController, &ShortcutController::loadProfile); connect(&m_inputController, &InputController::profileLoaded, m_shortcutController, &ShortcutController::loadProfile);
m_log.setLevels(mLOG_WARN | mLOG_ERROR | mLOG_FATAL); m_log.setLevels(mLOG_WARN | mLOG_ERROR | mLOG_FATAL);
m_fpsTimer.setInterval(FPS_TIMER_INTERVAL); m_fpsTimer.setInterval(FPS_TIMER_INTERVAL);
m_frameTimer.setInterval(FRAME_LIST_INTERVAL);
m_focusCheck.setInterval(200); m_focusCheck.setInterval(200);
m_shortcutController->setConfigController(m_config); m_shortcutController->setConfigController(m_config);
@ -773,7 +771,6 @@ void Window::gameStopped() {
m_audioChannels->clear(); m_audioChannels->clear();
m_fpsTimer.stop(); m_fpsTimer.stop();
m_frameTimer.stop();
m_focusCheck.stop(); m_focusCheck.stop();
emit paused(false); emit paused(false);
@ -903,19 +900,8 @@ void Window::mustRestart() {
} }
void Window::recordFrame() { void Window::recordFrame() {
if (m_frameList.isEmpty()) { m_frameList.append(m_frameTimer.nsecsElapsed());
m_frameList.append(1); m_frameTimer.restart();
} else {
++m_frameList.back();
}
}
void Window::delimitFrames() {
if (m_frameList.size() >= FRAME_LIST_SIZE) {
m_frameCounter -= m_frameList.takeAt(0);
}
m_frameCounter += m_frameList.back();
m_frameList.append(0);
} }
void Window::showFPS() { void Window::showFPS() {
@ -923,7 +909,12 @@ void Window::showFPS() {
updateTitle(); updateTitle();
return; return;
} }
float fps = m_frameCounter * 10000.f / (FRAME_LIST_INTERVAL * (m_frameList.size() - 1)); qint64 total = 0;
for (qint64 t : m_frameList) {
total += t;
}
double fps = (m_frameList.size() * 1e10) / total;
m_frameList.clear();
fps = round(fps) / 10.f; fps = round(fps) / 10.f;
updateTitle(fps); updateTitle(fps);
} }
@ -1655,7 +1646,6 @@ void Window::setupMenu(QMenuBar* menubar) {
showFps->connect([this](const QVariant& value) { showFps->connect([this](const QVariant& value) {
if (!value.toInt()) { if (!value.toInt()) {
m_fpsTimer.stop(); m_fpsTimer.stop();
m_frameTimer.stop();
updateTitle(); updateTitle();
} else if (m_controller) { } else if (m_controller) {
m_fpsTimer.start(); m_fpsTimer.start();

View File

@ -7,6 +7,7 @@
#include <QAction> #include <QAction>
#include <QDateTime> #include <QDateTime>
#include <QElapsedTimer>
#include <QList> #include <QList>
#include <QMainWindow> #include <QMainWindow>
#include <QTimer> #include <QTimer>
@ -132,7 +133,6 @@ private slots:
void mustRestart(); void mustRestart();
void recordFrame(); void recordFrame();
void delimitFrames();
void showFPS(); void showFPS();
void focusCheck(); void focusCheck();
@ -140,8 +140,6 @@ private slots:
private: private:
static const int FPS_TIMER_INTERVAL = 2000; static const int FPS_TIMER_INTERVAL = 2000;
static const int FRAME_LIST_INTERVAL = 100;
static const int FRAME_LIST_SIZE = 40;
void setupMenu(QMenuBar*); void setupMenu(QMenuBar*);
void openStateWindow(LoadSave); void openStateWindow(LoadSave);
@ -189,10 +187,9 @@ private:
QPixmap m_logo{":/res/mgba-1024.png"}; QPixmap m_logo{":/res/mgba-1024.png"};
ConfigController* m_config; ConfigController* m_config;
InputController m_inputController; InputController m_inputController;
QList<int> m_frameList; QList<qint64> m_frameList;
int m_frameCounter = 0; QElapsedTimer m_frameTimer;
QTimer m_fpsTimer; QTimer m_fpsTimer;
QTimer m_frameTimer;
QList<QString> m_mruFiles; QList<QString> m_mruFiles;
QMenu* m_mruMenu = nullptr; QMenu* m_mruMenu = nullptr;
QMenu* m_videoLayers; QMenu* m_videoLayers;