2009-01-10 18:42:49 +00:00
|
|
|
//============================================================================
|
2003-09-25 16:20:34 +00:00
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
2014-01-12 17:23:42 +00:00
|
|
|
// Copyright (c) 1995-2014 by Bradford W. Mott, Stephen Anthony
|
2010-04-10 21:37:23 +00:00
|
|
|
// and the Stella Team
|
2003-09-25 16:20:34 +00:00
|
|
|
//
|
2010-01-10 03:23:32 +00:00
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
2003-09-25 16:20:34 +00:00
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2009-05-13 13:55:40 +00:00
|
|
|
// $Id$
|
2003-09-25 16:20:34 +00:00
|
|
|
//============================================================================
|
|
|
|
|
Reworked 'fullres' argument to also accept the 'auto' option. In this case,
fullscreen resolutions will be automatically chosen based on the required
size for the window. The image will be centered and keep the same aspect
ratio, however, so operation will still work correctly on widescreen
monitors. 'Auto' will be the new default. Otherwise, if a specific
resolution is requested, Stella will try to accomodate it *only* if it fits
into the resolution; otherwise the smallest resolution that fits will be
used.
Removed 'zoom_ui' and 'zoom_tia'. The UI can now only be at 1x mode.
Aded 'tia_filter' commandline argument, which specifies to the filter
to use when rendering the tia image. For now, these accept 'zoom1x',
'zoom2x'..., up to 'zoom10x', and duplicate previous behaviour. Eventually,
Scalexx and HQxx filters may be added. Still TODO is add this to the UI.
First pass at making the standard build use a minimum of zoom2x for the TIA,
so the UI can be larger and use a better looking font. There's still work
to do in this area, especially for those ports with limited hardware that
support zoom1x only.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1544 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2008-07-22 14:54:39 +00:00
|
|
|
#include <algorithm>
|
2003-09-30 01:22:45 +00:00
|
|
|
#include <sstream>
|
|
|
|
|
2003-09-25 16:20:34 +00:00
|
|
|
#include "bspf.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
|
|
|
|
#include "CommandMenu.hxx"
|
2003-09-25 16:20:34 +00:00
|
|
|
#include "Console.hxx"
|
The first version of a GUI for event remapping is here!
Now for the things that aren't finished yet:
- Only the most basic functions can be remapped. If you
erase the mapping for those that can't yet be remapped,
you'll have to delete the 'keymap' line from stellarc and
start over.
- Core events can only be remapped to other keys on the keyboard.
I haven't got the joystick remapping working yet (but it should
be easy to do).
- The TIA needs to be modified to show 320 pixels horizontally.
Right now, I'm using 8 pixel-width fonts on a framebuffer of
160 pixels, so there's not a lot of horizontal real estate.
So text will probably overwrite other stuff. This is cosmetic,
and WILL be fixed.
- Modification of the TIA will break every frontends rendering
code. It had to be done sometime ...
- I haven't yet added any user feedback mechanism for the user. So when
you go into remap mode and are about to remap a key, you won't
know it :) I'll be adding arrows (like in XMAME) ...
I've added a "Game Information" menu, which shows things like Game name,
manufacturer, rarity, type, etc. Basically stuff from the stella.pro file.
It has no purpose other than for coolness :)
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@193 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2003-09-28 21:59:24 +00:00
|
|
|
#include "EventHandler.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
#include "Event.hxx"
|
2005-06-08 18:45:09 +00:00
|
|
|
#include "Font.hxx"
|
2014-02-05 22:09:57 +00:00
|
|
|
#include "StellaFont.hxx"
|
|
|
|
#include "StellaMediumFont.hxx"
|
|
|
|
#include "StellaLargeFont.hxx"
|
|
|
|
#include "ConsoleFont.hxx"
|
Added first pass of the ROM launcher. When you press 'Start' in the ROM
launcher, it launches Frostbite. Then pressing 'Escape' goes back to the
launcher, and you're able to then launch Frostbite again! Success !!!
Still TODO is actually get a ROM listing and use the selected game, but
the fact that it works multiple times for some game means that the
infrastructure is working correctly :)
Changed behaviour of the 'Escape' key. Specifically, it now only acts
as a key to enter ROM launcher mode. In the case where the emulation
was started without the launcher, the key will now do nothing. From now
on, the only way to quit Stella is Ctrl-Q (or equivalent for OSX),
close the window, or from the 'Quit' button.
Also, the 'Enter launcher mode' event will eventually be made remappable,
as will the 'Enter menu mode' event (currently the 'Tab' key).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@412 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2005-05-06 18:39:00 +00:00
|
|
|
#include "Launcher.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
#include "Menu.hxx"
|
2005-02-21 02:23:57 +00:00
|
|
|
#include "OSystem.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
#include "Settings.hxx"
|
2009-01-19 16:52:32 +00:00
|
|
|
#include "TIA.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
|
2014-04-30 16:53:21 +00:00
|
|
|
#include "FBSurface.hxx"
|
2014-05-12 23:34:25 +00:00
|
|
|
#include "TIASurface.hxx"
|
2007-09-03 18:37:24 +00:00
|
|
|
#include "FrameBuffer.hxx"
|
2005-08-24 22:54:30 +00:00
|
|
|
|
2006-12-15 16:43:12 +00:00
|
|
|
#ifdef DEBUGGER_SUPPORT
|
2005-08-24 22:54:30 +00:00
|
|
|
#include "Debugger.hxx"
|
|
|
|
#endif
|
|
|
|
|
2003-09-25 16:20:34 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
FrameBuffer::FrameBuffer(OSystem& osystem)
|
Reworked the mapping of joysticks yet again. After some thought, it
made no sense to restrict Stella to only work with two joysticks, since
there's no reason one couldn't use four devices, with each one emulating
a paddle (once I get paddle remapping done). So I've removed that
restriction, and also removed the 'leftport' and 'rightport' arguments.
The one case where remapping a joystick *does* make sense is for
multiple Stelladaptors. In that case, there might only be one
Stelladaptor installed, but you'd like it to emulate the right virtual
port. Previously this wasn't possible, but now it is with the addition
of the 'sa1' and 'sa2' commandline arguments. These arguments accept
either 'left' or 'right', specifying which virtual port to emulate.
Updated the InputDialog virtual device tab for remapping Stelladaptors.
Shortened some keynames in EventHandler, so that the actual character is
used (for example, ? instead of QUESTION).
Some fixes for the OS/2 port.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@884 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2005-11-19 22:26:14 +00:00
|
|
|
: myOSystem(osystem),
|
2007-01-30 17:13:10 +00:00
|
|
|
myInitializedCount(0),
|
2014-11-02 23:40:20 +00:00
|
|
|
myPausedCount(0)
|
2003-09-25 16:20:34 +00:00
|
|
|
{
|
2014-11-02 23:40:20 +00:00
|
|
|
myMsg.surface = myStatsMsg.surface = nullptr;
|
First pass at adding a cart-specific bankswitch/info tab to the
debugger. In the process, I had to spend several days extending
the UI/dialog class to actually contain multiple tabs. This was
harder than expected, and it still isn't quite finished. In many
ways, we're beginning to reach the limits of the current code; it
was never designed for a full-fledged, graphically rich UI.
For now the tab is empty, but eventually it will contain general
info about the ROM bankswitch type (size, virtual layout, etc),
but also cart-specific info, including the ability to change
banks, which can be vary greatly among the different schemes.
Eventually, it may even allow to see/modify very cart-specific
info (like display RAM in DPC, etc).
Better handle errors in opening the serial port (AtariVox support)
for Windows and OSX.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2678 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2013-03-31 00:10:05 +00:00
|
|
|
myMsg.enabled = myStatsMsg.enabled = false;
|
2003-10-17 18:02:16 +00:00
|
|
|
}
|
2003-10-01 19:01:02 +00:00
|
|
|
|
2003-10-17 18:02:16 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-11-02 23:40:20 +00:00
|
|
|
FrameBuffer::~FrameBuffer()
|
2003-10-17 18:02:16 +00:00
|
|
|
{
|
2008-12-12 18:32:53 +00:00
|
|
|
// Free all allocated surfaces
|
|
|
|
while(!mySurfaceList.empty())
|
|
|
|
{
|
|
|
|
delete (*mySurfaceList.begin()).second;
|
|
|
|
mySurfaceList.erase(mySurfaceList.begin());
|
|
|
|
}
|
2003-10-17 18:02:16 +00:00
|
|
|
}
|
2003-09-26 22:39:36 +00:00
|
|
|
|
2003-10-17 18:02:16 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-02-05 22:09:57 +00:00
|
|
|
bool FrameBuffer::initialize()
|
|
|
|
{
|
2014-03-07 22:12:39 +00:00
|
|
|
// Get desktop resolution and supported renderers
|
2014-09-01 21:17:33 +00:00
|
|
|
queryHardware(myDisplays, myRenderers);
|
2014-09-03 13:27:33 +00:00
|
|
|
uInt32 query_w = myDisplays[0].w, query_h = myDisplays[0].h;
|
2014-02-05 22:09:57 +00:00
|
|
|
|
2014-02-22 17:31:16 +00:00
|
|
|
// Check the 'maxres' setting, which is an undocumented developer feature
|
|
|
|
// that specifies the desktop size (not normally set)
|
2014-05-12 23:34:25 +00:00
|
|
|
const GUI::Size& s = myOSystem.settings().getSize("maxres");
|
2014-11-07 23:28:40 +00:00
|
|
|
if(s.valid())
|
2014-02-22 17:31:16 +00:00
|
|
|
{
|
2014-04-29 14:52:35 +00:00
|
|
|
query_w = s.w;
|
|
|
|
query_h = s.h;
|
2014-02-22 17:31:16 +00:00
|
|
|
}
|
2014-04-28 16:47:10 +00:00
|
|
|
// Various parts of the codebase assume a minimum screen size
|
2014-04-29 14:52:35 +00:00
|
|
|
myDesktopSize.w = BSPF_max(query_w, (uInt32)kFBMinW);
|
|
|
|
myDesktopSize.h = BSPF_max(query_h, (uInt32)kFBMinH);
|
2014-02-05 22:09:57 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////
|
|
|
|
// Create fonts to draw text
|
|
|
|
// NOTE: the logic determining appropriate font sizes is done here,
|
|
|
|
// so that the UI classes can just use the font they expect,
|
|
|
|
// and not worry about it
|
|
|
|
// This logic should also take into account the size of the
|
|
|
|
// framebuffer, and try to be intelligent about font sizes
|
|
|
|
// We can probably add ifdefs to take care of corner cases,
|
|
|
|
// but that means we've failed to abstract it enough ...
|
|
|
|
////////////////////////////////////////////////////////////////////
|
2014-09-03 13:27:33 +00:00
|
|
|
bool smallScreen = myDesktopSize.w < kFBMinW || myDesktopSize.h < kFBMinH;
|
2014-02-05 22:09:57 +00:00
|
|
|
|
|
|
|
// This font is used in a variety of situations when a really small
|
|
|
|
// font is needed; we let the specific widget/dialog decide when to
|
|
|
|
// use it
|
2014-11-02 23:40:20 +00:00
|
|
|
mySmallFont = make_ptr<GUI::Font>(GUI::stellaDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
|
|
|
|
// The general font used in all UI elements
|
|
|
|
// This is determined by the size of the framebuffer
|
2014-11-02 23:40:20 +00:00
|
|
|
myFont = make_ptr<GUI::Font>(smallScreen ? GUI::stellaDesc : GUI::stellaMediumDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
|
|
|
|
// The info font used in all UI elements
|
|
|
|
// This is determined by the size of the framebuffer
|
2014-11-02 23:40:20 +00:00
|
|
|
myInfoFont = make_ptr<GUI::Font>(smallScreen ? GUI::stellaDesc : GUI::consoleDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
|
|
|
|
// The font used by the ROM launcher
|
|
|
|
// Normally, this is configurable by the user, except in the case of
|
|
|
|
// very small screens
|
|
|
|
if(!smallScreen)
|
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
const string& lf = myOSystem.settings().getString("launcherfont");
|
2014-02-05 22:09:57 +00:00
|
|
|
if(lf == "small")
|
2014-11-02 23:40:20 +00:00
|
|
|
myLauncherFont = make_ptr<GUI::Font>(GUI::consoleDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
else if(lf == "medium")
|
2014-11-02 23:40:20 +00:00
|
|
|
myLauncherFont = make_ptr<GUI::Font>(GUI::stellaMediumDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
else
|
2014-11-02 23:40:20 +00:00
|
|
|
myLauncherFont = make_ptr<GUI::Font>(GUI::stellaLargeDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
}
|
|
|
|
else
|
2014-11-02 23:40:20 +00:00
|
|
|
myLauncherFont = make_ptr<GUI::Font>(GUI::stellaDesc);
|
2014-02-05 22:09:57 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// Determine possible TIA windowed zoom levels
|
|
|
|
uInt32 maxZoom = maxWindowSizeForScreen((uInt32)kTIAMinW, (uInt32)kTIAMinH,
|
2014-04-29 14:52:35 +00:00
|
|
|
myDesktopSize.w, myDesktopSize.h);
|
2014-04-28 16:47:10 +00:00
|
|
|
|
|
|
|
// Figure our the smallest zoom level we can use
|
|
|
|
uInt32 firstZoom = smallScreen ? 1 : 2;
|
|
|
|
for(uInt32 zoom = firstZoom; zoom <= maxZoom; ++zoom)
|
|
|
|
{
|
|
|
|
ostringstream desc;
|
|
|
|
desc << "Zoom " << zoom << "x";
|
2014-11-08 21:27:36 +00:00
|
|
|
VList::push_back(myTIAZoomLevels, desc.str(), zoom);
|
2014-04-28 16:47:10 +00:00
|
|
|
}
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
// Set palette for GUI (upper area of array, doesn't change during execution)
|
2014-09-03 13:27:33 +00:00
|
|
|
int palID = myOSystem.settings().getString("uipalette") == "classic" ? 1 : 0;
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
for(int i = 0, j = 256; i < kNumColors-256; ++i, ++j)
|
|
|
|
{
|
2014-09-03 13:27:33 +00:00
|
|
|
Uint8 r = (ourGUIColors[palID][i] >> 16) & 0xff;
|
|
|
|
Uint8 g = (ourGUIColors[palID][i] >> 8) & 0xff;
|
|
|
|
Uint8 b = ourGUIColors[palID][i] & 0xff;
|
2014-05-12 23:34:25 +00:00
|
|
|
|
|
|
|
myPalette[j] = mapRGB(r, g, b);
|
|
|
|
}
|
|
|
|
FBSurface::setPalette(myPalette);
|
|
|
|
|
|
|
|
// Create a TIA surface; we need it for rendering TIA images
|
2014-11-02 23:40:20 +00:00
|
|
|
myTIASurface = make_ptr<TIASurface>(myOSystem);
|
2014-05-12 23:34:25 +00:00
|
|
|
|
2014-02-05 22:09:57 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
FBInitStatus FrameBuffer::createDisplay(const string& title,
|
|
|
|
uInt32 width, uInt32 height)
|
2003-10-17 18:02:16 +00:00
|
|
|
{
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
myInitializedCount++;
|
2014-04-29 14:52:35 +00:00
|
|
|
myScreenTitle = title;
|
2006-12-03 01:24:34 +00:00
|
|
|
|
2010-07-22 15:41:46 +00:00
|
|
|
// A 'windowed' system is defined as one where the window size can be
|
|
|
|
// larger than the screen size, as there's some sort of window manager
|
|
|
|
// that takes care of it (all current desktop systems fall in this category)
|
|
|
|
// However, some systems have no concept of windowing, and have hard limits
|
|
|
|
// on how large a window can be (ie, the size of the 'desktop' is the
|
|
|
|
// absolute upper limit on window size)
|
|
|
|
//
|
|
|
|
// If the WINDOWED_SUPPORT macro is defined, we treat the system as the
|
|
|
|
// former type; if not, as the latter type
|
2006-12-03 01:24:34 +00:00
|
|
|
|
2013-09-28 00:51:10 +00:00
|
|
|
bool useFullscreen = false;
|
2009-06-05 14:05:23 +00:00
|
|
|
#ifdef WINDOWED_SUPPORT
|
2014-04-28 16:47:10 +00:00
|
|
|
// We assume that a desktop of at least minimum acceptable size means that
|
|
|
|
// we're running on a 'large' system, and the window size requirements
|
|
|
|
// can be relaxed
|
2010-07-22 15:41:46 +00:00
|
|
|
// Otherwise, we treat the system as if WINDOWED_SUPPORT is not defined
|
2014-05-03 17:48:25 +00:00
|
|
|
if(myDesktopSize.w < kFBMinW && myDesktopSize.h < kFBMinH &&
|
2014-04-29 14:52:35 +00:00
|
|
|
(myDesktopSize.w < width || myDesktopSize.h < height))
|
2010-07-22 15:41:46 +00:00
|
|
|
return kFailTooLarge;
|
2010-11-07 16:19:26 +00:00
|
|
|
|
2014-06-04 12:15:54 +00:00
|
|
|
useFullscreen = myOSystem.settings().getBool("fullscreen");
|
2010-07-22 15:41:46 +00:00
|
|
|
#else
|
|
|
|
// Make sure this mode is even possible
|
|
|
|
// We only really need to worry about it in non-windowed environments,
|
|
|
|
// where requesting a window that's too large will probably cause a crash
|
2014-04-29 14:52:35 +00:00
|
|
|
if(myDesktopSize.w < width || myDesktopSize.h < height)
|
2010-07-22 15:41:46 +00:00
|
|
|
return kFailTooLarge;
|
2009-06-05 14:05:23 +00:00
|
|
|
#endif
|
|
|
|
|
2008-06-19 12:01:31 +00:00
|
|
|
// Set the available video modes for this framebuffer
|
|
|
|
setAvailableVidModes(width, height);
|
2008-04-02 21:22:16 +00:00
|
|
|
|
2008-06-19 12:01:31 +00:00
|
|
|
// Initialize video subsystem (make sure we get a valid mode)
|
2014-03-08 22:15:02 +00:00
|
|
|
string pre_about = about();
|
2014-04-28 16:47:10 +00:00
|
|
|
const VideoMode& mode = getSavedVidMode(useFullscreen);
|
2014-06-02 14:34:12 +00:00
|
|
|
if(width <= (uInt32)mode.screen.w && height <= (uInt32)mode.screen.h)
|
2008-05-30 19:07:55 +00:00
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
if(setVideoMode(myScreenTitle, mode))
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-06-02 14:34:12 +00:00
|
|
|
myImageRect = mode.image;
|
|
|
|
myScreenSize = mode.screen;
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
// Inform TIA surface about new mode
|
|
|
|
if(myOSystem.eventHandler().state() != EventHandler::S_LAUNCHER &&
|
|
|
|
myOSystem.eventHandler().state() != EventHandler::S_DEBUGGER)
|
|
|
|
myTIASurface->initialize(myOSystem.console(), mode);
|
|
|
|
|
2009-06-05 14:05:23 +00:00
|
|
|
// Did we get the requested fullscreen state?
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.settings().setValue("fullscreen", fullScreen());
|
|
|
|
resetSurfaces();
|
2009-08-07 11:45:14 +00:00
|
|
|
setCursorState();
|
2008-06-19 12:01:31 +00:00
|
|
|
}
|
2010-08-11 21:53:19 +00:00
|
|
|
else
|
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.logMessage("ERROR: Couldn't initialize video subsystem", 0);
|
2010-08-11 21:53:19 +00:00
|
|
|
return kFailNotSupported;
|
|
|
|
}
|
2008-05-30 19:07:55 +00:00
|
|
|
}
|
2008-06-19 12:01:31 +00:00
|
|
|
else
|
2010-07-22 15:41:46 +00:00
|
|
|
return kFailTooLarge;
|
2005-05-12 18:45:21 +00:00
|
|
|
|
|
|
|
// Erase any messages from a previous run
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.counter = 0;
|
|
|
|
|
|
|
|
// Create surfaces for TIA statistics and general messages
|
|
|
|
myStatsMsg.color = kBtnTextColor;
|
2014-02-05 22:09:57 +00:00
|
|
|
myStatsMsg.w = infoFont().getMaxCharWidth() * 24 + 2;
|
|
|
|
myStatsMsg.h = (infoFont().getFontHeight() + 2) * 2;
|
2008-12-25 23:05:16 +00:00
|
|
|
|
2014-11-02 23:40:20 +00:00
|
|
|
if(myStatsMsg.surface == nullptr)
|
2008-12-12 15:51:07 +00:00
|
|
|
{
|
First pass at adding a cart-specific bankswitch/info tab to the
debugger. In the process, I had to spend several days extending
the UI/dialog class to actually contain multiple tabs. This was
harder than expected, and it still isn't quite finished. In many
ways, we're beginning to reach the limits of the current code; it
was never designed for a full-fledged, graphically rich UI.
For now the tab is empty, but eventually it will contain general
info about the ROM bankswitch type (size, virtual layout, etc),
but also cart-specific info, including the ability to change
banks, which can be vary greatly among the different schemes.
Eventually, it may even allow to see/modify very cart-specific
info (like display RAM in DPC, etc).
Better handle errors in opening the serial port (AtariVox support)
for Windows and OSX.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2678 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2013-03-31 00:10:05 +00:00
|
|
|
uInt32 surfaceID = allocateSurface(myStatsMsg.w, myStatsMsg.h);
|
|
|
|
myStatsMsg.surface = surface(surfaceID);
|
2008-12-12 15:51:07 +00:00
|
|
|
}
|
2014-11-02 23:40:20 +00:00
|
|
|
if(myMsg.surface == nullptr)
|
2008-12-12 15:51:07 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
uInt32 surfaceID = allocateSurface((uInt32)kFBMinW, font().getFontHeight()+10);
|
First pass at adding a cart-specific bankswitch/info tab to the
debugger. In the process, I had to spend several days extending
the UI/dialog class to actually contain multiple tabs. This was
harder than expected, and it still isn't quite finished. In many
ways, we're beginning to reach the limits of the current code; it
was never designed for a full-fledged, graphically rich UI.
For now the tab is empty, but eventually it will contain general
info about the ROM bankswitch type (size, virtual layout, etc),
but also cart-specific info, including the ability to change
banks, which can be vary greatly among the different schemes.
Eventually, it may even allow to see/modify very cart-specific
info (like display RAM in DPC, etc).
Better handle errors in opening the serial port (AtariVox support)
for Windows and OSX.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2678 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2013-03-31 00:10:05 +00:00
|
|
|
myMsg.surface = surface(surfaceID);
|
2008-12-12 15:51:07 +00:00
|
|
|
}
|
2006-12-11 00:15:34 +00:00
|
|
|
|
2014-06-30 22:46:33 +00:00
|
|
|
// Print initial usage message, but only print it later if the status has changed
|
|
|
|
if (myInitializedCount == 1)
|
2014-01-31 16:23:10 +00:00
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.logMessage(about(), 1);
|
2014-01-31 16:23:10 +00:00
|
|
|
}
|
2014-03-08 22:15:02 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
string post_about = about();
|
|
|
|
if(post_about != pre_about)
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.logMessage(post_about, 1);
|
2014-03-08 22:15:02 +00:00
|
|
|
}
|
2008-05-30 19:07:55 +00:00
|
|
|
|
2010-07-22 15:41:46 +00:00
|
|
|
return kSuccess;
|
2003-10-26 19:40:39 +00:00
|
|
|
}
|
The first version of a GUI for event remapping is here!
Now for the things that aren't finished yet:
- Only the most basic functions can be remapped. If you
erase the mapping for those that can't yet be remapped,
you'll have to delete the 'keymap' line from stellarc and
start over.
- Core events can only be remapped to other keys on the keyboard.
I haven't got the joystick remapping working yet (but it should
be easy to do).
- The TIA needs to be modified to show 320 pixels horizontally.
Right now, I'm using 8 pixel-width fonts on a framebuffer of
160 pixels, so there's not a lot of horizontal real estate.
So text will probably overwrite other stuff. This is cosmetic,
and WILL be fixed.
- Modification of the TIA will break every frontends rendering
code. It had to be done sometime ...
- I haven't yet added any user feedback mechanism for the user. So when
you go into remap mode and are about to remap a key, you won't
know it :) I'll be adding arrows (like in XMAME) ...
I've added a "Game Information" menu, which shows things like Game name,
manufacturer, rarity, type, etc. Basically stuff from the stella.pro file.
It has no purpose other than for coolness :)
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@193 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2003-09-28 21:59:24 +00:00
|
|
|
|
2003-10-26 19:40:39 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::update()
|
|
|
|
{
|
2005-02-27 23:41:19 +00:00
|
|
|
// Determine which mode we are in (from the EventHandler)
|
|
|
|
// Take care of S_EMULATE mode here, otherwise let the GUI
|
|
|
|
// figure out what to draw
|
2014-05-12 23:34:25 +00:00
|
|
|
switch(myOSystem.eventHandler().state())
|
Huge changes across the map. Lets see if I can remember it all ...
There is now an SDL OpenGL port with filtering and alpha-blending.
It's a work in progress right now, but is already quite stable.
It's not as optimized as the software version yet, but this will
change as well. For now, you have to compile the SDL version in
either normal software mode or OpenGL mode. This will change
before the 1.4 release.
When entering menu mode, the emulation is now suspended. And when
pause is pressed, you can't enter menu mode. Because of these changes,
CPU use has dropped dramatically when viewing menus. This will benefit
all ports, since menus are now redrawn only when necessary, instead of
at the current framerate.
For a reference, on a Pentium-IV 2.4GHz, the software SDL version
maxes CPU usage at 9%, and the SDL OpenGL version at 13.5%. This is
at 60 fps and a zoomlevel of 4. While some small improvements can
(possibly) be made to the OpenGL version, I think we'll soon be hitting
the glass ceiling.
Work on the Porting.txt document is progressing, and I estimate it to
be 45% complete.
The Windows version still doesn't compile, and I still haven't looked
at it. Rest assured that it will be done before 1.4. There will be
a simultaneous release, even if the Linux versions are finished.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@200 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2003-11-06 22:22:33 +00:00
|
|
|
{
|
2005-02-27 23:41:19 +00:00
|
|
|
case EventHandler::S_EMULATE:
|
|
|
|
{
|
OK, some huge changes across the board, so lets see if I get it all:
After much request, added ability to access the settings menu from the
ROM browser dialog. This menu now contains almost all items that can
be selected in Stella, and can be accessed in-game as before.
Completely removed pause functionality from the core code. It made
sense back when Stella was a single-mode program: there were two modes;
emulation and pause. Now that there are other event modes, the
EventHandler state machine is getting too complicated. If you want to
pause, you can simply enter one of the in-game menus. Related to this,
when the app is minimized, Stella enters the menu dialog state.
Previously, minimizing the app caused a pause, but since there was no
onscreen feedback, many people assumed the app locked up.
Added centering to all Dialog boxes, which is done dynamically, as they're
placed on the dialog stack to be drawn to the screen.
Cleaned up the API of Console/FrameBuffer/OSystem classes wrt to palettes
and timing. Parts of each were being done in different classes; now it
should be more consistent.
Started infrastructure for user-selectable UI palettes. For now, there's
no way to change it in the GUI, and it defaults to the normal palette.
Eventually, there will be several choices selectable from an in-game
menu.
Removed '-channels' commandline argument, since that feature can be
set from the ROM properties.
Added '128' to the choices for fragment size in AudioDialog.
Tweaked the OpenGL dynamic loading code to test both the given GL
lib, and if that fails to use auto-detection. It seems in the OSX port,
the first approach works for some people, and not the other (and vice-versa),
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1255 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-12-30 22:26:29 +00:00
|
|
|
// Run the console for one frame
|
2009-01-12 15:11:55 +00:00
|
|
|
// Note that the debugger can cause a breakpoint to occur, which changes
|
|
|
|
// the EventHandler state 'behind our back' - we need to check for that
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.console().tia().update();
|
2009-01-12 15:11:55 +00:00
|
|
|
#ifdef DEBUGGER_SUPPORT
|
2014-05-12 23:34:25 +00:00
|
|
|
if(myOSystem.eventHandler().state() != EventHandler::S_EMULATE) break;
|
2009-01-12 15:11:55 +00:00
|
|
|
#endif
|
2014-05-12 23:34:25 +00:00
|
|
|
if(myOSystem.eventHandler().frying())
|
|
|
|
myOSystem.console().fry();
|
2006-01-11 20:28:07 +00:00
|
|
|
|
OK, some huge changes across the board, so lets see if I get it all:
After much request, added ability to access the settings menu from the
ROM browser dialog. This menu now contains almost all items that can
be selected in Stella, and can be accessed in-game as before.
Completely removed pause functionality from the core code. It made
sense back when Stella was a single-mode program: there were two modes;
emulation and pause. Now that there are other event modes, the
EventHandler state machine is getting too complicated. If you want to
pause, you can simply enter one of the in-game menus. Related to this,
when the app is minimized, Stella enters the menu dialog state.
Previously, minimizing the app caused a pause, but since there was no
onscreen feedback, many people assumed the app locked up.
Added centering to all Dialog boxes, which is done dynamically, as they're
placed on the dialog stack to be drawn to the screen.
Cleaned up the API of Console/FrameBuffer/OSystem classes wrt to palettes
and timing. Parts of each were being done in different classes; now it
should be more consistent.
Started infrastructure for user-selectable UI palettes. For now, there's
no way to change it in the GUI, and it defaults to the normal palette.
Eventually, there will be several choices selectable from an in-game
menu.
Removed '-channels' commandline argument, since that feature can be
set from the ROM properties.
Added '128' to the choices for fragment size in AudioDialog.
Tweaked the OpenGL dynamic loading code to test both the given GL
lib, and if that fails to use auto-detection. It seems in the OSX port,
the first approach works for some people, and not the other (and vice-versa),
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1255 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-12-30 22:26:29 +00:00
|
|
|
// And update the screen
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
2003-09-25 16:20:34 +00:00
|
|
|
|
2008-05-20 13:42:50 +00:00
|
|
|
// Show frame statistics
|
2008-06-19 12:01:31 +00:00
|
|
|
if(myStatsMsg.enabled)
|
2008-05-20 13:42:50 +00:00
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
const ConsoleInfo& info = myOSystem.console().about();
|
2008-05-20 13:42:50 +00:00
|
|
|
char msg[30];
|
2012-05-01 19:09:28 +00:00
|
|
|
BSPF_snprintf(msg, 30, "%3u @ %3.2ffps => %s",
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.console().tia().scanlines(),
|
|
|
|
myOSystem.console().getFramerate(), info.DisplayFormat.c_str());
|
2008-06-19 12:01:31 +00:00
|
|
|
myStatsMsg.surface->fillRect(0, 0, myStatsMsg.w, myStatsMsg.h, kBGColor);
|
2014-02-05 22:09:57 +00:00
|
|
|
myStatsMsg.surface->drawString(infoFont(),
|
2009-01-01 00:08:59 +00:00
|
|
|
msg, 1, 1, myStatsMsg.w, myStatsMsg.color, kTextAlignLeft);
|
2014-02-05 22:09:57 +00:00
|
|
|
myStatsMsg.surface->drawString(infoFont(),
|
2009-02-01 22:17:09 +00:00
|
|
|
info.BankSwitch, 1, 15, myStatsMsg.w, myStatsMsg.color, kTextAlignLeft);
|
2014-08-24 21:47:51 +00:00
|
|
|
myStatsMsg.surface->setDirty();
|
2014-05-04 16:59:11 +00:00
|
|
|
myStatsMsg.surface->setDstPos(myImageRect.x() + 1, myImageRect.y() + 1);
|
2014-05-02 15:58:57 +00:00
|
|
|
myStatsMsg.surface->render();
|
2008-05-20 13:42:50 +00:00
|
|
|
}
|
2005-02-27 23:41:19 +00:00
|
|
|
break; // S_EMULATE
|
Huge changes across the map. Lets see if I can remember it all ...
There is now an SDL OpenGL port with filtering and alpha-blending.
It's a work in progress right now, but is already quite stable.
It's not as optimized as the software version yet, but this will
change as well. For now, you have to compile the SDL version in
either normal software mode or OpenGL mode. This will change
before the 1.4 release.
When entering menu mode, the emulation is now suspended. And when
pause is pressed, you can't enter menu mode. Because of these changes,
CPU use has dropped dramatically when viewing menus. This will benefit
all ports, since menus are now redrawn only when necessary, instead of
at the current framerate.
For a reference, on a Pentium-IV 2.4GHz, the software SDL version
maxes CPU usage at 9%, and the SDL OpenGL version at 13.5%. This is
at 60 fps and a zoomlevel of 4. While some small improvements can
(possibly) be made to the OpenGL version, I think we'll soon be hitting
the glass ceiling.
Work on the Porting.txt document is progressing, and I estimate it to
be 45% complete.
The Windows version still doesn't compile, and I still haven't looked
at it. Rest assured that it will be done before 1.4. There will be
a simultaneous release, even if the Linux versions are finished.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@200 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2003-11-06 22:22:33 +00:00
|
|
|
}
|
2003-10-26 19:40:39 +00:00
|
|
|
|
2007-01-30 17:13:10 +00:00
|
|
|
case EventHandler::S_PAUSE:
|
|
|
|
{
|
|
|
|
// Show a pause message every 5 seconds
|
2014-05-12 23:34:25 +00:00
|
|
|
if(myPausedCount++ >= 7*myOSystem.frameRate())
|
2007-01-30 17:13:10 +00:00
|
|
|
{
|
|
|
|
myPausedCount = 0;
|
|
|
|
showMessage("Paused", kMiddleCenter);
|
|
|
|
}
|
|
|
|
break; // S_PAUSE
|
|
|
|
}
|
|
|
|
|
2005-03-13 03:38:41 +00:00
|
|
|
case EventHandler::S_MENU:
|
2005-02-27 23:41:19 +00:00
|
|
|
{
|
2014-06-23 15:34:25 +00:00
|
|
|
myOSystem.menu().draw();
|
2005-07-20 15:52:58 +00:00
|
|
|
break; // S_MENU
|
2005-02-27 23:41:19 +00:00
|
|
|
}
|
Huge changes across the map. Lets see if I can remember it all ...
There is now an SDL OpenGL port with filtering and alpha-blending.
It's a work in progress right now, but is already quite stable.
It's not as optimized as the software version yet, but this will
change as well. For now, you have to compile the SDL version in
either normal software mode or OpenGL mode. This will change
before the 1.4 release.
When entering menu mode, the emulation is now suspended. And when
pause is pressed, you can't enter menu mode. Because of these changes,
CPU use has dropped dramatically when viewing menus. This will benefit
all ports, since menus are now redrawn only when necessary, instead of
at the current framerate.
For a reference, on a Pentium-IV 2.4GHz, the software SDL version
maxes CPU usage at 9%, and the SDL OpenGL version at 13.5%. This is
at 60 fps and a zoomlevel of 4. While some small improvements can
(possibly) be made to the OpenGL version, I think we'll soon be hitting
the glass ceiling.
Work on the Porting.txt document is progressing, and I estimate it to
be 45% complete.
The Windows version still doesn't compile, and I still haven't looked
at it. Rest assured that it will be done before 1.4. There will be
a simultaneous release, even if the Linux versions are finished.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@200 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2003-11-06 22:22:33 +00:00
|
|
|
|
2005-08-29 18:36:42 +00:00
|
|
|
case EventHandler::S_CMDMENU:
|
|
|
|
{
|
2014-06-23 15:34:25 +00:00
|
|
|
myOSystem.commandMenu().draw();
|
2005-08-29 18:36:42 +00:00
|
|
|
break; // S_CMDMENU
|
|
|
|
}
|
|
|
|
|
Added first pass of the ROM launcher. When you press 'Start' in the ROM
launcher, it launches Frostbite. Then pressing 'Escape' goes back to the
launcher, and you're able to then launch Frostbite again! Success !!!
Still TODO is actually get a ROM listing and use the selected game, but
the fact that it works multiple times for some game means that the
infrastructure is working correctly :)
Changed behaviour of the 'Escape' key. Specifically, it now only acts
as a key to enter ROM launcher mode. In the case where the emulation
was started without the launcher, the key will now do nothing. From now
on, the only way to quit Stella is Ctrl-Q (or equivalent for OSX),
close the window, or from the 'Quit' button.
Also, the 'Enter launcher mode' event will eventually be made remappable,
as will the 'Enter menu mode' event (currently the 'Tab' key).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@412 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2005-05-06 18:39:00 +00:00
|
|
|
case EventHandler::S_LAUNCHER:
|
|
|
|
{
|
2014-06-23 15:34:25 +00:00
|
|
|
myOSystem.launcher().draw();
|
2005-07-20 15:52:58 +00:00
|
|
|
break; // S_LAUNCHER
|
Added first pass of the ROM launcher. When you press 'Start' in the ROM
launcher, it launches Frostbite. Then pressing 'Escape' goes back to the
launcher, and you're able to then launch Frostbite again! Success !!!
Still TODO is actually get a ROM listing and use the selected game, but
the fact that it works multiple times for some game means that the
infrastructure is working correctly :)
Changed behaviour of the 'Escape' key. Specifically, it now only acts
as a key to enter ROM launcher mode. In the case where the emulation
was started without the launcher, the key will now do nothing. From now
on, the only way to quit Stella is Ctrl-Q (or equivalent for OSX),
close the window, or from the 'Quit' button.
Also, the 'Enter launcher mode' event will eventually be made remappable,
as will the 'Enter menu mode' event (currently the 'Tab' key).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@412 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2005-05-06 18:39:00 +00:00
|
|
|
}
|
2004-06-23 03:43:47 +00:00
|
|
|
|
2006-12-15 16:43:12 +00:00
|
|
|
#ifdef DEBUGGER_SUPPORT
|
2005-02-27 23:41:19 +00:00
|
|
|
case EventHandler::S_DEBUGGER:
|
2005-06-23 14:33:12 +00:00
|
|
|
{
|
2014-06-23 15:34:25 +00:00
|
|
|
myOSystem.debugger().draw();
|
2005-05-27 18:00:49 +00:00
|
|
|
break; // S_DEBUGGER
|
2005-06-23 14:33:12 +00:00
|
|
|
}
|
2005-08-24 22:54:30 +00:00
|
|
|
#endif
|
2005-02-27 23:41:19 +00:00
|
|
|
|
2005-08-24 22:54:30 +00:00
|
|
|
default:
|
2005-02-27 23:41:19 +00:00
|
|
|
return;
|
2003-10-26 19:40:39 +00:00
|
|
|
}
|
|
|
|
|
2006-12-18 12:53:33 +00:00
|
|
|
// Draw any pending messages
|
2009-01-10 18:42:49 +00:00
|
|
|
if(myMsg.enabled)
|
2006-12-18 12:53:33 +00:00
|
|
|
drawMessage();
|
|
|
|
|
2008-12-04 16:53:26 +00:00
|
|
|
// Do any post-frame stuff
|
2008-08-04 11:56:12 +00:00
|
|
|
postFrameUpdate();
|
2003-09-25 16:20:34 +00:00
|
|
|
}
|
|
|
|
|
2005-03-13 03:38:41 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2006-03-19 18:17:48 +00:00
|
|
|
void FrameBuffer::showMessage(const string& message, MessagePosition position,
|
2012-01-03 20:52:45 +00:00
|
|
|
bool force)
|
2005-03-13 03:38:41 +00:00
|
|
|
{
|
Revamped the result on floating pins for TIA reads. Previously, this was
controlled by 'tiafloat', which has now been removed. Now, all
undriven pins take on the last value on the databus. This fixes a bug
in those reads where bit 6 or bits 6 & 7 are also undriven (previously,
these bits would always be zero, and only bits 0-5 were from lastdatabus.
Added new commandline argument 'tiadriven', which defaults to false.
In this default case, relevant bits take on values from the databus.
If true, relevant bits still take on databus values, but some are
randomly driven high as well. This helps to expose bugs when
developers assume the values for undriven/floating bits.
Added 'uimessages' commandline argument and associated UI item. When
disabled, messages which are normally shown in-game are disabled.
Certain messages which indicate a serious error are still shown, however.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1900 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2009-11-10 20:12:50 +00:00
|
|
|
// Only show messages if they've been enabled
|
2014-05-12 23:34:25 +00:00
|
|
|
if(!(force || myOSystem.settings().getBool("uimessages")))
|
Revamped the result on floating pins for TIA reads. Previously, this was
controlled by 'tiafloat', which has now been removed. Now, all
undriven pins take on the last value on the databus. This fixes a bug
in those reads where bit 6 or bits 6 & 7 are also undriven (previously,
these bits would always be zero, and only bits 0-5 were from lastdatabus.
Added new commandline argument 'tiadriven', which defaults to false.
In this default case, relevant bits take on values from the databus.
If true, relevant bits still take on databus values, but some are
randomly driven high as well. This helps to expose bugs when
developers assume the values for undriven/floating bits.
Added 'uimessages' commandline argument and associated UI item. When
disabled, messages which are normally shown in-game are disabled.
Certain messages which indicate a serious error are still shown, however.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1900 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2009-11-10 20:12:50 +00:00
|
|
|
return;
|
|
|
|
|
2005-07-20 18:44:38 +00:00
|
|
|
// Erase old messages on the screen
|
2008-06-19 12:01:31 +00:00
|
|
|
if(myMsg.counter > 0)
|
2008-12-27 23:27:32 +00:00
|
|
|
refresh();
|
2005-07-20 18:44:38 +00:00
|
|
|
|
2006-03-19 18:17:48 +00:00
|
|
|
// Precompute the message coordinates
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.text = message;
|
2014-05-12 23:34:25 +00:00
|
|
|
myMsg.counter = uInt32(myOSystem.frameRate()) << 1; // Show message for 2 seconds
|
2012-01-03 20:52:45 +00:00
|
|
|
myMsg.color = kBtnTextColor;
|
2006-03-19 18:17:48 +00:00
|
|
|
|
2014-02-05 22:09:57 +00:00
|
|
|
myMsg.w = font().getStringWidth(myMsg.text) + 10;
|
|
|
|
myMsg.h = font().getFontHeight() + 8;
|
2014-05-07 20:02:47 +00:00
|
|
|
myMsg.surface->setSrcSize(myMsg.w, myMsg.h);
|
2014-05-04 16:59:11 +00:00
|
|
|
myMsg.surface->setDstSize(myMsg.w, myMsg.h);
|
2009-01-10 18:42:49 +00:00
|
|
|
myMsg.position = position;
|
|
|
|
myMsg.enabled = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::toggleFrameStats()
|
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
showFrameStats(!myOSystem.settings().getBool("stats"));
|
2009-01-10 18:42:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::showFrameStats(bool enable)
|
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.settings().setValue("stats", enable);
|
2009-01-10 18:42:49 +00:00
|
|
|
myStatsMsg.enabled = enable;
|
|
|
|
refresh();
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::enableMessages(bool enable)
|
|
|
|
{
|
|
|
|
if(enable)
|
|
|
|
{
|
2010-04-14 15:41:42 +00:00
|
|
|
// Only re-enable frame stats if they were already enabled before
|
2014-05-12 23:34:25 +00:00
|
|
|
myStatsMsg.enabled = myOSystem.settings().getBool("stats");
|
2009-01-10 18:42:49 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Temporarily disable frame stats
|
|
|
|
myStatsMsg.enabled = false;
|
2006-03-19 18:17:48 +00:00
|
|
|
|
2009-01-10 18:42:49 +00:00
|
|
|
// Erase old messages on the screen
|
|
|
|
myMsg.enabled = false;
|
|
|
|
myMsg.counter = 0;
|
|
|
|
|
|
|
|
refresh();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
inline void FrameBuffer::drawMessage()
|
|
|
|
{
|
|
|
|
// Draw the bounded box and text
|
|
|
|
switch(myMsg.position)
|
2006-03-19 18:17:48 +00:00
|
|
|
{
|
|
|
|
case kTopLeft:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = 5;
|
|
|
|
myMsg.y = 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kTopCenter:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = (myImageRect.width() - myMsg.w) >> 1;
|
|
|
|
myMsg.y = 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kTopRight:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = myImageRect.width() - myMsg.w - 5;
|
|
|
|
myMsg.y = 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kMiddleLeft:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = 5;
|
|
|
|
myMsg.y = (myImageRect.height() - myMsg.h) >> 1;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kMiddleCenter:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = (myImageRect.width() - myMsg.w) >> 1;
|
|
|
|
myMsg.y = (myImageRect.height() - myMsg.h) >> 1;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kMiddleRight:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = myImageRect.width() - myMsg.w - 5;
|
|
|
|
myMsg.y = (myImageRect.height() - myMsg.h) >> 1;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kBottomLeft:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = 5;
|
|
|
|
myMsg.y = myImageRect.height() - myMsg.h - 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kBottomCenter:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = (myImageRect.width() - myMsg.w) >> 1;
|
|
|
|
myMsg.y = myImageRect.height() - myMsg.h - 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case kBottomRight:
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.x = myImageRect.width() - myMsg.w - 5;
|
|
|
|
myMsg.y = myImageRect.height() - myMsg.h - 5;
|
2006-03-19 18:17:48 +00:00
|
|
|
break;
|
|
|
|
}
|
2005-03-13 03:38:41 +00:00
|
|
|
|
2014-05-04 16:59:11 +00:00
|
|
|
myMsg.surface->setDstPos(myMsg.x + myImageRect.x(), myMsg.y + myImageRect.y());
|
2012-01-03 20:52:45 +00:00
|
|
|
myMsg.surface->fillRect(1, 1, myMsg.w-2, myMsg.h-2, kBtnColor);
|
|
|
|
myMsg.surface->box(0, 0, myMsg.w, myMsg.h, kColor, kShadowColor);
|
2014-02-05 22:09:57 +00:00
|
|
|
myMsg.surface->drawString(font(), myMsg.text, 4, 4,
|
|
|
|
myMsg.w, myMsg.color, kTextAlignLeft);
|
2008-06-19 12:01:31 +00:00
|
|
|
myMsg.counter--;
|
2006-03-18 00:00:30 +00:00
|
|
|
|
|
|
|
// Either erase the entire message (when time is reached),
|
|
|
|
// or show again this frame
|
2008-06-19 12:01:31 +00:00
|
|
|
if(myMsg.counter == 0) // Force an immediate update
|
2009-01-10 18:42:49 +00:00
|
|
|
{
|
|
|
|
myMsg.enabled = false;
|
2008-12-27 23:27:32 +00:00
|
|
|
refresh();
|
2009-01-10 18:42:49 +00:00
|
|
|
}
|
2006-03-18 00:00:30 +00:00
|
|
|
else
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-08-24 21:47:51 +00:00
|
|
|
myMsg.surface->setDirty();
|
2014-05-02 15:58:57 +00:00
|
|
|
myMsg.surface->render();
|
2008-06-19 12:01:31 +00:00
|
|
|
}
|
2006-03-18 00:00:30 +00:00
|
|
|
}
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
inline void FrameBuffer::drawTIA()
|
|
|
|
{
|
|
|
|
myTIASurface->render();
|
|
|
|
}
|
|
|
|
|
2006-05-15 12:24:09 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::refresh()
|
|
|
|
{
|
2008-12-27 23:27:32 +00:00
|
|
|
// This method partly duplicates the behaviour in ::update()
|
|
|
|
// Here, however, make sure to redraw *all* surfaces applicable to the
|
|
|
|
// current EventHandler state
|
|
|
|
// We also check for double-buffered modes, and when present
|
|
|
|
// update both buffers accordingly
|
|
|
|
//
|
|
|
|
// This method is in essence a FULL refresh, putting all rendering
|
|
|
|
// buffers in a known, fully redrawn state
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
switch(myOSystem.eventHandler().state())
|
2008-12-27 23:27:32 +00:00
|
|
|
{
|
|
|
|
case EventHandler::S_EMULATE:
|
|
|
|
case EventHandler::S_PAUSE:
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
2008-12-27 23:27:32 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case EventHandler::S_MENU:
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
|
|
|
myOSystem.menu().draw(true);
|
2014-03-08 22:57:16 +00:00
|
|
|
if(isDoubleBuffered())
|
2008-12-27 23:27:32 +00:00
|
|
|
{
|
|
|
|
postFrameUpdate();
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
|
|
|
myOSystem.menu().draw(true);
|
2008-12-27 23:27:32 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case EventHandler::S_CMDMENU:
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
|
|
|
myOSystem.commandMenu().draw(true);
|
2014-03-08 22:57:16 +00:00
|
|
|
if(isDoubleBuffered())
|
2008-12-27 23:27:32 +00:00
|
|
|
{
|
|
|
|
postFrameUpdate();
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
drawTIA();
|
|
|
|
myOSystem.commandMenu().draw(true);
|
2008-12-27 23:27:32 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case EventHandler::S_LAUNCHER:
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.launcher().draw(true);
|
2014-03-08 22:57:16 +00:00
|
|
|
if(isDoubleBuffered())
|
2008-12-27 23:27:32 +00:00
|
|
|
{
|
|
|
|
postFrameUpdate();
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.launcher().draw(true);
|
2008-12-27 23:27:32 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
#ifdef DEBUGGER_SUPPORT
|
|
|
|
case EventHandler::S_DEBUGGER:
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.debugger().draw(true);
|
2014-03-08 22:57:16 +00:00
|
|
|
if(isDoubleBuffered())
|
2008-12-27 23:27:32 +00:00
|
|
|
{
|
|
|
|
postFrameUpdate();
|
2010-07-22 15:41:46 +00:00
|
|
|
invalidate();
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.debugger().draw(true);
|
2008-12-27 23:27:32 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2006-05-15 12:24:09 +00:00
|
|
|
}
|
|
|
|
|
2008-12-12 15:51:07 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-14 22:04:59 +00:00
|
|
|
uInt32 FrameBuffer::allocateSurface(int w, int h, const uInt32* data)
|
2008-12-12 15:51:07 +00:00
|
|
|
{
|
|
|
|
// Create a new surface
|
2014-05-14 22:04:59 +00:00
|
|
|
FBSurface* surface = createSurface(w, h, data);
|
2008-12-12 15:51:07 +00:00
|
|
|
|
|
|
|
// Add it to the list
|
2013-04-25 14:03:11 +00:00
|
|
|
mySurfaceList.insert(make_pair((uInt32)mySurfaceList.size(), surface));
|
2008-12-12 15:51:07 +00:00
|
|
|
|
|
|
|
// Return a reference to it
|
2014-05-12 23:34:25 +00:00
|
|
|
return (uInt32)mySurfaceList.size() - 1;
|
2008-12-12 15:51:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
First pass at adding a cart-specific bankswitch/info tab to the
debugger. In the process, I had to spend several days extending
the UI/dialog class to actually contain multiple tabs. This was
harder than expected, and it still isn't quite finished. In many
ways, we're beginning to reach the limits of the current code; it
was never designed for a full-fledged, graphically rich UI.
For now the tab is empty, but eventually it will contain general
info about the ROM bankswitch type (size, virtual layout, etc),
but also cart-specific info, including the ability to change
banks, which can be vary greatly among the different schemes.
Eventually, it may even allow to see/modify very cart-specific
info (like display RAM in DPC, etc).
Better handle errors in opening the serial port (AtariVox support)
for Windows and OSX.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@2678 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2013-03-31 00:10:05 +00:00
|
|
|
FBSurface* FrameBuffer::surface(uInt32 id) const
|
2008-12-12 15:51:07 +00:00
|
|
|
{
|
2014-11-02 23:40:20 +00:00
|
|
|
const auto& iter = mySurfaceList.find(id);
|
|
|
|
return iter != mySurfaceList.end() ? iter->second : nullptr;
|
2008-12-12 15:51:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
void FrameBuffer::resetSurfaces()
|
2008-12-12 15:51:07 +00:00
|
|
|
{
|
2008-12-20 23:32:46 +00:00
|
|
|
// Free all resources for each surface, then reload them
|
|
|
|
// Due to possible timing and/or synchronization issues, all free()'s
|
|
|
|
// are done first, then all reload()'s
|
|
|
|
// Any derived FrameBuffer classes that call this method should be
|
|
|
|
// aware of these restrictions, and act accordingly
|
|
|
|
|
2014-11-02 23:40:20 +00:00
|
|
|
for(auto& s: mySurfaceList)
|
|
|
|
s.second->free();
|
|
|
|
for(auto& s: mySurfaceList)
|
|
|
|
s.second->reload();
|
2008-12-12 15:51:07 +00:00
|
|
|
}
|
|
|
|
|
2009-01-03 15:44:13 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-06-02 14:34:12 +00:00
|
|
|
void FrameBuffer::setPalette(const uInt32* raw_palette)
|
2009-01-03 15:44:13 +00:00
|
|
|
{
|
2006-01-10 02:09:34 +00:00
|
|
|
// Set palette for normal fill
|
2014-05-12 23:34:25 +00:00
|
|
|
for(int i = 0; i < 256; ++i)
|
2006-01-10 02:09:34 +00:00
|
|
|
{
|
2014-06-02 14:34:12 +00:00
|
|
|
Uint8 r = (raw_palette[i] >> 16) & 0xff;
|
|
|
|
Uint8 g = (raw_palette[i] >> 8) & 0xff;
|
|
|
|
Uint8 b = raw_palette[i] & 0xff;
|
2003-10-26 19:40:39 +00:00
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
myPalette[i] = mapRGB(r, g, b);
|
2005-03-28 00:04:54 +00:00
|
|
|
}
|
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
// Let the TIA surface know about the new palette
|
2014-06-02 14:34:12 +00:00
|
|
|
myTIASurface->setPalette(myPalette, raw_palette);
|
2003-10-26 19:40:39 +00:00
|
|
|
}
|
|
|
|
|
2009-01-10 18:52:55 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::stateChanged(EventHandler::State state)
|
|
|
|
{
|
|
|
|
// Make sure any onscreen messages are removed
|
|
|
|
myMsg.enabled = false;
|
|
|
|
myMsg.counter = 0;
|
|
|
|
}
|
|
|
|
|
2005-05-01 20:11:07 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::setFullscreen(bool enable)
|
|
|
|
{
|
2014-06-02 14:34:12 +00:00
|
|
|
const VideoMode& mode = getSavedVidMode(enable);
|
|
|
|
if(setVideoMode(myScreenTitle, mode, true))
|
|
|
|
{
|
|
|
|
myImageRect = mode.image;
|
|
|
|
myScreenSize = mode.screen;
|
2003-10-26 19:40:39 +00:00
|
|
|
|
2014-06-02 14:34:12 +00:00
|
|
|
// Inform TIA surface about new mode
|
|
|
|
if(myOSystem.eventHandler().state() != EventHandler::S_LAUNCHER &&
|
|
|
|
myOSystem.eventHandler().state() != EventHandler::S_DEBUGGER)
|
|
|
|
myTIASurface->initialize(myOSystem.console(), mode);
|
2003-10-26 19:40:39 +00:00
|
|
|
|
2014-06-02 14:34:12 +00:00
|
|
|
// Did we get the requested fullscreen state?
|
|
|
|
myOSystem.settings().setValue("fullscreen", fullScreen());
|
|
|
|
resetSurfaces();
|
|
|
|
setCursorState();
|
2014-06-17 11:49:38 +00:00
|
|
|
refresh();
|
2014-06-02 14:34:12 +00:00
|
|
|
}
|
2005-03-28 00:04:54 +00:00
|
|
|
}
|
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::toggleFullscreen()
|
|
|
|
{
|
|
|
|
setFullscreen(!fullScreen());
|
|
|
|
}
|
|
|
|
|
2005-03-28 00:04:54 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-04-29 14:52:35 +00:00
|
|
|
bool FrameBuffer::changeWindowedVidMode(int direction)
|
2005-03-28 00:04:54 +00:00
|
|
|
{
|
2014-04-29 14:52:35 +00:00
|
|
|
#ifdef WINDOWED_SUPPORT
|
2014-05-12 23:34:25 +00:00
|
|
|
EventHandler::State state = myOSystem.eventHandler().state();
|
2014-04-29 14:52:35 +00:00
|
|
|
bool tiaMode = (state != EventHandler::S_DEBUGGER &&
|
|
|
|
state != EventHandler::S_LAUNCHER);
|
2008-06-19 12:01:31 +00:00
|
|
|
|
2014-04-29 14:52:35 +00:00
|
|
|
// Ignore any attempts to change video size while in invalid modes
|
|
|
|
if(!tiaMode || fullScreen())
|
Reworked 'fullres' argument to also accept the 'auto' option. In this case,
fullscreen resolutions will be automatically chosen based on the required
size for the window. The image will be centered and keep the same aspect
ratio, however, so operation will still work correctly on widescreen
monitors. 'Auto' will be the new default. Otherwise, if a specific
resolution is requested, Stella will try to accomodate it *only* if it fits
into the resolution; otherwise the smallest resolution that fits will be
used.
Removed 'zoom_ui' and 'zoom_tia'. The UI can now only be at 1x mode.
Aded 'tia_filter' commandline argument, which specifies to the filter
to use when rendering the tia image. For now, these accept 'zoom1x',
'zoom2x'..., up to 'zoom10x', and duplicate previous behaviour. Eventually,
Scalexx and HQxx filters may be added. Still TODO is add this to the UI.
First pass at making the standard build use a minimum of zoom2x for the TIA,
so the UI can be larger and use a better looking font. There's still work
to do in this area, especially for those ports with limited hardware that
support zoom1x only.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1544 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2008-07-22 14:54:39 +00:00
|
|
|
return false;
|
|
|
|
|
|
|
|
if(direction == +1)
|
|
|
|
myCurrentModeList->next();
|
|
|
|
else if(direction == -1)
|
|
|
|
myCurrentModeList->previous();
|
2014-04-29 14:52:35 +00:00
|
|
|
else
|
|
|
|
return false;
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
|
2014-04-29 14:52:35 +00:00
|
|
|
const VideoMode& mode = myCurrentModeList->current();
|
2014-05-12 23:34:25 +00:00
|
|
|
if(setVideoMode(myScreenTitle, mode))
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-06-02 14:34:12 +00:00
|
|
|
myImageRect = mode.image;
|
|
|
|
myScreenSize = mode.screen;
|
|
|
|
|
2014-05-14 22:04:59 +00:00
|
|
|
// Inform TIA surface about new mode
|
2014-06-02 14:34:12 +00:00
|
|
|
myTIASurface->initialize(myOSystem.console(), mode);
|
2014-05-14 22:04:59 +00:00
|
|
|
|
2014-05-12 23:34:25 +00:00
|
|
|
resetSurfaces();
|
2014-04-29 14:52:35 +00:00
|
|
|
showMessage(mode.description);
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.settings().setValue("tia.zoom", mode.zoom);
|
2008-12-28 21:01:55 +00:00
|
|
|
refresh();
|
2014-04-29 14:52:35 +00:00
|
|
|
return true;
|
2008-06-19 12:01:31 +00:00
|
|
|
}
|
2014-02-19 15:34:22 +00:00
|
|
|
#endif
|
2014-04-29 14:52:35 +00:00
|
|
|
return false;
|
2003-10-26 19:40:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2005-03-28 00:04:54 +00:00
|
|
|
void FrameBuffer::setCursorState()
|
2003-10-26 19:40:39 +00:00
|
|
|
{
|
2014-06-04 16:01:45 +00:00
|
|
|
// Always grab mouse in emulation (if enabled),
|
|
|
|
// and don't show the cursor during emulation (if enabled)
|
2011-05-06 14:29:39 +00:00
|
|
|
bool emulation =
|
2014-05-12 23:34:25 +00:00
|
|
|
myOSystem.eventHandler().state() == EventHandler::S_EMULATE;
|
2014-06-04 16:01:45 +00:00
|
|
|
grabMouse(emulation && myOSystem.settings().getBool("grabmouse"));
|
|
|
|
showCursor(!(emulation || myOSystem.settings().getBool("hidecursor")));
|
2003-10-01 19:01:02 +00:00
|
|
|
}
|
|
|
|
|
2011-06-07 13:40:59 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::toggleGrabMouse()
|
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
bool state = myOSystem.settings().getBool("grabmouse");
|
|
|
|
myOSystem.settings().setValue("grabmouse", !state);
|
2011-06-07 13:40:59 +00:00
|
|
|
setCursorState();
|
|
|
|
}
|
|
|
|
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2008-06-19 12:01:31 +00:00
|
|
|
uInt32 FrameBuffer::maxWindowSizeForScreen(uInt32 baseWidth, uInt32 baseHeight,
|
2014-10-21 23:02:20 +00:00
|
|
|
uInt32 screenWidth, uInt32 screenHeight) const
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
{
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
uInt32 multiplier = 1;
|
|
|
|
for(;;)
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
{
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
// Figure out the zoomed size of the window
|
2008-06-19 12:01:31 +00:00
|
|
|
uInt32 width = baseWidth * multiplier;
|
|
|
|
uInt32 height = baseHeight * multiplier;
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
if((width > screenWidth) || (height > screenHeight))
|
|
|
|
break;
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
++multiplier;
|
|
|
|
}
|
|
|
|
return multiplier > 1 ? multiplier - 1 : 1;
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2008-06-19 12:01:31 +00:00
|
|
|
void FrameBuffer::setAvailableVidModes(uInt32 baseWidth, uInt32 baseHeight)
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
{
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
myWindowedModeList.clear();
|
2014-09-01 21:17:33 +00:00
|
|
|
|
2014-11-02 23:40:20 +00:00
|
|
|
for(auto& mode: myFullscreenModeLists)
|
|
|
|
mode.clear();
|
2014-11-08 23:50:23 +00:00
|
|
|
for(size_t i = myFullscreenModeLists.size(); i < myDisplays.size(); ++i)
|
2014-09-01 21:17:33 +00:00
|
|
|
myFullscreenModeLists.push_back(VideoModeList());
|
2008-06-19 12:01:31 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// Check if zooming is allowed for this state (currently only allowed
|
|
|
|
// for TIA screens)
|
2014-05-12 23:34:25 +00:00
|
|
|
EventHandler::State state = myOSystem.eventHandler().state();
|
2014-04-28 16:47:10 +00:00
|
|
|
bool tiaMode = (state != EventHandler::S_DEBUGGER &&
|
|
|
|
state != EventHandler::S_LAUNCHER);
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// TIA mode allows zooming at integral factors in windowed modes,
|
|
|
|
// and also non-integral factors in fullscreen mode
|
|
|
|
if(tiaMode)
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
// TIA windowed modes
|
|
|
|
uInt32 maxZoom = maxWindowSizeForScreen(baseWidth, baseHeight,
|
2014-04-29 14:52:35 +00:00
|
|
|
myDesktopSize.w, myDesktopSize.h);
|
2009-01-14 20:31:07 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// Aspect ratio
|
2014-05-12 23:34:25 +00:00
|
|
|
bool ntsc = myOSystem.console().about().InitialFrameRate == "60";
|
|
|
|
uInt32 aspect = myOSystem.settings().getInt(ntsc ?
|
2014-04-28 16:47:10 +00:00
|
|
|
"tia.aspectn" : "tia.aspectp");
|
2009-01-14 20:31:07 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// Figure our the smallest zoom level we can use
|
|
|
|
uInt32 firstZoom = 2;
|
2014-04-29 14:52:35 +00:00
|
|
|
if(myDesktopSize.w < 640 || myDesktopSize.h < 480)
|
2014-04-28 16:47:10 +00:00
|
|
|
firstZoom = 1;
|
|
|
|
for(uInt32 zoom = firstZoom; zoom <= maxZoom; ++zoom)
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
ostringstream desc;
|
|
|
|
desc << "Zoom " << zoom << "x";
|
|
|
|
|
|
|
|
VideoMode mode(baseWidth*zoom, baseHeight*zoom,
|
2014-09-01 21:17:33 +00:00
|
|
|
baseWidth*zoom, baseHeight*zoom, -1, zoom, desc.str());
|
2014-04-28 16:47:10 +00:00
|
|
|
mode.applyAspectCorrection(aspect);
|
|
|
|
myWindowedModeList.add(mode);
|
2008-06-19 12:01:31 +00:00
|
|
|
}
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// TIA fullscreen mode
|
2014-09-01 21:17:33 +00:00
|
|
|
for(uInt32 i = 0; i < myDisplays.size(); ++i)
|
|
|
|
{
|
|
|
|
maxZoom = maxWindowSizeForScreen(baseWidth, baseHeight,
|
|
|
|
myDisplays[i].w, myDisplays[i].h);
|
|
|
|
VideoMode mode(baseWidth*maxZoom, baseHeight*maxZoom,
|
|
|
|
myDisplays[i].w, myDisplays[i].h, i);
|
|
|
|
mode.applyAspectCorrection(aspect, myOSystem.settings().getBool("tia.fsfill"));
|
|
|
|
myFullscreenModeLists[i].add(mode);
|
|
|
|
}
|
2014-04-28 16:47:10 +00:00
|
|
|
}
|
|
|
|
else // UI mode
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
// Windowed and fullscreen mode differ only in screen size
|
|
|
|
myWindowedModeList.add(
|
2014-09-01 21:17:33 +00:00
|
|
|
VideoMode(baseWidth, baseHeight, baseWidth, baseHeight, -1)
|
2014-04-28 16:47:10 +00:00
|
|
|
);
|
2014-09-01 21:17:33 +00:00
|
|
|
for(uInt32 i = 0; i < myDisplays.size(); ++i)
|
|
|
|
{
|
|
|
|
myFullscreenModeLists[i].add(
|
|
|
|
VideoMode(baseWidth, baseHeight, myDisplays[i].w, myDisplays[i].h, i)
|
|
|
|
);
|
|
|
|
}
|
2006-11-18 13:29:12 +00:00
|
|
|
}
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
}
|
Added preliminary framework for using advanced scalers. Right now,
functionality is exactly the same as before; Alt-Equals goes to the
next valid scaler, and Alt-Minus goes to the previous one.
What were previously zoomed modes are now treated as scalers, named
'Zoom1x', 'Zoom2x', etc. Various scalexx and hqxx modes will also be made
available.
For now, and probably forever, these advanced scaling modes will only
be available for OpenGL, since if you don't have a card that can handle
GL well, the scalers will probably be too much anyway. Also, the advanced
scaling will not be available in UI mode, only OpenGL emulation mode.
The UI (Launcher, Debugger) and emulation modes are now scaled separately,
specified with the new settings 'scale_ui' and 'scale_tia'. The 'zoom'
setting has been removed.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1133 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2006-10-14 20:08:29 +00:00
|
|
|
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
const VideoMode& FrameBuffer::getSavedVidMode(bool fullscreen)
|
Added 'WINDOWED_SUPPORT' compile-time argument, which can be used for
those systems which don't actually have a windowing environment. When
this is set, toggling from fullscreen will not be possible, and certain
window-related UI functions will not be accessible.
Completely revamped video subsystem. Windowed and fullscreen modes are
now dealt with separately. Windows can be zoomed using the 'zoom_ui'
and 'zoom_tia' arguments. Fullscreen modes are now set by resolution,
not zoom, so you can specify to always use a certain fullscreen
resolution, and the images will be scaled appropriately. This also
fixes the fullscreen issues on widescreen monitors; just select a
widescreen video mode, and the aspect ratio will always be correct.
Removed dirty-rect support for software rendering of the TIA image,
as it ended up being slower than just updating the entire image.
For those resolutions where it will start to slow down (1024x768 or
higher), one should be using OpenGL.
Fixed issue in Windows when returning from fullscreen mode made the
window constantly 'shrink' in size. It was related to auto-detecting
the desktop resolution, which is really the job of SDL. As such, all
further releases of Stella will require SDL 1.2.10, which includes
this auto-detection code internally.
Made ROM launcher resizable, configurable in sizes from 320x240
to 800x600. Updated the UIDialog to change these quantities from the
UI (Stella will need to be restarted for it to take effect).
Removed aspect ratio support, since it was causing problems, and the
new fullscreen mode work has made it obsolete. i *may* consider it
again in the future, if there's sufficient demand.
Added 'fullres' commandline argument, used to set the fullscreen
resolution.
Added 'launcherres' commandline argument, used to set the ROM
launcher resolution. This replaces 'launchersize' argument, which
has been removed.
Changed 'scale_ui' and 'scale_tia' to 'zoom_ui' and 'zoom_tia',
respectively. Their function remains the same.
Changed meaning of 'gl_fsmax' argument to specify what modes to use
fullscreen OpenGL scaling (previously, this was a boolean, and
didn't consider different modes).
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1323 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2007-06-20 16:33:23 +00:00
|
|
|
{
|
2014-05-12 23:34:25 +00:00
|
|
|
EventHandler::State state = myOSystem.eventHandler().state();
|
2007-07-11 15:08:13 +00:00
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
if(fullscreen)
|
2014-09-01 21:17:33 +00:00
|
|
|
{
|
|
|
|
Int32 i = getCurrentDisplayIndex();
|
|
|
|
if(i < 0)
|
|
|
|
{
|
|
|
|
// default to the first display
|
|
|
|
i = 0;
|
|
|
|
}
|
|
|
|
myCurrentModeList = &myFullscreenModeLists[i];
|
|
|
|
}
|
2008-06-19 12:01:31 +00:00
|
|
|
else
|
|
|
|
myCurrentModeList = &myWindowedModeList;
|
|
|
|
|
|
|
|
// Now select the best resolution depending on the state
|
|
|
|
// UI modes (launcher and debugger) have only one supported resolution
|
|
|
|
// so the 'current' one is the only valid one
|
|
|
|
if(state == EventHandler::S_DEBUGGER || state == EventHandler::S_LAUNCHER)
|
2014-04-28 16:47:10 +00:00
|
|
|
myCurrentModeList->setZoom(1);
|
|
|
|
else
|
2014-05-12 23:34:25 +00:00
|
|
|
myCurrentModeList->setZoom(myOSystem.settings().getInt("tia.zoom"));
|
2014-04-28 16:47:10 +00:00
|
|
|
|
|
|
|
return myCurrentModeList->current();
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
//
|
|
|
|
// VideoMode implementation
|
|
|
|
//
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
VideoMode::VideoMode()
|
2014-09-01 21:17:33 +00:00
|
|
|
: fsIndex(-1),
|
2014-04-28 16:47:10 +00:00
|
|
|
zoom(1),
|
|
|
|
description("")
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
VideoMode::VideoMode(uInt32 iw, uInt32 ih, uInt32 sw, uInt32 sh,
|
2014-09-01 21:17:33 +00:00
|
|
|
Int32 full, uInt32 z, const string& desc)
|
|
|
|
: fsIndex(full),
|
2014-04-28 16:47:10 +00:00
|
|
|
zoom(z),
|
|
|
|
description(desc)
|
|
|
|
{
|
|
|
|
sw = BSPF_max(sw, (uInt32)FrameBuffer::kTIAMinW);
|
|
|
|
sh = BSPF_max(sh, (uInt32)FrameBuffer::kTIAMinH);
|
|
|
|
iw = BSPF_min(iw, sw);
|
|
|
|
ih = BSPF_min(ih, sh);
|
|
|
|
int ix = (sw - iw) >> 1;
|
|
|
|
int iy = (sh - ih) >> 1;
|
|
|
|
image = GUI::Rect(ix, iy, ix+iw, iy+ih);
|
|
|
|
screen = GUI::Size(sw, sh);
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-06-02 14:34:12 +00:00
|
|
|
void VideoMode::applyAspectCorrection(uInt32 aspect, bool stretch)
|
2014-04-28 16:47:10 +00:00
|
|
|
{
|
|
|
|
// Width is modified by aspect ratio; other factors may be applied below
|
|
|
|
uInt32 iw = (uInt32)(float(image.width() * aspect) / 100.0);
|
|
|
|
uInt32 ih = image.height();
|
|
|
|
|
2014-09-01 21:17:33 +00:00
|
|
|
if(fsIndex != -1)
|
2008-06-19 12:01:31 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
// Fullscreen mode stretching
|
2014-06-02 14:34:12 +00:00
|
|
|
float stretchFactor = 1.0;
|
2014-06-04 12:15:54 +00:00
|
|
|
float scaleX = float(iw) / screen.w;
|
|
|
|
float scaleY = float(ih) / screen.h;
|
2014-04-28 16:47:10 +00:00
|
|
|
|
2014-06-02 14:34:12 +00:00
|
|
|
// Scale to actual or integral factors
|
|
|
|
if(stretch)
|
|
|
|
{
|
|
|
|
// Scale to full (non-integral) available space
|
|
|
|
if(scaleX > scaleY)
|
2014-06-04 12:15:54 +00:00
|
|
|
stretchFactor = float(screen.w) / iw;
|
2014-06-02 14:34:12 +00:00
|
|
|
else
|
2014-06-04 12:15:54 +00:00
|
|
|
stretchFactor = float(screen.h) / ih;
|
2014-06-02 14:34:12 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Only scale to an integral amount
|
|
|
|
if(scaleX > scaleY)
|
2014-04-28 16:47:10 +00:00
|
|
|
{
|
2014-06-04 12:15:54 +00:00
|
|
|
int bw = iw / zoom;
|
|
|
|
stretchFactor = float(int(screen.w / bw) * bw) / iw;
|
2014-04-28 16:47:10 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-06-04 12:15:54 +00:00
|
|
|
int bh = ih / zoom;
|
|
|
|
stretchFactor = float(int(screen.h / bh) * bh) / ih;
|
2014-04-28 16:47:10 +00:00
|
|
|
}
|
|
|
|
}
|
2014-06-04 12:15:54 +00:00
|
|
|
iw = (uInt32) (stretchFactor * iw);
|
|
|
|
ih = (uInt32) (stretchFactor * ih);
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-06-02 14:34:12 +00:00
|
|
|
// In windowed mode, the screen size changes to match the image width
|
2014-04-28 16:47:10 +00:00
|
|
|
// Height is never modified in this mode
|
|
|
|
screen.w = iw;
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// Now re-calculate the dimensions
|
|
|
|
iw = BSPF_min(iw, (uInt32)screen.w);
|
|
|
|
ih = BSPF_min(ih, (uInt32)screen.h);
|
|
|
|
|
|
|
|
image.moveTo((screen.w - iw) >> 1, (screen.h - ih) >> 1);
|
|
|
|
image.setWidth(iw);
|
|
|
|
image.setHeight(ih);
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
2014-04-28 16:47:10 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
//
|
|
|
|
// VideoModeList implementation
|
|
|
|
//
|
2008-07-04 14:27:17 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
FrameBuffer::VideoModeList::VideoModeList()
|
2009-06-05 14:05:23 +00:00
|
|
|
: myIdx(-1)
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
FrameBuffer::VideoModeList::~VideoModeList()
|
|
|
|
{
|
|
|
|
clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-04-28 16:47:10 +00:00
|
|
|
void FrameBuffer::VideoModeList::add(const VideoMode& mode)
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
2014-11-09 03:05:19 +00:00
|
|
|
myModeList.emplace_back(mode);
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
void FrameBuffer::VideoModeList::clear()
|
|
|
|
{
|
|
|
|
myModeList.clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-11-07 23:28:40 +00:00
|
|
|
bool FrameBuffer::VideoModeList::empty() const
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
2014-11-07 23:28:40 +00:00
|
|
|
return myModeList.empty();
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
uInt32 FrameBuffer::VideoModeList::size() const
|
|
|
|
{
|
2014-11-08 22:40:50 +00:00
|
|
|
return (uInt32)myModeList.size();
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
Reworked 'fullres' argument to also accept the 'auto' option. In this case,
fullscreen resolutions will be automatically chosen based on the required
size for the window. The image will be centered and keep the same aspect
ratio, however, so operation will still work correctly on widescreen
monitors. 'Auto' will be the new default. Otherwise, if a specific
resolution is requested, Stella will try to accomodate it *only* if it fits
into the resolution; otherwise the smallest resolution that fits will be
used.
Removed 'zoom_ui' and 'zoom_tia'. The UI can now only be at 1x mode.
Aded 'tia_filter' commandline argument, which specifies to the filter
to use when rendering the tia image. For now, these accept 'zoom1x',
'zoom2x'..., up to 'zoom10x', and duplicate previous behaviour. Eventually,
Scalexx and HQxx filters may be added. Still TODO is add this to the UI.
First pass at making the standard build use a minimum of zoom2x for the TIA,
so the UI can be larger and use a better looking font. There's still work
to do in this area, especially for those ports with limited hardware that
support zoom1x only.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1544 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2008-07-22 14:54:39 +00:00
|
|
|
void FrameBuffer::VideoModeList::previous()
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
|
|
|
--myIdx;
|
2014-11-08 22:40:50 +00:00
|
|
|
if(myIdx < 0) myIdx = (int)myModeList.size() - 1;
|
2008-07-04 14:27:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-05-12 23:34:25 +00:00
|
|
|
const VideoMode& FrameBuffer::VideoModeList::current() const
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
|
|
|
return myModeList[myIdx];
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
Reworked 'fullres' argument to also accept the 'auto' option. In this case,
fullscreen resolutions will be automatically chosen based on the required
size for the window. The image will be centered and keep the same aspect
ratio, however, so operation will still work correctly on widescreen
monitors. 'Auto' will be the new default. Otherwise, if a specific
resolution is requested, Stella will try to accomodate it *only* if it fits
into the resolution; otherwise the smallest resolution that fits will be
used.
Removed 'zoom_ui' and 'zoom_tia'. The UI can now only be at 1x mode.
Aded 'tia_filter' commandline argument, which specifies to the filter
to use when rendering the tia image. For now, these accept 'zoom1x',
'zoom2x'..., up to 'zoom10x', and duplicate previous behaviour. Eventually,
Scalexx and HQxx filters may be added. Still TODO is add this to the UI.
First pass at making the standard build use a minimum of zoom2x for the TIA,
so the UI can be larger and use a better looking font. There's still work
to do in this area, especially for those ports with limited hardware that
support zoom1x only.
git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1544 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
2008-07-22 14:54:39 +00:00
|
|
|
void FrameBuffer::VideoModeList::next()
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
|
|
|
myIdx = (myIdx + 1) % myModeList.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
2014-04-28 16:47:10 +00:00
|
|
|
void FrameBuffer::VideoModeList::setZoom(uInt32 zoom)
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
for(uInt32 i = 0; i < myModeList.size(); ++i)
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
2014-04-28 16:47:10 +00:00
|
|
|
if(myModeList[i].zoom == zoom)
|
2008-07-04 14:27:17 +00:00
|
|
|
{
|
|
|
|
myIdx = i;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
myIdx = 0;
|
|
|
|
}
|
|
|
|
|
2014-01-31 16:23:10 +00:00
|
|
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
|
|
/*
|
|
|
|
Palette is defined as follows:
|
|
|
|
// Base colors
|
|
|
|
kColor Normal foreground color (non-text)
|
|
|
|
kBGColor Normal background color (non-text)
|
|
|
|
kShadowColor Item is disabled
|
|
|
|
kTextColor Normal text color
|
|
|
|
kTextColorHi Highlighted text color
|
|
|
|
kTextColorEm Emphasized text color
|
|
|
|
|
|
|
|
// UI elements (dialog and widgets)
|
|
|
|
kDlgColor Dialog background
|
|
|
|
kWidColor Widget background
|
|
|
|
kWidFrameColor Border for currently selected widget
|
|
|
|
|
|
|
|
// Button colors
|
|
|
|
kBtnColor Normal button background
|
|
|
|
kBtnColorHi Highlighted button background
|
|
|
|
kBtnTextColor Normal button font color
|
|
|
|
kBtnTextColorHi Highlighted button font color
|
|
|
|
|
|
|
|
// Checkbox colors
|
|
|
|
kCheckColor Color of 'X' in checkbox
|
|
|
|
|
|
|
|
// Scrollbar colors
|
|
|
|
kScrollColor Normal scrollbar color
|
|
|
|
kScrollColorHi Highlighted scrollbar color
|
|
|
|
|
|
|
|
// Debugger colors
|
|
|
|
kDbgChangedColor Background color for changed cells
|
|
|
|
kDbgChangedTextColor Text color for changed cells
|
|
|
|
kDbgColorHi Highlighted color in debugger data cells
|
|
|
|
*/
|
2014-09-03 13:27:33 +00:00
|
|
|
uInt32 FrameBuffer::ourGUIColors[2][kNumColors-256] = {
|
|
|
|
// Standard
|
|
|
|
{ 0x686868, 0x000000, 0x404040, 0x000000, 0x62a108, 0x9f0000,
|
|
|
|
0xc9af7c, 0xf0f0cf, 0xc80000,
|
|
|
|
0xac3410, 0xd55941, 0xffffff, 0xffd652,
|
|
|
|
0xac3410,
|
|
|
|
0xac3410, 0xd55941,
|
|
|
|
0xac3410, 0xd55941,
|
|
|
|
0xc80000, 0x00ff00, 0xc8c8ff
|
|
|
|
},
|
|
|
|
|
|
|
|
// Classic
|
|
|
|
{ 0x686868, 0x000000, 0x404040, 0x20a020, 0x00ff00, 0xc80000,
|
|
|
|
0x000000, 0x000000, 0xc80000,
|
|
|
|
0x000000, 0x000000, 0x20a020, 0x00ff00,
|
|
|
|
0x20a020,
|
|
|
|
0x20a020, 0x00ff00,
|
|
|
|
0x20a020, 0x00ff00,
|
|
|
|
0xc80000, 0x00ff00, 0xc8c8ff
|
|
|
|
}
|
2014-01-31 16:23:10 +00:00
|
|
|
};
|