X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fevents.c;h=940fd3790891bc48cd7a3a50731f9480a192a617;hb=e1e1f0e96140865d39f667f6af11ebec5e8c9cad;hp=69b67685b87b95f7503fdd6a75843f12fc531076;hpb=cf5b3a1e9077e88eb40ce2fb59e985a0ae037c84;p=rocksndiamonds.git diff --git a/src/events.c b/src/events.c index 69b67685..940fd379 100644 --- a/src/events.c +++ b/src/events.c @@ -149,7 +149,7 @@ void HandleExposeEvent(XExposeEvent *event) int x1 = (x-SX)/TILEX, y1 = (y-SY)/TILEY; int x2 = (x-SX+width)/TILEX, y2 = (y-SY+height)/TILEY; - drawto_field = backbuffer; + SetDrawtoField(DRAW_BACKBUFFER); for(xx=0;xxtype == FocusIn) { @@ -263,8 +269,8 @@ void HandleButton(int mx, int my, int button) } int Gamespeed = 4; -int Movemethod = 0; -int Movespeed[2] = { 10, 3 }; +int Movemethod = 1; +int Movespeed[2] = { 10, 4 }; char *Movespeed_text[2] = { "asynchron", "syncron" }; void HandleKey(KeySym key, int key_status) @@ -361,6 +367,8 @@ void HandleKey(KeySym key, int key_status) case XK_Control_R: case XK_Alt_R: case XK_Meta_R: + case XK_Mode_switch: + case XK_Multi_key: case XK_B: /* (Bombe legen) */ case XK_b: joy |= JOY_BUTTON_2; @@ -377,11 +385,11 @@ void HandleKey(KeySym key, int key_status) key_joystick_mapping &= ~joy; HandleJoystick(); - - if (game_status != PLAYING) - key_joystick_mapping = 0; } + if (game_status != PLAYING) + key_joystick_mapping = 0; + if (key_status == KEY_RELEASED) return; @@ -488,7 +496,7 @@ void HandleKey(KeySym key, int key_status) printf("gamespeed == %d\n", Gamespeed); break; case XK_l: - Gamespeed = 10; + Gamespeed = 50; printf("gamespeed == %d\n", Gamespeed); break; @@ -496,7 +504,6 @@ void HandleKey(KeySym key, int key_status) case XK_q: Dynamite = 1000; break; -#endif case XK_x: @@ -520,11 +527,11 @@ void HandleKey(KeySym key, int key_status) { if (DelayReached(&scroll_delay, scroll_delay_value)) { - XCopyArea(display,backbuffer,window,gc, + XCopyArea(display,fieldbuffer,window,gc, SX+xxx,SY, SXSIZE-xxx,SYSIZE, SX,SY); - XCopyArea(display,backbuffer,window,gc, + XCopyArea(display,fieldbuffer,window,gc, SX,SY, xxx,SYSIZE, SX+SXSIZE-xxx,SY); @@ -553,6 +560,22 @@ void HandleKey(KeySym key, int key_status) break; + case XK_y: + { + printf("FX = %d, FY = %d\n", FX,FY); + + XCopyArea(display,fieldbuffer,window,gc, + 0,0, + MIN(WIN_XSIZE,FXSIZE),MIN(WIN_YSIZE,FYSIZE), + 0,0); + XFlush(display); + XSync(display,FALSE); + Delay(1000000); + } + + break; +#endif + default: break; } @@ -565,7 +588,7 @@ void HandleKey(KeySym key, int key_status) void HandleNoXEvent() { - if (button_status && game_status!=PLAYING) + if (button_status && game_status != PLAYING) { HandleButton(-1,-1,button_status); return; @@ -645,13 +668,6 @@ void HandleJoystick() return; } - - - if (PlayerMovPos) - ScrollFigure(0); - - - if (tape.pausing || PlayerGone) joy = 0; @@ -705,9 +721,6 @@ void HandleJoystick() } } } - - DrawPlayerField(); - break; } default: