diff options
author | Alexander Harkness <bearbin@gmail.com> | 2013-11-26 18:21:06 +0100 |
---|---|---|
committer | Alexander Harkness <bearbin@gmail.com> | 2013-11-26 18:21:06 +0100 |
commit | 0de95a215f960c51bd7180218c1acef2414ce7d0 (patch) | |
tree | 80c80002565be1dc2fa537416ca7e6a1fd3e9da0 /src/Mobs | |
parent | Merge branch 'master' into foldermove2 (diff) | |
parent | cWorld::SpawnExperienceOrb() now returns the entity ID of the spawned orb. (diff) | |
download | cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar.gz cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar.bz2 cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar.lz cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar.xz cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.tar.zst cuberite-0de95a215f960c51bd7180218c1acef2414ce7d0.zip |
Diffstat (limited to 'src/Mobs')
-rw-r--r-- | src/Mobs/Monster.cpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/Mobs/Monster.cpp b/src/Mobs/Monster.cpp index 8a5717e27..091623c8a 100644 --- a/src/Mobs/Monster.cpp +++ b/src/Mobs/Monster.cpp @@ -7,6 +7,7 @@ #include "../ClientHandle.h" #include "../World.h" #include "../Entities/Player.h" +#include "../Entities/ExpOrb.h" #include "../Defines.h" #include "../MonsterConfig.h" #include "../MersenneTwister.h" @@ -258,6 +259,60 @@ void cMonster::KilledBy(cEntity * a_Killer) { m_World->BroadcastSoundEffect(m_SoundDeath, (int)(GetPosX() * 8), (int)(GetPosY() * 8), (int)(GetPosZ() * 8), 1.0f, 0.8f); } + int Reward; + switch (m_MobType) + { + // Animals + case cMonster::mtChicken: + case cMonster::mtCow: + case cMonster::mtHorse: + case cMonster::mtPig: + case cMonster::mtSheep: + case cMonster::mtSquid: + case cMonster::mtMooshroom: + case cMonster::mtOcelot: + case cMonster::mtWolf: + { + Reward = m_World->GetTickRandomNumber(2) + 1; + } + + // Monsters + case cMonster::mtCaveSpider: + case cMonster::mtCreeper: + case cMonster::mtEnderman: + case cMonster::mtGhast: + case cMonster::mtSilverfish: + case cMonster::mtSkeleton: + case cMonster::mtSpider: + case cMonster::mtWitch: + case cMonster::mtZombie: + case cMonster::mtZombiePigman: + case cMonster::mtSlime: + case cMonster::mtMagmaCube: + { + Reward = 6 + (m_World->GetTickRandomNumber(2)); + } + case cMonster::mtBlaze: + { + Reward = 10; + } + + // Bosses + case cMonster::mtEnderDragon: + { + Reward = 12000; + } + case cMonster::mtWither: + { + Reward = 50; + } + + default: + { + Reward = 0; + } + } + m_World->SpawnExperienceOrb(GetPosX(), GetPosY(), GetPosZ(), Reward); m_DestroyTimer = 0; } |