mirror of https://github.com/stella-emu/stella.git
First attempt at adding SDL_VIDEODRIVER support as a commandline option.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@345 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
a76e7516a8
commit
03d8c0eab5
|
@ -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: mainSDL.cxx,v 1.16 2004-08-17 01:17:08 stephena Exp $
|
// $Id: mainSDL.cxx,v 1.17 2004-09-14 16:10:27 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
@ -824,6 +824,18 @@ int main(int argc, char* argv[])
|
||||||
// Request that the SDL window be centered, if possible
|
// Request that the SDL window be centered, if possible
|
||||||
putenv("SDL_VIDEO_CENTERED=1");
|
putenv("SDL_VIDEO_CENTERED=1");
|
||||||
|
|
||||||
|
// Set the SDL_VIDEODRIVER environment variable, if possible
|
||||||
|
if(theSettings->getString("video_driver") != "")
|
||||||
|
{
|
||||||
|
ostringstream buf;
|
||||||
|
buf << "SDL_VIDEODRIVER=" << theSettings->getString("video_driver");
|
||||||
|
putenv((char*) buf.str().c_str());
|
||||||
|
|
||||||
|
buf.str("");
|
||||||
|
buf << "Using SDL video driver = " << theSettings->getString("video_driver") << ".";
|
||||||
|
ShowInfo(buf.str());
|
||||||
|
}
|
||||||
|
|
||||||
// Get a pointer to the file which contains the cartridge ROM
|
// Get a pointer to the file which contains the cartridge ROM
|
||||||
const char* file = argv[argc - 1];
|
const char* file = argv[argc - 1];
|
||||||
|
|
||||||
|
@ -846,20 +858,20 @@ int main(int argc, char* argv[])
|
||||||
if(videodriver == "soft")
|
if(videodriver == "soft")
|
||||||
{
|
{
|
||||||
theDisplay = new FrameBufferSoft();
|
theDisplay = new FrameBufferSoft();
|
||||||
ShowInfo("Using software mode for video.");
|
ShowInfo("Using software mode for video rendering.");
|
||||||
}
|
}
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
else if(videodriver == "gl")
|
else if(videodriver == "gl")
|
||||||
{
|
{
|
||||||
theDisplay = new FrameBufferGL();
|
theDisplay = new FrameBufferGL();
|
||||||
theUseOpenGLFlag = true;
|
theUseOpenGLFlag = true;
|
||||||
ShowInfo("Using OpenGL mode for video.");
|
ShowInfo("Using OpenGL mode for video rendering.");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
else // a driver that doesn't exist was requested, so use software mode
|
else // a driver that doesn't exist was requested, so use software mode
|
||||||
{
|
{
|
||||||
theDisplay = new FrameBufferSoft();
|
theDisplay = new FrameBufferSoft();
|
||||||
ShowInfo("Using software mode for video.");
|
ShowInfo("Using software mode for video rendering.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!theDisplay)
|
if(!theDisplay)
|
||||||
|
|
|
@ -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: Settings.cxx,v 1.29 2004-08-17 01:17:08 stephena Exp $
|
// $Id: Settings.cxx,v 1.30 2004-09-14 16:10:28 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
@ -33,6 +33,7 @@ Settings::Settings()
|
||||||
|
|
||||||
// Now fill it with options that are common to all versions of Stella
|
// Now fill it with options that are common to all versions of Stella
|
||||||
set("video", "soft");
|
set("video", "soft");
|
||||||
|
set("video_driver", "");
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
set("gl_filter", "nearest");
|
set("gl_filter", "nearest");
|
||||||
set("gl_aspect", "2");
|
set("gl_aspect", "2");
|
||||||
|
@ -171,37 +172,38 @@ void Settings::usage()
|
||||||
<< endl
|
<< endl
|
||||||
<< "Valid options are:" << endl
|
<< "Valid options are:" << endl
|
||||||
<< endl
|
<< endl
|
||||||
<< " -video <type> Type is one of the following:\n"
|
<< " -video <type> Type is one of the following:\n"
|
||||||
<< " soft SDL software mode\n"
|
<< " soft SDL software mode\n"
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
<< " gl SDL OpenGL mode\n"
|
<< " gl SDL OpenGL mode\n"
|
||||||
|
<< " -video_driver <type> SDL Video driver (see manual).\n"
|
||||||
<< endl
|
<< endl
|
||||||
<< " -gl_filter <type> Type is one of the following:\n"
|
<< " -gl_filter <type> Type is one of the following:\n"
|
||||||
<< " nearest Normal scaling (GL_NEAREST)\n"
|
<< " nearest Normal scaling (GL_NEAREST)\n"
|
||||||
<< " linear Blurred scaling (GL_LINEAR)\n"
|
<< " linear Blurred scaling (GL_LINEAR)\n"
|
||||||
<< " -gl_aspect <number> Scale the width by the given amount\n"
|
<< " -gl_aspect <number> Scale the width by the given amount\n"
|
||||||
<< " -gl_fsmax <1|0> Use the largest available screenmode in fullscreen OpenGL\n"
|
<< " -gl_fsmax <1|0> Use the largest available screenmode in fullscreen OpenGL\n"
|
||||||
<< endl
|
<< endl
|
||||||
#endif
|
#endif
|
||||||
<< " -sound <1|0> Enable sound generation\n"
|
<< " -sound <1|0> Enable sound generation\n"
|
||||||
<< " -fragsize <number> The size of sound fragments (must be a power of two)\n"
|
<< " -fragsize <number> The size of sound fragments (must be a power of two)\n"
|
||||||
<< " -framerate <number> Display the given number of frames per second\n"
|
<< " -framerate <number> Display the given number of frames per second\n"
|
||||||
<< " -zoom <size> Makes window be 'size' times normal\n"
|
<< " -zoom <size> Makes window be 'size' times normal\n"
|
||||||
<< " -fullscreen <1|0> Play the game in fullscreen mode\n"
|
<< " -fullscreen <1|0> Play the game in fullscreen mode\n"
|
||||||
<< " -grabmouse <1|0> Keeps the mouse in the game window\n"
|
<< " -grabmouse <1|0> Keeps the mouse in the game window\n"
|
||||||
<< " -hidecursor <1|0> Hides the mouse cursor in the game window\n"
|
<< " -hidecursor <1|0> Hides the mouse cursor in the game window\n"
|
||||||
<< " -volume <number> Set the volume (0 - 100)\n"
|
<< " -volume <number> Set the volume (0 - 100)\n"
|
||||||
<< " -paddle <0|1|2|3> Indicates which paddle the mouse should emulate\n"
|
<< " -paddle <0|1|2|3> Indicates which paddle the mouse should emulate\n"
|
||||||
<< " -altpro <props file> Use the given properties file instead of stella.pro\n"
|
<< " -altpro <props file> Use the given properties file instead of stella.pro\n"
|
||||||
<< " -showinfo <1|0> Shows some game info\n"
|
<< " -showinfo <1|0> Shows some game info\n"
|
||||||
<< " -accurate <1|0> Accurate game timing (uses more CPU)\n"
|
<< " -accurate <1|0> Accurate game timing (uses more CPU)\n"
|
||||||
#ifdef SNAPSHOT_SUPPORT
|
#ifdef SNAPSHOT_SUPPORT
|
||||||
<< " -ssdir <path> The directory to save snapshot files to\n"
|
<< " -ssdir <path> The directory to save snapshot files to\n"
|
||||||
<< " -ssname <name> How to name the snapshot (romname or md5sum)\n"
|
<< " -ssname <name> How to name the snapshot (romname or md5sum)\n"
|
||||||
<< " -sssingle <1|0> Generate single snapshot instead of many\n"
|
<< " -sssingle <1|0> Generate single snapshot instead of many\n"
|
||||||
#endif
|
#endif
|
||||||
<< " -mergeprops <1|0> Merge changed properties into properties file,\n"
|
<< " -mergeprops <1|0> Merge changed properties into properties file,\n"
|
||||||
<< " or save into a separate file\n"
|
<< " or save into a separate file\n"
|
||||||
<< endl;
|
<< endl;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue