aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/FireworksMenu.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Minecraft.World/FireworksMenu.cpp')
-rw-r--r--Minecraft.World/FireworksMenu.cpp150
1 files changed, 150 insertions, 0 deletions
diff --git a/Minecraft.World/FireworksMenu.cpp b/Minecraft.World/FireworksMenu.cpp
new file mode 100644
index 00000000..68c9e0f2
--- /dev/null
+++ b/Minecraft.World/FireworksMenu.cpp
@@ -0,0 +1,150 @@
+#include "stdafx.h"
+#include "net.minecraft.world.entity.player.h"
+#include "net.minecraft.world.level.h"
+#include "net.minecraft.world.level.tile.h"
+#include "net.minecraft.world.item.h"
+#include "net.minecraft.world.item.crafting.h"
+#include "CraftingContainer.h"
+#include "ResultContainer.h"
+#include "ResultSlot.h"
+#include "FireworksMenu.h"
+
+FireworksMenu::FireworksMenu(shared_ptr<Inventory> inventory, Level *level, int xt, int yt, int zt) : AbstractContainerMenu()
+{
+ m_canMakeFireworks = false;
+ m_canMakeCharge = false;
+ m_canMakeFade = false;
+
+ craftSlots = shared_ptr<CraftingContainer>( new CraftingContainer(this, 3, 3) );
+ resultSlots = shared_ptr<ResultContainer>( new ResultContainer() );
+
+ this->level = level;
+ x = xt;
+ y = yt;
+ z = zt;
+ addSlot(new ResultSlot( inventory->player, craftSlots, resultSlots, 0, 120 + 4, 31 + 4));
+
+ for (int y = 0; y < 3; y++)
+ {
+ for (int x = 0; x < 3; x++)
+ {
+ addSlot(new Slot(craftSlots, x + y * 3, 30 + x * 18, 17 + y * 18));
+ }
+ }
+
+ for (int y = 0; y < 3; y++)
+ {
+ for (int x = 0; x < 9; x++)
+ {
+ addSlot(new Slot(inventory, x + y * 9 + 9, 8 + x * 18, 84 + y * 18));
+ }
+ }
+ for (int x = 0; x < 9; x++)
+ {
+ addSlot(new Slot(inventory, x, 8 + x * 18, 142));
+ }
+
+ slotsChanged(); // 4J - removed craftSlots parameter, see comment below
+}
+
+void FireworksMenu::slotsChanged() // 4J used to take a shared_ptr<Container> but wasn't using it, so removed to simplify things
+{
+ FireworksRecipe::updatePossibleRecipes(craftSlots, &m_canMakeFireworks, &m_canMakeCharge, &m_canMakeFade);
+ resultSlots->setItem(0, Recipes::getInstance()->getItemFor(craftSlots, level, Recipes::pFireworksRecipes));
+}
+
+void FireworksMenu::removed(shared_ptr<Player> player)
+{
+ AbstractContainerMenu::removed(player);
+ if (level->isClientSide) return;
+
+ for (int i = 0; i < 9; i++)
+ {
+ shared_ptr<ItemInstance> item = craftSlots->removeItemNoUpdate(i);
+ if (item != NULL)
+ {
+ player->drop(item);
+ }
+ }
+}
+
+bool FireworksMenu::stillValid(shared_ptr<Player> player)
+{
+ return true;
+}
+
+shared_ptr<ItemInstance> FireworksMenu::quickMoveStack(shared_ptr<Player> player, int slotIndex)
+{
+ shared_ptr<ItemInstance> clicked = nullptr;
+ Slot *slot = slots.at(slotIndex);
+ if (slot != NULL && slot->hasItem())
+ {
+ shared_ptr<ItemInstance> stack = slot->getItem();
+ clicked = stack->copy();
+
+ if (slotIndex == RESULT_SLOT)
+ {
+ if(!moveItemStackTo(stack, INV_SLOT_START, USE_ROW_SLOT_END, true))
+ {
+ return nullptr;
+ }
+ slot->onQuickCraft(stack, clicked);
+ }
+ else if (slotIndex >= INV_SLOT_START && slotIndex < INV_SLOT_END)
+ {
+ if(isValidIngredient(stack, -1) && moveItemStackTo(stack, CRAFT_SLOT_START, CRAFT_SLOT_END, false))
+ {
+ }
+ else if(!moveItemStackTo(stack, USE_ROW_SLOT_START, USE_ROW_SLOT_END, false))
+ {
+ return nullptr;
+ }
+ }
+ else if (slotIndex >= USE_ROW_SLOT_START && slotIndex < USE_ROW_SLOT_END)
+ {
+ if(isValidIngredient(stack, -1) && moveItemStackTo(stack, CRAFT_SLOT_START, CRAFT_SLOT_END, false))
+ {
+ }
+ else if(!moveItemStackTo(stack, INV_SLOT_START, INV_SLOT_END, false))
+ {
+ return nullptr;
+ }
+ }
+ else
+ {
+ if(!moveItemStackTo(stack, INV_SLOT_START, USE_ROW_SLOT_END, false))
+ {
+ return nullptr;
+ }
+ }
+ if (stack->count == 0)
+ {
+ slot->set(nullptr);
+ }
+ else
+ {
+ slot->setChanged();
+ }
+ if (stack->count == clicked->count)
+ {
+ // nothing moved
+ return nullptr;
+ }
+ else
+ {
+ slot->onTake(player, stack);
+ }
+ }
+ return clicked;
+}
+
+bool FireworksMenu::canTakeItemForPickAll(shared_ptr<ItemInstance> carried, Slot *target)
+{
+ return target->container != resultSlots && AbstractContainerMenu::canTakeItemForPickAll(carried, target);
+}
+
+bool FireworksMenu::isValidIngredient(shared_ptr<ItemInstance> item, int slotId)
+{
+ if(item == NULL || slotId == RESULT_SLOT) return true;
+ return FireworksRecipe::isValidIngredient(item, m_canMakeFireworks, m_canMakeCharge, m_canMakeFade);
+} \ No newline at end of file