X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fmobs%2FMob.java;h=5d18755c590feb3ebbf9df3071cc96a32da8fa66;hb=91283c3181af9700e20b5600f4e9017e0c31d33a;hp=04fa1bbe91f8b88ca6879094dbf343f5dbbef068;hpb=6bb7e1d207c640ff3b8e41ce2fb1c6203985bdb1;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/mobs/Mob.java b/core/src/ru/deadsoftware/cavedroid/game/mobs/Mob.java index 04fa1bb..5d18755 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/mobs/Mob.java +++ b/core/src/ru/deadsoftware/cavedroid/game/mobs/Mob.java @@ -8,15 +8,19 @@ import com.badlogic.gdx.math.Rectangle; import com.badlogic.gdx.math.Vector2; import com.badlogic.gdx.utils.Timer; import ru.deadsoftware.cavedroid.game.GameItemsHolder; +import ru.deadsoftware.cavedroid.game.model.dto.SaveDataDto; +import ru.deadsoftware.cavedroid.game.model.item.InventoryItem; import ru.deadsoftware.cavedroid.game.world.GameWorld; +import ru.deadsoftware.cavedroid.misc.Saveable; import javax.annotation.CheckForNull; -import java.io.Serializable; +import java.util.Collections; +import java.util.List; /** * Mob class. */ -public abstract class Mob extends Rectangle implements Serializable { +public abstract class Mob extends Rectangle implements Saveable { private static final float DAMAGE_TINT_TIMEOUT_S = 0.5f; private static final Color DAMAGE_TINT_COLOR = new Color(0xff8080ff); @@ -71,16 +75,16 @@ public abstract class Mob extends Rectangle implements Serializable { protected int mAnimDelta = ANIMATION_SPEED; protected float mAnim; - private Direction mDirection; + protected Direction mDirection; protected boolean mDead; - private boolean mCanJump; - private boolean mFlyMode; + protected boolean mCanJump; + protected boolean mFlyMode; - private final int mMaxHealth; - private int mHealth; + protected int mMaxHealth; + protected int mHealth; - private transient boolean mTakingDamage = false; - @CheckForNull private transient ResetTakeDamageTask mResetTakeDamageTask = null; + private boolean mTakingDamage = false; + @CheckForNull private ResetTakeDamageTask mResetTakeDamageTask = null; /** * @param x in pixels @@ -209,7 +213,7 @@ public abstract class Mob extends Rectangle implements Serializable { /** * Set's mob's dead variable to true and nothing else. It doesn't delete the */ - public final void kill() { + public void kill() { mDead = true; } @@ -259,6 +263,10 @@ public abstract class Mob extends Rectangle implements Serializable { return mHealth; } + public final int getMaxHealth() { + return mMaxHealth; + } + public final void attachToController(MobsController controller) { controller.addMob(this); } @@ -323,6 +331,10 @@ public abstract class Mob extends Rectangle implements Serializable { return isTakingDamage() ? DAMAGE_TINT_COLOR : Color.WHITE; } + public List getDrop(GameItemsHolder gameItemsHolder) { + return Collections.emptyList(); + } + public abstract void draw(SpriteBatch spriteBatch, float x, float y, float delta); public abstract void ai(GameWorld gameWorld, GameItemsHolder gameItemsHolder, MobsController mobsController, float delta); @@ -332,4 +344,11 @@ public abstract class Mob extends Rectangle implements Serializable { public abstract float getSpeed(); public abstract void jump(); + + @Override + public abstract SaveDataDto.MobSaveDataDto getSaveData(); + + public static Mob fromSaveData(SaveDataDto.MobSaveDataDto saveData) { + return MobSaveDataMapperKt.fromSaveData(saveData); + } }