123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- package pathgame.rendering;
- import me.hammerle.snuviengine.api.Renderer;
- import pathgame.gameplay.Camera;
- import pathgame.gameplay.Gamestate;
- import pathgame.gameplay.Gamestates;
- import pathgame.gameplay.Level;
- import pathgame.gameplay.Player;
- import pathgame.tilemap.TileMap;
- public class LevelRenderer
- {
- private final PlayerRenderer playerRenderer = new PlayerRenderer();
- private final TileMapRenderer mapRenderer = new TileMapRenderer();
- private final HUDRenderer hudRenderer = new HUDRenderer();
- private final Camera cam = new Camera();
- private final ScoreMenuRenderer scoreRenderer = new ScoreMenuRenderer();
- public void tick(Level level, Gamestate gamestate)
- {
- cam.tick(level, gamestate);
- mapRenderer.tick();
- if(level.getPlayer().isMoving())
- {
- cam.reset();
- }
- }
- public void renderTick(Renderer r, float lag, Level level, Gamestate gamestate)
- {
- TileMap map = level.getMap();
- Player player = level.getPlayer();
- float zoomRestrictionX = r.getViewWidth() / (map.getWidth() * TileRenderer.TILE_SIZE);
- float zoomRestrictionY = (r.getViewHeight() - HUDRenderer.OFFSET_Y) / (map.getHeight() * TileRenderer.TILE_SIZE);
- cam.limitScale(Math.max(zoomRestrictionX, zoomRestrictionY));
- float interScale = cam.getInterpolatedScale(lag);
- mapRenderer.setScale(interScale);
- float offX = getMapOffsetX(map, player, r, lag, interScale);
- float offY = getMapOffsetY(map, player, r, lag, interScale) + HUDRenderer.OFFSET_Y;
- mapRenderer.renderTick(map, r, false, offX, offY);
- if(gamestate.is(Gamestates.GAMEPLAY))
- {
- playerRenderer.renderTick(map, mapRenderer, r, player, lag, offX, offY);
- if(!level.getShowScoreMenu())
- {
- hudRenderer.renderTick(r, player, lag);
- }
- else if(level.getShowScoreMenu())
- {
- scoreRenderer.renderTick(r, lag, level);
- }
- }
- }
- private float getMapOffsetX(TileMap map, Player player, Renderer r, float lag, float interScale)
- {
- float ix = (player.getLastX() + (player.getX() - player.getLastX()) * lag) * interScale * TileRenderer.TILE_SIZE;
- float offX = (-ix + r.getViewWidth() * 0.5f) - TileRenderer.TILE_SIZE * 0.5f * interScale;
- float minOffX = -mapRenderer.getWidth(map) + r.getViewWidth();
- if(offX < minOffX)
- {
- return cam.getCamOffsetX(minOffX, minOffX, lag, interScale);
- }
- else if(offX > 0.0f)
- {
- return cam.getCamOffsetX(0.0f, minOffX, lag, interScale);
- }
- return cam.getCamOffsetX(offX, minOffX, lag, interScale);
- }
- private float getMapOffsetY(TileMap map, Player player, Renderer r, float lag, float interScale)
- {
- float viewHeight = r.getViewHeight() - HUDRenderer.OFFSET_Y;
- float iy = (player.getLastY() + (player.getY() - player.getLastY()) * lag) * interScale * TileRenderer.TILE_SIZE;
- float offY = (-iy + viewHeight * 0.5f) - TileRenderer.TILE_SIZE * 0.5f * interScale;
- float minOffY = -mapRenderer.getHeight(map) + viewHeight;
- if(offY < minOffY)
- {
- return cam.getCamOffsetY(minOffY, minOffY, lag, interScale);
- }
- else if(offY > 0.0f)
- {
- return cam.getCamOffsetY(0.0f, minOffY, lag, interScale);
- }
- return cam.getCamOffsetY(offY, minOffY, lag, interScale);
- }
- }
|