From 834fc2df0f6ef92baf90bc672f904b4423d23c56 Mon Sep 17 00:00:00 2001 From: klei1984 <53688147+klei1984@users.noreply.github.com> Date: Sat, 29 Jun 2024 22:20:40 +0200 Subject: [PATCH] Corrected a reimplementation issue. - Path markers were drawn even if they were off screen. --- src/searcher.cpp | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) diff --git a/src/searcher.cpp b/src/searcher.cpp index e8cac18..cdbdf15 100644 --- a/src/searcher.cpp +++ b/src/searcher.cpp @@ -41,24 +41,23 @@ void Searcher_DrawMarker(int32_t angle, int32_t grid_x, int32_t grid_y, int32_t window = WindowManager_GetWindow(WINDOW_MAIN_MAP); - pixel_x = grid_x * 64 + 32; - pixel_y = grid_y * 64 + 32; + grid_x = grid_x * 64 + 32; + grid_y = grid_y * 64 + 32; - if (pixel_x < GameManager_MapWindowDrawBounds.lrx && pixel_x > GameManager_MapWindowDrawBounds.ulx && - pixel_y < GameManager_MapWindowDrawBounds.lry && pixel_y > GameManager_MapWindowDrawBounds.uly) { - } - - grid_x = (pixel_x << 16) / Gfx_MapScalingFactor - Gfx_MapWindowUlx; - grid_y = (pixel_y << 16) / Gfx_MapScalingFactor - Gfx_MapWindowUly; + if (grid_x < GameManager_MapWindowDrawBounds.lrx && grid_x > GameManager_MapWindowDrawBounds.ulx && + grid_y < GameManager_MapWindowDrawBounds.lry && grid_y > GameManager_MapWindowDrawBounds.uly) { + pixel_x = (grid_x << 16) / Gfx_MapScalingFactor - Gfx_MapWindowUlx; + pixel_y = (grid_y << 16) / Gfx_MapScalingFactor - Gfx_MapWindowUly; - Paths_DrawMarker(window, angle, grid_x, grid_y, color); + Paths_DrawMarker(window, angle, pixel_x, pixel_y, color); - bounds.ulx = window->window.ulx + grid_x - (Gfx_ZoomLevel / 2); - bounds.uly = window->window.uly + grid_y - (Gfx_ZoomLevel / 2); - bounds.lrx = bounds.ulx + Gfx_ZoomLevel; - bounds.lry = bounds.uly + Gfx_ZoomLevel; + bounds.ulx = window->window.ulx + pixel_x - (Gfx_ZoomLevel / 2); + bounds.uly = window->window.uly + pixel_y - (Gfx_ZoomLevel / 2); + bounds.lrx = bounds.ulx + Gfx_ZoomLevel; + bounds.lry = bounds.uly + Gfx_ZoomLevel; - win_draw_rect(window->id, &bounds); + win_draw_rect(window->id, &bounds); + } } int32_t Searcher_EvaluateCost(const Point position, const Point new_position, const bool air_support) {