diff options
author | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-12-21 12:57:01 +0100 |
---|---|---|
committer | Tiger Wang <ziwei.tiger@hotmail.co.uk> | 2014-12-21 12:57:01 +0100 |
commit | 9755c5ba699493b3aa18ad4927f5a6a87e991e3b (patch) | |
tree | cc9a83ff0b5c87e4edd31f0785b14c902d577768 /src/Mobs/Guardian.cpp | |
parent | Fix repeater unpowering (diff) | |
parent | Merge pull request #1680 from Masy98/entities (diff) | |
download | cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar.gz cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar.bz2 cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar.lz cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar.xz cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.tar.zst cuberite-9755c5ba699493b3aa18ad4927f5a6a87e991e3b.zip |
Diffstat (limited to '')
-rw-r--r-- | src/Mobs/Guardian.cpp | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/src/Mobs/Guardian.cpp b/src/Mobs/Guardian.cpp new file mode 100644 index 000000000..d69ee1683 --- /dev/null +++ b/src/Mobs/Guardian.cpp @@ -0,0 +1,65 @@ + +#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules + +#include "Guardian.h" +#include "../Vector3.h" +#include "../Chunk.h" + + + + + +cGuardian::cGuardian(void) : + super("Guardian", mtGuardian, "mob.guardian.idle", "mob.guardian.death", 0.875, 0.8) +{ +} + + + + + +void cGuardian::GetDrops(cItems & a_Drops, cEntity * a_Killer) +{ + // Drops 0-3 Ink Sacs + int LootingLevel = 0; + if (a_Killer != nullptr) + { + LootingLevel = a_Killer->GetEquippedWeapon().m_Enchantments.GetLevel(cEnchantments::enchLooting); + } + AddRandomDropItem(a_Drops, 0, 2 + LootingLevel, E_ITEM_PRISMARINE_SHARD); + AddRandomDropItem(a_Drops, 0, 1 + LootingLevel, E_ITEM_RAW_FISH); + AddRandomDropItem(a_Drops, 0, 1 + LootingLevel, E_ITEM_PRISMARINE_CRYSTALS); // ToDo: Prismarine Crystals only drop if the raw fish drop is 0 +} + + + + + +void cGuardian::Tick(float a_Dt, cChunk & a_Chunk) +{ + // We must first process current location, and only then tick, otherwise we risk processing a location in a chunk + // that is not where the entity currently resides (FS #411) + + Vector3d Pos = GetPosition(); + + // TODO: Not a real behavior, but cool :D + int RelY = (int)floor(Pos.y); + if ((RelY < 0) || (RelY >= cChunkDef::Height)) + { + return; + } + int RelX = (int)floor(Pos.x) - a_Chunk.GetPosX() * cChunkDef::Width; + int RelZ = (int)floor(Pos.z) - a_Chunk.GetPosZ() * cChunkDef::Width; + BLOCKTYPE BlockType; + if (a_Chunk.UnboundedRelGetBlockType(RelX, RelY, RelZ, BlockType) && !IsBlockWater(BlockType) && !IsOnFire()) + { + // Burn for 10 ticks, then decide again + StartBurning(10); + } + + super::Tick(a_Dt, a_Chunk); +} + + + + |