#define NUM_GAME_BUTTONS 6
+
/* forward declaration for internal use */
-#if 0
-static void ResetGfxAnimation(int, int);
-#endif
static void InitBeltMovement(void);
static void CloseAllOpenTimegates(void);
Feld[x][y] = EL_SP_MURPHY_CLONE;
break;
}
+ else
+ {
+ stored_player[0].use_murphy_graphic = TRUE;
+ }
Feld[x][y] = EL_PLAYER1;
}
for (j=0; j<4; j++)
if (stored_player[i].key[j])
DrawMiniGraphicExt(drawto, DX_KEYS + j * MINI_TILEX, DY_KEYS,
- IMG_KEY1 + j);
+ el2edimg(EL_KEY1 + j));
DrawText(DX + XX_EMERALDS, DY + YY_EMERALDS,
- int2str(local_player->gems_still_needed, 3), FS_SMALL, FC_YELLOW);
+ int2str(local_player->gems_still_needed, 3), FONT_DEFAULT_SMALL);
DrawText(DX + XX_DYNAMITE, DY + YY_DYNAMITE,
- int2str(local_player->dynamite, 3), FS_SMALL, FC_YELLOW);
+ int2str(local_player->dynamite, 3), FONT_DEFAULT_SMALL);
DrawText(DX + XX_SCORE, DY + YY_SCORE,
- int2str(local_player->score, 5), FS_SMALL, FC_YELLOW);
+ int2str(local_player->score, 5), FONT_DEFAULT_SMALL);
DrawText(DX + XX_TIME, DY + YY_TIME,
- int2str(TimeLeft, 3), FS_SMALL, FC_YELLOW);
+ int2str(TimeLeft, 3), FONT_DEFAULT_SMALL);
}
player->GfxPos = 0;
player->Frame = 0;
- player->actual_frame_counter = 0;
+ player->GfxAction = ACTION_DEFAULT;
- player->frame_reset_delay = 0;
+ player->use_murphy_graphic = FALSE;
+
+ player->actual_frame_counter = 0;
player->last_move_dir = MV_NO_MOVING;
player->is_moving = FALSE;
+ player->is_moving = FALSE;
+ player->is_waiting = FALSE;
+
player->move_delay = game.initial_move_delay;
player->move_delay_value = game.initial_move_delay_value;
if (level_nr < 100)
DrawText(DX + XX_LEVEL, DY + YY_LEVEL,
- int2str(level_nr, 2), FS_SMALL, FC_YELLOW);
+ int2str(level_nr, 2), FONT_DEFAULT_SMALL);
else
{
DrawTextExt(drawto, DX + XX_EMERALDS, DY + YY_EMERALDS,
- int2str(level_nr, 3), FS_SMALL, FC_SPECIAL3, FONT_OPAQUE);
+ int2str(level_nr, 3), FONT_SPECIAL_NARROW, FONT_OPAQUE);
BlitBitmap(drawto, drawto,
DX + XX_EMERALDS, DY + YY_EMERALDS + 1,
- FONT5_XSIZE * 3, FONT5_YSIZE - 1,
+ getFontWidth(FONT_SPECIAL_NARROW) * 3,
+ getFontHeight(FONT_SPECIAL_NARROW) - 1,
DX + XX_LEVEL - 1, DY + YY_LEVEL + 1);
}
TimeLeft -= 10;
else
TimeLeft--;
- DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FONT_DEFAULT_SMALL);
BackToFront();
if (!tape.playing)
TimePlayed += 10;
else
TimePlayed++;
- DrawText(DX_TIME, DY_TIME, int2str(TimePlayed, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimePlayed, 3), FONT_DEFAULT_SMALL);
BackToFront();
if (!tape.playing)
StopSound(SND_GAME_LEVELTIME_BONUS);
}
-#if 0
- FadeSounds();
-#endif
-
/* Hero disappears */
DrawLevelField(ExitX, ExitY);
BackToFront();
return position;
}
+static void InitPlayerGfxAnimation(struct PlayerInfo *player, int action)
+{
+ if (player->GfxAction != action)
+ {
+ player->GfxAction = action;
+ player->Frame = 0;
+ }
+}
+
static void ResetRandomAnimationValue(int x, int y)
{
GfxRandom[x][y] = INIT_GFX_RANDOM();
static void ResetGfxAnimation(int x, int y)
{
-#if 0
-#if 1
- int element = Feld[x][y];
- int graphic = el2img(element);
-
- /* reset random value not until one full delay cycle was reached */
- if (ANIM_MODE(graphic) == ANIM_RANDOM &&
- GfxFrame[x][y] > ANIM_DELAY(graphic))
-#endif
- ResetRandomAnimationValue(x, y);
-#endif
-
GfxFrame[x][y] = 0;
GfxAction[x][y] = ACTION_DEFAULT;
-
-#if 0
- if (Feld[x][y] == EL_ROCK)
- printf("ResetGfxAnimation: EL_ROCK [%d, %d]\n",
- JustStopped[x][y], MovDir[x][y]);
-#endif
}
void InitMovingField(int x, int y, int direction)
RemoveMovingField(x, y);
}
- if (IS_MASSIVE(element) || element == EL_FLAMES)
+ if (IS_INDESTRUCTIBLE(element) || element == EL_FLAMES)
continue;
if (IS_PLAYER(x, y) && SHIELD_ON(PLAYERINFO(x, y)))
int y = ey + j * xy[i % 4][1];
int element;
- if (!IN_LEV_FIELD(x, y) || IS_MASSIVE(Feld[x][y]))
+ if (!IN_LEV_FIELD(x, y) || IS_INDESTRUCTIBLE(Feld[x][y]))
break;
element = Feld[x][y];
!CAN_FALL(MovingOrBlocked2Element(x+1, y-1))))
Feld[x+1][y] = EL_ACID_SPLASH_RIGHT;
}
-
-#if 0
- else /* go on */
- {
- int graphic = (element == EL_ACID_SPLASH_LEFT ?
- IMG_ACID_SPLASH_LEFT :
- IMG_ACID_SPLASH_RIGHT);
-
- if (!MovDelay[x][y]) /* initialize animation counter */
- MovDelay[x][y] = 9;
-
- if (MovDelay[x][y]) /* continue animation */
- {
- MovDelay[x][y]--;
- if (MovDelay[x][y]/2 && IN_SCR_FIELD(SCREENX(x), SCREENY(y)))
- {
- int frame = getGraphicAnimationFrame(graphic, 8 - MovDelay[x][y]);
-
- DrawGraphic(SCREENX(x), SCREENY(y), graphic, frame);
- }
-
- if (!MovDelay[x][y])
- {
- Feld[x][y] = EL_EMPTY;
- DrawLevelField(x, y);
- }
- }
- }
-#endif
}
static void InitBeltMovement()
return;
}
-#if 1
if (lastline || object_hit)
{
-#if 0
- MovDir[x][y] = 0;
-#endif
ResetGfxAnimation(x, y);
DrawLevelField(x, y);
}
-#endif
if ((element == EL_BOMB ||
element == EL_SP_DISK_ORANGE ||
EL_BD_MAGIC_WALL_FILLING);
Store[x][y] = element;
}
+#if 0
else if (CAN_SMASH(element) && Feld[x][y+1] == EL_ACID)
+#else
+ else if (CAN_FALL(element) && Feld[x][y+1] == EL_ACID)
+#endif
{
SplashAcid(x, y);
started_moving = TRUE;
Store[x][y] = EL_ACID;
+#if 0
+ /* !!! TEST !!! better use "_FALLING" etc. !!! */
+ GfxAction[x][y+1] = ACTION_ACTIVE;
+#endif
}
else if (CAN_SMASH(element) && Feld[x][y+1] == EL_BLOCKED &&
JustStopped[x][y])
element != EL_DARK_YAMYAM &&
element != EL_PACMAN)
{
-#if 0
- if (element == EL_SPRING)
- printf("1--> %d\n", MovDir[x][y]);
-#endif
TurnRound(x, y);
-#if 0
- if (element == EL_SPRING)
- printf("2--> %d\n", MovDir[x][y]);
-#endif
+
if (MovDelay[x][y] && (element == EL_BUG ||
element == EL_SPACESHIP ||
element == EL_SP_SNIKSNAK ||
element == EL_YAMYAM ||
element == EL_DARK_YAMYAM)
{
-#if 1
DrawLevelElementAnimationIfNeeded(x, y, element);
-#else
- if (IN_SCR_FIELD(SCREENX(x), SCREENY(y)))
- {
- int graphic = el2img(element);
- int frame = getGraphicAnimationFrame(graphic, MovDelay[x][y] % 8);
-
- DrawGraphic(SCREENX(x), SCREENY(y), graphic, frame);
- }
-#endif
-
-#if 1
PlaySoundLevelAction(x, y, ACTION_WAITING);
-#else
- if (MovDelay[x][y] % 4 == 3)
- {
- if (element == EL_YAMYAM)
- PlaySoundLevel(x, y, SND_YAMYAM_WAITING);
- else if (element == EL_DARK_YAMYAM)
- PlaySoundLevel(x, y, SND_DARK_YAMYAM_WAITING);
- }
-#endif
}
else if (element == EL_SP_ELECTRON)
DrawLevelElementAnimationIfNeeded(x, y, element);
MovPos[x][y] = MovDir[x][y] = MovDelay[x][y] = 0;
MovDelay[newx][newy] = 0;
-#if 0
- /* all done in "InitMovingField()" */
- GfxAction[newx][newy] = GfxAction[x][y]; /* keep action one frame */
- GfxRandom[newx][newy] = GfxRandom[x][y]; /* keep same random value */
-#endif
-
/* copy animation control values to new field */
GfxFrame[newx][newy] = GfxFrame[x][y];
- GfxAction[newx][newy] = GfxAction[x][y];
- GfxRandom[newx][newy] = GfxRandom[x][y];
+ GfxAction[newx][newy] = GfxAction[x][y]; /* keep action one frame */
+ GfxRandom[newx][newy] = GfxRandom[x][y]; /* keep same random value */
ResetGfxAnimation(x, y); /* reset animation values for old field */
}
else /* still moving on */
{
-#if 0
- if (GfxAction[x][y] == ACTION_DEFAULT)
- {
- printf("reset GfxAction...\n");
-
- GfxAction[x][y] = ACTION_MOVING;
- }
-#endif
-
DrawLevelField(x, y);
}
}
return;
if (Feld[x][y] == EL_BD_DIAMOND)
-#if 0
- DrawLevelElementAnimation(x, y, el2img(Feld[x][y]));
-#else
return;
-#endif
- else
- {
- if (MovDelay[x][y] == 0) /* next animation frame */
- MovDelay[x][y] = 11 * !SimpleRND(500);
- if (MovDelay[x][y] != 0) /* wait some time before next frame */
- {
- MovDelay[x][y]--;
+ if (MovDelay[x][y] == 0) /* next animation frame */
+ MovDelay[x][y] = 11 * !SimpleRND(500);
- if (setup.direct_draw && MovDelay[x][y])
- SetDrawtoField(DRAW_BUFFERED);
+ if (MovDelay[x][y] != 0) /* wait some time before next frame */
+ {
+ MovDelay[x][y]--;
-#if 0
- DrawGraphic(SCREENX(x), SCREENY(y), el2img(Feld[x][y]), 0);
-#else
- DrawLevelElementAnimation(x, y, Feld[x][y]);
-#endif
+ if (setup.direct_draw && MovDelay[x][y])
+ SetDrawtoField(DRAW_BUFFERED);
- if (MovDelay[x][y] != 0)
- {
- int frame = getGraphicAnimationFrame(IMG_TWINKLE_WHITE,
- 10 - MovDelay[x][y]);
+ DrawLevelElementAnimation(x, y, Feld[x][y]);
- DrawGraphicThruMask(SCREENX(x), SCREENY(y), IMG_TWINKLE_WHITE, frame);
+ if (MovDelay[x][y] != 0)
+ {
+ int frame = getGraphicAnimationFrame(IMG_TWINKLE_WHITE,
+ 10 - MovDelay[x][y]);
- if (setup.direct_draw)
- {
- int dest_x, dest_y;
+ DrawGraphicThruMask(SCREENX(x), SCREENY(y), IMG_TWINKLE_WHITE, frame);
- dest_x = FX + SCREENX(x) * TILEX;
- dest_y = FY + SCREENY(y) * TILEY;
+ if (setup.direct_draw)
+ {
+ int dest_x, dest_y;
- BlitBitmap(drawto_field, window,
- dest_x, dest_y, TILEX, TILEY, dest_x, dest_y);
- SetDrawtoField(DRAW_DIRECT);
- }
+ dest_x = FX + SCREENX(x) * TILEX;
+ dest_y = FY + SCREENY(y) * TILEY;
+
+ BlitBitmap(drawto_field, window,
+ dest_x, dest_y, TILEX, TILEY, dest_x, dest_y);
+ SetDrawtoField(DRAW_DIRECT);
}
}
}
{
static byte stored_player_action[MAX_PLAYERS];
static int num_stored_actions = 0;
-#if 0
- static boolean save_tape_entry = FALSE;
-#endif
boolean moved = FALSE, snapped = FALSE, bombed = FALSE;
int left = player_action & JOY_LEFT;
int right = player_action & JOY_RIGHT;
if (player_action)
{
-#if 0
- save_tape_entry = TRUE;
-#endif
- player->frame_reset_delay = 0;
-
if (button1)
snapped = SnapField(player, dx, dy);
else
}
}
-#if 0
- if (tape.recording && (moved || snapped || bombed))
- {
- if (bombed && !moved)
- player_action &= JOY_BUTTON;
-
- stored_player_action[player->index_nr] = player_action;
- save_tape_entry = TRUE;
- }
- else if (tape.playing && snapped)
- SnapField(player, 0, 0); /* stop snapping */
-#else
stored_player_action[player->index_nr] = player_action;
-#endif
}
else
{
SnapField(player, 0, 0);
CheckGravityMovement(player);
-#if 1
+ InitPlayerGfxAnimation(player, ACTION_DEFAULT);
+
if (player->MovPos == 0) /* needed for tape.playing */
player->is_moving = FALSE;
-#endif
-#if 0
- if (player->MovPos == 0) /* needed for tape.playing */
- player->last_move_dir = MV_NO_MOVING;
-
- /* !!! CHECK THIS AGAIN !!!
- (Seems to be needed for some EL_ROBOT stuff, but breaks
- tapes when walking through pipes!)
- */
-
- /* it seems that "player->last_move_dir" is misused as some sort of
- "player->is_just_moving_in_this_moment", which is needed for the
- robot stuff (robots don't kill players when they are moving)
- */
-#endif
-
- /* if the player does not move for some time, reset animation to start */
- if (++player->frame_reset_delay > player->move_delay_value)
- player->Frame = 0;
}
-#if 0
- if (tape.recording && num_stored_actions >= MAX_PLAYERS && save_tape_entry)
- {
- TapeRecordAction(stored_player_action);
- num_stored_actions = 0;
- save_tape_entry = FALSE;
- }
-#else
if (tape.recording && num_stored_actions >= MAX_PLAYERS)
{
TapeRecordAction(stored_player_action);
num_stored_actions = 0;
}
-#endif
-
-#if 0
- if (tape.playing && !tape.pausing && !player_action &&
- tape.counter < tape.length)
- {
- int jx = player->jx, jy = player->jy;
- int next_joy =
- tape.pos[tape.counter].action[player->index_nr] & (JOY_LEFT|JOY_RIGHT);
-
- if ((next_joy == JOY_LEFT || next_joy == JOY_RIGHT) &&
- (player->MovDir != JOY_UP && player->MovDir != JOY_DOWN))
- {
- int dx = (next_joy == JOY_LEFT ? -1 : +1);
-
- if (IN_LEV_FIELD(jx+dx, jy) && IS_PUSHABLE(Feld[jx+dx][jy]))
- {
- int el = Feld[jx+dx][jy];
- int push_delay = (IS_SB_ELEMENT(el) || el == EL_SATELLITE ? 2 :
- (el == EL_BALLOON || el == EL_SPRING) ? 0 : 10);
-
- if (tape.delay_played + push_delay >= tape.pos[tape.counter].delay)
- {
- player->MovDir = next_joy;
- player->Frame = FrameCounter % 4;
- player->Pushing = TRUE;
- }
- }
- }
- }
-#endif
}
void GameActions()
ScrollScreen(NULL, SCROLL_GO_ON);
-
-
-#ifdef DEBUG
-#if 0
- if (TimeFrames == 0 && local_player->active)
- {
- extern unsigned int last_RND();
-
- printf("DEBUG: %03d last RND was %d \t [state checksum is %d]\n",
- TimePlayed, last_RND(), getStateCheckSum(TimePlayed));
- }
-#endif
-#endif
-
-#ifdef DEBUG
-#if 0
- if (GameFrameDelay >= 500)
- printf("FrameCounter == %d\n", FrameCounter);
-#endif
-#endif
-
FrameCounter++;
TimeFrames++;
+ for (i=0; i<MAX_PLAYERS; i++)
+ stored_player[i].Frame++;
+
for (y=0; y<lev_fieldy; y++) for (x=0; x<lev_fieldx; x++)
{
Stop[x][y] = FALSE;
if (TimeLeft <= 10 && setup.time_limit)
PlaySoundStereo(SND_GAME_RUNNING_OUT_OF_TIME, SOUND_MAX_RIGHT);
- DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FONT_DEFAULT_SMALL);
if (!TimeLeft && setup.time_limit)
for (i=0; i<MAX_PLAYERS; i++)
KillHero(&stored_player[i]);
}
else if (level.time == 0 && !AllPlayersGone) /* level without time limit */
- DrawText(DX_TIME, DY_TIME, int2str(TimePlayed, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimePlayed, 3), FONT_DEFAULT_SMALL);
}
DrawAllPlayers();
}
}
- if (!(moved & MF_MOVING) && !player->Pushing)
- player->Frame = 0;
- else
#if 0
- player->Frame = (player->Frame + 1) % 4;
+#if 1
+ InitPlayerGfxAnimation(player, ACTION_DEFAULT);
#else
- player->Frame += 1 * 0;
+ if (!(moved & MF_MOVING) && !player->Pushing)
+ player->Frame = 0;
+#endif
#endif
if (moved & MF_MOVING)
{
player->actual_frame_counter = FrameCounter;
player->GfxPos = move_stepsize * (player->MovPos / move_stepsize);
- if (player->Frame)
- player->Frame += 1;
if (Feld[last_jx][last_jy] == EL_EMPTY)
Feld[last_jx][last_jy] = EL_PLAYER_IS_LEAVING;
player->MovPos += (player->MovPos > 0 ? -1 : 1) * move_stepsize;
player->GfxPos = move_stepsize * (player->MovPos / move_stepsize);
- player->Frame += 1;
if (Feld[last_jx][last_jy] == EL_PLAYER_IS_LEAVING)
Feld[last_jx][last_jy] = EL_EMPTY;
dy == +1 ? MV_DOWN : MV_NO_MOVING);
int element;
+ player->is_digging = FALSE;
+
if (player->MovPos == 0)
player->Pushing = FALSE;
RaiseScoreElement(element);
DrawText(DX_EMERALDS, DY_EMERALDS,
int2str(local_player->gems_still_needed, 3),
- FS_SMALL, FC_YELLOW);
+ FONT_DEFAULT_SMALL);
PlaySoundLevelElementAction(x, y, element, ACTION_COLLECTING);
break;
if (level.time > 0)
{
TimeLeft += 10;
- DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FONT_DEFAULT_SMALL);
}
PlaySoundStereo(SND_EXTRA_TIME_COLLECTING, SOUND_MAX_RIGHT);
break;
player->dynamite++;
RaiseScoreElement(EL_DYNAMITE);
DrawText(DX_DYNAMITE, DY_DYNAMITE,
- int2str(local_player->dynamite, 3),
- FS_SMALL, FC_YELLOW);
+ int2str(local_player->dynamite, 3), FONT_DEFAULT_SMALL);
PlaySoundLevelElementAction(x, y, element, ACTION_COLLECTING);
break;
case EL_KEY4:
{
int key_nr = element - EL_KEY1;
+ int graphic = el2edimg(element);
RemoveField(x, y);
player->key[key_nr] = TRUE;
RaiseScoreElement(element);
DrawMiniGraphicExt(drawto, DX_KEYS + key_nr * MINI_TILEX, DY_KEYS,
- IMG_KEY1 + key_nr);
+ graphic);
DrawMiniGraphicExt(window, DX_KEYS + key_nr * MINI_TILEX, DY_KEYS,
- IMG_KEY1 + key_nr);
+ graphic);
PlaySoundLevel(x, y, SND_KEY_COLLECTING);
break;
}
case EL_EM_KEY4:
{
int key_nr = element - EL_EM_KEY1;
+ int graphic = el2edimg(EL_KEY1 + key_nr);
RemoveField(x, y);
player->key[key_nr] = TRUE;
RaiseScoreElement(element);
DrawMiniGraphicExt(drawto, DX_KEYS + key_nr * MINI_TILEX, DY_KEYS,
- IMG_KEY1 + key_nr);
+ graphic);
DrawMiniGraphicExt(window, DX_KEYS + key_nr * MINI_TILEX, DY_KEYS,
- IMG_KEY1 + key_nr);
+ graphic);
PlaySoundLevel(x, y, SND_KEY_COLLECTING);
break;
}
case EL_SPRING:
if (mode == DF_SNAP)
return MF_NO_ACTION;
+
/* no "break" -- fall through to next case */
+
/* the following elements can be pushed by "snapping" */
case EL_BD_ROCK:
if (dy)
player->push_delay = FrameCounter;
#if 0
if (!FrameReached(&player->push_delay, player->push_delay_value) &&
- !tape.playing && element != EL_SPRING)
+ !tape.playing &&
+ element != EL_SPRING)
return MF_NO_ACTION;
#else
if (!FrameReached(&player->push_delay, player->push_delay_value) &&
case EL_TIME_ORB_FULL:
Feld[x][y] = EL_TIME_ORB_EMPTY;
TimeLeft += 10;
- DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FS_SMALL, FC_YELLOW);
+ DrawText(DX_TIME, DY_TIME, int2str(TimeLeft, 3), FONT_DEFAULT_SMALL);
DrawLevelField(x, y);
PlaySoundStereo(SND_TIME_ORB_FULL_COLLECTING, SOUND_MAX_RIGHT);
return MF_ACTION;
break;
default:
+ if (IS_PUSHABLE(element))
+ {
+ if (mode == DF_SNAP)
+ return MF_NO_ACTION;
+
+ if (CAN_FALL(element) && dy)
+ return MF_NO_ACTION;
+
+ player->Pushing = TRUE;
+
+ if (!IN_LEV_FIELD(x+dx, y+dy) || !IS_FREE(x+dx, y+dy))
+ return MF_NO_ACTION;
+
+ if (dx && real_dy)
+ {
+ if (IN_LEV_FIELD(jx, jy+real_dy) && !IS_SOLID(Feld[jx][jy+real_dy]))
+ return MF_NO_ACTION;
+ }
+ else if (dy && real_dx)
+ {
+ if (IN_LEV_FIELD(jx+real_dx, jy) && !IS_SOLID(Feld[jx+real_dx][jy]))
+ return MF_NO_ACTION;
+ }
+
+ if (player->push_delay == 0)
+ player->push_delay = FrameCounter;
+
+ if (!FrameReached(&player->push_delay, player->push_delay_value) &&
+ !(tape.playing && tape.file_version < FILE_VERSION_2_0))
+ return MF_NO_ACTION;
+
+ RemoveField(x, y);
+ Feld[x + dx][y + dy] = element;
+
+ player->push_delay_value = 2 + RND(8);
+
+ DrawLevelField(x + dx, y + dy);
+ PlaySoundLevelElementAction(x, y, element, ACTION_PUSHING);
+
+ break;
+ }
+
return MF_NO_ACTION;
}
player->push_delay = 0;
+ if (Feld[x][y] != element) /* really digged something */
+ player->is_digging = TRUE;
+
return MF_MOVING;
}
player->Pushing = FALSE;
player->snapped = FALSE;
+ player->is_digging = FALSE;
return FALSE;
}
return FALSE;
player->snapped = TRUE;
+ player->is_digging = FALSE;
DrawLevelField(x, y);
BackToFront();
player->dynamite--;
DrawText(DX_DYNAMITE, DY_DYNAMITE, int2str(local_player->dynamite, 3),
- FS_SMALL, FC_YELLOW);
+ FONT_DEFAULT_SMALL);
if (IN_SCR_FIELD(SCREENX(jx), SCREENY(jy)))
{
if (game.emulation == EMU_SUPAPLEX)
{
local_player->score += value;
DrawText(DX_SCORE, DY_SCORE, int2str(local_player->score, 5),
- FS_SMALL, FC_YELLOW);
+ FONT_DEFAULT_SMALL);
}
void RaiseScoreElement(int element)