Skip to content

Commit

Permalink
Date: Sun, 3 Aug 2003 22:07:57 +0200
Browse files Browse the repository at this point in the history
From: Max Horn
Subject: SDL OSX fullscreen FIX

the attached patch fixes the fullscreen problems on SDL/OSX. The cause
was that click events are bounded by winRect. Now, winRect is set to
the size of the video surface. But if you e.g. request a 640x420
surface, you might get a 640x480 "real" surface. Still,
SDL_VideoSurface->h will be set to 420! Thus, the upper 60 pixels in my
example received no mouse down events.

My fix simply disables this clipping when in full screen mode - after
all, all clicks then should be inside the screen surface. Higher SDL
functions ensure that the coordinates then are clipped to 640x420. It
works fine in all my tests here. I don't know if it's the right thing
to do in multi screen scenarios, though.
  • Loading branch information
slouken committed Aug 4, 2003
1 parent 11fbf1b commit a69f791
Showing 1 changed file with 3 additions and 6 deletions.
9 changes: 3 additions & 6 deletions src/video/quartz/SDL_QuartzEvents.m
Expand Up @@ -255,13 +255,13 @@ static void QZ_DoKey (_THIS, int state, NSEvent *event) {

static void QZ_DoModifiers (_THIS, unsigned int newMods) {

const int mapping[] = { SDLK_CAPSLOCK, SDLK_LSHIFT, SDLK_LCTRL, SDLK_LALT, SDLK_LMETA } ;
const int mapping[] = { SDLK_CAPSLOCK, SDLK_LSHIFT, SDLK_LCTRL, SDLK_LALT, SDLK_LMETA };

int i;
int bit;
SDL_keysym key;

key.scancode = 0;
key.scancode = 0;
key.sym = SDLK_UNKNOWN;
key.unicode = 0;
key.mod = KMOD_NONE;
Expand Down Expand Up @@ -405,7 +405,6 @@ static void QZ_PumpEvents (_THIS)
NSDate *distantPast;
NSEvent *event;
NSRect winRect;
NSRect titleBarRect;
NSAutoreleasePool *pool;

/* Update activity every five seconds to prevent screensaver. --ryan. */
Expand All @@ -421,8 +420,6 @@ static void QZ_PumpEvents (_THIS)
distantPast = [ NSDate distantPast ];

winRect = NSMakeRect (0, 0, SDL_VideoSurface->w, SDL_VideoSurface->h);
titleBarRect = NSMakeRect (0, SDL_VideoSurface->h, SDL_VideoSurface->w,
SDL_VideoSurface->h + 22);

/* send the first mouse event in absolute coordinates */
firstMouseEvent = 1;
Expand Down Expand Up @@ -467,7 +464,7 @@ static void QZ_PumpEvents (_THIS)

type = [ event type ];
isForGameWin = (qz_window == [ event window ]);
isInGameWin = NSPointInRect([event locationInWindow], winRect);
isInGameWin = (mode_flags & SDL_FULLSCREEN) ? true : NSPointInRect([event locationInWindow], winRect);
switch (type) {
case NSLeftMouseDown:
if ( getenv("SDL_HAS3BUTTONMOUSE") ) {
Expand Down

0 comments on commit a69f791

Please sign in to comment.