Make FIFO frame count inclusive

The 'zero frames in the range' check can be removed because now there is always at least 1 frame; of course that might be the same frame over and over again, but that's still useful for e.g. Free Look (and the 1 frame repeating effect already occurred when frame count was exclusive).
This commit is contained in:
Pokechu22 2021-02-08 16:25:57 -08:00
parent 263ca79aae
commit 58333d6feb
2 changed files with 12 additions and 15 deletions

View File

@ -51,7 +51,7 @@ bool FifoPlayer::Open(const std::string& filename)
{ {
FifoPlaybackAnalyzer::AnalyzeFrames(m_File.get(), m_FrameInfo); FifoPlaybackAnalyzer::AnalyzeFrames(m_File.get(), m_FrameInfo);
m_FrameRangeEnd = m_File->GetFrameCount(); m_FrameRangeEnd = m_File->GetFrameCount() - 1;
} }
if (m_FileLoadedCb) if (m_FileLoadedCb)
@ -131,13 +131,10 @@ private:
CPU::State FifoPlayer::AdvanceFrame() CPU::State FifoPlayer::AdvanceFrame()
{ {
if (m_CurrentFrame >= m_FrameRangeEnd) if (m_CurrentFrame > m_FrameRangeEnd)
{ {
if (!m_Loop) if (!m_Loop)
return CPU::State::PowerDown; return CPU::State::PowerDown;
// If there are zero frames in the range then sleep instead of busy spinning
if (m_FrameRangeStart >= m_FrameRangeEnd)
return CPU::State::Stepping;
// When looping, reload the contents of all the BP/CP/CF registers. // When looping, reload the contents of all the BP/CP/CF registers.
// This ensures that each time the first frame is played back, the state of the // This ensures that each time the first frame is played back, the state of the
@ -215,9 +212,9 @@ void FifoPlayer::SetFrameRangeStart(u32 start)
{ {
if (m_File) if (m_File)
{ {
u32 frameCount = m_File->GetFrameCount(); const u32 lastFrame = m_File->GetFrameCount() - 1;
if (start > frameCount) if (start > lastFrame)
start = frameCount; start = lastFrame;
m_FrameRangeStart = start; m_FrameRangeStart = start;
if (m_FrameRangeEnd < start) if (m_FrameRangeEnd < start)
@ -232,9 +229,9 @@ void FifoPlayer::SetFrameRangeEnd(u32 end)
{ {
if (m_File) if (m_File)
{ {
u32 frameCount = m_File->GetFrameCount(); const u32 lastFrame = m_File->GetFrameCount() - 1;
if (end > frameCount) if (end > lastFrame)
end = frameCount; end = lastFrame;
m_FrameRangeEnd = end; m_FrameRangeEnd = end;
if (m_FrameRangeStart > end) if (m_FrameRangeStart > end)

View File

@ -301,12 +301,12 @@ void FIFOPlayerWindow::OnFIFOLoaded()
auto object_count = FifoPlayer::GetInstance().GetMaxObjectCount(); auto object_count = FifoPlayer::GetInstance().GetMaxObjectCount();
auto frame_count = file->GetFrameCount(); auto frame_count = file->GetFrameCount();
m_frame_range_to->setMaximum(frame_count); m_frame_range_to->setMaximum(frame_count - 1);
m_object_range_to->setMaximum(object_count - 1); m_object_range_to->setMaximum(object_count - 1);
m_frame_range_from->setValue(0); m_frame_range_from->setValue(0);
m_object_range_from->setValue(0); m_object_range_from->setValue(0);
m_frame_range_to->setValue(frame_count); m_frame_range_to->setValue(frame_count - 1);
m_object_range_to->setValue(object_count - 1); m_object_range_to->setValue(object_count - 1);
UpdateInfo(); UpdateInfo();
@ -334,8 +334,8 @@ void FIFOPlayerWindow::OnLimitsChanged()
void FIFOPlayerWindow::UpdateLimits() void FIFOPlayerWindow::UpdateLimits()
{ {
m_frame_range_from->setMaximum(std::max(m_frame_range_to->value() - 1, 0)); m_frame_range_from->setMaximum(m_frame_range_to->value());
m_frame_range_to->setMinimum(m_frame_range_from->value() + 1); m_frame_range_to->setMinimum(m_frame_range_from->value());
m_object_range_from->setMaximum(m_object_range_to->value()); m_object_range_from->setMaximum(m_object_range_to->value());
m_object_range_to->setMinimum(m_object_range_from->value()); m_object_range_to->setMinimum(m_object_range_from->value());
} }