mirror of https://github.com/stella-emu/stella.git
All changes are to the SDL version.
Made emulator pause when toggling between windowed and fullscreen modes. Added code for the TEXTURES_ARE_LOST definition. In Windows, when changing the window size or toggling fullscreen/windowed modes, the OpenGL textures are lost and must be reloaded. This now works. Fixed a long-standing bug in snapshot files. I made sure they were opened in binary mode. That wasn't required in Linux. Sometimes developing multi-platform code can really work the bugs out. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@228 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
1457853110
commit
eddc10294d
|
@ -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: Snapshot.cxx,v 1.8 2003-11-19 15:57:10 stephena Exp $
|
// $Id: Snapshot.cxx,v 1.9 2003-12-06 00:17:28 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <png.h>
|
#include <png.h>
|
||||||
|
@ -88,7 +88,7 @@ uInt32 Snapshot::savePNG(string filename, uInt32 multiplier)
|
||||||
uInt32 width = myMediaSource->width();
|
uInt32 width = myMediaSource->width();
|
||||||
uInt32 height = myMediaSource->height();
|
uInt32 height = myMediaSource->height();
|
||||||
|
|
||||||
ofstream* out = new ofstream(filename.c_str());
|
ofstream* out = new ofstream(filename.c_str(), ios_base::binary);
|
||||||
if(!out)
|
if(!out)
|
||||||
return 0;
|
return 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: FrameBufferGL.cxx,v 1.11 2003-12-03 18:11:25 stephena Exp $
|
// $Id: FrameBufferGL.cxx,v 1.12 2003-12-06 00:17:29 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
@ -71,6 +71,17 @@ bool FrameBufferGL::createScreen()
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
glLoadIdentity();
|
glLoadIdentity();
|
||||||
|
|
||||||
|
#ifdef TEXTURES_ARE_LOST
|
||||||
|
createTextures();
|
||||||
|
|
||||||
|
glDisable(GL_DEPTH_TEST);
|
||||||
|
glDisable(GL_CULL_FACE);
|
||||||
|
glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||||
|
glEnable(GL_TEXTURE_2D);
|
||||||
|
#endif
|
||||||
|
|
||||||
theRedrawEntireFrameIndicator = true;
|
theRedrawEntireFrameIndicator = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -194,8 +205,10 @@ bool FrameBufferGL::init()
|
||||||
SDL_GL_GetAttribute( SDL_GL_BLUE_SIZE, (int*)&myRGB[2] );
|
SDL_GL_GetAttribute( SDL_GL_BLUE_SIZE, (int*)&myRGB[2] );
|
||||||
SDL_GL_GetAttribute( SDL_GL_ALPHA_SIZE, (int*)&myRGB[3] );
|
SDL_GL_GetAttribute( SDL_GL_ALPHA_SIZE, (int*)&myRGB[3] );
|
||||||
|
|
||||||
|
#ifndef TEXTURES_ARE_LOST
|
||||||
// Create the texture surface and texture fonts
|
// Create the texture surface and texture fonts
|
||||||
createTextures();
|
createTextures();
|
||||||
|
#endif
|
||||||
|
|
||||||
// Set up the palette *after* we know the color components
|
// Set up the palette *after* we know the color components
|
||||||
// and the textures
|
// and the textures
|
||||||
|
@ -349,6 +362,12 @@ void FrameBufferGL::drawChar(uInt32 x, uInt32 y, uInt32 c)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool FrameBufferGL::createTextures()
|
bool FrameBufferGL::createTextures()
|
||||||
{
|
{
|
||||||
|
if(myTexture)
|
||||||
|
SDL_FreeSurface(myTexture);
|
||||||
|
|
||||||
|
glDeleteTextures(1, &myTextureID);
|
||||||
|
glDeleteTextures(256, myFontTextureID);
|
||||||
|
|
||||||
uInt32 w = power_of_two(myWidth);
|
uInt32 w = power_of_two(myWidth);
|
||||||
uInt32 h = power_of_two(myHeight);
|
uInt32 h = power_of_two(myHeight);
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: mainSDL.cxx,v 1.65 2003-12-05 19:51:09 stephena Exp $
|
// $Id: mainSDL.cxx,v 1.66 2003-12-06 00:17:29 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
@ -342,7 +342,12 @@ void handleEvents()
|
||||||
else if(key == SDLK_MINUS)
|
else if(key == SDLK_MINUS)
|
||||||
theDisplay->resize(-1);
|
theDisplay->resize(-1);
|
||||||
else if(key == SDLK_RETURN)
|
else if(key == SDLK_RETURN)
|
||||||
|
{
|
||||||
theDisplay->toggleFullscreen();
|
theDisplay->toggleFullscreen();
|
||||||
|
// Pause when switching modes
|
||||||
|
if(!theConsole->eventHandler().doPause())
|
||||||
|
theConsole->eventHandler().sendEvent(Event::Pause, 1);
|
||||||
|
}
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
else if(key == SDLK_f && theUseOpenGLFlag)
|
else if(key == SDLK_f && theUseOpenGLFlag)
|
||||||
((FrameBufferGL*)theDisplay)->toggleFilter();
|
((FrameBufferGL*)theDisplay)->toggleFilter();
|
||||||
|
|
Loading…
Reference in New Issue