mirror of https://github.com/stella-emu/stella.git
Changed the behaviour of pause() wrt the FrameBuffer. Now the base
FrameBuffer class is paused, and *it* notifies the child class of this event. Previously, the code for pausing the parent class had to be provided by the child, meaning that if the derived classes of FrameBuffer didn't provide it, then the emulation core would not pause. This is exactly what happened to me in the Windows version, and I spent 10 minutes trying to figure out why pause wasn't working :) git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@204 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
505a38057d
commit
9d2e1cfcc0
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.cxx,v 1.4 2003-11-09 23:53:19 stephena Exp $
|
// $Id: FrameBuffer.cxx,v 1.5 2003-11-12 19:36:25 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -50,10 +50,10 @@ FrameBuffer::FrameBuffer()
|
||||||
myWidth(160),
|
myWidth(160),
|
||||||
myHeight(300),
|
myHeight(300),
|
||||||
theRedrawEntireFrameIndicator(true),
|
theRedrawEntireFrameIndicator(true),
|
||||||
myPauseStatus(false),
|
|
||||||
myFGColor(10),
|
myFGColor(10),
|
||||||
myBGColor(0),
|
myBGColor(0),
|
||||||
myFrameRate(0),
|
myFrameRate(0),
|
||||||
|
myPauseStatus(false),
|
||||||
myCurrentWidget(W_NONE),
|
myCurrentWidget(W_NONE),
|
||||||
myRemapEventSelectedFlag(false),
|
myRemapEventSelectedFlag(false),
|
||||||
mySelectedEvent(Event::NoType),
|
mySelectedEvent(Event::NoType),
|
||||||
|
@ -449,6 +449,16 @@ MediaSource* FrameBuffer::mediaSource() const
|
||||||
return (MediaSource*) NULL;
|
return (MediaSource*) NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FrameBuffer::pause(bool status)
|
||||||
|
{
|
||||||
|
myPauseStatus = status;
|
||||||
|
|
||||||
|
// Now notify the child object, in case it wants to do something
|
||||||
|
// special when pause is received
|
||||||
|
pauseEvent(myPauseStatus);
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
FrameBuffer::Widget FrameBuffer::currentSelectedWidget()
|
FrameBuffer::Widget FrameBuffer::currentSelectedWidget()
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.hxx,v 1.4 2003-11-09 23:53:19 stephena Exp $
|
// $Id: FrameBuffer.hxx,v 1.5 2003-11-12 19:36:25 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_HXX
|
#ifndef FRAMEBUFFER_HXX
|
||||||
|
@ -35,7 +35,7 @@ class Console;
|
||||||
can be changed.
|
can be changed.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBuffer.hxx,v 1.4 2003-11-09 23:53:19 stephena Exp $
|
@version $Id: FrameBuffer.hxx,v 1.5 2003-11-12 19:36:25 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBuffer
|
class FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -120,6 +120,14 @@ class FrameBuffer
|
||||||
*/
|
*/
|
||||||
MediaSource* mediaSource() const;
|
MediaSource* mediaSource() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sets the pause status. While pause is selected, the
|
||||||
|
MediaSource will not be updated.
|
||||||
|
|
||||||
|
@param status Toggle pause based on status
|
||||||
|
*/
|
||||||
|
void pause(bool status);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// The following methods are system-specific and must be implemented
|
// The following methods are system-specific and must be implemented
|
||||||
|
@ -179,11 +187,12 @@ class FrameBuffer
|
||||||
virtual void postFrameUpdate() = 0;
|
virtual void postFrameUpdate() = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This routine is called when the emulation has been paused.
|
This routine is called when the emulation has received
|
||||||
|
a pause event.
|
||||||
|
|
||||||
@param status Toggle pause based on status
|
@param status The received pause status
|
||||||
*/
|
*/
|
||||||
virtual void pause(bool status) = 0;
|
virtual void pauseEvent(bool status) = 0;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// The Console for the system
|
// The Console for the system
|
||||||
|
@ -198,9 +207,6 @@ class FrameBuffer
|
||||||
// Indicates if the entire frame should be redrawn
|
// Indicates if the entire frame should be redrawn
|
||||||
bool theRedrawEntireFrameIndicator;
|
bool theRedrawEntireFrameIndicator;
|
||||||
|
|
||||||
// Indicates the current pause status
|
|
||||||
bool myPauseStatus;
|
|
||||||
|
|
||||||
// Table of bitmapped fonts.
|
// Table of bitmapped fonts.
|
||||||
static const uInt8 ourFontData[2048];
|
static const uInt8 ourFontData[2048];
|
||||||
|
|
||||||
|
@ -246,6 +252,9 @@ class FrameBuffer
|
||||||
// Indicates the current framerate of the system
|
// Indicates the current framerate of the system
|
||||||
uInt32 myFrameRate;
|
uInt32 myFrameRate;
|
||||||
|
|
||||||
|
// Indicates the current pause status
|
||||||
|
bool myPauseStatus;
|
||||||
|
|
||||||
// Structure used for main menu items
|
// Structure used for main menu items
|
||||||
struct MainMenuItem
|
struct MainMenuItem
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSDL.cxx,v 1.3 2003-11-09 23:53:20 stephena Exp $
|
// $Id: FrameBufferSDL.cxx,v 1.4 2003-11-12 19:36:25 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
@ -43,12 +43,10 @@ FrameBufferSDL::~FrameBufferSDL()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSDL::pause(bool status)
|
void FrameBufferSDL::pauseEvent(bool status)
|
||||||
{
|
{
|
||||||
myPauseStatus = status;
|
|
||||||
|
|
||||||
// Shade the palette to 75% normal value in pause mode
|
// Shade the palette to 75% normal value in pause mode
|
||||||
if(myPauseStatus)
|
if(status)
|
||||||
setupPalette(0.75);
|
setupPalette(0.75);
|
||||||
else
|
else
|
||||||
setupPalette(1.0);
|
setupPalette(1.0);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSDL.hxx,v 1.3 2003-11-09 23:53:20 stephena Exp $
|
// $Id: FrameBufferSDL.hxx,v 1.4 2003-11-12 19:36:25 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_SDL_HXX
|
#ifndef FRAMEBUFFER_SDL_HXX
|
||||||
|
@ -34,7 +34,7 @@
|
||||||
the core FrameBuffer.
|
the core FrameBuffer.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBufferSDL.hxx,v 1.3 2003-11-09 23:53:20 stephena Exp $
|
@version $Id: FrameBufferSDL.hxx,v 1.4 2003-11-12 19:36:25 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBufferSDL : public FrameBuffer
|
class FrameBufferSDL : public FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -100,7 +100,7 @@ class FrameBufferSDL : public FrameBuffer
|
||||||
|
|
||||||
@param status Toggle pause based on status
|
@param status Toggle pause based on status
|
||||||
*/
|
*/
|
||||||
void pause(bool status);
|
void pauseEvent(bool status);
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// The following methods must be defined in child classes
|
// The following methods must be defined in child classes
|
||||||
|
|
Loading…
Reference in New Issue