Bridge sprite cleanup

This commit is contained in:
Anuken 2019-02-21 17:16:42 -05:00
parent 9c240850b8
commit b0126206e1
5 changed files with 32 additions and 23 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 MiB

After

Width:  |  Height:  |  Size: 1.1 MiB

View File

@ -219,6 +219,7 @@ public abstract class Unit extends DestructibleEntity implements SaveTrait, Targ
return status.hasEffect(effect); return status.hasEffect(effect);
} }
//TODO optimize
public void avoidOthers(float scaling){ public void avoidOthers(float scaling){
hitbox(queryRect); hitbox(queryRect);
queryRect.setSize(queryRect.getWidth() * scaling); queryRect.setSize(queryRect.getWidth() * scaling);

View File

@ -2,6 +2,7 @@ package io.anuke.mindustry.world;
/**Methods for a packed position 'struct', contained in an int.*/ /**Methods for a packed position 'struct', contained in an int.*/
public class Pos{ public class Pos{
public static final int invalid = get(-1, -1);
/**Returns packed position from an x/y position. The values must be within short limits.*/ /**Returns packed position from an x/y position. The values must be within short limits.*/
public static int get(int x, int y){ public static int get(int x, int y){

View File

@ -7,12 +7,10 @@ import io.anuke.arc.collection.IntArray;
import io.anuke.arc.collection.IntSet; import io.anuke.arc.collection.IntSet;
import io.anuke.arc.collection.IntSet.IntSetIterator; import io.anuke.arc.collection.IntSet.IntSetIterator;
import io.anuke.arc.graphics.Color; import io.anuke.arc.graphics.Color;
import io.anuke.arc.graphics.g2d.CapStyle; import io.anuke.arc.graphics.g2d.*;
import io.anuke.arc.graphics.g2d.Draw;
import io.anuke.arc.graphics.g2d.Lines;
import io.anuke.arc.graphics.g2d.TextureRegion;
import io.anuke.arc.math.Mathf; import io.anuke.arc.math.Mathf;
import io.anuke.arc.math.geom.Geometry; import io.anuke.arc.math.geom.Geometry;
import io.anuke.arc.math.geom.Point2;
import io.anuke.arc.util.Time; import io.anuke.arc.util.Time;
import io.anuke.mindustry.entities.type.Player; import io.anuke.mindustry.entities.type.Player;
import io.anuke.mindustry.entities.type.TileEntity; import io.anuke.mindustry.entities.type.TileEntity;
@ -34,8 +32,6 @@ import static io.anuke.mindustry.Vars.tilesize;
import static io.anuke.mindustry.Vars.world; import static io.anuke.mindustry.Vars.world;
public class ItemBridge extends Block{ public class ItemBridge extends Block{
protected static int lastPlaced;
protected int timerTransport = timers++; protected int timerTransport = timers++;
protected int range; protected int range;
protected float transportTime = 2f; protected float transportTime = 2f;
@ -85,29 +81,39 @@ public class ItemBridge extends Block{
@Override @Override
public void playerPlaced(Tile tile){ public void playerPlaced(Tile tile){
Tile last = world.tile(lastPlaced); Tile link = findLink(tile.x, tile.y);
if(linkValid(tile, last)){ if(linkValid(tile, link)){
ItemBridgeEntity entity = last.entity(); Call.linkItemBridge(null, link, tile);
if(!linkValid(last, world.tile(entity.link))){ }
Call.linkItemBridge(null, last, tile); }
public Tile findLink(int x, int y){
for(int j = 0; j < 4; j ++){
Point2 p = Geometry.d4(j + 1);
for(int i = 1; i <= range; i++){
Tile tile = world.tile(x + p.x * i, y + p.y * i);
if(tile == null) break;
if(tile.block() == this && tile.<ItemBridgeEntity>entity().link == Pos.invalid){
return tile;
}
} }
} }
lastPlaced = tile.pos(); return null;
} }
@Override @Override
public void drawPlace(int x, int y, int rotation, boolean valid){ public void drawPlace(int x, int y, int rotation, boolean valid){
Lines.stroke(2f); Tile link = findLink(x, y);
Draw.color(Pal.placing);
for(int i = 0; i < 4; i++){
Lines.dashLine(
x * tilesize + Geometry.d4[i].x * (tilesize / 2f + 2),
y * tilesize + Geometry.d4[i].y * (tilesize / 2f + 2),
x * tilesize + Geometry.d4[i].x * (range + 0.5f) * tilesize,
y * tilesize + Geometry.d4[i].y * (range + 0.5f) * tilesize,
range);
}
Lines.stroke(1f, Pal.placing);
if(link != null){
int rot = link.absoluteRelativeTo(x, y);
float w = (link.x == x ? tilesize : Math.abs(link.x - x) * tilesize - tilesize);
float h = (link.y == y ? tilesize : Math.abs(link.y - y) * tilesize - tilesize);
Lines.rect((x + link.x)/2f * tilesize - w/2f, (y + link.y)/2f * tilesize - h/2f, w, h);
Fill.poly(link.x * tilesize + Geometry.d4[rot].x * tilesize, link.y * tilesize + Geometry.d4[rot].y * tilesize, 3, 2.8f, link.absoluteRelativeTo(x, y)*90);
}
Draw.reset(); Draw.reset();
} }
@ -175,6 +181,7 @@ public class ItemBridge extends Block{
Tile other = world.tile(entity.link); Tile other = world.tile(entity.link);
if(!linkValid(tile, other)){ if(!linkValid(tile, other)){
entity.link = Pos.invalid;
tryDump(tile); tryDump(tile);
entity.uptime = 0f; entity.uptime = 0f;
}else{ }else{
@ -310,7 +317,7 @@ public class ItemBridge extends Block{
} }
public static class ItemBridgeEntity extends TileEntity{ public static class ItemBridgeEntity extends TileEntity{
public int link = -1; public int link = Pos.invalid;
public IntSet incoming = new IntSet(); public IntSet incoming = new IntSet();
public float uptime; public float uptime;
public float time; public float time;