diff options
author | peterbell10 <peterbell10@live.co.uk> | 2017-10-21 18:56:09 +0200 |
---|---|---|
committer | Alexander Harkness <me@bearbin.net> | 2017-10-21 18:56:09 +0200 |
commit | 0bacda32692729e4b9743f91d92cd329e198d73a (patch) | |
tree | 6d5780aafb44679125145f3bc255a200a840c3c2 /src/UI/HorseWindow.cpp | |
parent | Fixed some small passive mob issues (#4057) (diff) | |
download | cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar.gz cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar.bz2 cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar.lz cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar.xz cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.tar.zst cuberite-0bacda32692729e4b9743f91d92cd329e198d73a.zip |
Diffstat (limited to 'src/UI/HorseWindow.cpp')
-rw-r--r-- | src/UI/HorseWindow.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/UI/HorseWindow.cpp b/src/UI/HorseWindow.cpp new file mode 100644 index 000000000..ab060609d --- /dev/null +++ b/src/UI/HorseWindow.cpp @@ -0,0 +1,61 @@ + +// HorseWindow.cpp + +// Representing the UI window for a horse entity + +#include "Globals.h" +#include "Mobs/Horse.h" +#include "UI/HorseWindow.h" +#include "UI/SlotArea.h" + + + + + +cHorseWindow::cHorseWindow(cHorse & a_Horse): + Super(wtAnimalChest, "Horse"), + m_Horse(a_Horse) +{ + m_SlotAreas.push_back(new cSlotAreaHorse(a_Horse, *this)); + m_SlotAreas.push_back(new cSlotAreaInventory(*this)); + m_SlotAreas.push_back(new cSlotAreaHotBar(*this)); +} + + + + + +void cHorseWindow::DistributeStack(cItem & a_ItemStack, int a_Slot, cPlayer & a_Player, cSlotArea * a_ClickedArea, bool a_ShouldApply) +{ + cSlotAreas AreasInOrder; + + if (a_ClickedArea == m_SlotAreas[0]) + { + // Horse Area + AreasInOrder.push_back(m_SlotAreas[2]); /* Hotbar */ + AreasInOrder.push_back(m_SlotAreas[1]); /* Inventory */ + Super::DistributeStackToAreas(a_ItemStack, a_Player, AreasInOrder, a_ShouldApply, true); + } + else + { + // Inventory or Hotbar + if (ItemCategory::IsHorseArmor(a_ItemStack.m_ItemType) || (a_ItemStack.m_ItemType == E_ITEM_SADDLE)) + { + AreasInOrder.push_back(m_SlotAreas[0]); /* Horse */ + Super::DistributeStackToAreas(a_ItemStack, a_Player, AreasInOrder, a_ShouldApply, false); + } + } +} + + + + + +UInt32 cHorseWindow::GetHorseID() const +{ + return m_Horse.GetUniqueID(); +} + + + + |