Merge pull request #1014 from RachelBryk/active-movie
Add an IsMovieActive function.
This commit is contained in:
commit
a21ad12f1e
|
@ -338,7 +338,7 @@ u32 CEXIIPL::GetGCTime()
|
||||||
u64 ltime = 0;
|
u64 ltime = 0;
|
||||||
static const u32 cJanuary2000 = 0x386D4380; // Seconds between 1.1.1970 and 1.1.2000
|
static const u32 cJanuary2000 = 0x386D4380; // Seconds between 1.1.1970 and 1.1.2000
|
||||||
|
|
||||||
if (Movie::IsRecordingInput() || Movie::IsPlayingInput())
|
if (Movie::IsMovieActive())
|
||||||
{
|
{
|
||||||
ltime = Movie::GetRecordingStartTime();
|
ltime = Movie::GetRecordingStartTime();
|
||||||
|
|
||||||
|
|
|
@ -500,7 +500,7 @@ void CEXIMemoryCard::DoState(PointerWrap &p)
|
||||||
// for movie sync, we need to save/load memory card contents (and other data) in savestates.
|
// for movie sync, we need to save/load memory card contents (and other data) in savestates.
|
||||||
// otherwise, we'll assume the user wants to keep their memcards and saves separate,
|
// otherwise, we'll assume the user wants to keep their memcards and saves separate,
|
||||||
// unless we're loading (in which case we let the savestate contents decide, in order to stay aligned with them).
|
// unless we're loading (in which case we let the savestate contents decide, in order to stay aligned with them).
|
||||||
bool storeContents = (Movie::IsRecordingInput() || Movie::IsPlayingInput());
|
bool storeContents = (Movie::IsMovieActive());
|
||||||
p.Do(storeContents);
|
p.Do(storeContents);
|
||||||
|
|
||||||
if (storeContents)
|
if (storeContents)
|
||||||
|
|
|
@ -230,8 +230,7 @@ void DoState(PointerWrap &p)
|
||||||
// if we had to create a temporary device, discard it if we're not loading.
|
// if we had to create a temporary device, discard it if we're not loading.
|
||||||
// also, if no movie is active, we'll assume the user wants to keep their current devices
|
// also, if no movie is active, we'll assume the user wants to keep their current devices
|
||||||
// instead of the ones they had when the savestate was created.
|
// instead of the ones they had when the savestate was created.
|
||||||
if (p.GetMode() != PointerWrap::MODE_READ ||
|
if (p.GetMode() != PointerWrap::MODE_READ || !Movie::IsMovieActive())
|
||||||
(!Movie::IsRecordingInput() && !Movie::IsPlayingInput()))
|
|
||||||
{
|
{
|
||||||
delete pSaveDevice;
|
delete pSaveDevice;
|
||||||
}
|
}
|
||||||
|
@ -257,7 +256,7 @@ void Init()
|
||||||
g_Channel[i].m_InHi.Hex = 0;
|
g_Channel[i].m_InHi.Hex = 0;
|
||||||
g_Channel[i].m_InLo.Hex = 0;
|
g_Channel[i].m_InLo.Hex = 0;
|
||||||
|
|
||||||
if (Movie::IsRecordingInput() || Movie::IsPlayingInput())
|
if (Movie::IsMovieActive())
|
||||||
AddDevice(Movie::IsUsingPad(i) ? (Movie::IsUsingBongo(i) ? SIDEVICE_GC_TARUKONGA : SIDEVICE_GC_CONTROLLER) : SIDEVICE_NONE, i);
|
AddDevice(Movie::IsUsingPad(i) ? (Movie::IsUsingBongo(i) ? SIDEVICE_GC_TARUKONGA : SIDEVICE_GC_CONTROLLER) : SIDEVICE_NONE, i);
|
||||||
else if (!NetPlay::IsNetPlayRunning())
|
else if (!NetPlay::IsNetPlayRunning())
|
||||||
AddDevice(SConfig::GetInstance().m_SIDevice[i], i);
|
AddDevice(SConfig::GetInstance().m_SIDevice[i], i);
|
||||||
|
@ -531,7 +530,7 @@ void RunSIBuffer()
|
||||||
int GetTicksToNextSIPoll()
|
int GetTicksToNextSIPoll()
|
||||||
{
|
{
|
||||||
// Poll for input at regular intervals (once per frame) when playing or recording a movie
|
// Poll for input at regular intervals (once per frame) when playing or recording a movie
|
||||||
if (Movie::IsPlayingInput() || Movie::IsRecordingInput())
|
if (Movie::IsMovieActive())
|
||||||
{
|
{
|
||||||
if (Movie::IsNetPlayRecording())
|
if (Movie::IsNetPlayRecording())
|
||||||
return SystemTimers::GetTicksPerSecond() / VideoInterface::TargetRefreshRate / 2;
|
return SystemTimers::GetTicksPerSecond() / VideoInterface::TargetRefreshRate / 2;
|
||||||
|
|
|
@ -53,7 +53,7 @@ void Initialize(void* const hwnd, bool wait)
|
||||||
WiimoteReal::Initialize(wait);
|
WiimoteReal::Initialize(wait);
|
||||||
|
|
||||||
// reload Wiimotes with our settings
|
// reload Wiimotes with our settings
|
||||||
if (Movie::IsPlayingInput() || Movie::IsRecordingInput())
|
if (Movie::IsMovieActive())
|
||||||
Movie::ChangeWiiPads();
|
Movie::ChangeWiiPads();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -330,7 +330,7 @@ bool Wiimote::Step()
|
||||||
m_rumble->controls[0]->control_ref->State(m_rumble_on);
|
m_rumble->controls[0]->control_ref->State(m_rumble_on);
|
||||||
|
|
||||||
// when a movie is active, this button status update is disabled (moved), because movies only record data reports.
|
// when a movie is active, this button status update is disabled (moved), because movies only record data reports.
|
||||||
if (!(Movie::IsPlayingInput() || Movie::IsRecordingInput()) || NetPlay::IsNetPlayRunning())
|
if (!(Movie::IsMovieActive()) || NetPlay::IsNetPlayRunning())
|
||||||
{
|
{
|
||||||
UpdateButtonsStatus();
|
UpdateButtonsStatus();
|
||||||
}
|
}
|
||||||
|
@ -384,7 +384,7 @@ void Wiimote::UpdateButtonsStatus()
|
||||||
void Wiimote::GetCoreData(u8* const data)
|
void Wiimote::GetCoreData(u8* const data)
|
||||||
{
|
{
|
||||||
// when a movie is active, the button update happens here instead of Wiimote::Step, to avoid potential desync issues.
|
// when a movie is active, the button update happens here instead of Wiimote::Step, to avoid potential desync issues.
|
||||||
if (Movie::IsPlayingInput() || Movie::IsRecordingInput() || NetPlay::IsNetPlayRunning())
|
if (Movie::IsMovieActive() || NetPlay::IsNetPlayRunning())
|
||||||
{
|
{
|
||||||
UpdateButtonsStatus();
|
UpdateButtonsStatus();
|
||||||
}
|
}
|
||||||
|
|
|
@ -113,7 +113,7 @@ static bool IsMovieHeader(u8 magic[4])
|
||||||
|
|
||||||
std::string GetInputDisplay()
|
std::string GetInputDisplay()
|
||||||
{
|
{
|
||||||
if (!IsPlayingInput() && !IsRecordingInput())
|
if (!IsMovieActive())
|
||||||
{
|
{
|
||||||
g_numPads = 0;
|
g_numPads = 0;
|
||||||
for (int i = 0; i < 4; i++)
|
for (int i = 0; i < 4; i++)
|
||||||
|
@ -198,7 +198,7 @@ void Init()
|
||||||
for (auto& disp : g_InputDisplay)
|
for (auto& disp : g_InputDisplay)
|
||||||
disp.clear();
|
disp.clear();
|
||||||
|
|
||||||
if (!IsPlayingInput() && !IsRecordingInput())
|
if (!IsMovieActive())
|
||||||
{
|
{
|
||||||
g_bRecordingFromSaveState = false;
|
g_bRecordingFromSaveState = false;
|
||||||
g_rerecords = 0;
|
g_rerecords = 0;
|
||||||
|
@ -273,7 +273,7 @@ void SetReadOnly(bool bEnabled)
|
||||||
void FrameSkipping()
|
void FrameSkipping()
|
||||||
{
|
{
|
||||||
// Frameskipping will desync movie playback
|
// Frameskipping will desync movie playback
|
||||||
if (!IsPlayingInput() && !IsRecordingInput())
|
if (!IsMovieActive())
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lk(cs_frameSkip);
|
std::lock_guard<std::mutex> lk(cs_frameSkip);
|
||||||
|
|
||||||
|
@ -310,6 +310,11 @@ bool IsPlayingInput()
|
||||||
return (g_playMode == MODE_PLAYING);
|
return (g_playMode == MODE_PLAYING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool IsMovieActive()
|
||||||
|
{
|
||||||
|
return g_playMode != MODE_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
bool IsReadOnly()
|
bool IsReadOnly()
|
||||||
{
|
{
|
||||||
return g_bReadOnly;
|
return g_bReadOnly;
|
||||||
|
|
|
@ -123,6 +123,7 @@ bool IsRecordingInputFromSaveState();
|
||||||
bool IsJustStartingRecordingInputFromSaveState();
|
bool IsJustStartingRecordingInputFromSaveState();
|
||||||
bool IsJustStartingPlayingInputFromSaveState();
|
bool IsJustStartingPlayingInputFromSaveState();
|
||||||
bool IsPlayingInput();
|
bool IsPlayingInput();
|
||||||
|
bool IsMovieActive();
|
||||||
bool IsReadOnly();
|
bool IsReadOnly();
|
||||||
u64 GetRecordingStartTime();
|
u64 GetRecordingStartTime();
|
||||||
|
|
||||||
|
|
|
@ -236,9 +236,9 @@ static void CompressAndDumpState(CompressAndDumpState_args save_args)
|
||||||
File::Rename(filename + ".dtm", File::GetUserPath(D_STATESAVES_IDX) + "lastState.sav.dtm");
|
File::Rename(filename + ".dtm", File::GetUserPath(D_STATESAVES_IDX) + "lastState.sav.dtm");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((Movie::IsRecordingInput() || Movie::IsPlayingInput()) && !Movie::IsJustStartingRecordingInputFromSaveState())
|
if ((Movie::IsMovieActive()) && !Movie::IsJustStartingRecordingInputFromSaveState())
|
||||||
Movie::SaveRecording(filename + ".dtm");
|
Movie::SaveRecording(filename + ".dtm");
|
||||||
else if (!Movie::IsRecordingInput() && !Movie::IsPlayingInput())
|
else if (!Movie::IsMovieActive())
|
||||||
File::Delete(filename + ".dtm");
|
File::Delete(filename + ".dtm");
|
||||||
|
|
||||||
File::IOFile f(filename, "wb");
|
File::IOFile f(filename, "wb");
|
||||||
|
@ -437,7 +437,7 @@ void LoadAs(const std::string& filename)
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lk(g_cs_undo_load_buffer);
|
std::lock_guard<std::mutex> lk(g_cs_undo_load_buffer);
|
||||||
SaveToBuffer(g_undo_load_buffer);
|
SaveToBuffer(g_undo_load_buffer);
|
||||||
if (Movie::IsRecordingInput() || Movie::IsPlayingInput())
|
if (Movie::IsMovieActive())
|
||||||
Movie::SaveRecording(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
Movie::SaveRecording(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
||||||
else if (File::Exists(File::GetUserPath(D_STATESAVES_IDX) +"undo.dtm"))
|
else if (File::Exists(File::GetUserPath(D_STATESAVES_IDX) +"undo.dtm"))
|
||||||
File::Delete(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
File::Delete(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
||||||
|
@ -607,10 +607,10 @@ void UndoLoadState()
|
||||||
std::lock_guard<std::mutex> lk(g_cs_undo_load_buffer);
|
std::lock_guard<std::mutex> lk(g_cs_undo_load_buffer);
|
||||||
if (!g_undo_load_buffer.empty())
|
if (!g_undo_load_buffer.empty())
|
||||||
{
|
{
|
||||||
if (File::Exists(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm") || (!Movie::IsRecordingInput() && !Movie::IsPlayingInput()))
|
if (File::Exists(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm") || (!Movie::IsMovieActive()))
|
||||||
{
|
{
|
||||||
LoadFromBuffer(g_undo_load_buffer);
|
LoadFromBuffer(g_undo_load_buffer);
|
||||||
if (Movie::IsRecordingInput() || Movie::IsPlayingInput())
|
if (Movie::IsMovieActive())
|
||||||
Movie::LoadInput(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
Movie::LoadInput(File::GetUserPath(D_STATESAVES_IDX) + "undo.dtm");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -757,7 +757,7 @@ void CConfigMain::CreateGUIControls()
|
||||||
{
|
{
|
||||||
sbGamecubeDevSettings->Add(GCSIDeviceText[i], 1, wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT|wxBOTTOM, 0);
|
sbGamecubeDevSettings->Add(GCSIDeviceText[i], 1, wxALIGN_CENTER_VERTICAL|wxLEFT|wxRIGHT|wxBOTTOM, 0);
|
||||||
sbGamecubeDevSettings->Add(GCSIDevice[i], 1, wxEXPAND|wxLEFT|wxRIGHT|wxBOTTOM, 0);
|
sbGamecubeDevSettings->Add(GCSIDevice[i], 1, wxEXPAND|wxLEFT|wxRIGHT|wxBOTTOM, 0);
|
||||||
if (NetPlay::IsNetPlayRunning() || Movie::IsRecordingInput() || Movie::IsPlayingInput())
|
if (NetPlay::IsNetPlayRunning() || Movie::IsMovieActive())
|
||||||
{
|
{
|
||||||
GCSIDevice[i]->Disable();
|
GCSIDevice[i]->Disable();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1097,7 +1097,7 @@ void CFrame::DoStop()
|
||||||
// TODO: Show the author/description dialog here
|
// TODO: Show the author/description dialog here
|
||||||
if (Movie::IsRecordingInput())
|
if (Movie::IsRecordingInput())
|
||||||
DoRecordingSave();
|
DoRecordingSave();
|
||||||
if (Movie::IsPlayingInput() || Movie::IsRecordingInput())
|
if (Movie::IsMovieActive())
|
||||||
Movie::EndPlayInput(false);
|
Movie::EndPlayInput(false);
|
||||||
NetPlay::StopGame();
|
NetPlay::StopGame();
|
||||||
|
|
||||||
|
@ -1644,7 +1644,7 @@ void CFrame::UpdateGUI()
|
||||||
GetMenuBar()->FindItem(IDM_RESET)->Enable(Running || Paused);
|
GetMenuBar()->FindItem(IDM_RESET)->Enable(Running || Paused);
|
||||||
GetMenuBar()->FindItem(IDM_RECORD)->Enable(!Movie::IsRecordingInput());
|
GetMenuBar()->FindItem(IDM_RECORD)->Enable(!Movie::IsRecordingInput());
|
||||||
GetMenuBar()->FindItem(IDM_PLAYRECORD)->Enable(!Initialized);
|
GetMenuBar()->FindItem(IDM_PLAYRECORD)->Enable(!Initialized);
|
||||||
GetMenuBar()->FindItem(IDM_RECORDEXPORT)->Enable(Movie::IsPlayingInput() || Movie::IsRecordingInput());
|
GetMenuBar()->FindItem(IDM_RECORDEXPORT)->Enable(Movie::IsMovieActive());
|
||||||
GetMenuBar()->FindItem(IDM_FRAMESTEP)->Enable(Running || Paused);
|
GetMenuBar()->FindItem(IDM_FRAMESTEP)->Enable(Running || Paused);
|
||||||
GetMenuBar()->FindItem(IDM_SCREENSHOT)->Enable(Running || Paused);
|
GetMenuBar()->FindItem(IDM_SCREENSHOT)->Enable(Running || Paused);
|
||||||
GetMenuBar()->FindItem(IDM_TOGGLE_FULLSCREEN)->Enable(Running || Paused);
|
GetMenuBar()->FindItem(IDM_TOGGLE_FULLSCREEN)->Enable(Running || Paused);
|
||||||
|
|
Loading…
Reference in New Issue