X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fmobs%2Fplayer%2FInventory.kt;h=43f298c876e9702fb5e675e5b429602b22fbf13d;hb=90daad1796cd59f11f12589686d9afe882ddb9b1;hp=c5e10d06b30600a2c4aaac74ebedd9a97d67a781;hpb=c447b95aeb883113ff1d53a3178828929c1eb92f;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/mobs/player/Inventory.kt b/core/src/ru/deadsoftware/cavedroid/game/mobs/player/Inventory.kt index c5e10d0..43f298c 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/mobs/player/Inventory.kt +++ b/core/src/ru/deadsoftware/cavedroid/game/mobs/player/Inventory.kt @@ -59,7 +59,9 @@ class Inventory( } } - private fun getItemPickSlot(item: Item): Int { + private fun getItemPickSlot(drop: Drop): Int { + val item = drop.item + for (i in _items.indices) { val inventoryItem = _items[i] @@ -79,24 +81,31 @@ class Inventory( return -1 } - fun canPickItem(item: Item): Boolean { - return getItemPickSlot(item) >= 0 + fun canPickItem(drop: Drop): Boolean { + return getItemPickSlot(drop) >= 0 } fun pickDrop(drop: Drop) { - val slot = getItemPickSlot(drop.item).takeIf { it >= 0 } ?: return + val slot = getItemPickSlot(drop).takeIf { it >= 0 } ?: return val inventoryItem = _items[slot] if (inventoryItem.item == drop.item) { - inventoryItem.add(drop.amount) + if (inventoryItem.canBeAdded(drop.amount)) { + inventoryItem.add(drop.amount) + drop.pickedUp = true + } else { + val addCount = inventoryItem.item.params.maxStack - inventoryItem.amount + inventoryItem.add(addCount) + drop.subtract(addCount) + pickDrop(drop) + } } else { _items[slot] = drop.item.toInventoryItem(drop.amount) if (slot == activeSlot) { showCurrentItemTooltip() } + drop.pickedUp = true } - - drop.pickedUp = true } fun addItem(item: Item) { @@ -124,4 +133,10 @@ class Inventory( fun decreaseCurrentItemAmount(count: Int = 1) { decreaseItemAmount(activeSlot, count) } + + fun clear() { + for (i in _items.indices) { + _items[i] = fallbackItem + } + } } \ No newline at end of file