-/***********************************************************
-* Mirror Magic -- McDuffin's Revenge *
-*----------------------------------------------------------*
-* (c) 1994-2001 Artsoft Entertainment *
-* Holger Schemel *
-* Detmolder Strasse 189 *
-* 33604 Bielefeld *
-* Germany *
-* e-mail: info@artsoft.org *
-*----------------------------------------------------------*
-* tools.c *
-***********************************************************/
+// ============================================================================
+// Mirror Magic -- McDuffin's Revenge
+// ----------------------------------------------------------------------------
+// (c) 1994-2017 by Artsoft Entertainment
+// Holger Schemel
+// info@artsoft.org
+// http://www.artsoft.org/
+// ----------------------------------------------------------------------------
+// mm_tools.c
+// ============================================================================
#include "main_mm.h"
#include "mm_tools.h"
-void ClearWindow()
+void SetDrawtoField_MM(int mode)
+{
+ int full_xsize = lev_fieldx * TILESIZE_VAR;
+ int full_ysize = lev_fieldy * TILESIZE_VAR;
+
+ // distance (delta) from screen border (SX/SY) to centered level playfield
+ dSX = (full_xsize < SXSIZE ? (SXSIZE - full_xsize) / 2 : 0);
+ dSY = (full_ysize < SYSIZE ? (SYSIZE - full_ysize) / 2 : 0);
+
+ // for convenience, absolute screen position to centered level playfield
+ cSX = SX + dSX;
+ cSY = SY + dSY;
+ cSX2 = SX + dSX + 2; // including playfield border
+ cSY2 = SY + dSY + 2; // including playfield border
+
+ if (mode == DRAW_TO_BACKBUFFER)
+ {
+ cFX = FX + dSX;
+ cFY = FY + dSY;
+ }
+
+ SetTileCursorSXSY(cSX, cSY);
+}
+
+void ClearWindow(void)
{
ClearRectangle(backbuffer, REAL_SX, REAL_SY, FULL_SXSIZE, FULL_SYSIZE);
- SetDrawtoField(DRAW_BACKBUFFER);
+ SetDrawtoField(DRAW_TO_BACKBUFFER);
+ SetDrawtoField_MM(DRAW_TO_BACKBUFFER);
redraw_mask |= REDRAW_FIELD;
}
getGraphicSource(graphic, frame, &bitmap, &src_x, &src_y);
BlitBitmap(bitmap, drawto_field, src_x, src_y, TILEX, TILEY,
- FX + x * TILEX, FY + y * TILEY);
+ cFX + x * TILEX, cFY + y * TILEY);
}
void DrawGraphic_MM(int x, int y, int graphic)
}
#endif
- DrawGraphicExt_MM(drawto_field, FX + x*TILEX, FY + y*TILEY, graphic);
+ DrawGraphicExt_MM(drawto_field, cFX + x * TILEX, cFY + y * TILEY, graphic);
+
MarkTileDirty(x, y);
}
int src_x, src_y;
getGraphicSource(graphic, 0, &bitmap, &src_x, &src_y);
+
BlitBitmap(bitmap, d, src_x, src_y, TILEX, TILEY, x, y);
}
}
#endif
- DrawGraphicThruMaskExt_MM(drawto_field, FX + x*TILEX, FY + y*TILEY, graphic);
+ DrawGraphicThruMaskExt_MM(drawto_field, cFX + x * TILEX, cFY + y * TILEY,
+ graphic);
+
MarkTileDirty(x,y);
}
void DrawMiniGraphic_MM(int x, int y, int graphic)
{
- DrawMiniGraphicExt_MM(drawto, SX + x*MINI_TILEX, SY + y*MINI_TILEY, graphic);
- MarkTileDirty(x/2, y/2);
+ DrawMiniGraphicExt_MM(drawto, cSX + x * MINI_TILEX, cSY + y * MINI_TILEY,
+ graphic);
+
+ MarkTileDirty(x / 2, y / 2);
}
-void getMicroGraphicSource(int graphic, Bitmap **bitmap, int *x, int *y)
+#if 0
+static void getMicroGraphicSource(int graphic, Bitmap **bitmap, int *x, int *y)
{
getSizedGraphicSource(graphic, 0, TILESIZE / 4, bitmap, x, y);
}
+#endif
void DrawMiniGraphicExt_MM(DrawBuffer *d, int x, int y, int graphic)
{
int src_x, src_y;
getMiniGraphicSource(graphic, &bitmap, &src_x, &src_y);
+
BlitBitmap(bitmap, d, src_x, src_y, MINI_TILEX, MINI_TILEY, x, y);
}
if (graphic < 0)
{
DrawGraphic_MM(x, y, graphic);
+
return;
}
- if (dx || dy) /* Verschiebung der Grafik? */
+ if (dx || dy) // Verschiebung der Grafik?
{
- if (x < BX1) /* Element kommt von links ins Bild */
+ if (x < BX1) // Element kommt von links ins Bild
{
x = BX1;
width = dx;
cx = TILEX - dx;
dx = 0;
}
- else if (x > BX2) /* Element kommt von rechts ins Bild */
+ else if (x > BX2) // Element kommt von rechts ins Bild
{
x = BX2;
width = -dx;
dx = TILEX + dx;
}
- else if (x==BX1 && dx < 0) /* Element verläßt links das Bild */
+ else if (x==BX1 && dx < 0) // Element verläßt links das Bild
{
width += dx;
cx = -dx;
dx = 0;
}
- else if (x==BX2 && dx > 0) /* Element verläßt rechts das Bild */
+ else if (x==BX2 && dx > 0) // Element verläßt rechts das Bild
width -= dx;
- else if (dx) /* allg. Bewegung in x-Richtung */
+ else if (dx) // allg. Bewegung in x-Richtung
MarkTileDirty(x + SIGN(dx), y);
- if (y < BY1) /* Element kommt von oben ins Bild */
+ if (y < BY1) // Element kommt von oben ins Bild
{
- if (cut_mode==CUT_BELOW) /* Element oberhalb des Bildes */
+ if (cut_mode==CUT_BELOW) // Element oberhalb des Bildes
return;
y = BY1;
cy = TILEY - dy;
dy = 0;
}
- else if (y > BY2) /* Element kommt von unten ins Bild */
+ else if (y > BY2) // Element kommt von unten ins Bild
{
y = BY2;
height = -dy;
dy = TILEY + dy;
}
- else if (y==BY1 && dy < 0) /* Element verläßt oben das Bild */
+ else if (y==BY1 && dy < 0) // Element verläßt oben das Bild
{
height += dy;
cy = -dy;
}
else if (dy > 0 && cut_mode == CUT_ABOVE)
{
- if (y == BY2) /* Element unterhalb des Bildes */
+ if (y == BY2) // Element unterhalb des Bildes
return;
height = dy;
cy = TILEY - dy;
dy = TILEY;
MarkTileDirty(x, y + 1);
- } /* Element verläßt unten das Bild */
+ } // Element verläßt unten das Bild
else if (dy > 0 && (y == BY2 || cut_mode == CUT_BELOW))
+ {
height -= dy;
- else if (dy) /* allg. Bewegung in y-Richtung */
+ }
+ else if (dy) // allg. Bewegung in y-Richtung
+ {
MarkTileDirty(x, y + SIGN(dy));
+ }
}
getGraphicSource(graphic, 0, &src_bitmap, &src_x, &src_y);
src_x += cx;
src_y += cy;
- dest_x = FX + x * TILEX + dx;
- dest_y = FY + y * TILEY + dy;
+ dest_x = cFX + x * TILEX + dx;
+ dest_y = cFY + y * TILEY + dy;
#if DEBUG
if (!IN_SCR_FIELD(x,y))
#endif
if (mask_mode == USE_MASKING)
- {
BlitBitmapMasked(src_bitmap, drawto_field,
src_x, src_y, TILEX, TILEY, dest_x, dest_y);
- }
else
BlitBitmap(src_bitmap, drawto_field,
src_x, src_y, width, height, dest_x, dest_y);
void DrawGraphicShiftedThruMask_MM(int x,int y, int dx,int dy, int graphic,
int cut_mode)
{
- DrawGraphicShifted_MM(x,y, dx,dy, graphic, cut_mode, USE_MASKING);
+ DrawGraphicShifted_MM(x, y, dx, dy, graphic, cut_mode, USE_MASKING);
}
void DrawScreenElementExt_MM(int x, int y, int dx, int dy, int element,
int horiz_move;
Blocked2Moving(x, y, &oldx, &oldy);
+
sx = SCREENX(oldx);
sy = SCREENY(oldy);
horiz_move = (MovDir[oldx][oldy] == MV_LEFT ||
MovDir[oldx][oldy] == MV_RIGHT);
DrawScreenElement_MM(x, y, EL_EMPTY);
+
element = Feld[oldx][oldy];
if (horiz_move)
- DrawScreenElementShifted_MM(sx,sy, MovPos[oldx][oldy],0,element,NO_CUTTING);
+ DrawScreenElementShifted_MM(sx, sy, MovPos[oldx][oldy], 0, element,
+ NO_CUTTING);
else
- DrawScreenElementShifted_MM(sx,sy, 0,MovPos[oldx][oldy],element,NO_CUTTING);
+ DrawScreenElementShifted_MM(sx, sy, 0, MovPos[oldx][oldy], element,
+ NO_CUTTING);
}
else if (IS_DRAWABLE(element))
+ {
DrawScreenElement_MM(x, y, element);
+ }
else
+ {
DrawScreenElement_MM(x, y, EL_EMPTY);
+ }
}
void DrawLevelField_MM(int x, int y)
if (!element)
{
DrawMiniGraphic_MM(x, y, IMG_EMPTY);
+
return;
}
graphic = el2gfx(element);
+
DrawMiniGraphic_MM(x, y, graphic);
}
DrawElement_MM(x, y, element);
}
-void DrawLevel_MM()
+void DrawLevel_MM(void)
{
int x,y;
ClearWindow();
- for (x=0; x<lev_fieldx; x++)
- for (y=0; y<lev_fieldy; y++)
+ for (x = 0; x < lev_fieldx; x++)
+ for (y = 0; y < lev_fieldy; y++)
DrawField_MM(x, y);
redraw_mask |= REDRAW_FIELD;
getMiniGraphicSource(graphic, &bitmap, &gx, &gy);
- if (game_status != LEVELED || !editor.draw_walls_masked)
- DrawGraphic_MM(x, y, IMG_EMPTY);
+ DrawGraphic_MM(x, y, IMG_EMPTY);
/*
if (IS_WALL_WOOD(element) || IS_WALL_AMOEBA(element) ||
gy += MINI_TILEY;
*/
- for(i=0; i<4; i++)
+ for (i = 0; i < 4; i++)
{
- int dest_x = SX + x * TILEX + MINI_TILEX * (i % 2);
- int dest_y = SY + y * TILEY + MINI_TILEY * (i / 2);
+ int dest_x = cSX + x * TILEX + MINI_TILEX * (i % 2);
+ int dest_y = cSY + y * TILEY + MINI_TILEY * (i / 2);
if (!((1 << i) & draw_mask))
continue;
if (element & (1 << i))
BlitBitmap(bitmap, drawto, gx, gy, MINI_TILEX, MINI_TILEY,
dest_x, dest_y);
- else if (!editor.draw_walls_masked)
+ else
ClearRectangle(drawto, dest_x, dest_y, MINI_TILEX, MINI_TILEY);
}
int frame;
Bitmap *bitmap;
int src_x, src_y;
- int dst_x = SX + x * TILEX + (i % 2) * MINI_TILEX;
- int dst_y = SY + y * TILEY + (i / 2) * MINI_TILEY;
+ int dst_x = cSX + x * TILEX + (i % 2) * MINI_TILEX;
+ int dst_y = cSY + y * TILEY + (i / 2) * MINI_TILEY;
if (bit_mask & (1 << i))
{
#endif
else if (element == EL_PACMAN)
DrawLevelField_MM(x, y);
+ else if (element == EL_FUSE_ON &&
+ laser.fuse_off &&
+ laser.fuse_x == x &&
+ laser.fuse_y == y)
+ DrawGraphic_MM(x, y, IMG_MM_FUSE);
else
DrawGraphic_MM(x, y, el2gfx(element));
}
-void DrawMicroWalls_MM(int x, int y, int element)
+#if 0
+static void DrawMicroWalls_MM(int x, int y, int element)
{
Bitmap *bitmap;
int graphic = el2gfx(WALL_BASE(element));
getMicroGraphicSource(graphic, &bitmap, &gx, &gy);
- for (i=0; i<4; i++)
+ for (i = 0; i < 4; i++)
{
int xpos = MICROLEV_XPOS + x * MICRO_TILEX + MICRO_WALLX * (i % 2);
int ypos = MICROLEV_YPOS + y * MICRO_TILEY + MICRO_WALLY * (i / 2);
}
}
-void DrawMicroElement_MM(int x, int y, int element)
+static void DrawMicroElement_MM(int x, int y, int element)
{
Bitmap *bitmap;
int graphic = el2gfx(element);
if (IS_WALL(element))
{
DrawMicroWalls_MM(x, y, element);
+
return;
}
MICROLEV_XPOS + x * MICRO_TILEX, MICROLEV_YPOS + y * MICRO_TILEY);
}
-void DrawMicroLevelExt_MM(int xpos, int ypos)
+static void DrawMicroLevelExt_MM(int xpos, int ypos)
{
- int x,y;
+ int x, y;
ClearRectangle(drawto, xpos, ypos, MICROLEV_XSIZE, MICROLEV_YSIZE);
- for (x=0; x<STD_LEV_FIELDX; x++)
- for (y=0; y<STD_LEV_FIELDY; y++)
+ for (x = 0; x < STD_LEV_FIELDX; x++)
+ for (y = 0; y < STD_LEV_FIELDY; y++)
DrawMicroElement_MM(x, y, Ur[x][y]);
redraw_mask |= REDRAW_FIELD;
}
+#endif
void DrawMiniLevel_MM(int size_x, int size_y, int scroll_x, int scroll_y)
{
- int x,y;
+ int x, y;
- for(x=0; x<size_x; x++)
- for(y=0; y<size_y; y++)
+ for (x = 0; x < size_x; x++)
+ for (y = 0; y < size_y; y++)
DrawMiniElementOrWall_MM(x, y, scroll_x, scroll_y);
redraw_mask |= REDRAW_FIELD;
}
-int REQ_in_range(int x, int y)
+#if 0
+static int REQ_in_range(int x, int y)
{
- if (y > DY+249 && y < DY+278)
+ if (y > DY + 249 && y < DY + 278)
{
- if (x > DX+1 && x < DX+48)
+ if (x > DX + 1 && x < DX + 48)
return 1;
- else if (x > DX+51 && x < DX+98)
+ else if (x > DX + 51 && x < DX + 98)
return 2;
}
+
return 0;
}
+#endif
Pixel ReadPixel(DrawBuffer *bitmap, int x, int y)
{
}
}
-void RedrawPlayfield_MM()
+void RedrawPlayfield_MM(void)
{
DrawLevel_MM();
+ DrawLaser_MM();
}
void BlitScreenToBitmap_MM(Bitmap *target_bitmap)