X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fgame_em%2Flogic.c;h=5b39eab03dbe8189ea3aa54d6e20df8b75ecdb75;hb=320d4a2e79c5562cc55d83927e0ac4d05080ccb4;hp=0fec08c951243376901045fb92447573d7ad593f;hpb=e227a361d63ac92e9ed1ceb276f739fa3edc45be;p=rocksndiamonds.git diff --git a/src/game_em/logic.c b/src/game_em/logic.c index 0fec08c9..5b39eab0 100644 --- a/src/game_em/logic.c +++ b/src/game_em/logic.c @@ -1228,7 +1228,7 @@ static void check_player(struct PLAYER *ply) static void set_nearest_player_xy(int x, int y, int *dx, int *dy) { - int distance, distance_shortest = EM_MAX_CAVE_WIDTH + EM_MAX_CAVE_HEIGHT; + int distance, distance_shortest = CAVE_WIDTH + CAVE_HEIGHT; int i; /* default values if no players are alive anymore */ @@ -6210,9 +6210,9 @@ void logic_1(void) int start_check_nr; int i; - cave = Cave; - next = Next; - boom = Boom; + cave = lev.cave; + next = lev.next; + boom = lev.boom; game_em.any_player_moving = FALSE; game_em.any_player_snapping = FALSE; @@ -6228,6 +6228,17 @@ void logic_1(void) for (i = 0; i < MAX_PLAYERS; i++) { + /* check for wrap-around movement */ + if (ply[i].x < lev.left || + ply[i].x > lev.right - 1) + { + ply[i].x = (ply[i].x < lev.left ? lev.right - 1 : lev.left); + + game.centered_player_nr_next = i; + game.set_centered_player = TRUE; + game.set_centered_player_fast = TRUE; + } + ply[i].oldx = ply[i].x; ply[i].oldy = ply[i].y; ply[i].anim = PLY_still; @@ -6266,15 +6277,15 @@ void logic_2(void) { int x, y; - cave = Cave; - next = Next; - boom = Boom; + cave = lev.cave; + next = lev.next; + boom = lev.boom; seed = RandomEM; score = 0; - for (y = 1; y < HEIGHT - 1; y++) - for (x = 0; x < WIDTH; x++) + for (y = lev.top; y < lev.bottom; y++) + for (x = lev.left; x < lev.right; x++) handle_tile(x, y); if (ply[0].alive || ply[1].alive || ply[2].alive || ply[3].alive) @@ -6285,10 +6296,10 @@ void logic_2(void) RandomEM = seed; /* triple buffering */ - void *temp = Cave; - Cave = Next; - Next = Draw; - Draw = temp; + void *temp = lev.cave; + lev.cave = lev.next; + lev.next = lev.draw; + lev.draw = temp; } void logic_3(void) @@ -6298,9 +6309,9 @@ void logic_3(void) int count; unsigned int random; - cave = Cave; - next = Next; - boom = Boom; + cave = lev.cave; + next = lev.next; + boom = lev.boom; /* update variables */ @@ -6334,10 +6345,12 @@ void logic_3(void) for (count = lev.amoeba_time; count--;) { - x = (random >> 10) % (WIDTH - 2); - y = (random >> 20) % (HEIGHT - 2); + x = lev.left - 1 + (random >> 10) % (CAVE_WIDTH + 2); + y = lev.top - 1 + (random >> 20) % (CAVE_HEIGHT + 2); - Lamoeba(x, y); + if (x >= lev.left && x < lev.right && + y >= lev.top && y < lev.bottom) + Lamoeba(x, y); random = random * 129 + 1; } @@ -6346,13 +6359,13 @@ void logic_3(void) /* handle explosions */ - for (y = 1; y < HEIGHT - 1; y++) - for (x = 1; x < WIDTH - 1; x++) + for (y = lev.top; y < lev.bottom; y++) + for (x = lev.left; x < lev.right; x++) Lexplode(x, y); /* triple buffering */ - for (y = 0; y < HEIGHT; y++) - for (x = 0; x < WIDTH; x++) - Next[x][y] = Cave[x][y]; + for (y = lev.top; y < lev.bottom; y++) + for (x = lev.left; x < lev.right; x++) + next[x][y] = cave[x][y]; }