From a2b46eee6f0c33645f749af14ca1e9eb53614904 Mon Sep 17 00:00:00 2001 From: Anuken Date: Thu, 4 Apr 2019 18:58:48 -0400 Subject: [PATCH] Improved pixel zoom / Possible player duplicate glitch --- core/src/io/anuke/mindustry/core/NetClient.java | 5 +++++ .../io/anuke/mindustry/graphics/Pixelator.java | 17 ++++------------- 2 files changed, 9 insertions(+), 13 deletions(-) diff --git a/core/src/io/anuke/mindustry/core/NetClient.java b/core/src/io/anuke/mindustry/core/NetClient.java index 1a873bc539..9d3289eac2 100644 --- a/core/src/io/anuke/mindustry/core/NetClient.java +++ b/core/src/io/anuke/mindustry/core/NetClient.java @@ -213,6 +213,11 @@ public class NetClient implements ApplicationListener{ SyncTrait entity = (SyncTrait) group.getByID(id); boolean add = false; + if(entity == null && id == player.id){ + entity = player; + add = true; + } + //entity must not be added yet, so create it if(entity == null){ entity = (SyncTrait) TypeTrait.getTypeByID(typeID).get(); //create entity from supplier diff --git a/core/src/io/anuke/mindustry/graphics/Pixelator.java b/core/src/io/anuke/mindustry/graphics/Pixelator.java index 46d37e8212..afc4b91cd8 100644 --- a/core/src/io/anuke/mindustry/graphics/Pixelator.java +++ b/core/src/io/anuke/mindustry/graphics/Pixelator.java @@ -4,7 +4,6 @@ import io.anuke.arc.Core; import io.anuke.arc.graphics.Blending; import io.anuke.arc.graphics.g2d.Draw; import io.anuke.arc.graphics.glutils.FrameBuffer; -import io.anuke.arc.math.Mathf; import io.anuke.arc.util.Disposable; import io.anuke.mindustry.entities.type.Player; @@ -15,21 +14,12 @@ import static io.anuke.mindustry.Vars.renderer; public class Pixelator implements Disposable{ private FrameBuffer buffer = new FrameBuffer(2, 2); - private float lastScale = -1; public void drawPixelate(){ + float pre = renderer.getScale(); float scale = renderer.getScale(); - if(lastScale > 0){ - //going smaller - if(scale < lastScale){ - scale = (int)scale; - }else if(scale > lastScale){ - scale = Mathf.ceil(scale); - - } - renderer.setScale(scale); - } - lastScale = renderer.getScale(); + scale = (int)scale; + renderer.setScale(scale); camera.width = (int)camera.width; camera.height = (int)camera.height; @@ -65,6 +55,7 @@ public class Pixelator implements Disposable{ Core.camera.position.set(px, py); Core.settings.put("animatedwater", hadWater); Core.settings.put("animatedshields", hadShields); + renderer.setScale(pre); } public void rebind(){