X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Finput%2Fhandler%2Fmouse%2FCloseGameWindowMouseInputHandler.kt;h=f6f6cfc97eeb83ad0a126225decd6d84b260e685;hb=b2f824726f647543e69f31ac5723df37750b5778;hp=8a7fdb46ff4559af473fb7dc1a40bcbc287c7d6d;hpb=6b49d51c59f6d639d949d1e9c264f7f144a305ab;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/input/handler/mouse/CloseGameWindowMouseInputHandler.kt b/core/src/ru/deadsoftware/cavedroid/game/input/handler/mouse/CloseGameWindowMouseInputHandler.kt index 8a7fdb4..f6f6cfc 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/input/handler/mouse/CloseGameWindowMouseInputHandler.kt +++ b/core/src/ru/deadsoftware/cavedroid/game/input/handler/mouse/CloseGameWindowMouseInputHandler.kt @@ -9,7 +9,7 @@ import ru.deadsoftware.cavedroid.game.input.action.MouseInputAction import ru.deadsoftware.cavedroid.game.input.action.keys.MouseInputActionKey import ru.deadsoftware.cavedroid.game.input.isInsideWindow import ru.deadsoftware.cavedroid.game.mobs.MobsController -import ru.deadsoftware.cavedroid.game.objects.DropController +import ru.deadsoftware.cavedroid.game.objects.drop.DropController import ru.deadsoftware.cavedroid.misc.Assets import javax.inject.Inject @@ -23,11 +23,13 @@ class CloseGameWindowMouseInputHandler @Inject constructor( private val creativeInventoryTexture get() = requireNotNull(Assets.textureRegions["creative"]) private val survivalInventoryTexture get() = requireNotNull(Assets.textureRegions["survival"]) private val craftingInventoryTexture get() = requireNotNull(Assets.textureRegions["crafting_table"]) + private val furnaceInventoryTexture get() = requireNotNull(Assets.textureRegions["furnace"]) + private val chestInventoryTexture get() = requireNotNull(Assets.textureRegions["chest"]) override fun checkConditions(action: MouseInputAction): Boolean { return gameWindowsManager.getCurrentWindow() != GameUiWindow.NONE && (action.actionKey is MouseInputActionKey.Left || action.actionKey is MouseInputActionKey.Screen) && - !action.actionKey.touchUp && + action.actionKey.touchUp && !isInsideWindow(action, getCurrentWindowTexture()) } @@ -36,6 +38,8 @@ class CloseGameWindowMouseInputHandler @Inject constructor( GameUiWindow.CREATIVE_INVENTORY -> creativeInventoryTexture GameUiWindow.SURVIVAL_INVENTORY -> survivalInventoryTexture GameUiWindow.CRAFTING_TABLE -> craftingInventoryTexture + GameUiWindow.FURNACE -> furnaceInventoryTexture + GameUiWindow.CHEST -> chestInventoryTexture else -> throw UnsupportedOperationException("Cant close window ${window.name}") } } @@ -43,13 +47,12 @@ class CloseGameWindowMouseInputHandler @Inject constructor( override fun handle(action: MouseInputAction) { val selectedItem = gameWindowsManager.currentWindow?.selectedItem if (selectedItem != null) { - for (i in 1 .. selectedItem.amount) { dropController.addDrop( /* x = */ mobsController.player.x + (32f * mobsController.player.direction.basis), /* y = */ mobsController.player.y, - /* item = */ selectedItem.item + /* item = */ selectedItem.item, + /* count = */ selectedItem.amount, ) - } gameWindowsManager.currentWindow?.selectedItem = null } gameWindowsManager.closeWindow()