mirror of https://github.com/stella-emu/stella.git
Hmm, looks like we're still not ready for the 2.6.1 release.
Removed scanline autodetection from the Console startup code. It makes more sense to just assume the Console is either NTSC or PAL, and let the TIA auto-adjust the framerate if necessary. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1530 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
832fab1ee8
commit
8d4d5b4563
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Console.cxx,v 1.146 2008-05-21 21:01:40 stephena Exp $
|
// $Id: Console.cxx,v 1.147 2008-05-21 21:36:18 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
@ -126,7 +126,6 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
|
||||||
|
|
||||||
// Auto-detect NTSC/PAL mode if it's requested
|
// Auto-detect NTSC/PAL mode if it's requested
|
||||||
myDisplayFormat = myProperties.get(Display_Format);
|
myDisplayFormat = myProperties.get(Display_Format);
|
||||||
float avgScanlineCount = 0.0;
|
|
||||||
vidinfo << " Display Format: " << myDisplayFormat;
|
vidinfo << " Display Format: " << myDisplayFormat;
|
||||||
if(myDisplayFormat == "AUTO-DETECT" ||
|
if(myDisplayFormat == "AUTO-DETECT" ||
|
||||||
myOSystem->settings().getBool("rominfo"))
|
myOSystem->settings().getBool("rominfo"))
|
||||||
|
@ -137,18 +136,13 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
|
||||||
// Unfortunately, this means we have to always enable 'fastscbios',
|
// Unfortunately, this means we have to always enable 'fastscbios',
|
||||||
// since otherwise the BIOS loading will take over 250 frames!
|
// since otherwise the BIOS loading will take over 250 frames!
|
||||||
mySystem->reset();
|
mySystem->reset();
|
||||||
int palCount = 0, scanlineCount = 0;
|
int palCount = 0;
|
||||||
for(int i = 0; i < 60; ++i)
|
for(int i = 0; i < 60; ++i)
|
||||||
{
|
{
|
||||||
myMediaSource->update();
|
myMediaSource->update();
|
||||||
if(i >= 30)
|
if(i >= 30 && myMediaSource->scanlines() > 285)
|
||||||
{
|
++palCount;
|
||||||
if(myMediaSource->scanlines() > 285)
|
|
||||||
++palCount;
|
|
||||||
scanlineCount += myMediaSource->scanlines();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
avgScanlineCount = scanlineCount / 30.0;
|
|
||||||
myDisplayFormat = (palCount >= 15) ? "PAL" : "NTSC";
|
myDisplayFormat = (palCount >= 15) ? "PAL" : "NTSC";
|
||||||
if(myProperties.get(Display_Format) == "AUTO-DETECT")
|
if(myProperties.get(Display_Format) == "AUTO-DETECT")
|
||||||
vidinfo << " ==> " << myDisplayFormat;
|
vidinfo << " ==> " << myDisplayFormat;
|
||||||
|
@ -158,26 +152,17 @@ Console::Console(OSystem* osystem, Cartridge* cart, const Properties& props)
|
||||||
// Note that this can be overridden if a format is forced
|
// Note that this can be overridden if a format is forced
|
||||||
// For example, if a PAL ROM is forced to be NTSC, it will use NTSC-like
|
// For example, if a PAL ROM is forced to be NTSC, it will use NTSC-like
|
||||||
// properties (60Hz, 262 scanlines, etc) and cycle between NTSC-like modes
|
// properties (60Hz, 262 scanlines, etc) and cycle between NTSC-like modes
|
||||||
|
// The TIA will self-adjust the framerate if necessary
|
||||||
if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" ||
|
if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" ||
|
||||||
myDisplayFormat == "SECAM60")
|
myDisplayFormat == "SECAM60")
|
||||||
{
|
{
|
||||||
// Try to be as accurate as possible with the framerate
|
// Assume we've got ~262 scanlines (NTSC-like format)
|
||||||
// Use the scanline count if available, otherwise assume we've got
|
|
||||||
// ~262 scanlines (NTSC-like format)
|
|
||||||
if(avgScanlineCount > 0.0)
|
|
||||||
myFramerate = 15720.0 / avgScanlineCount;
|
|
||||||
else
|
|
||||||
myFramerate = 60.0;
|
myFramerate = 60.0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Try to be as accurate as possible with the framerate
|
// Assume we've got ~312 scanlines (PAL-like format)
|
||||||
// Use the scanline count if available, otherwise assume we've got
|
myFramerate = 50.0;
|
||||||
// ~312 scanlines (PAL-like format)
|
|
||||||
if(avgScanlineCount > 0.0)
|
|
||||||
myFramerate = 15600.0 / avgScanlineCount;
|
|
||||||
else
|
|
||||||
myFramerate = 50.0;
|
|
||||||
|
|
||||||
if(myProperties.get(Display_Height) == "210")
|
if(myProperties.get(Display_Height) == "210")
|
||||||
myProperties.set(Display_Height, "250");
|
myProperties.set(Display_Height, "250");
|
||||||
|
|
Loading…
Reference in New Issue