X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;ds=inline;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fmobs%2FFallingSand.java;h=c59c3fc94d4de16a1bf94eb2c03d4295ace04bae;hb=462f97f8da742fe35f516fec00ca9a581d688e7a;hp=b1777c485c7ecffb1bd553bc5c7115a57c53d33a;hpb=2948fcd9c40ebf588ef7d0e7cd8dd34ecaa1f9b2;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/mobs/FallingSand.java b/core/src/ru/deadsoftware/cavedroid/game/mobs/FallingSand.java index b1777c4..c59c3fc 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/mobs/FallingSand.java +++ b/core/src/ru/deadsoftware/cavedroid/game/mobs/FallingSand.java @@ -3,7 +3,8 @@ package ru.deadsoftware.cavedroid.game.mobs; import com.badlogic.gdx.graphics.g2d.SpriteBatch; import com.badlogic.gdx.math.Vector2; import ru.deadsoftware.cavedroid.game.GameItems; -import ru.deadsoftware.cavedroid.misc.Assets; +import ru.deadsoftware.cavedroid.game.world.GameWorld; + /** * Falling sand is actually a mob, that spawns in place of gravel when there is no block under it, @@ -13,30 +14,40 @@ public class FallingSand extends Mob { /** * Creates a FallingSand mob at coordinates + * * @param x X in pixels * @param y Y in pixels */ public FallingSand(float x, float y) { - super(x, y, 16, 16, 0); - mov = new Vector2(0, 1); + super(x, y, 16, 16, Direction.LEFT, Type.SAND); + mVelocity = new Vector2(0, 1); } @Override - public void ai() { + public float getSpeed() { + return 0; } @Override - public void changeDir() { + public void jump() { + // no-op + } + + @Override + public void ai(GameWorld gameWorld, float delta) { + if (mVelocity.isZero()) { + gameWorld.setForeMap(getMapX(), getMiddleMapY(), 10); + kill(); + } } @Override - public void draw(SpriteBatch spriteBatch, float x, float y) { - spriteBatch.draw(GameItems.getBlock("sand").getTex(), x, y); + public void changeDir() { } @Override - public int getType() { - return 10; + public void draw(SpriteBatch spriteBatch, float x, float y, float delta) { + spriteBatch.draw(GameItems.getBlockTex(10), x, y); } }