diff options
Diffstat (limited to 'core/src/ch/asynk')
| -rw-r--r-- | core/src/ch/asynk/tankontank/screens/GameScreen.java | 23 | 
1 files changed, 11 insertions, 12 deletions
| diff --git a/core/src/ch/asynk/tankontank/screens/GameScreen.java b/core/src/ch/asynk/tankontank/screens/GameScreen.java index 736a499..ee52985 100644 --- a/core/src/ch/asynk/tankontank/screens/GameScreen.java +++ b/core/src/ch/asynk/tankontank/screens/GameScreen.java @@ -48,7 +48,7 @@ public class GameScreen implements Screen      private final FitViewport mapViewport;      private final Batch mapBatch; -    private final ShapeRenderer debugShapes; +    private ShapeRenderer debugShapes = null;      private final TankOnTank game;      private GameFactory factory; @@ -56,11 +56,9 @@ public class GameScreen implements Screen      private Hud hud;      private GameCtrl ctrl; -    private Vector2 screenToWorld = new Vector2();          // ratio -    private Vector3 touchPos = new Vector3();               // world coordinates -    private Vector2 dragPos = new Vector2();                // screen coordinates - -    private GridPoint2 cell = new GridPoint2(-1, -1);    // current map cell +    private Vector2 dragPos = new Vector2(); +    private Vector3 touchPos = new Vector3(); +    private Vector2 screenToWorld = new Vector2();      public GameScreen(final TankOnTank game)      { @@ -74,7 +72,6 @@ public class GameScreen implements Screen          virtualWidth = map.getWidth();          virtualHeight = map.getHeight(); -        mapBatch = new SpriteBatch();          cam = new OrthographicCamera(virtualWidth, virtualHeight);          cam.setToOrtho(false);          mapViewport = new FitViewport(virtualWidth, virtualHeight, cam); @@ -82,9 +79,10 @@ public class GameScreen implements Screen          ctrl = new GameCtrl(map); +        mapBatch = new SpriteBatch(); +        if (DEBUG) debugShapes = new ShapeRenderer(); +          factory.fakeSetup(map); -        // DEBUG -        debugShapes = new ShapeRenderer();          Gdx.input.setInputProcessor(getMultiplexer());      } @@ -151,7 +149,8 @@ public class GameScreen implements Screen      private void unproject(int x, int y, Vector3 v)      { -        cam.unproject(v.set(x, y, 0), mapViewport.getScreenX(), mapViewport.getScreenY(), mapViewport.getScreenWidth(), mapViewport.getScreenHeight()); +        cam.unproject(v.set(x, y, 0), mapViewport.getScreenX(), mapViewport.getScreenY(), +                mapViewport.getScreenWidth(), mapViewport.getScreenHeight());      }      private void clampCameraPos() @@ -196,7 +195,7 @@ public class GameScreen implements Screen          // Gdx.app.debug("GameScreen", "resize (" + width + "," + height + ")");          mapViewport.update(width, height); -        maxZoomOut = Math.min((map.getWidth() / cam.viewportWidth), (map.getHeight() / cam.viewportHeight)); +        maxZoomOut = Math.min((virtualWidth / cam.viewportWidth), (virtualHeight / cam.viewportHeight));          cam.zoom = MathUtils.clamp(cam.zoom, ZOOM_IN_MAX, maxZoomOut);          screenToWorld.set((cam.viewportWidth / width), (cam.viewportHeight / height)); @@ -211,7 +210,7 @@ public class GameScreen implements Screen          factory.dispose();          game.unloadAssets();          mapBatch.dispose(); -        debugShapes.dispose(); +        if (DEBUG) debugShapes.dispose();      }      @Override | 
