From 4df23d19b7be2f274974e3dfe91e716e6296f11c Mon Sep 17 00:00:00 2001 From: "madmaxoft@gmail.com" Date: Sat, 29 Sep 2012 13:59:32 +0000 Subject: Unified folder name-casing git-svn-id: http://mc-server.googlecode.com/svn/trunk@902 0a769ca7-a7f5-676a-18bf-c427514a06d6 --- source/Blocks/BlockCrops.h | 64 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 64 insertions(+) create mode 100644 source/Blocks/BlockCrops.h (limited to 'source/Blocks/BlockCrops.h') diff --git a/source/Blocks/BlockCrops.h b/source/Blocks/BlockCrops.h new file mode 100644 index 000000000..b30139e79 --- /dev/null +++ b/source/Blocks/BlockCrops.h @@ -0,0 +1,64 @@ +#pragma once +#include "BlockHandler.h" +#include "../MersenneTwister.h" +#include "../World.h" + +class cBlockCropsHandler : public cBlockHandler +{ +public: + cBlockCropsHandler(BLOCKTYPE a_BlockID) + : cBlockHandler(a_BlockID) + { + } + + virtual bool NeedsRandomTicks() override + { + return true; + } + + virtual bool AllowBlockOnTop() override + { + return false; + } + + virtual int GetDropID() override + { + return E_ITEM_EMPTY; + } + + virtual void OnDestroyed(cWorld *a_World, int a_X, int a_Y, int a_Z) override + { + MTRand rand; + NIBBLETYPE Meta = a_World->GetBlockMeta(a_X, a_Y, a_Z); + + cItems Drops; + + if(Meta & 0x7) //Is Wheat + { + Drops.push_back(cItem(E_ITEM_WHEAT, 1, 0)); + } + if(rand.randInt(3) == 0) + { //Drop an second seed + Drops.push_back(cItem(E_ITEM_SEEDS, 1, 0)); + } + Drops.push_back(cItem(E_ITEM_SEEDS, 1, 0)); + a_World->SpawnItemPickups(Drops, a_X, a_Y, a_Z); + } + + void OnUpdate(cWorld *a_World, int a_X, int a_Y, int a_Z) override + { + + //TODO: Handle Growing here + } + + virtual bool CanBeAt(cWorld *a_World, int a_X, int a_Y, int a_Z) override + { + return a_World->GetBlock(a_X, a_Y - 1, a_Z) == E_BLOCK_FARMLAND; + } + + virtual AString GetStepSound(void) override + { + return "step.grass"; + } + +}; -- cgit v1.2.3