For Qt GUI, added state recorder status display to config window.
This commit is contained in:
parent
b4efaa91d8
commit
47f795b04b
|
@ -43,7 +43,7 @@ StateRecorderDialog_t::StateRecorderDialog_t(QWidget *parent)
|
||||||
QVBoxLayout *mainLayout, *vbox1;
|
QVBoxLayout *mainLayout, *vbox1;
|
||||||
QHBoxLayout *hbox, *hbox1;
|
QHBoxLayout *hbox, *hbox1;
|
||||||
QGroupBox *frame, *frame1;
|
QGroupBox *frame, *frame1;
|
||||||
QGridLayout *grid, *memStatsGrid;
|
QGridLayout *grid, *memStatsGrid, *sysStatusGrid;
|
||||||
QSettings settings;
|
QSettings settings;
|
||||||
int opt;
|
int opt;
|
||||||
|
|
||||||
|
@ -207,13 +207,65 @@ StateRecorderDialog_t::StateRecorderDialog_t(QWidget *parent)
|
||||||
hbox = new QHBoxLayout();
|
hbox = new QHBoxLayout();
|
||||||
frame->setLayout(hbox);
|
frame->setLayout(hbox);
|
||||||
|
|
||||||
hbox->addWidget(new QLabel(tr("Save Time:")));
|
hbox->addWidget(new QLabel(tr("Snapshot\nSave Time:")), 2);
|
||||||
hbox->addWidget(saveTimeLbl);
|
hbox->addWidget(saveTimeLbl, 2);
|
||||||
|
|
||||||
grid->addWidget(frame, 3, 3, 1, 1);
|
grid->addWidget(frame, 3, 3, 1, 1);
|
||||||
|
|
||||||
mainLayout->addLayout(grid);
|
mainLayout->addLayout(grid);
|
||||||
|
|
||||||
|
frame1 = new QGroupBox(tr("Recorder Status"));
|
||||||
|
sysStatusGrid = new QGridLayout();
|
||||||
|
frame1->setLayout(sysStatusGrid);
|
||||||
|
|
||||||
|
frame = new QGroupBox();
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
|
||||||
|
sysStatusGrid->addWidget( frame, 0, 0, 1, 2);
|
||||||
|
frame->setLayout(hbox);
|
||||||
|
|
||||||
|
recStatusLbl = new QLineEdit();
|
||||||
|
recStatusLbl->setReadOnly(true);
|
||||||
|
startStopButton = new QPushButton( tr("Start") );
|
||||||
|
hbox->addWidget( new QLabel(tr("State:")), 1 );
|
||||||
|
hbox->addWidget( recStatusLbl, 2 );
|
||||||
|
hbox->addWidget( startStopButton, 1 );
|
||||||
|
|
||||||
|
updateStartStopBuffon();
|
||||||
|
updateRecorderStatusLabel();
|
||||||
|
|
||||||
|
connect(startStopButton, SIGNAL(clicked(void)), this, SLOT(startStopClicked(void)));
|
||||||
|
|
||||||
|
frame = new QGroupBox();
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
|
||||||
|
sysStatusGrid->addWidget( frame, 0, 2, 1, 1);
|
||||||
|
frame->setLayout(hbox);
|
||||||
|
|
||||||
|
recBufSizeLbl = new QLineEdit();
|
||||||
|
recBufSizeLbl->setReadOnly(true);
|
||||||
|
hbox->addWidget( new QLabel(tr("Buffer Size:")), 1 );
|
||||||
|
hbox->addWidget( recBufSizeLbl, 1 );
|
||||||
|
|
||||||
|
frame = new QGroupBox( tr("Buffer Use:") );
|
||||||
|
hbox = new QHBoxLayout();
|
||||||
|
|
||||||
|
sysStatusGrid->addWidget( frame, 1, 0, 1, 3);
|
||||||
|
frame->setLayout(hbox);
|
||||||
|
|
||||||
|
bufUsage = new QProgressBar();
|
||||||
|
bufUsage->setToolTip( tr("% use of history record buffer.") );
|
||||||
|
bufUsage->setOrientation( Qt::Horizontal );
|
||||||
|
bufUsage->setMinimum( 0 );
|
||||||
|
bufUsage->setMaximum( 100 );
|
||||||
|
bufUsage->setValue( 0 );
|
||||||
|
|
||||||
|
hbox->addWidget(bufUsage);
|
||||||
|
|
||||||
|
updateBufferSizeStatus();
|
||||||
|
|
||||||
|
mainLayout->addWidget(frame1);
|
||||||
|
|
||||||
hbox = new QHBoxLayout();
|
hbox = new QHBoxLayout();
|
||||||
mainLayout->addLayout(hbox);
|
mainLayout->addLayout(hbox);
|
||||||
|
|
||||||
|
@ -236,6 +288,12 @@ StateRecorderDialog_t::StateRecorderDialog_t(QWidget *parent)
|
||||||
|
|
||||||
recalcMemoryUsage();
|
recalcMemoryUsage();
|
||||||
pauseOnLoadChanged( pauseOnLoadCbox->currentIndex() );
|
pauseOnLoadChanged( pauseOnLoadCbox->currentIndex() );
|
||||||
|
|
||||||
|
updateTimer = new QTimer(this);
|
||||||
|
|
||||||
|
connect(updateTimer, &QTimer::timeout, this, &StateRecorderDialog_t::updatePeriodic);
|
||||||
|
|
||||||
|
updateTimer->start(1000); // 1hz
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
StateRecorderDialog_t::~StateRecorderDialog_t(void)
|
StateRecorderDialog_t::~StateRecorderDialog_t(void)
|
||||||
|
@ -290,6 +348,86 @@ void StateRecorderDialog_t::applyChanges(void)
|
||||||
g_config->save();
|
g_config->save();
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::startStopClicked(void)
|
||||||
|
{
|
||||||
|
FCEU_WRAPPER_LOCK();
|
||||||
|
bool isRunning = FCEU_StateRecorderRunning();
|
||||||
|
|
||||||
|
if (isRunning)
|
||||||
|
{
|
||||||
|
FCEU_StateRecorderStop();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FCEU_StateRecorderStart();
|
||||||
|
}
|
||||||
|
updateStatusDisplay();
|
||||||
|
|
||||||
|
FCEU_WRAPPER_UNLOCK();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::updateStartStopBuffon(void)
|
||||||
|
{
|
||||||
|
bool isRunning = FCEU_StateRecorderRunning();
|
||||||
|
|
||||||
|
if (isRunning)
|
||||||
|
{
|
||||||
|
startStopButton->setText( tr("Stop") );
|
||||||
|
startStopButton->setIcon( style()->standardIcon( QStyle::SP_MediaStop ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
startStopButton->setText( tr("Start") );
|
||||||
|
startStopButton->setIcon( QIcon(":icons/media-record.png") );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::updateBufferSizeStatus(void)
|
||||||
|
{
|
||||||
|
char stmp[64];
|
||||||
|
|
||||||
|
int numSnapsSaved = FCEU_StateRecorderGetNumSnapsSaved();
|
||||||
|
int maxSnaps = FCEU_StateRecorderGetMaxSnaps();
|
||||||
|
|
||||||
|
snprintf( stmp, sizeof(stmp), "%i", maxSnaps );
|
||||||
|
|
||||||
|
recBufSizeLbl->setText( tr(stmp) );
|
||||||
|
|
||||||
|
if (maxSnaps > 0)
|
||||||
|
{
|
||||||
|
bufUsage->setMaximum( maxSnaps );
|
||||||
|
}
|
||||||
|
bufUsage->setValue( numSnapsSaved );
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::updateRecorderStatusLabel(void)
|
||||||
|
{
|
||||||
|
bool isRunning = FCEU_StateRecorderRunning();
|
||||||
|
|
||||||
|
if (isRunning)
|
||||||
|
{
|
||||||
|
recStatusLbl->setText( tr("Recording") );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
recStatusLbl->setText( tr("Off") );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::updateStatusDisplay(void)
|
||||||
|
{
|
||||||
|
updateStartStopBuffon();
|
||||||
|
updateRecorderStatusLabel();
|
||||||
|
updateBufferSizeStatus();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
void StateRecorderDialog_t::updatePeriodic(void)
|
||||||
|
{
|
||||||
|
FCEU_WRAPPER_LOCK();
|
||||||
|
updateStatusDisplay();
|
||||||
|
FCEU_WRAPPER_UNLOCK();
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
void StateRecorderDialog_t::enableChanged(int val)
|
void StateRecorderDialog_t::enableChanged(int val)
|
||||||
{
|
{
|
||||||
bool ena = val ? true : false;
|
bool ena = val ? true : false;
|
||||||
|
|
|
@ -12,10 +12,12 @@
|
||||||
#include <QSpinBox>
|
#include <QSpinBox>
|
||||||
#include <QComboBox>
|
#include <QComboBox>
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
|
#include <QProgressBar>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QFrame>
|
#include <QFrame>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
|
#include <QTimer>
|
||||||
|
|
||||||
class StateRecorderDialog_t : public QDialog
|
class StateRecorderDialog_t : public QDialog
|
||||||
{
|
{
|
||||||
|
@ -28,28 +30,39 @@ public:
|
||||||
protected:
|
protected:
|
||||||
void closeEvent(QCloseEvent *event);
|
void closeEvent(QCloseEvent *event);
|
||||||
|
|
||||||
QSpinBox *snapMinutes;
|
QSpinBox *snapMinutes;
|
||||||
QSpinBox *snapSeconds;
|
QSpinBox *snapSeconds;
|
||||||
QSpinBox *historyDuration;
|
QSpinBox *historyDuration;
|
||||||
QSpinBox *pauseDuration;
|
QSpinBox *pauseDuration;
|
||||||
QCheckBox *recorderEnable;
|
QCheckBox *recorderEnable;
|
||||||
QLineEdit *numSnapsLbl;
|
QLineEdit *numSnapsLbl;
|
||||||
QLineEdit *snapMemSizeLbl;
|
QLineEdit *snapMemSizeLbl;
|
||||||
QLineEdit *totalMemUsageLbl;
|
QLineEdit *totalMemUsageLbl;
|
||||||
QLineEdit *saveTimeLbl;
|
QLineEdit *saveTimeLbl;
|
||||||
QPushButton *applyButton;
|
QPushButton *applyButton;
|
||||||
QPushButton *closeButton;
|
QPushButton *closeButton;
|
||||||
QComboBox *cmprLvlCbox;
|
QComboBox *cmprLvlCbox;
|
||||||
QComboBox *pauseOnLoadCbox;
|
QComboBox *pauseOnLoadCbox;
|
||||||
|
QLineEdit *recStatusLbl;
|
||||||
|
QLineEdit *recBufSizeLbl;
|
||||||
|
QPushButton *startStopButton;
|
||||||
|
QProgressBar *bufUsage;
|
||||||
|
QTimer *updateTimer;
|
||||||
|
|
||||||
double saveTimeMs;
|
double saveTimeMs;
|
||||||
|
|
||||||
void recalcMemoryUsage(void);
|
void recalcMemoryUsage(void);
|
||||||
|
void updateStartStopBuffon(void);
|
||||||
|
void updateRecorderStatusLabel(void);
|
||||||
|
void updateBufferSizeStatus(void);
|
||||||
|
void updateStatusDisplay(void);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void closeWindow(void);
|
void closeWindow(void);
|
||||||
private slots:
|
private slots:
|
||||||
void applyChanges(void);
|
void applyChanges(void);
|
||||||
|
void updatePeriodic(void);
|
||||||
|
void startStopClicked(void);
|
||||||
void spinBoxValueChanged(int newValue);
|
void spinBoxValueChanged(int newValue);
|
||||||
void enableChanged(int);
|
void enableChanged(int);
|
||||||
void compressionLevelChanged(int newValue);
|
void compressionLevelChanged(int newValue);
|
||||||
|
|
|
@ -1251,7 +1251,7 @@ class StateRecorder
|
||||||
|
|
||||||
void update(void)
|
void update(void)
|
||||||
{
|
{
|
||||||
bool isPaused = FCEUI_EmulationPaused() ? true : false;
|
bool isPaused = EmulationPaused ? true : false;
|
||||||
|
|
||||||
unsigned int curFrame = static_cast<unsigned int>(currFrameCounter);
|
unsigned int curFrame = static_cast<unsigned int>(currFrameCounter);
|
||||||
|
|
||||||
|
@ -1399,6 +1399,10 @@ class StateRecorder
|
||||||
return ringBuf.size() * ringBuf[0]->size();
|
return ringBuf.size() * ringBuf[0]->size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t ringBufferSize(void)
|
||||||
|
{
|
||||||
|
return ringBuf.size();
|
||||||
|
}
|
||||||
static bool enabled;
|
static bool enabled;
|
||||||
static int lastState;
|
static int lastState;
|
||||||
private:
|
private:
|
||||||
|
@ -1469,6 +1473,28 @@ bool FCEU_StateRecorderRunning(void)
|
||||||
return stateRecorder != nullptr;
|
return stateRecorder != nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int FCEU_StateRecorderGetMaxSnaps(void)
|
||||||
|
{
|
||||||
|
int size = 0;
|
||||||
|
|
||||||
|
if (stateRecorder != nullptr)
|
||||||
|
{
|
||||||
|
size = stateRecorder->ringBufferSize();
|
||||||
|
}
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
int FCEU_StateRecorderGetNumSnapsSaved(void)
|
||||||
|
{
|
||||||
|
int n = 0;
|
||||||
|
|
||||||
|
if (stateRecorder != nullptr)
|
||||||
|
{
|
||||||
|
n = stateRecorder->numSnapsSaved();
|
||||||
|
}
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
int FCEU_StateRecorderLoadState(int snapIndex)
|
int FCEU_StateRecorderLoadState(int snapIndex)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
|
@ -109,6 +109,8 @@ int FCEU_StateRecorderUpdate(void);
|
||||||
bool FCEU_StateRecorderRunning(void);
|
bool FCEU_StateRecorderRunning(void);
|
||||||
bool FCEU_StateRecorderIsEnabled(void);
|
bool FCEU_StateRecorderIsEnabled(void);
|
||||||
void FCEU_StateRecorderSetEnabled(bool enabled);
|
void FCEU_StateRecorderSetEnabled(bool enabled);
|
||||||
|
int FCEU_StateRecorderGetMaxSnaps(void);
|
||||||
|
int FCEU_StateRecorderGetNumSnapsSaved(void);
|
||||||
int FCEU_StateRecorderGetStateIndex(void);
|
int FCEU_StateRecorderGetStateIndex(void);
|
||||||
int FCEU_StateRecorderLoadState(int snapIndex);
|
int FCEU_StateRecorderLoadState(int snapIndex);
|
||||||
int FCEU_StateRecorderLoadPrevState(void);
|
int FCEU_StateRecorderLoadPrevState(void);
|
||||||
|
|
Loading…
Reference in New Issue