[Android] Handle end emulation better
This commit is contained in:
parent
78a89f4bde
commit
084cdaef52
|
@ -47,7 +47,7 @@ import android.view.WindowManager.LayoutParams;
|
||||||
|
|
||||||
public class GameLifecycleHandler implements SurfaceHolder.Callback, GameSurface.SurfaceInfo
|
public class GameLifecycleHandler implements SurfaceHolder.Callback, GameSurface.SurfaceInfo
|
||||||
{
|
{
|
||||||
private final static boolean LOG_GAMELIFECYCLEHANDLER = true;
|
private final static boolean LOG_GAMELIFECYCLEHANDLER = false;
|
||||||
|
|
||||||
// Activity and views
|
// Activity and views
|
||||||
private Activity mActivity;
|
private Activity mActivity;
|
||||||
|
@ -214,27 +214,44 @@ public class GameLifecycleHandler implements SurfaceHolder.Callback, GameSurface
|
||||||
}
|
}
|
||||||
if (NativeExports.SettingsLoadBool(SettingsID.GameRunning_CPU_Running.getValue()) == true)
|
if (NativeExports.SettingsLoadBool(SettingsID.GameRunning_CPU_Running.getValue()) == true)
|
||||||
{
|
{
|
||||||
int CurrentSaveState = NativeExports.SettingsLoadDword(SettingsID.Game_CurrentSaveState.getValue());
|
Boolean pause = false;
|
||||||
int OriginalSaveTime = NativeExports.SettingsLoadDword(SettingsID.Game_LastSaveTime.getValue());
|
int PauseType = 0;
|
||||||
NativeExports.SettingsSaveDword(SettingsID.Game_CurrentSaveState.getValue(), 0);
|
if (NativeExports.SettingsLoadBool(SettingsID.GameRunning_CPU_Paused.getValue()) == true)
|
||||||
NativeExports.ExternalEvent(SystemEvent.SysEvent_SaveMachineState.getValue());
|
{
|
||||||
for (int i = 0; i < 100; i++)
|
pause = true;
|
||||||
{
|
PauseType = NativeExports.SettingsLoadDword(SettingsID.GameRunning_CPU_PausedType.getValue());
|
||||||
int LastSaveTime = NativeExports.SettingsLoadDword(SettingsID.Game_LastSaveTime.getValue());
|
NativeExports.ExternalEvent( SystemEvent.SysEvent_ResumeCPU_FromMenu.getValue());
|
||||||
if (LastSaveTime != OriginalSaveTime)
|
}
|
||||||
{
|
int CurrentSaveState = NativeExports.SettingsLoadDword(SettingsID.Game_CurrentSaveState.getValue());
|
||||||
break;
|
int OriginalSaveTime = NativeExports.SettingsLoadDword(SettingsID.Game_LastSaveTime.getValue());
|
||||||
}
|
NativeExports.SettingsSaveDword(SettingsID.Game_CurrentSaveState.getValue(), 0);
|
||||||
try
|
NativeExports.ExternalEvent(SystemEvent.SysEvent_SaveMachineState.getValue());
|
||||||
{
|
for (int i = 0; i < 100; i++)
|
||||||
Thread.sleep(100);
|
{
|
||||||
}
|
int LastSaveTime = NativeExports.SettingsLoadDword(SettingsID.Game_LastSaveTime.getValue());
|
||||||
catch(InterruptedException ex)
|
if (LOG_GAMELIFECYCLEHANDLER)
|
||||||
{
|
{
|
||||||
Thread.currentThread().interrupt();
|
Log.i("GameLifecycleHandler", "LastSaveTime = " + LastSaveTime + " OriginalSaveTime = " + OriginalSaveTime);
|
||||||
}
|
}
|
||||||
}
|
if (LastSaveTime != OriginalSaveTime)
|
||||||
NativeExports.SettingsSaveDword(SettingsID.Game_CurrentSaveState.getValue(), CurrentSaveState);
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
Thread.sleep(100);
|
||||||
|
}
|
||||||
|
catch(InterruptedException ex)
|
||||||
|
{
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
NativeExports.SettingsSaveDword(SettingsID.Game_CurrentSaveState.getValue(), CurrentSaveState);
|
||||||
|
if (pause)
|
||||||
|
{
|
||||||
|
NativeExports.ExternalEvent( SystemEvent.SysEvent_PauseCPU_FromMenu.getValue());
|
||||||
|
NativeExports.SettingsSaveDword(SettingsID.GameRunning_CPU_PausedType.getValue(), PauseType);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (LOG_GAMELIFECYCLEHANDLER)
|
else if (LOG_GAMELIFECYCLEHANDLER)
|
||||||
{
|
{
|
||||||
|
@ -254,19 +271,13 @@ public class GameLifecycleHandler implements SurfaceHolder.Callback, GameSurface
|
||||||
Log.i("GameLifecycleHandler", "onPause");
|
Log.i("GameLifecycleHandler", "onPause");
|
||||||
}
|
}
|
||||||
mIsResumed = false;
|
mIsResumed = false;
|
||||||
mStopped = true;
|
|
||||||
if (NativeExports.SettingsLoadBool(SettingsID.GameRunning_CPU_Running.getValue()) == true)
|
if (NativeExports.SettingsLoadBool(SettingsID.GameRunning_CPU_Running.getValue()) == true)
|
||||||
{
|
{
|
||||||
AutoSave();
|
AutoSave();
|
||||||
if (LOG_GAMELIFECYCLEHANDLER)
|
}
|
||||||
{
|
|
||||||
Log.i("GameLifecycleHandler", "Stop Emulation");
|
|
||||||
}
|
|
||||||
NativeExports.StopEmulation();
|
|
||||||
}
|
|
||||||
if (LOG_GAMELIFECYCLEHANDLER)
|
if (LOG_GAMELIFECYCLEHANDLER)
|
||||||
{
|
{
|
||||||
Log.i("GameLifecycleHandler", "onPause - done");
|
Log.i("GameLifecycleHandler", "onPause - done");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue