From b8295f1d9810e2396c6c5b91a2a732c79dd0e04c Mon Sep 17 00:00:00 2001 From: adelikat Date: Sat, 5 Sep 2015 22:04:26 -0400 Subject: [PATCH] Basic Bot - ability to replay best attempt --- .../tools/BasicBot/BasicBot.Designer.cs | 61 ++++++++++++------- .../tools/BasicBot/BasicBot.cs | 45 +++++++++++++- 2 files changed, 81 insertions(+), 25 deletions(-) diff --git a/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.Designer.cs b/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.Designer.cs index a92494ba8d..71d4018200 100644 --- a/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.Designer.cs +++ b/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.Designer.cs @@ -30,9 +30,12 @@ { this.BotMenu = new MenuStripEx(); this.fileToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.NewMenuItem = new System.Windows.Forms.ToolStripMenuItem(); this.OpenMenuItem = new System.Windows.Forms.ToolStripMenuItem(); this.SaveMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.SaveAsMenuItem = new System.Windows.Forms.ToolStripMenuItem(); this.RecentSubMenu = new System.Windows.Forms.ToolStripMenuItem(); + this.toolStripSeparator2 = new System.Windows.Forms.ToolStripSeparator(); this.toolStripSeparator1 = new System.Windows.Forms.ToolStripSeparator(); this.ExitMenuItem = new System.Windows.Forms.ToolStripMenuItem(); this.optionsToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem(); @@ -78,9 +81,7 @@ this.label8 = new System.Windows.Forms.Label(); this.StartFromSlotBox = new System.Windows.Forms.ComboBox(); this.ClearBestButton = new System.Windows.Forms.Button(); - this.SaveAsMenuItem = new System.Windows.Forms.ToolStripMenuItem(); - this.toolStripSeparator2 = new System.Windows.Forms.ToolStripSeparator(); - this.NewMenuItem = new System.Windows.Forms.ToolStripMenuItem(); + this.PlayBestButton = new System.Windows.Forms.Button(); this.BotMenu.SuspendLayout(); this.ControlsBox.SuspendLayout(); this.BestGroupBox.SuspendLayout(); @@ -115,6 +116,14 @@ this.fileToolStripMenuItem.Size = new System.Drawing.Size(37, 20); this.fileToolStripMenuItem.Text = "&File"; // + // NewMenuItem + // + this.NewMenuItem.Image = global::BizHawk.Client.EmuHawk.Properties.Resources.NewFile; + this.NewMenuItem.Name = "NewMenuItem"; + this.NewMenuItem.ShortcutKeys = ((System.Windows.Forms.Keys)((System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.N))); + this.NewMenuItem.Size = new System.Drawing.Size(195, 22); + this.NewMenuItem.Text = "&New"; + // // OpenMenuItem // this.OpenMenuItem.Image = global::BizHawk.Client.EmuHawk.Properties.Resources.OpenFile; @@ -131,6 +140,14 @@ this.SaveMenuItem.Size = new System.Drawing.Size(195, 22); this.SaveMenuItem.Text = "&Save"; // + // SaveAsMenuItem + // + this.SaveAsMenuItem.Name = "SaveAsMenuItem"; + this.SaveAsMenuItem.ShortcutKeys = ((System.Windows.Forms.Keys)(((System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Shift) + | System.Windows.Forms.Keys.S))); + this.SaveAsMenuItem.Size = new System.Drawing.Size(195, 22); + this.SaveAsMenuItem.Text = "Save &As..."; + // // RecentSubMenu // this.RecentSubMenu.DropDownItems.AddRange(new System.Windows.Forms.ToolStripItem[] { @@ -140,6 +157,11 @@ this.RecentSubMenu.Size = new System.Drawing.Size(195, 22); this.RecentSubMenu.Text = "Recent"; // + // toolStripSeparator2 + // + this.toolStripSeparator2.Name = "toolStripSeparator2"; + this.toolStripSeparator2.Size = new System.Drawing.Size(57, 6); + // // toolStripSeparator1 // this.toolStripSeparator1.Name = "toolStripSeparator1"; @@ -598,7 +620,7 @@ // this.ClearBestButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); this.ClearBestButton.Enabled = false; - this.ClearBestButton.Location = new System.Drawing.Point(490, 41); + this.ClearBestButton.Location = new System.Drawing.Point(490, 38); this.ClearBestButton.Name = "ClearBestButton"; this.ClearBestButton.Size = new System.Drawing.Size(75, 23); this.ClearBestButton.TabIndex = 2003; @@ -606,32 +628,24 @@ this.ClearBestButton.UseVisualStyleBackColor = true; this.ClearBestButton.Click += new System.EventHandler(this.ClearBestButton_Click); // - // SaveAsMenuItem + // PlayBestButton // - this.SaveAsMenuItem.Name = "SaveAsMenuItem"; - this.SaveAsMenuItem.ShortcutKeys = ((System.Windows.Forms.Keys)(((System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.Shift) - | System.Windows.Forms.Keys.S))); - this.SaveAsMenuItem.Size = new System.Drawing.Size(195, 22); - this.SaveAsMenuItem.Text = "Save &As..."; - // - // toolStripSeparator2 - // - this.toolStripSeparator2.Name = "toolStripSeparator2"; - this.toolStripSeparator2.Size = new System.Drawing.Size(149, 6); - // - // NewMenuItem - // - this.NewMenuItem.Image = global::BizHawk.Client.EmuHawk.Properties.Resources.NewFile; - this.NewMenuItem.Name = "NewMenuItem"; - this.NewMenuItem.ShortcutKeys = ((System.Windows.Forms.Keys)((System.Windows.Forms.Keys.Control | System.Windows.Forms.Keys.N))); - this.NewMenuItem.Size = new System.Drawing.Size(195, 22); - this.NewMenuItem.Text = "&New"; + this.PlayBestButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right))); + this.PlayBestButton.Enabled = false; + this.PlayBestButton.Location = new System.Drawing.Point(490, 66); + this.PlayBestButton.Name = "PlayBestButton"; + this.PlayBestButton.Size = new System.Drawing.Size(75, 23); + this.PlayBestButton.TabIndex = 2004; + this.PlayBestButton.Text = "&Play"; + this.PlayBestButton.UseVisualStyleBackColor = true; + this.PlayBestButton.Click += new System.EventHandler(this.PlayBestButton_Click); // // BasicBot // this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.ClientSize = new System.Drawing.Size(574, 552); + this.Controls.Add(this.PlayBestButton); this.Controls.Add(this.ClearBestButton); this.Controls.Add(this.StartFromSlotBox); this.Controls.Add(this.label8); @@ -721,5 +735,6 @@ private System.Windows.Forms.ToolStripMenuItem SaveAsMenuItem; private System.Windows.Forms.ToolStripSeparator toolStripSeparator2; private System.Windows.Forms.ToolStripMenuItem NewMenuItem; + private System.Windows.Forms.Button PlayBestButton; } } \ No newline at end of file diff --git a/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.cs b/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.cs index ccde346f83..72fd3a645f 100644 --- a/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.cs +++ b/BizHawk.Client.EmuHawk/tools/BasicBot/BasicBot.cs @@ -20,6 +20,8 @@ namespace BizHawk.Client.EmuHawk private bool _oldCountingSetting = false; private BotAttempt _currentBotAttempt = null; private BotAttempt _bestBotAttempt = null; + private bool _replayMode = false; + private int _startFrame = 0; private bool _dontUpdateValues = false; @@ -235,6 +237,16 @@ namespace BizHawk.Client.EmuHawk UpdateBestAttempt(); } + private void PlayBestButton_Click(object sender, EventArgs e) + { + _replayMode = true; + _dontUpdateValues = true; + GlobalWin.MainForm.LoadQuickSave(SelectedSlot); // Triggers an UpdateValues call + _dontUpdateValues = false; + _startFrame = Emulator.Frame; + GlobalWin.MainForm.UnpauseEmulator(); + } + #endregion private class BotAttempt @@ -261,7 +273,36 @@ namespace BizHawk.Client.EmuHawk private void Update(bool fast) { - if (_isBotting && !_dontUpdateValues) + if (_dontUpdateValues) + { + return; + } + + if (_replayMode) + { + int index = Emulator.Frame - _startFrame; + + if (index < _bestBotAttempt.Log.Count) + { + var logEntry = _bestBotAttempt.Log[index]; + var lg = Global.MovieSession.MovieControllerInstance(); + lg.SetControllersAsMnemonic(logEntry); + + foreach (var button in lg.Type.BoolButtons) + { + // TODO: make an input adapter specifically for the bot? + Global.LuaAndAdaptor.SetButton(button, lg.IsPressed(button)); + } + } + else // Finished + { + GlobalWin.MainForm.PauseEmulator(); + _startFrame = 0; + _replayMode = false; + + } + } + else if (_isBotting) { if (Global.Emulator.Frame >= _targetFrame) { @@ -272,6 +313,7 @@ namespace BizHawk.Client.EmuHawk _currentBotAttempt.TieBreak1 = TieBreaker1Value; _currentBotAttempt.TieBreak2 = TieBreaker2Value; _currentBotAttempt.TieBreak3 = TieBreaker3Value; + PlayBestButton.Enabled = true; if (_bestBotAttempt == null || IsBetter(_bestBotAttempt, _currentBotAttempt)) { @@ -378,7 +420,6 @@ namespace BizHawk.Client.EmuHawk return; } - _isBotting = true; ControlsBox.Enabled = false; StartFromSlotBox.Enabled = false;