From 8d0205f96228e7d50ae0084aaa382dd123508e24 Mon Sep 17 00:00:00 2001 From: zeromus Date: Wed, 17 Dec 2014 02:54:43 +0000 Subject: [PATCH] psx - fix some small bugs in PAL support and make psx options dialog update labels with calculated resolutions so you can better understand what the options do --- .../config/PSX/PSXOptions.Designer.cs | 123 +++++++++--------- .../config/PSX/PSXOptions.cs | 88 ++++++++++--- .../config/PSX/PSXOptions.resx | 2 +- .../Consoles/Sony/PSX/Octoshock.cs | 106 +++++++++------ output/dll/octoshock.dll | Bin 839168 -> 839168 bytes psx/octoshock/psx/psx.cpp | 5 +- 6 files changed, 206 insertions(+), 118 deletions(-) diff --git a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.Designer.cs b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.Designer.cs index 7c121cad1c..46f1410117 100644 --- a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.Designer.cs +++ b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.Designer.cs @@ -32,27 +32,27 @@ this.btnCancel = new System.Windows.Forms.Button(); this.btnOk = new System.Windows.Forms.Button(); this.groupBox1 = new System.Windows.Forms.GroupBox(); - this.label9 = new System.Windows.Forms.Label(); + this.lblTweakedMednafen = new System.Windows.Forms.Label(); this.rbTweakedMednafenMode = new System.Windows.Forms.RadioButton(); this.label3 = new System.Windows.Forms.Label(); this.rbDebugMode = new System.Windows.Forms.RadioButton(); this.btnNiceDisplayConfig = new System.Windows.Forms.Button(); - this.label2 = new System.Windows.Forms.Label(); + this.lblMednafen = new System.Windows.Forms.Label(); this.rbMednafenMode = new System.Windows.Forms.RadioButton(); - this.label8 = new System.Windows.Forms.Label(); + this.lblPixelPro = new System.Windows.Forms.Label(); this.rbPixelPro = new System.Windows.Forms.RadioButton(); this.label7 = new System.Windows.Forms.Label(); this.groupBox2 = new System.Windows.Forms.GroupBox(); - this.label6 = new System.Windows.Forms.Label(); + this.lblPAL = new System.Windows.Forms.Label(); this.PAL_LastLineNumeric = new System.Windows.Forms.NumericUpDown(); this.PAL_FirstLineNumeric = new System.Windows.Forms.NumericUpDown(); - this.label5 = new System.Windows.Forms.Label(); + this.lblNTSC = new System.Windows.Forms.Label(); this.btnAreaFull = new System.Windows.Forms.Button(); + this.checkClipHorizontal = new System.Windows.Forms.CheckBox(); this.label4 = new System.Windows.Forms.Label(); this.label1 = new System.Windows.Forms.Label(); this.NTSC_LastLineNumeric = new System.Windows.Forms.NumericUpDown(); this.NTSC_FirstLineNumeric = new System.Windows.Forms.NumericUpDown(); - this.checkClipHorizontal = new System.Windows.Forms.CheckBox(); this.groupBox1.SuspendLayout(); this.groupBox2.SuspendLayout(); ((System.ComponentModel.ISupportInitialize)(this.PAL_LastLineNumeric)).BeginInit(); @@ -85,29 +85,29 @@ // // groupBox1 // - this.groupBox1.Controls.Add(this.label9); + this.groupBox1.Controls.Add(this.lblTweakedMednafen); this.groupBox1.Controls.Add(this.rbTweakedMednafenMode); this.groupBox1.Controls.Add(this.label3); this.groupBox1.Controls.Add(this.rbDebugMode); this.groupBox1.Controls.Add(this.btnNiceDisplayConfig); - this.groupBox1.Controls.Add(this.label2); + this.groupBox1.Controls.Add(this.lblMednafen); this.groupBox1.Controls.Add(this.rbMednafenMode); - this.groupBox1.Controls.Add(this.label8); + this.groupBox1.Controls.Add(this.lblPixelPro); this.groupBox1.Controls.Add(this.rbPixelPro); this.groupBox1.Location = new System.Drawing.Point(12, 7); this.groupBox1.Name = "groupBox1"; this.groupBox1.Size = new System.Drawing.Size(474, 256); this.groupBox1.TabIndex = 6; this.groupBox1.TabStop = false; - this.groupBox1.Text = "Resolution Management (sample numbers do not reflect Drawing Area choices)"; + this.groupBox1.Text = "Resolution Management"; // - // label9 + // lblTweakedMednafen // - this.label9.Location = new System.Drawing.Point(255, 132); - this.label9.Name = "label9"; - this.label9.Size = new System.Drawing.Size(213, 79); - this.label9.TabIndex = 28; - this.label9.Text = "Displays all content at as multiple of 400x300.\r\n • Correct aspect ratio\r\n • Gene" + + this.lblTweakedMednafen.Location = new System.Drawing.Point(255, 132); + this.lblTweakedMednafen.Name = "lblTweakedMednafen"; + this.lblTweakedMednafen.Size = new System.Drawing.Size(213, 79); + this.lblTweakedMednafen.TabIndex = 28; + this.lblTweakedMednafen.Text = "Displays all content at as multiple of 400x300.\r\n • Correct aspect ratio\r\n • Gene" + "rally enjoyable game presentation\r\n • Detail loss at 1x in fewer cases\r\n • Requi" + "res certain display configuration:\r\n"; // @@ -153,13 +153,13 @@ this.btnNiceDisplayConfig.UseVisualStyleBackColor = true; this.btnNiceDisplayConfig.Click += new System.EventHandler(this.btnNiceDisplayConfig_Click); // - // label2 + // lblMednafen // - this.label2.Location = new System.Drawing.Point(6, 132); - this.label2.Name = "label2"; - this.label2.Size = new System.Drawing.Size(213, 82); - this.label2.TabIndex = 23; - this.label2.Text = resources.GetString("label2.Text"); + this.lblMednafen.Location = new System.Drawing.Point(6, 132); + this.lblMednafen.Name = "lblMednafen"; + this.lblMednafen.Size = new System.Drawing.Size(213, 82); + this.lblMednafen.TabIndex = 23; + this.lblMednafen.Text = resources.GetString("lblMednafen.Text"); // // rbMednafenMode // @@ -172,13 +172,13 @@ this.rbMednafenMode.Text = "Mednafen Mode (4:3 AR)"; this.rbMednafenMode.UseVisualStyleBackColor = true; // - // label8 + // lblPixelPro // - this.label8.Location = new System.Drawing.Point(6, 35); - this.label8.Name = "label8"; - this.label8.Size = new System.Drawing.Size(252, 78); - this.label8.TabIndex = 21; - this.label8.Text = "Converts content with nearest neighbor to \r\nfit gracefully in a 800x480 window.\r\n" + + this.lblPixelPro.Location = new System.Drawing.Point(6, 35); + this.lblPixelPro.Name = "lblPixelPro"; + this.lblPixelPro.Size = new System.Drawing.Size(252, 78); + this.lblPixelPro.TabIndex = 21; + this.lblPixelPro.Text = "Converts content with nearest neighbor to \r\nfit gracefully in a 800x480 window.\r\n" + " • Content is pixel perfect\r\n • Aspect ratio is usually wrong\r\n • Game may seen " + "to have scale varying by mode\r\n\r\n\r\n"; // @@ -205,10 +205,10 @@ // this.groupBox2.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) | System.Windows.Forms.AnchorStyles.Right))); - this.groupBox2.Controls.Add(this.label6); + this.groupBox2.Controls.Add(this.lblPAL); this.groupBox2.Controls.Add(this.PAL_LastLineNumeric); this.groupBox2.Controls.Add(this.PAL_FirstLineNumeric); - this.groupBox2.Controls.Add(this.label5); + this.groupBox2.Controls.Add(this.lblNTSC); this.groupBox2.Controls.Add(this.btnAreaFull); this.groupBox2.Controls.Add(this.checkClipHorizontal); this.groupBox2.Controls.Add(this.label4); @@ -222,14 +222,14 @@ this.groupBox2.TabStop = false; this.groupBox2.Text = "Drawing Area"; // - // label6 + // lblPAL // - this.label6.AutoSize = true; - this.label6.Location = new System.Drawing.Point(131, 22); - this.label6.Name = "label6"; - this.label6.Size = new System.Drawing.Size(27, 13); - this.label6.TabIndex = 44; - this.label6.Text = "PAL"; + this.lblPAL.AutoSize = true; + this.lblPAL.Location = new System.Drawing.Point(131, 22); + this.lblPAL.Name = "lblPAL"; + this.lblPAL.Size = new System.Drawing.Size(27, 13); + this.lblPAL.TabIndex = 44; + this.lblPAL.Text = "PAL"; // // PAL_LastLineNumeric // @@ -247,6 +247,7 @@ 0, 0, 0}); + this.PAL_LastLineNumeric.ValueChanged += new System.EventHandler(this.DrawingArea_ValueChanged); // // PAL_FirstLineNumeric // @@ -259,15 +260,16 @@ this.PAL_FirstLineNumeric.Name = "PAL_FirstLineNumeric"; this.PAL_FirstLineNumeric.Size = new System.Drawing.Size(47, 20); this.PAL_FirstLineNumeric.TabIndex = 42; + this.PAL_FirstLineNumeric.ValueChanged += new System.EventHandler(this.DrawingArea_ValueChanged); // - // label5 + // lblNTSC // - this.label5.AutoSize = true; - this.label5.Location = new System.Drawing.Point(62, 22); - this.label5.Name = "label5"; - this.label5.Size = new System.Drawing.Size(36, 13); - this.label5.TabIndex = 41; - this.label5.Text = "NTSC"; + this.lblNTSC.AutoSize = true; + this.lblNTSC.Location = new System.Drawing.Point(62, 22); + this.lblNTSC.Name = "lblNTSC"; + this.lblNTSC.Size = new System.Drawing.Size(36, 13); + this.lblNTSC.TabIndex = 41; + this.lblNTSC.Text = "NTSC"; // // btnAreaFull // @@ -279,6 +281,17 @@ this.btnAreaFull.UseVisualStyleBackColor = true; this.btnAreaFull.Click += new System.EventHandler(this.btnAreaFull_Click); // + // checkClipHorizontal + // + this.checkClipHorizontal.AutoSize = true; + this.checkClipHorizontal.Location = new System.Drawing.Point(7, 127); + this.checkClipHorizontal.Name = "checkClipHorizontal"; + this.checkClipHorizontal.Size = new System.Drawing.Size(142, 17); + this.checkClipHorizontal.TabIndex = 30; + this.checkClipHorizontal.Text = "Clip Horizontal Overscan"; + this.checkClipHorizontal.UseVisualStyleBackColor = true; + this.checkClipHorizontal.CheckedChanged += new System.EventHandler(this.checkClipHorizontal_CheckedChanged); + // // label4 // this.label4.AutoSize = true; @@ -313,6 +326,7 @@ 0, 0, 0}); + this.NTSC_LastLineNumeric.ValueChanged += new System.EventHandler(this.DrawingArea_ValueChanged); // // NTSC_FirstLineNumeric // @@ -325,16 +339,7 @@ this.NTSC_FirstLineNumeric.Name = "NTSC_FirstLineNumeric"; this.NTSC_FirstLineNumeric.Size = new System.Drawing.Size(47, 20); this.NTSC_FirstLineNumeric.TabIndex = 21; - // - // checkClipHorizontal - // - this.checkClipHorizontal.AutoSize = true; - this.checkClipHorizontal.Location = new System.Drawing.Point(7, 127); - this.checkClipHorizontal.Name = "checkClipHorizontal"; - this.checkClipHorizontal.Size = new System.Drawing.Size(142, 17); - this.checkClipHorizontal.TabIndex = 30; - this.checkClipHorizontal.Text = "Clip Horizontal Overscan"; - this.checkClipHorizontal.UseVisualStyleBackColor = true; + this.NTSC_FirstLineNumeric.ValueChanged += new System.EventHandler(this.DrawingArea_ValueChanged); // // PSXOptions // @@ -370,19 +375,19 @@ private System.Windows.Forms.GroupBox groupBox1; private System.Windows.Forms.RadioButton rbPixelPro; private System.Windows.Forms.Button btnNiceDisplayConfig; - private System.Windows.Forms.Label label2; + private System.Windows.Forms.Label lblMednafen; private System.Windows.Forms.RadioButton rbMednafenMode; - private System.Windows.Forms.Label label8; + private System.Windows.Forms.Label lblPixelPro; private System.Windows.Forms.Label label7; private System.Windows.Forms.Label label3; private System.Windows.Forms.RadioButton rbDebugMode; - private System.Windows.Forms.Label label9; + private System.Windows.Forms.Label lblTweakedMednafen; private System.Windows.Forms.RadioButton rbTweakedMednafenMode; private System.Windows.Forms.GroupBox groupBox2; - private System.Windows.Forms.Label label6; + private System.Windows.Forms.Label lblPAL; private System.Windows.Forms.NumericUpDown PAL_LastLineNumeric; private System.Windows.Forms.NumericUpDown PAL_FirstLineNumeric; - private System.Windows.Forms.Label label5; + private System.Windows.Forms.Label lblNTSC; private System.Windows.Forms.Button btnAreaFull; private System.Windows.Forms.CheckBox checkClipHorizontal; private System.Windows.Forms.Label label4; diff --git a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.cs b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.cs index 15a8b57910..bea584e9c3 100644 --- a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.cs +++ b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.cs @@ -14,10 +14,23 @@ namespace BizHawk.Client.EmuHawk { public partial class PSXOptions : Form { - public PSXOptions(Octoshock.Settings settings) + //backups of the labels for string replacing + string lblPixelPro_text, lblMednafen_text, lblTweakedMednafen_text; + + public PSXOptions(Octoshock.Settings settings, OctoshockDll.eVidStandard vidStandard, Size currentVideoSize) { InitializeComponent(); _settings = settings; + _previewVideoStandard = vidStandard; + _previewVideoSize = currentVideoSize; + + if (_previewVideoStandard == OctoshockDll.eVidStandard.NTSC) + lblNTSC.Font = new System.Drawing.Font(lblNTSC.Font, FontStyle.Bold); + else lblPAL.Font = new System.Drawing.Font(lblPAL.Font, FontStyle.Bold); + + lblPixelPro_text = lblPixelPro.Text; + lblMednafen_text = lblMednafen.Text; + lblTweakedMednafen_text = lblTweakedMednafen.Text; rbPixelPro.Checked = _settings.ResolutionMode == Octoshock.eResolutionMode.PixelPro; rbDebugMode.Checked = _settings.ResolutionMode == Octoshock.eResolutionMode.Debug; @@ -31,6 +44,8 @@ namespace BizHawk.Client.EmuHawk PAL_LastLineNumeric.Value = _settings.ScanlineEnd_PAL; } + Size _previewVideoSize; + OctoshockDll.eVidStandard _previewVideoStandard; Octoshock.Settings _settings; bool _dispSettingsSet = false; @@ -42,14 +57,32 @@ namespace BizHawk.Client.EmuHawk public static DialogResult DoSettingsDialog(IWin32Window owner) { - var s = ((Octoshock)Global.Emulator).GetSettings(); - var ss = ((Octoshock)Global.Emulator).GetSyncSettings(); - var dlg = new PSXOptions(s); + var psx = ((Octoshock)Global.Emulator); + var s = psx.GetSettings(); + var ss = psx.GetSyncSettings(); + var vid = psx.SystemVidStandard; + var size = psx.CurrentVideoSize; + var dlg = new PSXOptions(s,vid,size); var result = dlg.ShowDialog(owner); return result; } + void SyncGuiToTheseSettings(Octoshock.Settings settings) + { + if (rbPixelPro.Checked) settings.ResolutionMode = Octoshock.eResolutionMode.PixelPro; + if (rbDebugMode.Checked) settings.ResolutionMode = Octoshock.eResolutionMode.Debug; + if (rbMednafenMode.Checked) settings.ResolutionMode = Octoshock.eResolutionMode.Mednafen; + if (rbTweakedMednafenMode.Checked) settings.ResolutionMode = Octoshock.eResolutionMode.TweakedMednafen; + + settings.ClipHorizontalOverscan = checkClipHorizontal.Checked; + + settings.ScanlineStart_NTSC = (int)NTSC_FirstLineNumeric.Value; + settings.ScanlineEnd_NTSC = (int)NTSC_LastLineNumeric.Value; + settings.ScanlineStart_PAL = (int)PAL_FirstLineNumeric.Value; + settings.ScanlineEnd_PAL = (int)PAL_LastLineNumeric.Value; + } + private void btnOk_Click(object sender, EventArgs e) { if (_dispSettingsSet) @@ -60,20 +93,8 @@ namespace BizHawk.Client.EmuHawk Global.Config.DispFinalFilter = 1; //bilinear, I hope } - if(rbPixelPro.Checked) _settings.ResolutionMode = Octoshock.eResolutionMode.PixelPro; - if(rbDebugMode.Checked) _settings.ResolutionMode = Octoshock.eResolutionMode.Debug; - if(rbMednafenMode.Checked)_settings.ResolutionMode = Octoshock.eResolutionMode.Mednafen; - if(rbTweakedMednafenMode.Checked)_settings.ResolutionMode = Octoshock.eResolutionMode.TweakedMednafen; - - _settings.ClipHorizontalOverscan = checkClipHorizontal.Checked; - - _settings.ScanlineStart_NTSC = (int)NTSC_FirstLineNumeric.Value; - _settings.ScanlineEnd_NTSC = (int)NTSC_LastLineNumeric.Value; - _settings.ScanlineStart_PAL = (int)PAL_FirstLineNumeric.Value; - _settings.ScanlineEnd_PAL = (int)PAL_LastLineNumeric.Value; - + SyncGuiToTheseSettings(_settings); _settings.Validate(); - GlobalWin.MainForm.PutCoreSettings(_settings); DialogResult = DialogResult.OK; @@ -86,7 +107,40 @@ namespace BizHawk.Client.EmuHawk NTSC_LastLineNumeric.Value = 239; PAL_FirstLineNumeric.Value = 0; PAL_LastLineNumeric.Value = 287; + SyncLabels(); } + void SyncLabels() + { + var temp = _settings.Clone(); + SyncGuiToTheseSettings(temp); + _settings.Validate(); + + //actually, I think this is irrelevant. But it's nice in case we want to do some kind of a more detailed simulation later + int w = _previewVideoSize.Width; + int h = _previewVideoSize.Height; + + temp.ResolutionMode = Octoshock.eResolutionMode.PixelPro; + var size = Octoshock.CalculateResolution(_previewVideoStandard, temp, w, h); + lblPixelPro.Text = lblPixelPro_text.Replace("800x480", string.Format("{0}x{1}", size.Width, size.Height)); ; + + temp.ResolutionMode = Octoshock.eResolutionMode.Mednafen; + size = Octoshock.CalculateResolution(_previewVideoStandard, temp, w, h); + lblMednafen.Text = lblMednafen_text.Replace("320x240", string.Format("{0}x{1}", size.Width, size.Height)); + + temp.ResolutionMode = Octoshock.eResolutionMode.TweakedMednafen; + size = Octoshock.CalculateResolution(_previewVideoStandard, temp, w, h); + lblTweakedMednafen.Text = lblTweakedMednafen_text.Replace("400x300", string.Format("{0}x{1}", size.Width, size.Height)); + } + + private void DrawingArea_ValueChanged(object sender, EventArgs e) + { + SyncLabels(); + } + + private void checkClipHorizontal_CheckedChanged(object sender, EventArgs e) + { + SyncLabels(); + } } } diff --git a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.resx b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.resx index 52cee022a8..b174bca15e 100644 --- a/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.resx +++ b/BizHawk.Client.EmuHawk/config/PSX/PSXOptions.resx @@ -117,7 +117,7 @@ System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 - + Displays all content at as multiple of 320x240 • Correct aspect ratio • Generally enjoyable game presentation diff --git a/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs b/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs index 1a11ad9abc..5072bb4a27 100644 --- a/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs +++ b/BizHawk.Emulation.Cores/Consoles/Sony/PSX/Octoshock.cs @@ -178,8 +178,9 @@ namespace BizHawk.Emulation.Cores.Sony.PSX List discInterfaces = new List(); DiscInterface currentDiscInterface; - OctoshockDll.eRegion SystemRegion; - OctoshockDll.eVidStandard SystemVidStandard; + public OctoshockDll.eRegion SystemRegion { get; private set; } + public OctoshockDll.eVidStandard SystemVidStandard { get; private set; } + public System.Drawing.Size CurrentVideoSize { get; private set; } //note: its annoying that we have to have a disc before constructing this. //might want to change that later. HOWEVER - we need to definitely have a region, at least @@ -203,7 +204,7 @@ namespace BizHawk.Emulation.Cores.Sony.PSX if (discs != null) { - foreach(var disc in discs) + foreach (var disc in discs) { var discInterface = new DiscInterface(disc, (di) => @@ -234,10 +235,10 @@ namespace BizHawk.Emulation.Cores.Sony.PSX } //see http://problemkaputt.de/psx-spx.htm - int CpuClock_n = 44100*768; + int CpuClock_n = 44100 * 768; int CpuClock_d = 1; - int VidClock_n = CpuClock_n*11; - int VidClock_d = CpuClock_d*7; + int VidClock_n = CpuClock_n * 11; + int VidClock_d = CpuClock_d * 7; if (SystemRegion == OctoshockDll.eRegion.EU) { CoreComm.VsyncNum = VidClock_n; @@ -260,14 +261,22 @@ namespace BizHawk.Emulation.Cores.Sony.PSX SetMemoryDomains(); - //TODO - refactor resolution detection and set this accordingly to the first frame of emulation, or at least what the bios is doing first - VirtualWidth = 800; - VirtualHeight = 480; - - //set a default framebuffer - BufferWidth = VirtualWidth; - BufferHeight = VirtualHeight; - frameBuffer = new int[BufferWidth * BufferHeight]; + //set a default framebuffer based on the first frame of emulation, to cut down on flickering or whatever + //this is probably quixotic, but we have to pick something + { + BufferWidth = 280; + BufferHeight = 240; + if (SystemVidStandard == OctoshockDll.eVidStandard.PAL) + { + BufferWidth = 280; + BufferHeight = 288; + } + CurrentVideoSize = new System.Drawing.Size(BufferWidth, BufferHeight); + var size = Octoshock.CalculateResolution(SystemVidStandard, _Settings, BufferWidth, BufferHeight); + BufferWidth = VirtualWidth = size.Width; + BufferHeight = VirtualHeight = size.Height; + frameBuffer = new int[BufferWidth * BufferHeight]; + } if (discInterfaces.Count != 0) { @@ -347,6 +356,42 @@ namespace BizHawk.Emulation.Cores.Sony.PSX OctoshockDll.shock_Peripheral_SetPadInput(psx, 0x01, buttons, left_x, left_y, right_x, right_y); } + /// + /// Calculates what the output resolution would be for the given input resolution and settings + /// + public static System.Drawing.Size CalculateResolution(OctoshockDll.eVidStandard standard, Settings settings, int w, int h) + { + int virtual_width = settings.ClipHorizontalOverscan ? 768 : 800; + + int scanline_start = standard == OctoshockDll.eVidStandard.NTSC ? settings.ScanlineStart_NTSC : settings.ScanlineStart_PAL; + int scanline_end = standard == OctoshockDll.eVidStandard.NTSC ? settings.ScanlineEnd_NTSC : settings.ScanlineEnd_PAL; + int scanline_num = scanline_end - scanline_start + 1; + int real_scanline_num = standard == OctoshockDll.eVidStandard.NTSC ? 240 : 288; + + int VirtualWidth=-1, VirtualHeight=-1; + switch (settings.ResolutionMode) + { + case eResolutionMode.Debug: + VirtualWidth = w; + VirtualHeight = h; + break; + case eResolutionMode.Mednafen: + VirtualWidth = settings.ClipHorizontalOverscan ? 302 : 320; + VirtualHeight = scanline_num; + break; + case eResolutionMode.PixelPro: + VirtualWidth = virtual_width; + VirtualHeight = scanline_num * 2; + break; + case eResolutionMode.TweakedMednafen: + VirtualWidth = settings.ClipHorizontalOverscan ? 378 : 400; + VirtualHeight = (int)(scanline_num * 300.0f / real_scanline_num); + break; + } + + return new System.Drawing.Size(VirtualWidth, VirtualHeight); + } + public void FrameAdvance(bool render, bool rendersound) { Frame++; @@ -383,6 +428,11 @@ namespace BizHawk.Emulation.Cores.Sony.PSX if (render == false) return; OctoshockDll.ShockFramebufferInfo fb = new OctoshockDll.ShockFramebufferInfo(); + + //run this once to get current logical size + OctoshockDll.shock_GetFramebuffer(psx, ref fb); + CurrentVideoSize = new System.Drawing.Size(fb.width, fb.height); + if (_Settings.ResolutionMode == eResolutionMode.PixelPro) fb.flags = OctoshockDll.eShockFramebufferFlags.Normalize; @@ -393,31 +443,9 @@ namespace BizHawk.Emulation.Cores.Sony.PSX BufferWidth = w; BufferHeight = h; - int virtual_width = ropts.clipOverscan ? 768 : 800; - int scanline_num = ropts.scanline_end - ropts.scanline_start + 1; - int real_scanline_num = SystemVidStandard == OctoshockDll.eVidStandard.NTSC ? 240 : 288; - - switch (_Settings.ResolutionMode) - { - case eResolutionMode.Debug: - VirtualWidth = w; - VirtualHeight = h; - break; - case eResolutionMode.Mednafen: - VirtualWidth = ropts.clipOverscan ? 302 : 320; - VirtualHeight = scanline_num; - break; - case eResolutionMode.PixelPro: - VirtualWidth = virtual_width; - VirtualHeight = scanline_num*2; - break; - case eResolutionMode.TweakedMednafen: - { - VirtualWidth = ropts.clipOverscan ? 378 : 400; - VirtualHeight = (int)(scanline_num * 300.0f / real_scanline_num); - } - break; - } + var size = CalculateResolution(this.SystemVidStandard, _Settings, w, h); + VirtualWidth = size.Width; + VirtualHeight = size.Height; int len = w * h; if (frameBuffer.Length != len) diff --git a/output/dll/octoshock.dll b/output/dll/octoshock.dll index 93a0b7160d3c4efdca8698472596a3d48815888f..83575947e8d38e570433e105934d658f97aad9d2 100644 GIT binary patch delta 115 zcmZpeW85&ucmX5R$ybw^82y;Mr#1&Mwg)kSFcT0n12GE_vjQ<25VHd@2M}{^4`SrH zx{X_bnSmk0feA<`Y&Y7$Wx&FyuswMX*TX451Gl>ca+j@TWZu5_ANO-Urv0zBFXQEj GIsgEmLL{C5 delta 115 zcmZpeW85&ucmX5R`CF5j82y-RRGWhs+k+TEmGGJk3*q*$H>){ljf!o~zxy#lvGH&1dkNY_v)3ICIm+|sM G9RL7YpCh0E diff --git a/psx/octoshock/psx/psx.cpp b/psx/octoshock/psx/psx.cpp index 78741c8e45..15d3491ed8 100644 --- a/psx/octoshock/psx/psx.cpp +++ b/psx/octoshock/psx/psx.cpp @@ -33,7 +33,8 @@ #include #include -#define FB_WIDTH 768 +//we're a bit sloppy right now.. use this to make sure theres adequate room for double-sizing a 400px wide screen +#define FB_WIDTH 800 #define FB_HEIGHT 576 //extern MDFNGI EmulatedPSX; @@ -1360,7 +1361,7 @@ EW_EXPORT s32 shock_Step(void* psx, eShockStep step) //new frame, hasnt been normalized s_FramebufferNormalized = false; s_FramebufferCurrent = 0; - s_FramebufferCurrentWidth = 768; + s_FramebufferCurrentWidth = FB_WIDTH; return SHOCK_OK; }