From 9bff111ef7d4c976b7d749252b5ccc67b118bc5d Mon Sep 17 00:00:00 2001 From: Sesu8642 <45859254+Sesu8642@users.noreply.github.com> Date: Sun, 1 Dec 2024 14:05:32 +0100 Subject: [PATCH] add workaround for animation speed changing / stopping closes #90 --- .../feudaltactics/renderer/MapRenderer.java | 29 +++++++++++++++---- 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/core/src/main/java/de/sesu8642/feudaltactics/renderer/MapRenderer.java b/core/src/main/java/de/sesu8642/feudaltactics/renderer/MapRenderer.java index abf9120..ca5c2e1 100644 --- a/core/src/main/java/de/sesu8642/feudaltactics/renderer/MapRenderer.java +++ b/core/src/main/java/de/sesu8642/feudaltactics/renderer/MapRenderer.java @@ -40,6 +40,14 @@ */ public class MapRenderer { + /** + * If the stateTime reaches this value, it will be reduced by this value. + * The reason is that the stateTime must stay relatively small because of float limitations. + * See https://github.com/libgdx/libgdx/issues/7536. + * The subtracted amount must be a multiple of the animation duration. + * Equal to one day in seconds. + */ + private static final float STATE_TIME_THRESHOLD = 24 * 60 * 60f; public static final float SPRITE_SIZE_MULTIPLIER = 1.05F; public static final float LINE_EXTENSION = 0.14F; public static final float WATER_TILE_SIZE = 12; @@ -379,7 +387,7 @@ public synchronized void render() { HashMap frames = new HashMap<>(); // current frame for each map object HashMap darkenedFrames = new HashMap<>(); // current frame for each map object spriteBatch.setProjectionMatrix(camera.combined); - stateTime += Gdx.graphics.getDeltaTime(); + updateStateTime(Gdx.graphics.getDeltaTime()); // get the correct frames for (Entry> content : animatedContents.entrySet()) { frames.put(content.getKey(), (content.getValue()).getKeyFrame(stateTime, true)); @@ -631,14 +639,23 @@ public void placeCameraForFullMapView(GameState gameState, long marginLeftPx, lo camera.update(); } + /** + * See {@link MapRenderer#STATE_TIME_THRESHOLD} + */ + private void updateStateTime(float delta) { + stateTime += delta; + if (stateTime >= STATE_TIME_THRESHOLD) { + stateTime -= STATE_TIME_THRESHOLD; + } + } + + /** + * Disposes all the disposables used. + */ public void dispose() { spriteBatch.dispose(); } - - public void resize() { - spriteBatch.getProjectionMatrix().setToOrtho2D(0, 0, HEXTILE_WIDTH, HEXTILE_HEIGHT); - } - + private class DrawTile { Vector2 mapCoords; Color color;