tastudio: move LastPositionFrame to TasMovie, prepare for another revision

This commit is contained in:
feos 2016-11-21 19:29:11 +03:00
parent 05d47a7318
commit eea49f1895
2 changed files with 26 additions and 9 deletions

View File

@ -56,6 +56,7 @@ namespace BizHawk.Client.Common
BindMarkersToInput = true;
CurrentBranch = -1;
LastPositionFrame = -1;
}
public TasMovie(bool startsFromSavestate = false, BackgroundWorker progressReportWorker = null)
@ -78,6 +79,7 @@ namespace BizHawk.Client.Common
BindMarkersToInput = true;
CurrentBranch = -1;
LastPositionFrame = -1;
}
public TasLagLog TasLagLog { get { return LagLog; } }
@ -85,11 +87,23 @@ namespace BizHawk.Client.Common
public TasMovieMarkerList Markers { get; set; }
public bool BindMarkersToInput { get; set; }
public bool UseInputCache { get; set; }
public bool LastPositionStable = true;
public string NewBranchText = "";
public int CurrentBranch { get; set; }
public int BranchCount { get { return Branches.Count; } }
/// <summary>
/// Separates "restore last position" logic from seeking caused by navigation.
/// TASEditor never kills LastPositionFrame, and it only pauses on it,
/// if it hasn't been greenzoned beforehand and middle mouse button was pressed.
/// </summary>
public int LastPositionFrame { get; set; }
/// <summary>
/// If user emulated a new frame, current edited segment may change
/// TASEditor lets LastPositionFrame be changed then
/// </summary>
public bool LastPositionStable = true;
public TasBranch GetBranch(int index)
{
if (index >= Branches.Count || index < 0)
@ -313,7 +327,6 @@ namespace BizHawk.Client.Common
{
if (Global.Emulator.Frame > LastValidFrame)
{
// emulated a new frame, current editing segment may change now. taseditor logic
LastPositionStable = false;
}

View File

@ -115,12 +115,17 @@ namespace BizHawk.Client.EmuHawk
get { return GlobalWin.MainForm; }
}
/// <summary>
/// Separates "restore last position" logic from seeking caused by navigation.
/// TASEditor never kills LastPositionFrame, and it only pauses on it,
/// if it hasn't been greenzoned beforehand and middle mouse button was pressed.
/// </summary>
public int LastPositionFrame { get; set; }
public int LastPositionFrame
{
get
{
return CurrentTasMovie.LastPositionFrame;
}
set
{
CurrentTasMovie.LastPositionFrame = value;
}
}
#region "Initializing"
@ -169,7 +174,6 @@ namespace BizHawk.Client.EmuHawk
TasView.PointedCellChanged += TasView_PointedCellChanged;
TasView.MultiSelect = true;
TasView.MaxCharactersInHorizontal = 1;
LastPositionFrame = -1;
}
private void AutosaveTimerEventProcessor(object sender, EventArgs e)