diff options
author | madmaxoft <github@xoft.cz> | 2013-08-30 20:49:33 +0200 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2013-08-30 20:49:33 +0200 |
commit | 105251a986d741e34561df588582de3ef882d183 (patch) | |
tree | 8f414b24316af0fcfd3174e6c2e825ac53465362 /source/Items/ItemThrowable.h | |
parent | ProtoProxy: Log individual chunks in MapChunkBulk packet. (diff) | |
parent | AnvilStats: Implemented a cImageComposingCallback class. (diff) | |
download | cuberite-105251a986d741e34561df588582de3ef882d183.tar cuberite-105251a986d741e34561df588582de3ef882d183.tar.gz cuberite-105251a986d741e34561df588582de3ef882d183.tar.bz2 cuberite-105251a986d741e34561df588582de3ef882d183.tar.lz cuberite-105251a986d741e34561df588582de3ef882d183.tar.xz cuberite-105251a986d741e34561df588582de3ef882d183.tar.zst cuberite-105251a986d741e34561df588582de3ef882d183.zip |
Diffstat (limited to 'source/Items/ItemThrowable.h')
-rw-r--r-- | source/Items/ItemThrowable.h | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/source/Items/ItemThrowable.h b/source/Items/ItemThrowable.h new file mode 100644 index 000000000..dacdb6157 --- /dev/null +++ b/source/Items/ItemThrowable.h @@ -0,0 +1,90 @@ + +// ItemThrowable.h + +// Declares the itemhandlers for throwable items: eggs, snowballs and ender pearls + + + + + +#pragma once + + + + + +class cItemThrowableHandler : + public cItemHandler +{ + typedef cItemHandler super; +public: + cItemThrowableHandler(int a_ItemType, cProjectileEntity::eKind a_ProjectileKind, double a_SpeedCoeff) : + super(a_ItemType), + m_ProjectileKind(a_ProjectileKind), + m_SpeedCoeff(a_SpeedCoeff) + { + } + + + 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 + { + Vector3d Pos = a_Player->GetThrowStartPos(); + Vector3d Speed = a_Player->GetLookVector() * m_SpeedCoeff; + a_World->CreateProjectile(Pos.x, Pos.y, Pos.z, m_ProjectileKind, a_Player, &Speed); + return true; + } + +protected: + cProjectileEntity::eKind m_ProjectileKind; + double m_SpeedCoeff; +} ; + + + + + +class cItemEggHandler : + public cItemThrowableHandler +{ + typedef cItemThrowableHandler super; +public: + cItemEggHandler(void) : + super(E_ITEM_EGG, cProjectileEntity::pkEgg, 30) + { + } +} ; + + + + +class cItemSnowballHandler : + public cItemThrowableHandler +{ + typedef cItemThrowableHandler super; + +public: + cItemSnowballHandler(void) : + super(E_ITEM_SNOWBALL, cProjectileEntity::pkSnowball, 30) + { + } +} ; + + + + + +class cItemEnderPearlHandler : + public cItemThrowableHandler +{ + typedef cItemThrowableHandler super; + +public: + cItemEnderPearlHandler(void) : + super(E_ITEM_ENDER_PEARL, cProjectileEntity::pkEnderPearl, 30) + { + } +} ; + + + + |