From 1b8a51e447da842dc265ecbd126d0a8085c81e70 Mon Sep 17 00:00:00 2001 From: zeromus Date: Tue, 29 Mar 2016 03:40:37 -0500 Subject: [PATCH] rework sound config dialog and sound volume control to permit independent control of volume during FF & RW, and independent toggling of sound synthesis vs volume=0 suppression --- BizHawk.Client.Common/config/Config.cs | 3 + BizHawk.Client.EmuHawk/MainForm.cs | 23 +- BizHawk.Client.EmuHawk/Sound/Sound.cs | 26 +- .../config/SoundConfig.Designer.cs | 263 ++++++++++++------ BizHawk.Client.EmuHawk/config/SoundConfig.cs | 47 ++-- 5 files changed, 249 insertions(+), 113 deletions(-) diff --git a/BizHawk.Client.Common/config/Config.cs b/BizHawk.Client.Common/config/Config.cs index fe04fc50d6..d79c22e67e 100644 --- a/BizHawk.Client.Common/config/Config.cs +++ b/BizHawk.Client.Common/config/Config.cs @@ -329,8 +329,11 @@ namespace BizHawk.Client.Common public ESoundOutputMethod SoundOutputMethod = ESoundOutputMethod.OpenAL; #endif public bool SoundEnabled = true; + public bool SoundEnabledNormal = true; + public bool SoundEnabledRWFF = true; public bool MuteFrameAdvance = true; public int SoundVolume = 100; // Range 0-100 + public int SoundVolumeRWFF = 50; // Range 0-100 public bool SoundThrottle = false; public string SoundDevice = ""; public int SoundBufferSizeMs = 100; diff --git a/BizHawk.Client.EmuHawk/MainForm.cs b/BizHawk.Client.EmuHawk/MainForm.cs index 28f8f583b8..b0987245ed 100644 --- a/BizHawk.Client.EmuHawk/MainForm.cs +++ b/BizHawk.Client.EmuHawk/MainForm.cs @@ -2181,7 +2181,7 @@ namespace BizHawk.Client.EmuHawk Global.Config.SoundVolume = 100; } - GlobalWin.Sound.ApplyVolumeSettings(); + //GlobalWin.Sound.ApplyVolumeSettings(); GlobalWin.OSD.AddMessage("Volume " + Global.Config.SoundVolume); } @@ -2193,7 +2193,7 @@ namespace BizHawk.Client.EmuHawk Global.Config.SoundVolume = 0; } - GlobalWin.Sound.ApplyVolumeSettings(); + //GlobalWin.Sound.ApplyVolumeSettings(); GlobalWin.OSD.AddMessage("Volume " + Global.Config.SoundVolume); } @@ -2731,7 +2731,10 @@ namespace BizHawk.Client.EmuHawk runFrame = true; } - var genSound = false; + float atten = Global.Config.SoundVolume / 100.0f; + if (!Global.Config.SoundEnabledNormal) + atten = 0; + var coreskipaudio = false; if (runFrame || force) { @@ -2806,11 +2809,18 @@ namespace BizHawk.Client.EmuHawk if (!_runloopFrameadvance) { - genSound = true; + } else if (!Global.Config.MuteFrameAdvance) { - genSound = true; + atten = 0; + } + + if (isFastForwarding || IsTurboing || isRewinding) + { + atten *= Global.Config.SoundVolumeRWFF / 100.0f; + if (!Global.Config.SoundEnabledRWFF) + atten = 0; } Global.MovieSession.HandleMovieOnFrameLoop(); @@ -2883,8 +2893,7 @@ namespace BizHawk.Client.EmuHawk UpdateFrame = false; } - bool outputSilence = !genSound || coreskipaudio; - GlobalWin.Sound.UpdateSound(outputSilence); + GlobalWin.Sound.UpdateSound(atten); } #endregion diff --git a/BizHawk.Client.EmuHawk/Sound/Sound.cs b/BizHawk.Client.EmuHawk/Sound/Sound.cs index c8a607172d..d3fa5d96b9 100644 --- a/BizHawk.Client.EmuHawk/Sound/Sound.cs +++ b/BizHawk.Client.EmuHawk/Sound/Sound.cs @@ -67,7 +67,7 @@ namespace BizHawk.Client.EmuHawk IsStarted = true; - ApplyVolumeSettings(); + //ApplyVolumeSettings(); //LogUnderruns = true; //_outputProvider.LogDebug = true; @@ -86,15 +86,15 @@ namespace BizHawk.Client.EmuHawk IsStarted = false; } - public void ApplyVolumeSettings() - { - if (!IsStarted) return; + //public void ApplyVolumeSettings() + //{ + // if (!IsStarted) return; - double volume = Global.Config.SoundVolume / 100.0; - if (volume < 0.0) volume = 0.0; - if (volume > 1.0) volume = 1.0; - _soundOutput.ApplyVolumeSettings(volume); - } + // double volume = Global.Config.SoundVolume / 100.0; + // if (volume < 0.0) volume = 0.0; + // if (volume > 1.0) volume = 1.0; + // _soundOutput.ApplyVolumeSettings(volume); + //} public void SetSyncInputPin(ISyncSoundProvider source) { @@ -165,7 +165,7 @@ namespace BizHawk.Client.EmuHawk _outputProvider.OnVolatility(); } - public void UpdateSound(bool outputSilence) + public void UpdateSound(float atten) { if (!Global.Config.SoundEnabled || !IsStarted || _disposed) { @@ -175,11 +175,15 @@ namespace BizHawk.Client.EmuHawk return; } + if (atten < 0) atten = 0; + if (atten > 1) atten = 1; + _soundOutput.ApplyVolumeSettings(atten); + short[] samples; int samplesNeeded = _soundOutput.CalculateSamplesNeeded(); int samplesProvided; - if (outputSilence) + if (atten==0) { samples = new short[samplesNeeded * ChannelCount]; samplesProvided = samplesNeeded; diff --git a/BizHawk.Client.EmuHawk/config/SoundConfig.Designer.cs b/BizHawk.Client.EmuHawk/config/SoundConfig.Designer.cs index de875633f1..0fca0ca910 100644 --- a/BizHawk.Client.EmuHawk/config/SoundConfig.Designer.cs +++ b/BizHawk.Client.EmuHawk/config/SoundConfig.Designer.cs @@ -30,23 +30,32 @@ { this.Cancel = new System.Windows.Forms.Button(); this.OK = new System.Windows.Forms.Button(); - this.SoundOnCheckBox = new System.Windows.Forms.CheckBox(); - this.MuteFrameAdvance = new System.Windows.Forms.CheckBox(); - this.SoundVolGroup = new System.Windows.Forms.GroupBox(); - this.SoundVolBar = new System.Windows.Forms.TrackBar(); - this.SoundVolNumeric = new System.Windows.Forms.NumericUpDown(); + this.cbEnableNormal = new System.Windows.Forms.CheckBox(); + this.grpSoundVol = new System.Windows.Forms.GroupBox(); + this.nudRWFF = new System.Windows.Forms.NumericUpDown(); + this.cbEnableRWFF = new System.Windows.Forms.CheckBox(); + this.tbRWFF = new System.Windows.Forms.TrackBar(); + this.label2 = new System.Windows.Forms.Label(); + this.label1 = new System.Windows.Forms.Label(); + this.tbNormal = new System.Windows.Forms.TrackBar(); + this.nudNormal = new System.Windows.Forms.NumericUpDown(); this.listBoxSoundDevices = new System.Windows.Forms.ListBox(); this.SoundDeviceLabel = new System.Windows.Forms.Label(); this.BufferSizeLabel = new System.Windows.Forms.Label(); this.BufferSizeNumeric = new System.Windows.Forms.NumericUpDown(); this.BufferSizeUnitsLabel = new System.Windows.Forms.Label(); this.grpOutputMethod = new System.Windows.Forms.GroupBox(); + this.rbOutputMethodOpenAL = new System.Windows.Forms.RadioButton(); this.rbOutputMethodXAudio2 = new System.Windows.Forms.RadioButton(); this.rbOutputMethodDirectSound = new System.Windows.Forms.RadioButton(); - this.rbOutputMethodOpenAL = new System.Windows.Forms.RadioButton(); - this.SoundVolGroup.SuspendLayout(); - ((System.ComponentModel.ISupportInitialize)(this.SoundVolBar)).BeginInit(); - ((System.ComponentModel.ISupportInitialize)(this.SoundVolNumeric)).BeginInit(); + this.cbMuteFrameAdvance = new System.Windows.Forms.CheckBox(); + this.cbEnableMaster = new System.Windows.Forms.CheckBox(); + this.label3 = new System.Windows.Forms.Label(); + this.grpSoundVol.SuspendLayout(); + ((System.ComponentModel.ISupportInitialize)(this.nudRWFF)).BeginInit(); + ((System.ComponentModel.ISupportInitialize)(this.tbRWFF)).BeginInit(); + ((System.ComponentModel.ISupportInitialize)(this.tbNormal)).BeginInit(); + ((System.ComponentModel.ISupportInitialize)(this.nudNormal)).BeginInit(); ((System.ComponentModel.ISupportInitialize)(this.BufferSizeNumeric)).BeginInit(); this.grpOutputMethod.SuspendLayout(); this.SuspendLayout(); @@ -74,57 +83,112 @@ this.OK.UseVisualStyleBackColor = true; this.OK.Click += new System.EventHandler(this.OK_Click); // - // SoundOnCheckBox + // cbEnableNormal // - this.SoundOnCheckBox.AutoSize = true; - this.SoundOnCheckBox.Location = new System.Drawing.Point(108, 31); - this.SoundOnCheckBox.Name = "SoundOnCheckBox"; - this.SoundOnCheckBox.Size = new System.Drawing.Size(74, 17); - this.SoundOnCheckBox.TabIndex = 3; - this.SoundOnCheckBox.Text = "Sound On"; - this.SoundOnCheckBox.UseVisualStyleBackColor = true; - this.SoundOnCheckBox.CheckedChanged += new System.EventHandler(this.SoundOnCheckBox_CheckedChanged); + this.cbEnableNormal.AutoSize = true; + this.cbEnableNormal.Location = new System.Drawing.Point(6, 20); + this.cbEnableNormal.Name = "cbEnableNormal"; + this.cbEnableNormal.Size = new System.Drawing.Size(48, 17); + this.cbEnableNormal.TabIndex = 3; + this.cbEnableNormal.Text = "Ena."; + this.cbEnableNormal.UseVisualStyleBackColor = true; + this.cbEnableNormal.CheckedChanged += new System.EventHandler(this.UpdateSoundDialog); // - // MuteFrameAdvance + // grpSoundVol // - this.MuteFrameAdvance.AutoSize = true; - this.MuteFrameAdvance.Location = new System.Drawing.Point(108, 54); - this.MuteFrameAdvance.Name = "MuteFrameAdvance"; - this.MuteFrameAdvance.Size = new System.Drawing.Size(128, 17); - this.MuteFrameAdvance.TabIndex = 4; - this.MuteFrameAdvance.Text = "Mute Frame Advance"; - this.MuteFrameAdvance.UseVisualStyleBackColor = true; + this.grpSoundVol.Controls.Add(this.nudRWFF); + this.grpSoundVol.Controls.Add(this.cbEnableRWFF); + this.grpSoundVol.Controls.Add(this.tbRWFF); + this.grpSoundVol.Controls.Add(this.label2); + this.grpSoundVol.Controls.Add(this.label1); + this.grpSoundVol.Controls.Add(this.tbNormal); + this.grpSoundVol.Controls.Add(this.nudNormal); + this.grpSoundVol.Controls.Add(this.cbEnableNormal); + this.grpSoundVol.Location = new System.Drawing.Point(12, 12); + this.grpSoundVol.Name = "grpSoundVol"; + this.grpSoundVol.Size = new System.Drawing.Size(117, 255); + this.grpSoundVol.TabIndex = 2; + this.grpSoundVol.TabStop = false; + this.grpSoundVol.Text = "Volume"; // - // SoundVolGroup + // nudRWFF // - this.SoundVolGroup.Controls.Add(this.SoundVolBar); - this.SoundVolGroup.Controls.Add(this.SoundVolNumeric); - this.SoundVolGroup.Location = new System.Drawing.Point(12, 12); - this.SoundVolGroup.Name = "SoundVolGroup"; - this.SoundVolGroup.Size = new System.Drawing.Size(90, 219); - this.SoundVolGroup.TabIndex = 2; - this.SoundVolGroup.TabStop = false; - this.SoundVolGroup.Text = "Volume"; + this.nudRWFF.Location = new System.Drawing.Point(58, 223); + this.nudRWFF.Name = "nudRWFF"; + this.nudRWFF.Size = new System.Drawing.Size(45, 20); + this.nudRWFF.TabIndex = 15; + this.nudRWFF.Value = new decimal(new int[] { + 100, + 0, + 0, + 0}); // - // SoundVolBar + // cbEnableRWFF // - this.SoundVolBar.LargeChange = 10; - this.SoundVolBar.Location = new System.Drawing.Point(23, 23); - this.SoundVolBar.Maximum = 100; - this.SoundVolBar.Name = "SoundVolBar"; - this.SoundVolBar.Orientation = System.Windows.Forms.Orientation.Vertical; - this.SoundVolBar.Size = new System.Drawing.Size(45, 164); - this.SoundVolBar.TabIndex = 0; - this.SoundVolBar.TickFrequency = 10; - this.SoundVolBar.Scroll += new System.EventHandler(this.trackBar1_Scroll); + this.cbEnableRWFF.AutoSize = true; + this.cbEnableRWFF.Location = new System.Drawing.Point(58, 20); + this.cbEnableRWFF.Name = "cbEnableRWFF"; + this.cbEnableRWFF.Size = new System.Drawing.Size(48, 17); + this.cbEnableRWFF.TabIndex = 14; + this.cbEnableRWFF.Text = "Ena."; + this.cbEnableRWFF.UseVisualStyleBackColor = true; // - // SoundVolNumeric + // tbRWFF // - this.SoundVolNumeric.Location = new System.Drawing.Point(16, 190); - this.SoundVolNumeric.Name = "SoundVolNumeric"; - this.SoundVolNumeric.Size = new System.Drawing.Size(59, 20); - this.SoundVolNumeric.TabIndex = 1; - this.SoundVolNumeric.ValueChanged += new System.EventHandler(this.SoundVolNumeric_ValueChanged); + this.tbRWFF.LargeChange = 10; + this.tbRWFF.Location = new System.Drawing.Point(64, 53); + this.tbRWFF.Maximum = 100; + this.tbRWFF.Name = "tbRWFF"; + this.tbRWFF.Orientation = System.Windows.Forms.Orientation.Vertical; + this.tbRWFF.Size = new System.Drawing.Size(42, 164); + this.tbRWFF.TabIndex = 13; + this.tbRWFF.TickFrequency = 10; + this.tbRWFF.Scroll += new System.EventHandler(this.tbRWFF_Scroll); + // + // label2 + // + this.label2.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); + this.label2.AutoSize = true; + this.label2.Location = new System.Drawing.Point(56, 42); + this.label2.Name = "label2"; + this.label2.Size = new System.Drawing.Size(50, 13); + this.label2.TabIndex = 12; + this.label2.Text = "RW && FF"; + // + // label1 + // + this.label1.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); + this.label1.AutoSize = true; + this.label1.Location = new System.Drawing.Point(6, 42); + this.label1.Name = "label1"; + this.label1.Size = new System.Drawing.Size(40, 13); + this.label1.TabIndex = 11; + this.label1.Text = "Normal"; + // + // tbNormal + // + this.tbNormal.LargeChange = 10; + this.tbNormal.Location = new System.Drawing.Point(8, 53); + this.tbNormal.Maximum = 100; + this.tbNormal.Name = "tbNormal"; + this.tbNormal.Orientation = System.Windows.Forms.Orientation.Vertical; + this.tbNormal.Size = new System.Drawing.Size(42, 164); + this.tbNormal.TabIndex = 0; + this.tbNormal.TickFrequency = 10; + this.tbNormal.Scroll += new System.EventHandler(this.trackBar1_Scroll); + // + // nudNormal + // + this.nudNormal.Location = new System.Drawing.Point(5, 223); + this.nudNormal.Name = "nudNormal"; + this.nudNormal.Size = new System.Drawing.Size(45, 20); + this.nudNormal.TabIndex = 1; + this.nudNormal.Value = new decimal(new int[] { + 100, + 0, + 0, + 0}); + this.nudNormal.ValueChanged += new System.EventHandler(this.SoundVolNumeric_ValueChanged); // // listBoxSoundDevices // @@ -132,15 +196,15 @@ | System.Windows.Forms.AnchorStyles.Left) | System.Windows.Forms.AnchorStyles.Right))); this.listBoxSoundDevices.FormattingEnabled = true; - this.listBoxSoundDevices.Location = new System.Drawing.Point(108, 108); + this.listBoxSoundDevices.Location = new System.Drawing.Point(138, 110); this.listBoxSoundDevices.Name = "listBoxSoundDevices"; - this.listBoxSoundDevices.Size = new System.Drawing.Size(284, 95); + this.listBoxSoundDevices.Size = new System.Drawing.Size(254, 95); this.listBoxSoundDevices.TabIndex = 7; // // SoundDeviceLabel // this.SoundDeviceLabel.AutoSize = true; - this.SoundDeviceLabel.Location = new System.Drawing.Point(105, 92); + this.SoundDeviceLabel.Location = new System.Drawing.Point(135, 89); this.SoundDeviceLabel.Name = "SoundDeviceLabel"; this.SoundDeviceLabel.Size = new System.Drawing.Size(78, 13); this.SoundDeviceLabel.TabIndex = 6; @@ -150,7 +214,7 @@ // this.BufferSizeLabel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); this.BufferSizeLabel.AutoSize = true; - this.BufferSizeLabel.Location = new System.Drawing.Point(105, 213); + this.BufferSizeLabel.Location = new System.Drawing.Point(135, 210); this.BufferSizeLabel.Name = "BufferSizeLabel"; this.BufferSizeLabel.Size = new System.Drawing.Size(61, 13); this.BufferSizeLabel.TabIndex = 8; @@ -159,7 +223,7 @@ // BufferSizeNumeric // this.BufferSizeNumeric.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); - this.BufferSizeNumeric.Location = new System.Drawing.Point(172, 211); + this.BufferSizeNumeric.Location = new System.Drawing.Point(202, 208); this.BufferSizeNumeric.Maximum = new decimal(new int[] { 250, 0, @@ -183,7 +247,7 @@ // this.BufferSizeUnitsLabel.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); this.BufferSizeUnitsLabel.AutoSize = true; - this.BufferSizeUnitsLabel.Location = new System.Drawing.Point(237, 213); + this.BufferSizeUnitsLabel.Location = new System.Drawing.Point(267, 210); this.BufferSizeUnitsLabel.Name = "BufferSizeUnitsLabel"; this.BufferSizeUnitsLabel.Size = new System.Drawing.Size(63, 13); this.BufferSizeUnitsLabel.TabIndex = 10; @@ -201,6 +265,18 @@ this.grpOutputMethod.TabStop = false; this.grpOutputMethod.Text = "Output Method"; // + // rbOutputMethodOpenAL + // + this.rbOutputMethodOpenAL.AutoSize = true; + this.rbOutputMethodOpenAL.Location = new System.Drawing.Point(6, 65); + this.rbOutputMethodOpenAL.Name = "rbOutputMethodOpenAL"; + this.rbOutputMethodOpenAL.Size = new System.Drawing.Size(64, 17); + this.rbOutputMethodOpenAL.TabIndex = 2; + this.rbOutputMethodOpenAL.TabStop = true; + this.rbOutputMethodOpenAL.Text = "OpenAL"; + this.rbOutputMethodOpenAL.UseVisualStyleBackColor = true; + this.rbOutputMethodOpenAL.CheckedChanged += new System.EventHandler(this.OutputMethodRadioButtons_CheckedChanged); + // // rbOutputMethodXAudio2 // this.rbOutputMethodXAudio2.AutoSize = true; @@ -225,17 +301,35 @@ this.rbOutputMethodDirectSound.UseVisualStyleBackColor = true; this.rbOutputMethodDirectSound.CheckedChanged += new System.EventHandler(this.OutputMethodRadioButtons_CheckedChanged); // - // rbOutputMethodOpenAL + // cbMuteFrameAdvance // - this.rbOutputMethodOpenAL.AutoSize = true; - this.rbOutputMethodOpenAL.Location = new System.Drawing.Point(6, 65); - this.rbOutputMethodOpenAL.Name = "rbOutputMethodOpenAL"; - this.rbOutputMethodOpenAL.Size = new System.Drawing.Size(64, 17); - this.rbOutputMethodOpenAL.TabIndex = 2; - this.rbOutputMethodOpenAL.TabStop = true; - this.rbOutputMethodOpenAL.Text = "OpenAL"; - this.rbOutputMethodOpenAL.UseVisualStyleBackColor = true; - this.rbOutputMethodOpenAL.CheckedChanged += new System.EventHandler(this.OutputMethodRadioButtons_CheckedChanged); + this.cbMuteFrameAdvance.AutoSize = true; + this.cbMuteFrameAdvance.Location = new System.Drawing.Point(139, 68); + this.cbMuteFrameAdvance.Name = "cbMuteFrameAdvance"; + this.cbMuteFrameAdvance.Size = new System.Drawing.Size(128, 17); + this.cbMuteFrameAdvance.TabIndex = 17; + this.cbMuteFrameAdvance.Text = "Mute Frame Advance"; + this.cbMuteFrameAdvance.UseVisualStyleBackColor = true; + // + // cbEnableMaster + // + this.cbEnableMaster.AutoSize = true; + this.cbEnableMaster.Location = new System.Drawing.Point(139, 16); + this.cbEnableMaster.Name = "cbEnableMaster"; + this.cbEnableMaster.Size = new System.Drawing.Size(128, 17); + this.cbEnableMaster.TabIndex = 18; + this.cbEnableMaster.Text = "Sound Master Enable"; + this.cbEnableMaster.UseVisualStyleBackColor = true; + this.cbEnableMaster.CheckedChanged += new System.EventHandler(this.UpdateSoundDialog); + // + // label3 + // + this.label3.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left))); + this.label3.Location = new System.Drawing.Point(161, 35); + this.label3.Name = "label3"; + this.label3.Size = new System.Drawing.Size(126, 26); + this.label3.TabIndex = 19; + this.label3.Text = "Controls whether cores even generate audio."; // // SoundConfig // @@ -244,27 +338,31 @@ this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.CancelButton = this.Cancel; this.ClientSize = new System.Drawing.Size(404, 279); + this.Controls.Add(this.label3); + this.Controls.Add(this.cbEnableMaster); + this.Controls.Add(this.cbMuteFrameAdvance); this.Controls.Add(this.grpOutputMethod); this.Controls.Add(this.BufferSizeUnitsLabel); this.Controls.Add(this.BufferSizeNumeric); this.Controls.Add(this.BufferSizeLabel); this.Controls.Add(this.SoundDeviceLabel); this.Controls.Add(this.listBoxSoundDevices); - this.Controls.Add(this.SoundVolGroup); - this.Controls.Add(this.MuteFrameAdvance); - this.Controls.Add(this.SoundOnCheckBox); + this.Controls.Add(this.grpSoundVol); this.Controls.Add(this.OK); this.Controls.Add(this.Cancel); + this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; this.MinimumSize = new System.Drawing.Size(279, 259); this.Name = "SoundConfig"; this.ShowIcon = false; this.StartPosition = System.Windows.Forms.FormStartPosition.CenterParent; this.Text = "Sound Configuration"; this.Load += new System.EventHandler(this.SoundConfig_Load); - this.SoundVolGroup.ResumeLayout(false); - this.SoundVolGroup.PerformLayout(); - ((System.ComponentModel.ISupportInitialize)(this.SoundVolBar)).EndInit(); - ((System.ComponentModel.ISupportInitialize)(this.SoundVolNumeric)).EndInit(); + this.grpSoundVol.ResumeLayout(false); + this.grpSoundVol.PerformLayout(); + ((System.ComponentModel.ISupportInitialize)(this.nudRWFF)).EndInit(); + ((System.ComponentModel.ISupportInitialize)(this.tbRWFF)).EndInit(); + ((System.ComponentModel.ISupportInitialize)(this.tbNormal)).EndInit(); + ((System.ComponentModel.ISupportInitialize)(this.nudNormal)).EndInit(); ((System.ComponentModel.ISupportInitialize)(this.BufferSizeNumeric)).EndInit(); this.grpOutputMethod.ResumeLayout(false); this.grpOutputMethod.PerformLayout(); @@ -277,11 +375,10 @@ private System.Windows.Forms.Button Cancel; private System.Windows.Forms.Button OK; - private System.Windows.Forms.CheckBox SoundOnCheckBox; - private System.Windows.Forms.CheckBox MuteFrameAdvance; - private System.Windows.Forms.GroupBox SoundVolGroup; - private System.Windows.Forms.NumericUpDown SoundVolNumeric; - private System.Windows.Forms.TrackBar SoundVolBar; + private System.Windows.Forms.CheckBox cbEnableNormal; + private System.Windows.Forms.GroupBox grpSoundVol; + private System.Windows.Forms.NumericUpDown nudNormal; + private System.Windows.Forms.TrackBar tbNormal; private System.Windows.Forms.ListBox listBoxSoundDevices; private System.Windows.Forms.Label SoundDeviceLabel; private System.Windows.Forms.Label BufferSizeLabel; @@ -291,5 +388,13 @@ private System.Windows.Forms.RadioButton rbOutputMethodXAudio2; private System.Windows.Forms.RadioButton rbOutputMethodDirectSound; private System.Windows.Forms.RadioButton rbOutputMethodOpenAL; + private System.Windows.Forms.NumericUpDown nudRWFF; + private System.Windows.Forms.CheckBox cbEnableRWFF; + private System.Windows.Forms.TrackBar tbRWFF; + private System.Windows.Forms.Label label2; + private System.Windows.Forms.Label label1; + private System.Windows.Forms.CheckBox cbMuteFrameAdvance; + private System.Windows.Forms.CheckBox cbEnableMaster; + private System.Windows.Forms.Label label3; } } \ No newline at end of file diff --git a/BizHawk.Client.EmuHawk/config/SoundConfig.cs b/BizHawk.Client.EmuHawk/config/SoundConfig.cs index 1e3180377e..31b5b4f189 100644 --- a/BizHawk.Client.EmuHawk/config/SoundConfig.cs +++ b/BizHawk.Client.EmuHawk/config/SoundConfig.cs @@ -20,8 +20,10 @@ namespace BizHawk.Client.EmuHawk { _programmaticallyChangingValue = true; - SoundOnCheckBox.Checked = Global.Config.SoundEnabled; - MuteFrameAdvance.Checked = Global.Config.MuteFrameAdvance; + cbEnableMaster.Checked = Global.Config.SoundEnabled; + cbEnableNormal.Checked = Global.Config.SoundEnabledNormal; + cbEnableRWFF.Checked = Global.Config.SoundEnabledRWFF; + cbMuteFrameAdvance.Checked = Global.Config.MuteFrameAdvance; #if !WINDOWS rbOutputMethodDirectSound.Enabled = false; rbOutputMethodXAudio2.Enabled = false; @@ -30,8 +32,10 @@ namespace BizHawk.Client.EmuHawk rbOutputMethodXAudio2.Checked = Global.Config.SoundOutputMethod == Config.ESoundOutputMethod.XAudio2; rbOutputMethodOpenAL.Checked = Global.Config.SoundOutputMethod == Config.ESoundOutputMethod.OpenAL; BufferSizeNumeric.Value = Global.Config.SoundBufferSizeMs; - SoundVolBar.Value = Global.Config.SoundVolume; - SoundVolNumeric.Value = Global.Config.SoundVolume; + tbNormal.Value = Global.Config.SoundVolume; + nudNormal.Value = Global.Config.SoundVolume; + tbRWFF.Value = Global.Config.SoundVolumeRWFF; + nudRWFF.Value = Global.Config.SoundVolumeRWFF; UpdateSoundDialog(); _programmaticallyChangingValue = false; @@ -46,13 +50,16 @@ namespace BizHawk.Client.EmuHawk } var oldOutputMethod = Global.Config.SoundOutputMethod; var oldDevice = Global.Config.SoundDevice; - Global.Config.SoundEnabled = SoundOnCheckBox.Checked; - Global.Config.MuteFrameAdvance = MuteFrameAdvance.Checked; + Global.Config.SoundEnabled = cbEnableMaster.Checked; + Global.Config.SoundEnabledNormal = cbEnableNormal.Checked; + Global.Config.SoundEnabledRWFF = cbEnableRWFF.Checked; + Global.Config.MuteFrameAdvance = cbMuteFrameAdvance.Checked; if (rbOutputMethodDirectSound.Checked) Global.Config.SoundOutputMethod = Config.ESoundOutputMethod.DirectSound; if (rbOutputMethodXAudio2.Checked) Global.Config.SoundOutputMethod = Config.ESoundOutputMethod.XAudio2; if (rbOutputMethodOpenAL.Checked) Global.Config.SoundOutputMethod = Config.ESoundOutputMethod.OpenAL; Global.Config.SoundBufferSizeMs = (int)BufferSizeNumeric.Value; - Global.Config.SoundVolume = SoundVolBar.Value; + Global.Config.SoundVolume = tbNormal.Value; + Global.Config.SoundVolumeRWFF = tbRWFF.Value; Global.Config.SoundDevice = (string)listBoxSoundDevices.SelectedItem ?? ""; GlobalWin.Sound.StopSound(); if (Global.Config.SoundOutputMethod != oldOutputMethod || @@ -101,26 +108,34 @@ namespace BizHawk.Client.EmuHawk private void trackBar1_Scroll(object sender, EventArgs e) { - SoundVolNumeric.Value = SoundVolBar.Value; + nudNormal.Value = tbNormal.Value; + } + + private void tbRWFF_Scroll(object sender, EventArgs e) + { + nudRWFF.Value = tbRWFF.Value; } private void SoundVolNumeric_ValueChanged(object sender, EventArgs e) { - SoundVolBar.Value = (int)SoundVolNumeric.Value; + tbNormal.Value = (int)nudNormal.Value; // If the user is changing the volume, automatically turn on/off sound accordingly if (!_programmaticallyChangingValue) - SoundOnCheckBox.Checked = SoundVolBar.Value != 0; - } - - private void SoundOnCheckBox_CheckedChanged(object sender, EventArgs e) - { - UpdateSoundDialog(); + cbEnableNormal.Checked = tbNormal.Value != 0; } private void UpdateSoundDialog() { - MuteFrameAdvance.Enabled = SoundOnCheckBox.Checked; + cbEnableRWFF.Enabled = cbEnableNormal.Checked; + grpSoundVol.Enabled = cbEnableMaster.Checked; } + + + private void UpdateSoundDialog(object sender, EventArgs e) + { + UpdateSoundDialog(); + } + } }