From cbfc740ad0ade4b8f03648ea52c16368d3a026a8 Mon Sep 17 00:00:00 2001 From: jclever77 <82078401+jclever77@users.noreply.github.com> Date: Fri, 30 Apr 2021 07:39:10 -0400 Subject: Added functionality: mobs now enter boats and minecarts (#5214) * Added functionality: mobs now enter boats and minecarts when coming into collision with them. * Fixed basic style errors, nothing else * Added self to contributors and reverted .gitignore to original state. --- src/Entities/Minecart.cpp | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) (limited to 'src/Entities/Minecart.cpp') diff --git a/src/Entities/Minecart.cpp b/src/Entities/Minecart.cpp index 1f454c857..123965916 100644 --- a/src/Entities/Minecart.cpp +++ b/src/Entities/Minecart.cpp @@ -21,6 +21,35 @@ +class cMinecartAttachCallback +{ +public: + cMinecartAttachCallback(cMinecart * a_Minecart, cEntity * a_Attachee) : + m_Minecart(a_Minecart), m_Attachee(a_Attachee) + { + } + + bool operator () (cEntity & a_Entity) + { + // Check if minecart is empty and if given entity is a mob + if ((m_Attachee == nullptr) && (a_Entity.IsMob())) + { + // if so, attach to minecart and return true + a_Entity.AttachTo(m_Minecart); + return true; + } + return false; + } + +protected: + cMinecart * m_Minecart; + cEntity * m_Attachee; +}; + + + + + class cMinecartCollisionCallback { public: @@ -1054,6 +1083,12 @@ bool cMinecart::TestEntityCollision(NIBBLETYPE a_RailMeta) return false; } + // Collision was true, create bounding box for minecart, call attach callback for all entities within that box + cMinecartAttachCallback MinecartAttachCallback(this, m_Attachee); + Vector3d MinecartPosition = GetPosition(); + cBoundingBox bbMinecart(Vector3d(MinecartPosition.x, floor(MinecartPosition.y), MinecartPosition.z), GetWidth() / 2, GetHeight()); + m_World->ForEachEntityInBox(bbMinecart, MinecartAttachCallback); + switch (a_RailMeta) { case E_META_RAIL_ZM_ZP: -- cgit v1.2.3