summaryrefslogtreecommitdiffstats
path: root/src/Items/ItemFishingRod.h
diff options
context:
space:
mode:
authorMattes D <github@xoft.cz>2013-12-19 22:51:21 +0100
committerMattes D <github@xoft.cz>2013-12-19 22:51:21 +0100
commit03ec64aee153a4c217f0794e9310d80eda7629e6 (patch)
treecb5f0e532d5bcfc25324207f0c088507f6b6c6bc /src/Items/ItemFishingRod.h
parentMerge pull request #448 from mc-server/testbranch (diff)
parentFixed #include in Floater.cpp. (diff)
downloadcuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar.gz
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar.bz2
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar.lz
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar.xz
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.tar.zst
cuberite-03ec64aee153a4c217f0794e9310d80eda7629e6.zip
Diffstat (limited to 'src/Items/ItemFishingRod.h')
-rw-r--r--src/Items/ItemFishingRod.h78
1 files changed, 78 insertions, 0 deletions
diff --git a/src/Items/ItemFishingRod.h b/src/Items/ItemFishingRod.h
new file mode 100644
index 000000000..91c0e9638
--- /dev/null
+++ b/src/Items/ItemFishingRod.h
@@ -0,0 +1,78 @@
+
+// ItemFishingRod.h
+
+// Declares the various fishing rod ItemHandlers
+
+
+
+
+
+#pragma once
+
+#include "../Entities/Floater.h"
+#include "../Entities/Entity.h"
+#include "../Item.h"
+
+
+
+
+class cItemFishingRodHandler :
+ public cItemHandler
+{
+ typedef cItemHandler super;
+
+public:
+ cItemFishingRodHandler(int a_ItemType) :
+ super(a_ItemType)
+ {
+ }
+
+ virtual bool OnItemUse(cWorld * a_World, cPlayer * a_Player, const cItem & a_Item, int a_BlockX, int a_BlockY, int a_BlockZ, char a_Dir) override
+ {
+ if (a_Player->IsFishing())
+ {
+ class cFloaterCallback :
+ public cEntityCallback
+ {
+ public:
+ cFloaterCallback(void) :
+ m_CanPickup(false)
+ {
+ }
+
+ bool CanPickup(void) const { return m_CanPickup; }
+ Vector3d GetPos(void) const { return m_Pos; }
+
+ virtual bool Item(cEntity * a_Entity) override
+ {
+ m_CanPickup = ((cFloater *)a_Entity)->CanPickup();
+ m_Pos = Vector3d(a_Entity->GetPosX(), a_Entity->GetPosY(), a_Entity->GetPosZ());
+ a_Entity->Destroy(true);
+ return true;
+ }
+ protected:
+ bool m_CanPickup;
+ Vector3d m_Pos;
+ } Callbacks;
+ a_World->DoWithEntityByID(a_Player->GetFloaterID(), Callbacks);
+ a_Player->SetIsFishing(false);
+
+ if (Callbacks.CanPickup())
+ {
+ cItems Drops;
+ Drops.Add(cItem(E_ITEM_RAW_FISH));
+ Vector3d FloaterPos(Callbacks.GetPos());
+ Vector3d FlyDirection(a_Player->GetPosition() - FloaterPos);
+ a_World->SpawnItemPickups(Drops, FloaterPos.x, FloaterPos.y, FloaterPos.z, FlyDirection.x, FlyDirection.y, FlyDirection.z);
+ // TODO: More types of pickups.
+ }
+ }
+ else
+ {
+ cFloater * Floater = new cFloater(a_Player->GetPosX(), a_Player->GetStance(), a_Player->GetPosZ(), a_Player->GetLookVector() * 7, a_Player->GetUniqueID());
+ Floater->Initialize(a_World);
+ a_Player->SetIsFishing(true, Floater->GetUniqueID());
+ }
+ return true;
+ }
+} ; \ No newline at end of file