1 package ru
.deadsoftware
.cavedroid
.game
.mobs
;
3 import com
.badlogic
.gdx
.graphics
.g2d
.Sprite
;
4 import com
.badlogic
.gdx
.graphics
.g2d
.SpriteBatch
;
5 import com
.badlogic
.gdx
.math
.MathUtils
;
6 import com
.badlogic
.gdx
.math
.Vector2
;
7 import ru
.deadsoftware
.cavedroid
.game
.GameItemsHolder
;
8 import ru
.deadsoftware
.cavedroid
.game
.model
.block
.Block
;
9 import ru
.deadsoftware
.cavedroid
.game
.model
.item
.InventoryItem
;
10 import ru
.deadsoftware
.cavedroid
.game
.model
.item
.Item
;
11 import ru
.deadsoftware
.cavedroid
.game
.objects
.Drop
;
12 import ru
.deadsoftware
.cavedroid
.game
.world
.GameWorld
;
13 import ru
.deadsoftware
.cavedroid
.misc
.Assets
;
14 import ru
.deadsoftware
.cavedroid
.misc
.utils
.SpriteOrigin
;
15 import ru
.deadsoftware
.cavedroid
.misc
.utils
.SpriteUtilsKt
;
17 import javax
.annotation
.CheckForNull
;
19 public class Player
extends Mob
{
21 private static final float SPEED
= 69.072f;
22 private static final float JUMP_VELOCITY
= -133.332f;
23 private static final int MAX_HEALTH
= 20;
25 private boolean hitting
= false;
26 private float hitAnim
= 0f;
27 private float hitAnimDelta
= ANIMATION_SPEED
;
29 public final InventoryItem
[] inventory
;
33 public float headRotation
= 0f;
35 public float blockDamage
= 0f;
36 public int cursorX
= 0;
37 public int cursorY
= 0;
39 public Player(GameItemsHolder gameItemsHolder
) {
40 super(0, 0, 4, 30, randomDir(), Type
.MOB
, MAX_HEALTH
);
41 inventory
= new InventoryItem
[36];
42 for (int i
= 0; i
< inventory
.length
; i
++) {
43 inventory
[i
] = gameItemsHolder
.getFallbackItem().toInventoryItem();
48 public void initInventory(GameItemsHolder gameItemsHolder
) {
49 for (InventoryItem invItem
: inventory
) {
50 invItem
.init(gameItemsHolder
);
55 public Item
inventory(int i
) {
56 return inventory
[i
].getItem();
59 public void respawn(GameWorld gameWorld
, GameItemsHolder itemsHolder
) {
60 Vector2 pos
= getSpawnPoint(gameWorld
, itemsHolder
);
68 public void decreaseCurrentItemCount(GameItemsHolder gameItemsHolder
) {
72 getCurrentItem().setAmount(getCurrentItem().getAmount() - 1);
73 if (getCurrentItem().getAmount() <= 0) {
74 setCurrentInventorySlotItem(gameItemsHolder
.getFallbackItem());
78 public InventoryItem
getCurrentItem() {
79 return inventory
[slot
];
82 public void pickUpDrop(Drop drop
) {
83 for (InventoryItem invItem
: inventory
) {
84 if (!invItem
.getItem().isTool()
85 && invItem
.getItem() == drop
.getItem()
86 && invItem
.getAmount() < invItem
.getItem().getParams().getMaxStack()) {
87 invItem
.setAmount(invItem
.getAmount() + 1);
88 drop
.setPickedUp(true);
93 for (int i
= 0; i
< inventory
.length
; i
++) {
94 if (inventory(i
) == null || inventory(i
).getParams().getKey().equals(GameItemsHolder
.FALLBACK_ITEM_KEY
)) {
95 inventory
[i
] = drop
.getItem().toInventoryItem();
96 drop
.setPickedUp(true);
102 private Vector2
getSpawnPoint(GameWorld gameWorld
, GameItemsHolder itemsHolder
) {
104 for (y
= 0; y
< gameWorld
.getHeight(); y
++) {
105 if (y
== gameWorld
.getHeight() - 1) {
107 gameWorld
.setForeMap(0, y
, itemsHolder
.getBlock("grass"));
110 if (gameWorld
.hasForeAt(0, y
) && gameWorld
.getForeMap(0, y
).hasCollision()) {
114 return new Vector2(8 - getWidth() / 2, (float) y
* 16 - getHeight());
117 public void setDir(Direction dir
) {
118 if (dir
!= getDirection()) {
123 public void setCurrentInventorySlotItem(Item item
) {
124 inventory
[slot
] = item
.toInventoryItem();
128 public float getSpeed() {
134 mVelocity
.y
= JUMP_VELOCITY
;
138 public void ai(GameWorld gameWorld
, GameItemsHolder gameItemsHolder
, float delta
) {
139 updateAnimation(delta
);
145 final Block foregroundBlock
= gameWorld
.getForeMap(cursorX
, cursorY
);
146 final Block backgroundBlock
= gameWorld
.getBackMap(cursorX
, cursorY
);
147 @CheckForNull final Block target
;
149 if (!foregroundBlock
.isNone() && foregroundBlock
.getParams().getHitPoints() >= 0) {
150 target
= foregroundBlock
;
151 } else if (!backgroundBlock
.isNone() && backgroundBlock
.getParams().getHitPoints() >= 0) {
152 target
= backgroundBlock
;
157 final boolean canHitBlock
= target
!= null;
159 float multiplier
= 1f;
160 final Item currentItem
= inventory
[slot
].getItem();
161 if (currentItem
instanceof Item
.Tool
&& canHitBlock
) {
162 if (target
.getParams().getToolType() == currentItem
.getClass()
163 && ((Item
.Tool
)currentItem
).getLevel() >= target
.getParams().getToolLevel()) {
164 multiplier
= 2f * ((Item
.Tool
)currentItem
).getLevel();
166 multiplier
*= ((Item
.Tool
)currentItem
).getBlockDamageMultiplier();
169 if (hitting
&& canHitBlock
) {
170 blockDamage
+= 60f * delta
* multiplier
;
177 public void changeDir() {
181 public void damage(int damage
) {
187 getVelocity().y
+= JUMP_VELOCITY
/ 3f;
190 super.damage(damage
);
194 public void heal(int heal
) {
201 private void drawItem(SpriteBatch spriteBatch
, float x
, float y
, float anim
) {
202 final Item item
= inventory(slot
);
204 if (item
== null || item
.isNone()) {
208 final Sprite sprite
= item
.getSprite();
209 final boolean smallSprite
= !item
.isTool() || item
.isShears();
212 sprite
.setSize(Drop
.DROP_SIZE
, Drop
.DROP_SIZE
);
215 final float handLength
= Assets
.playerSprite
[0][2].getHeight();
217 final SpriteOrigin spriteOrigin
= item
.getParams().getInHandSpriteOrigin();
218 final int handMultiplier
= -getDirection().getBasis();
219 final float xOffset
= (-1 + getDirection().getIndex()) * sprite
.getWidth() + 4 + handMultiplier
* (sprite
.getWidth() * spriteOrigin
.getX());
220 final float yOffset
= !smallSprite ?
-sprite
.getHeight() / 2 : 0;
222 float rotate
= anim
+ 30;
225 sprite
.rotate90(looksLeft());
228 final float itemX
= x
+ handLength
* MathUtils
.sin(handMultiplier
* anim
* MathUtils
.degRad
) + xOffset
;
229 final float itemY
= y
+ handLength
* MathUtils
.cos(handMultiplier
* anim
* MathUtils
.degRad
) + yOffset
;
232 sprite
.setFlip(!item
.isTool(), sprite
.isFlipY());
233 SpriteUtilsKt
.applyOrigin(sprite
, spriteOrigin
.getFlipped(true, false));
235 sprite
.setFlip(item
.isTool(), sprite
.isFlipY());
236 SpriteUtilsKt
.applyOrigin(sprite
, spriteOrigin
);
239 SpriteUtilsKt
.drawSprite(spriteBatch
, sprite
, itemX
, itemY
, -handMultiplier
* rotate
);
241 // dont forget to reset
242 sprite
.setFlip(false, sprite
.isFlipY());
243 sprite
.setRotation(0);
244 sprite
.setOriginCenter();
246 sprite
.rotate90(looksRight());
250 public void startHitting() {
257 hitAnimDelta
= ANIMATION_SPEED
;
260 public void stopHitting() {
265 private float getRightHandAnim(float delta
) {
266 hitAnim
-= hitAnimDelta
* delta
;
268 if (hitAnim
< 30f || hitAnim
> 90f) {
270 hitAnim
= MathUtils
.clamp(hitAnim
, 30f, 90f);
271 hitAnimDelta
= -hitAnimDelta
;
273 hitAnimDelta
= ANIMATION_SPEED
;
278 if (hitAnim
< hitAnimDelta
* delta
) {
289 public void draw(SpriteBatch spriteBatch
, float x
, float y
, float delta
) {
290 final Sprite backHand
= Assets
.playerSprite
[1][2];
291 final Sprite backLeg
= Assets
.playerSprite
[1][3];
292 final Sprite frontLeg
= Assets
.playerSprite
[0][3];
293 final Sprite head
= Assets
.playerSprite
[getDirection().getIndex()][0];
294 final Sprite body
= Assets
.playerSprite
[getDirection().getIndex()][1];
295 final Sprite frontHand
= Assets
.playerSprite
[0][2];
297 float backHandAnim
, frontHandAnim
;
299 final float rightHandAnim
= getRightHandAnim(delta
);
302 backHandAnim
= rightHandAnim
;
303 frontHandAnim
= mAnim
;
305 backHandAnim
= -mAnim
;
306 frontHandAnim
= -rightHandAnim
;
309 SpriteUtilsKt
.drawSprite(spriteBatch
, backHand
, x
+ 2, y
+ 8, backHandAnim
);
312 drawItem(spriteBatch
, x
, y
, -backHandAnim
);
315 SpriteUtilsKt
.drawSprite(spriteBatch
, backLeg
, x
+ 2, y
+ 20, mAnim
);
316 SpriteUtilsKt
.drawSprite(spriteBatch
, frontLeg
, x
+ 2, y
+ 20, -mAnim
);
317 SpriteUtilsKt
.drawSprite(spriteBatch
, head
, x
, y
, headRotation
);
318 SpriteUtilsKt
.drawSprite(spriteBatch
, body
, x
+ 2, y
+ 8);
321 drawItem(spriteBatch
, x
, y
, frontHandAnim
);
324 SpriteUtilsKt
.drawSprite(spriteBatch
, frontHand
, x
+ 2, y
+ 8, frontHandAnim
);