projects
/
rocksndiamonds.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
rnd-19990824-1-src
[rocksndiamonds.git]
/
src
/
events.c
diff --git
a/src/events.c
b/src/events.c
index a336f013d3a5ae35140ad8095734aa216e643a58..0e8122853385e642df43e2dae3711a2b12b0d318 100644
(file)
--- a/
src/events.c
+++ b/
src/events.c
@@
-68,7
+68,8
@@
void EventLoop(void)
if (game_status != PLAYING)
{
XSync(display, FALSE);
if (game_status != PLAYING)
{
XSync(display, FALSE);
- Delay(10);
+ if (!XPending(display)) /* delay only if no pending events */
+ Delay(10);
}
/* refresh window contents from drawing buffer, if needed */
}
/* refresh window contents from drawing buffer, if needed */
@@
-299,13
+300,15
@@
void HandleFocusEvent(XFocusChangeEvent *event)
would be far better) set for each X11 window individually.
The effect would be keyboard auto repeat while playing the game
(game_status == PLAYING), which is not desired.
would be far better) set for each X11 window individually.
The effect would be keyboard auto repeat while playing the game
(game_status == PLAYING), which is not desired.
- To avoid this special case, we just wait 1/
5
0 second before
+ To avoid this special case, we just wait 1/
1
0 second before
processing the 'FocusIn' event.
*/
processing the 'FocusIn' event.
*/
- Delay(20);
if (game_status == PLAYING)
if (game_status == PLAYING)
+ {
+ Delay(100);
XAutoRepeatOff(display);
XAutoRepeatOff(display);
+ }
if (old_joystick_status != -1)
joystick_status = old_joystick_status;
}
if (old_joystick_status != -1)
joystick_status = old_joystick_status;
}
@@
-334,12
+337,6
@@
void HandleButton(int mx, int my, int button)
{
old_mx = mx;
old_my = my;
{
old_mx = mx;
old_my = my;
-
- /*
- HandleVideoButtons(mx,my, button);
- HandleSoundButtons(mx,my, button);
- HandleGameButtons(mx,my, button);
- */
}
HandleGadgets(mx, my, button);
}
HandleGadgets(mx, my, button);
@@
-480,7
+477,8
@@
void HandleKey(KeySym key, int key_status)
if (key_status == KEY_RELEASED)
return;
if (key_status == KEY_RELEASED)
return;
- if (key == XK_Return && game_status == PLAYING && AllPlayersGone)
+ if ((key == XK_Return || key == XK_space) &&
+ game_status == PLAYING && AllPlayersGone)
{
CloseDoor(DOOR_CLOSE_1);
game_status = MAINMENU;
{
CloseDoor(DOOR_CLOSE_1);
game_status = MAINMENU;
@@
-491,16
+489,6
@@
void HandleKey(KeySym key, int key_status)
/* allow quick escape to the main menu with the Escape key */
if (key == XK_Escape && game_status != MAINMENU)
{
/* allow quick escape to the main menu with the Escape key */
if (key == XK_Escape && game_status != MAINMENU)
{
- if (game_status == LEVELED)
- {
- /* draw smaller door */
- XCopyArea(display, pix[PIX_DOOR], drawto, gc,
- DOOR_GFX_PAGEX7, 64,
- 108, 64,
- EX - 4, EY - 12);
- redraw_mask |= REDRAW_ALL;
- }
-
CloseDoor(DOOR_CLOSE_1 | DOOR_OPEN_2 | DOOR_NO_DELAY);
game_status = MAINMENU;
DrawMainMenu();
CloseDoor(DOOR_CLOSE_1 | DOOR_OPEN_2 | DOOR_NO_DELAY);
game_status = MAINMENU;
DrawMainMenu();
@@
-533,6
+521,7
@@
void HandleKey(KeySym key, int key_status)
switch(key)
{
case XK_Return:
switch(key)
{
case XK_Return:
+ case XK_space:
if (game_status == MAINMENU)
HandleMainMenu(0,0, 0,0, MB_MENU_CHOICE);
else if (game_status == CHOOSELEVEL)
if (game_status == MAINMENU)
HandleMainMenu(0,0, 0,0, MB_MENU_CHOICE);
else if (game_status == CHOOSELEVEL)
@@
-543,6
+532,16
@@
void HandleKey(KeySym key, int key_status)
HandleSetupInputScreen(0,0, 0,0, MB_MENU_CHOICE);
break;
HandleSetupInputScreen(0,0, 0,0, MB_MENU_CHOICE);
break;
+ case XK_Page_Up:
+ if (game_status == CHOOSELEVEL)
+ HandleChooseLevel(0,0, 0,-SCR_FIELDY, MB_MENU_MARK);
+ break;
+
+ case XK_Page_Down:
+ if (game_status == CHOOSELEVEL)
+ HandleChooseLevel(0,0, 0,SCR_FIELDY, MB_MENU_MARK);
+ break;
+
default:
break;
}
default:
break;
}
@@
-556,6
+555,7
@@
void HandleKey(KeySym key, int key_status)
switch(key)
{
case XK_Return:
switch(key)
{
case XK_Return:
+ case XK_space:
game_status = MAINMENU;
DrawMainMenu();
BackToFront();
game_status = MAINMENU;
DrawMainMenu();
BackToFront();
@@
-610,7
+610,7
@@
void HandleKey(KeySym key, int key_status)
break;
#endif
break;
#endif
-#if
1
+#if
0
case XK_m:
if (MoveSpeed == 8)
{
case XK_m:
if (MoveSpeed == 8)
{