diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/i_video.c | 78 |
1 files changed, 43 insertions, 35 deletions
diff --git a/src/i_video.c b/src/i_video.c index 903883ff..d89c8561 100644 --- a/src/i_video.c +++ b/src/i_video.c @@ -1,7 +1,7 @@ // Emacs style mode select -*- C++ -*- //----------------------------------------------------------------------------- // -// $Id: i_video.c 134 2005-09-26 21:44:30Z fraggle $ +// $Id: i_video.c 140 2005-09-27 22:33:42Z fraggle $ // // Copyright(C) 1993-1996 Id Software, Inc. // Copyright(C) 2005 Simon Howard @@ -22,6 +22,10 @@ // 02111-1307, USA. // // $Log$ +// Revision 1.33 2005/09/27 22:33:42 fraggle +// Always use SDL_Flip to update the screen. Fixes problems in Windows when +// running fullscreen, introduced by fixes to the disk icon code. +// // Revision 1.32 2005/09/26 21:44:30 fraggle // Fix melting crap on startup - oops // @@ -137,7 +141,7 @@ //----------------------------------------------------------------------------- static const char -rcsid[] = "$Id: i_video.c 134 2005-09-26 21:44:30Z fraggle $"; +rcsid[] = "$Id: i_video.c 140 2005-09-27 22:33:42Z fraggle $"; #include <SDL.h> #include <ctype.h> @@ -511,22 +515,14 @@ void UpdateGrab(void) } // Update a small portion of the screen +// +// Does 2x stretching and buffer blitting if neccessary -static void UpdateArea(int x1, int y1, int x2, int y2, boolean always_update) +static void BlitArea(int x1, int y1, int x2, int y2) { int w = x2 - x1; int h = y2 - y1; - if (palette_to_set && !always_update) - { - // If we have a palette to set, the only way to update is to - // update the entire screen - // If we are only updating part of the screen (disk icon), we - // cannot update the screen - - return; - } - if (screenmultiply == 1 && !native_surface) { byte *bufp, *screenp; @@ -585,22 +581,21 @@ static void UpdateArea(int x1, int y1, int x2, int y2, boolean always_update) SDL_UnlockSurface(screen); } +} - // draw to screen - - if (palette_to_set) - { - SDL_SetColors(screen, palette, 0, 256); - palette_to_set = 0; - } - else - { - SDL_UpdateRect(screen, - x1 * screenmultiply, - y1 * screenmultiply, - w * screenmultiply, - h * screenmultiply); - } +void UpdateRect(int x1, int y1, int x2, int y2) +{ + // Do stretching and blitting + + BlitArea(x1, y1, x2, y2); + + // Update the area + + SDL_UpdateRect(screen, + x1 * screenmultiply, + y1 * screenmultiply, + (x2-x1) * screenmultiply, + (y2-y1) * screenmultiply); } void I_BeginRead(void) @@ -625,9 +620,8 @@ void I_BeginRead(void) memcpy(screenloc, disk_image + y * disk_image_w, disk_image_w); } - UpdateArea(SCREENWIDTH - disk_image_w, SCREENHEIGHT - disk_image_h, - SCREENWIDTH, SCREENHEIGHT, - false); + UpdateRect(SCREENWIDTH - disk_image_w, SCREENHEIGHT - disk_image_h, + SCREENWIDTH, SCREENHEIGHT); } void I_EndRead(void) @@ -649,9 +643,8 @@ void I_EndRead(void) memcpy(screenloc, saved_background + y * disk_image_w, disk_image_w); } - UpdateArea(SCREENWIDTH - disk_image_w, SCREENHEIGHT - disk_image_h, - SCREENWIDTH, SCREENHEIGHT, - false); + UpdateRect(SCREENWIDTH - disk_image_w, SCREENHEIGHT - disk_image_h, + SCREENWIDTH, SCREENHEIGHT); } // @@ -689,7 +682,22 @@ void I_FinishUpdate (void) } - UpdateArea(0, 0, SCREENWIDTH, SCREENHEIGHT, true); + // draw to screen + + BlitArea(0, 0, SCREENWIDTH, SCREENHEIGHT); + + // If we have a palette to set, the act of setting the palette + // updates the screen + + if (palette_to_set) + { + SDL_SetColors(screen, palette, 0, 256); + palette_to_set = 0; + } + else + { + SDL_Flip(screen); + } } |