From 50a8aa3a4d2a48f38c26b8153625b9d3dbfb484a Mon Sep 17 00:00:00 2001 From: Stephane Dallongeville Date: Fri, 3 Jan 2025 11:36:53 +0100 Subject: [PATCH] Added COLUMN_AHEAD and ROW_AHEAD definition so we can easily customize them if needed. --- inc/sys.h | 4 ++-- src/map.c | 37 +++++++++++++++++++++---------------- 2 files changed, 23 insertions(+), 18 deletions(-) diff --git a/inc/sys.h b/inc/sys.h index 4f9bd552..3d267ef5 100644 --- a/inc/sys.h +++ b/inc/sys.h @@ -37,7 +37,7 @@ * \brief * To force no inlining for this method */ -#define NO_INLINE __attribute__ ((noinline)) +#define NO_INLINE __attribute__((noinline)) /** * \brief @@ -49,7 +49,7 @@ * \brief * Declare function for the hint callback (generate a RTE to return from interrupt instead of RTS) */ -#define HINTERRUPT_CALLBACK __attribute__ ((interrupt)) void +#define HINTERRUPT_CALLBACK __attribute__((interrupt)) void // exist through rom_head.c diff --git a/src/map.c b/src/map.c index bdd740f2..50183d9d 100644 --- a/src/map.c +++ b/src/map.c @@ -13,6 +13,11 @@ //#define MAP_DEBUG //#define MAP_PROFIL +// max screen width = 320 - (320 / 16) = 20 +#define COLUMN_AHEAD (20 + 1) +// max screen heigth = 240 - (240 / 16) = 15 +#define ROW_AHEAD (15 + 1) + // we don't want to share it extern vu16 VBlankProcess; @@ -295,34 +300,34 @@ static void updateMap(Map* map, s16 xt, s16 yt) #endif // clip to 16 metatiles row max (full screen update) - if (deltaY > 16) + if (deltaY > ROW_AHEAD) { - cyt += deltaY - 16; - deltaY = 16; + cyt += deltaY - ROW_AHEAD; + deltaY = ROW_AHEAD; // as we have a full screen update, we don't need column update then deltaX = 0; } // clip to 16 metatiles row max (full screen update) - else if (deltaY < -16) + else if (deltaY < -ROW_AHEAD) { - cyt += deltaY + 16; - deltaY = -16; + cyt += deltaY + ROW_AHEAD; + deltaY = -ROW_AHEAD; // as we have a full screen update, we don't need column update then deltaX = 0; } // clip to 21 metatiles column max (full screen update) - else if (deltaX > 21) + else if (deltaX > COLUMN_AHEAD) { - cxt += deltaX - 21; - deltaX = 21; + cxt += deltaX - COLUMN_AHEAD; + deltaX = COLUMN_AHEAD; // as we have a full screen update, we don't need row update then deltaY = 0; } // clip to 21 metatiles column max (full screen update) - else if (deltaX < -21) + else if (deltaX < -COLUMN_AHEAD) { - cxt += deltaX + 21; - deltaX = -21; + cxt += deltaX + COLUMN_AHEAD; + deltaX = -COLUMN_AHEAD; // as we have a full screen update, we don't need row update then deltaY = 0; } @@ -330,7 +335,7 @@ static void updateMap(Map* map, s16 xt, s16 yt) if (deltaX > 0) { // update on right - cxt += 21; + cxt += COLUMN_AHEAD; // need to update map column on right while(deltaX--) @@ -352,7 +357,7 @@ static void updateMap(Map* map, s16 xt, s16 yt) if (deltaY > 0) { // update on bottom - cyt += 16; + cyt += ROW_AHEAD; // need to update map row on bottom while(deltaY--) @@ -414,7 +419,7 @@ static void setMapColumn(Map *map, u16 column, u16 x, u16 y) #endif // 16 metatile = 32 tiles = 256 pixels (full screen height + 16 pixels) - const u16 h = 16; + const u16 h = ROW_AHEAD; // clip Y against plane size const u16 yAdj = y & map->planeHeightMaskAdj; // get plane height @@ -471,7 +476,7 @@ static void setMapRow(Map *map, u16 row, u16 x, u16 y) #endif // 21 metatile = 42 tiles = 336 pixels (full screen width + 16 pixels) - u16 w = 21; + u16 w = COLUMN_AHEAD; // clip X against plane size const u16 xAdj = x & map->planeWidthMaskAdj; // get plane width (metatile)