X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fanim.c;h=71f9958857020ce938ee3edc49277b18333fa9a0;hb=eb201ff71896cf5291e3ad61ccc663d9cec1b825;hp=9d1f0b5c734dc75200cc077ff88d826051ceb443;hpb=b20de5f2d7dd54c56af6bda51748d2c03446bcdd;p=rocksndiamonds.git diff --git a/src/anim.c b/src/anim.c index 9d1f0b5c..71f99588 100644 --- a/src/anim.c +++ b/src/anim.c @@ -828,7 +828,8 @@ static boolean SetGlobalAnimPart_Viewport(struct GlobalAnimPartControlInfo *part int viewport_height; boolean changed = FALSE; - if (part->last_anim_status == global.anim_status) + if (part->last_anim_status == global.anim_status && + part->control_info.class != get_hash_from_key("pointer")) return FALSE; part->last_anim_status = global.anim_status; @@ -845,6 +846,15 @@ static boolean SetGlobalAnimPart_Viewport(struct GlobalAnimPartControlInfo *part part->drawing_stage = DRAW_GLOBAL_ANIM_STAGE_2; } + else if (part->control_info.class == get_hash_from_key("pointer")) + { + viewport_x = gfx.mouse_x + part->control_info.x; + viewport_y = gfx.mouse_y + part->control_info.y; + viewport_width = part->graphic_info.width; + viewport_height = part->graphic_info.height; + + part->drawing_stage = DRAW_GLOBAL_ANIM_STAGE_2; + } else if (part->control_info.class == get_hash_from_key("door_1")) { viewport_x = DX; @@ -1256,10 +1266,13 @@ static int HandleGlobalAnim_Part(struct GlobalAnimPartControlInfo *part, part->step_yoffset = 0; } - if (c->x != ARG_UNDEFINED_VALUE) - part->x = c->x; - if (c->y != ARG_UNDEFINED_VALUE) - part->y = c->y; + if (part->control_info.class != get_hash_from_key("pointer")) + { + if (c->x != ARG_UNDEFINED_VALUE) + part->x = c->x; + if (c->y != ARG_UNDEFINED_VALUE) + part->y = c->y; + } if (c->position == POS_LAST && anim->last_x > -g->width && anim->last_x < part->viewport_width && @@ -1782,7 +1795,7 @@ static void ResetGlobalAnim_Clicked(void) InitGlobalAnim_Clicked(-1, -1, ANIM_CLICKED_RESET); } -boolean HandleGlobalAnimClicks(int mx, int my, int button) +boolean HandleGlobalAnimClicks(int mx, int my, int button, boolean force_click) { static boolean click_consumed = FALSE; static int last_button = 0; @@ -1790,6 +1803,9 @@ boolean HandleGlobalAnimClicks(int mx, int my, int button) boolean release_event; boolean click_consumed_current = click_consumed; + if (button != 0 && force_click) + last_button = 0; + // check if button state has changed since last invocation press_event = (button != 0 && last_button == 0); release_event = (button == 0 && last_button != 0);