From 56d746d5a727b7a5fb489e81b1f19816f4ab9b9d Mon Sep 17 00:00:00 2001 From: Christopher John Purnell Date: Sat, 4 Aug 2001 12:24:21 +0000 Subject: [PATCH] Fixed redisplay bug. Fixed modifier values. git-svn-id: svn+ssh://svn.code.sf.net/p/freeglut/code/trunk/freeglut/freeglut@19 7f0cb862-5218-0410-a997-914c9d46530a --- freeglut-1.3/freeglut_main.c | 49 ++++++++++++++++++++++++++++++------------ include/GL/freeglut.h | 4 ++-- 2 files changed, 37 insertions(+), 16 deletions(-) diff --git a/freeglut-1.3/freeglut_main.c b/freeglut-1.3/freeglut_main.c index b002dab..682e316 100644 --- a/freeglut-1.3/freeglut_main.c +++ b/freeglut-1.3/freeglut_main.c @@ -72,7 +72,7 @@ static void fghRedrawWindowByHandle /* * Return if the window is not visible */ - freeglut_return_if_fail( window->State.Visible != TRUE ); + freeglut_return_if_fail( window->State.Visible == TRUE ); /* * Set the window as the current one. Calling glutSetWindow() @@ -139,9 +139,8 @@ static void fghcbDisplayWindow( SFG_Window *window, SFG_Enumerator *enumerator ) /* * Check if there is an idle callback hooked */ -# warning there is a redisplay hack here (see the code commented out) if( (window->Callbacks.Display != NULL) && - /*(window->State.Redisplay == TRUE) &&*/ + (window->State.Redisplay == TRUE) && (window->State.Visible == TRUE) ) { /* @@ -369,6 +368,7 @@ void FGAPIENTRY glutMainLoop( void ) #if TARGET_HOST_UNIX_X11 SFG_Window* window; XEvent event; + int modifiers; /* * This code was repeated constantly, so here it goes into a definition: @@ -672,7 +672,14 @@ void FGAPIENTRY glutMainLoop( void ) /* * Remember the current modifiers state */ - window->State.Modifiers = event.xbutton.state; + modifiers = 0; + if (event.xbutton.state & (ShiftMask|LockMask)) + modifiers |= GLUT_ACTIVE_SHIFT; + if (event.xbutton.state & ControlMask) + modifiers |= GLUT_ACTIVE_CTRL; + if (event.xbutton.state & Mod1Mask) + modifiers |= GLUT_ACTIVE_ALT; + window->State.Modifiers = modifiers; /* * Finally execute the mouse callback @@ -731,7 +738,14 @@ void FGAPIENTRY glutMainLoop( void ) /* * Remember the current modifiers state */ - window->State.Modifiers = event.xkey.state; + modifiers = 0; + if (event.xkey.state & (ShiftMask|LockMask)) + modifiers |= GLUT_ACTIVE_SHIFT; + if (event.xkey.state & ControlMask) + modifiers |= GLUT_ACTIVE_CTRL; + if (event.xkey.state & Mod1Mask) + modifiers |= GLUT_ACTIVE_ALT; + window->State.Modifiers = modifiers; /* * Execute the callback @@ -784,17 +798,24 @@ void FGAPIENTRY glutMainLoop( void ) */ if( (window->Callbacks.Special != NULL) && (special != -1) ) { - /* - * Remember the current modifiers state - */ - window->State.Modifiers = event.xkey.state; + /* + * Remember the current modifiers state + */ + modifiers = 0; + if (event.xkey.state & (ShiftMask|LockMask)) + modifiers |= GLUT_ACTIVE_SHIFT; + if (event.xkey.state & ControlMask) + modifiers |= GLUT_ACTIVE_CTRL; + if (event.xkey.state & Mod1Mask) + modifiers |= GLUT_ACTIVE_ALT; + window->State.Modifiers = modifiers; - window->Callbacks.Special( special, event.xkey.x, event.xkey.y ); + window->Callbacks.Special( special, event.xkey.x, event.xkey.y ); - /* - * Trash the modifiers state - */ - window->State.Modifiers = 0xffffffff; + /* + * Trash the modifiers state + */ + window->State.Modifiers = 0xffffffff; } } } diff --git a/include/GL/freeglut.h b/include/GL/freeglut.h index 66101c9..7dd8659 100644 --- a/include/GL/freeglut.h +++ b/include/GL/freeglut.h @@ -262,8 +262,8 @@ * GLUT API macro definitions -- the glutGetModifiers parameters */ #define GLUT_ACTIVE_SHIFT 0x0001 -#define GLUT_ACTIVE_CTRL 0x0004 -#define GLUT_ACTIVE_ALT 0x0008 +#define GLUT_ACTIVE_CTRL 0x0002 +#define GLUT_ACTIVE_ALT 0x0004 /* * GLUT API macro definitions -- the glutSetCursor parameters -- 1.7.10.4