fixed name of element 'beamer' to 'teleporter'
[rocksndiamonds.git] / src / game_sp / DDSpriteBuffer.c
index 9377eac3f2d7679cffea8567f5624c0f748d91ac..261459adbd04ee65f594eeee4448b4c5ded80412 100644 (file)
@@ -11,14 +11,10 @@ static void Blt(int pX, int pY, Bitmap *bitmap, int SpriteX, int SpriteY)
   int scy = (mScrollY_last < 0 ? 0 : mScrollY_last);
   int sx1 = scx - 2 * TILEX;
   int sy1 = scy - 2 * TILEY;
-  int sx2 = scx + SXSIZE + 1 * TILEX;
-  int sy2 = scy + SYSIZE + 1 * TILEY;
+  int sx2 = scx + (SCR_FIELDX + 1) * TILEX;
+  int sy2 = scy + (SCR_FIELDY + 1) * TILEY;
   int sx = pX - sx1;
   int sy = pY - sy1;
-  int tile_x = sx / TILESIZE;
-  int tile_y = sy / TILESIZE;
-  int move_x = (sx + TILESIZE - 1) / TILESIZE;
-  int move_y = (sy + TILESIZE - 1) / TILESIZE;
 
   if (NoDisplayFlag)
     return;
@@ -27,22 +23,11 @@ static void Blt(int pX, int pY, Bitmap *bitmap, int SpriteX, int SpriteY)
   if (pX < sx1 || pX > sx2 || pY < sy1 || pY > sy2)
     return;
 
+  sx = sx * TILESIZE_VAR / TILESIZE;
+  sy = sy * TILESIZE_VAR / TILESIZE;
+
   BlitBitmap(bitmap, bitmap_db_field_sp, SpriteX, SpriteY,
-            TILEX, TILEY, sx, sy);
-
-  redraw[tile_x][tile_y] = TRUE;
-  redraw_tiles++;
-
-  if (move_x != tile_x)
-  {
-    redraw[move_x][tile_y] = TRUE;
-    redraw_tiles++;
-  }
-  else if (move_y != tile_y)
-  {
-    redraw[tile_x][move_y] = TRUE;
-    redraw_tiles++;
-  }
+            TILEX_VAR, TILEY_VAR, sx, sy);
 }
 
 void DDSpriteBuffer_BltImg(int pX, int pY, int graphic, int sync_frame)