Mercurial > sdl-ios-xcode
annotate src/events/SDL_events_c.h @ 4223:63fd67e17705 SDL-1.2
Fixed bug #727
Lorenzo Desole 2009-04-19 07:36:10 PDT
I am one of the developers of a multimedia application (My Media System MMS),
which uses SDL.
MMS is normally running in fullscreen mode but it switches it off before
launching external applications (mplayer, xine, etc.).
The problem with fullscreen is that when the latter is switched off either via
SDL_WM_ToggleFullScreen() or SDL_SetVideoMode(), SDL compares the current
screen sizes with the ones saved when the video system was initted, and if they
don't match, it calls XF86VidModeSwitchToMode() to switch to the old modeline.
This makes it impossible for external programs and for MMS itself to use RandR
to change the screen size, because next time fullscreen mode is turned off, it
bombs out with the following error:
X Error of failed request: BadValue (integer parameter out of range for
operation)
Major opcode of failed request: 136 (XFree86-VidModeExtension)
Minor opcode of failed request: 10 (XF86VidModeSwitchToMode)
[...]
Obviously this happens only if the new screen resolution is smaller than the
original one and XF86VidModeSwitchToMode() can't succeed.
I couldn't find any way to inform SDL that the screen resolution it uses as
reference is no longer valid.
This can be fixed by adding "save_mode(this)" to
./src/video/x11/SDL_x11modes.c, API X11_EnterFullScreen(_THIS), like this:
int X11_EnterFullScreen(_THIS)
{
int okay;
+ save_mode(this);
I can't rule out possible side effects, but I don't see any.
While I admit this is a minor issue for the general users, it is a major
showstopper for our program where the ability to change screen resolution and
refresh rate according to the movie being played, is very important.
Thanks in advance.
author | Sam Lantinga <slouken@libsdl.org> |
---|---|
date | Mon, 21 Sep 2009 11:14:36 +0000 |
parents | a1b03ba2fcd0 |
children | 429c8dd3175d |
rev | line source |
---|---|
0 | 1 /* |
2 SDL - Simple DirectMedia Layer | |
4159 | 3 Copyright (C) 1997-2009 Sam Lantinga |
0 | 4 |
5 This library is free software; you can redistribute it and/or | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
6 modify it under the terms of the GNU Lesser General Public |
0 | 7 License as published by the Free Software Foundation; either |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
8 version 2.1 of the License, or (at your option) any later version. |
0 | 9 |
10 This library is distributed in the hope that it will be useful, | |
11 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
13 Lesser General Public License for more details. |
0 | 14 |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
15 You should have received a copy of the GNU Lesser General Public |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
16 License along with this library; if not, write to the Free Software |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
1123
diff
changeset
|
17 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
0 | 18 |
19 Sam Lantinga | |
252
e8157fcb3114
Updated the source with the correct e-mail address
Sam Lantinga <slouken@libsdl.org>
parents:
0
diff
changeset
|
20 slouken@libsdl.org |
0 | 21 */ |
1402
d910939febfa
Use consistent identifiers for the various platforms we support.
Sam Lantinga <slouken@libsdl.org>
parents:
1312
diff
changeset
|
22 #include "SDL_config.h" |
0 | 23 |
24 /* Useful functions and variables from SDL_events.c */ | |
25 #include "SDL_events.h" | |
26 | |
27 /* Start and stop the event processing loop */ | |
28 extern int SDL_StartEventLoop(Uint32 flags); | |
29 extern void SDL_StopEventLoop(void); | |
30 extern void SDL_QuitInterrupt(void); | |
31 | |
1612
97d0966f4bf7
Fixed some ultra-pedantic gcc warnings
Sam Lantinga <slouken@libsdl.org>
parents:
1402
diff
changeset
|
32 extern void SDL_Lock_EventThread(void); |
97d0966f4bf7
Fixed some ultra-pedantic gcc warnings
Sam Lantinga <slouken@libsdl.org>
parents:
1402
diff
changeset
|
33 extern void SDL_Unlock_EventThread(void); |
0 | 34 extern Uint32 SDL_EventThreadID(void); |
35 | |
36 /* Event handler init routines */ | |
37 extern int SDL_AppActiveInit(void); | |
38 extern int SDL_KeyboardInit(void); | |
39 extern int SDL_MouseInit(void); | |
40 extern int SDL_QuitInit(void); | |
41 | |
1123
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
42 /* Event handler quit routines */ |
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
43 extern void SDL_AppActiveQuit(void); |
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
44 extern void SDL_KeyboardQuit(void); |
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
45 extern void SDL_MouseQuit(void); |
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
46 extern void SDL_QuitQuit(void); |
28ac87a38c17
Date: Fri, 08 Jul 2005 22:43:48 +0200 (CEST)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
47 |
0 | 48 /* The event filter function */ |
49 extern SDL_EventFilter SDL_EventOK; | |
50 | |
51 /* The array of event processing states */ | |
52 extern Uint8 SDL_ProcessEvents[SDL_NUMEVENTS]; | |
53 | |
54 /* Internal event queueing functions | |
55 (from SDL_active.c, SDL_mouse.c, SDL_keyboard.c, SDL_quit.c, SDL_events.c) | |
56 */ | |
57 extern int SDL_PrivateAppActive(Uint8 gain, Uint8 state); | |
58 extern int SDL_PrivateMouseMotion(Uint8 buttonstate, int relative, | |
59 Sint16 x, Sint16 y); | |
60 extern int SDL_PrivateMouseButton(Uint8 state, Uint8 button,Sint16 x,Sint16 y); | |
61 extern int SDL_PrivateKeyboard(Uint8 state, SDL_keysym *key); | |
62 extern int SDL_PrivateResize(int w, int h); | |
63 extern int SDL_PrivateExpose(void); | |
64 extern int SDL_PrivateQuit(void); | |
65 extern int SDL_PrivateSysWMEvent(SDL_SysWMmsg *message); | |
66 | |
67 /* Used by the activity event handler to remove mouse focus */ | |
460
a888b3ae31ff
Reset mouse state when changing video modes
Sam Lantinga <slouken@libsdl.org>
parents:
297
diff
changeset
|
68 extern void SDL_ResetMouse(void); |
0 | 69 |
70 /* Used by the activity event handler to remove keyboard focus */ | |
71 extern void SDL_ResetKeyboard(void); | |
72 | |
73 /* Used by the event loop to queue pending keyboard repeat events */ | |
74 extern void SDL_CheckKeyRepeat(void); | |
75 | |
76 /* Used by the OS keyboard code to detect whether or not to do UNICODE */ | |
77 #ifndef DEFAULT_UNICODE_TRANSLATION | |
78 #define DEFAULT_UNICODE_TRANSLATION 0 /* Default off because of overhead */ | |
79 #endif | |
80 extern int SDL_TranslateUNICODE; |