X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fcommon%2FCapsule.cpp;h=3bfdde7456caa574451a6cf7bd26d5e00ff2ff61;hb=b9e715649b41cb69ea1b2d2a588522541eb87b46;hp=487958596fe767b94a75ad20d6e403a04a3f9b4c;hpb=e518ac67cf94e244df16078dcbc536e6b659e758;p=l2e.git diff --git a/src/common/Capsule.cpp b/src/common/Capsule.cpp index 4879585..3bfdde7 100644 --- a/src/common/Capsule.cpp +++ b/src/common/Capsule.cpp @@ -1,7 +1,9 @@ #include "Capsule.h" -#include "../common/Spell.h" -#include "../common/Stats.h" +#include "Item.h" +#include "LevelUp.h" +#include "Spell.h" +#include "Upgrade.h" #include "../graphics/Animation.h" #include "../graphics/Sprite.h" #include "../loader/Interpreter.h" @@ -16,6 +18,7 @@ using graphics::Sprite; using loader::FieldDescription; using loader::Interpreter; using loader::TypeDescription; +using std::vector; namespace common { @@ -74,18 +77,77 @@ Stats Capsule::GetStats() const { int Capsule::NextLevel() const { int levelOffset(Level() - 1); if (levelOffset < numLevels) { - return levelLadder[levelOffset] - Experience(); + return levelLadder[levelOffset].Experience() - Experience(); } else { return 0; } } +void Capsule::AddExperience(int exp, vector &info) { + if (level > numLevels) { + // don't award any experience if at highest level + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); + return; + } + int remain = exp; + while (remain >= NextLevel()) { + const LevelUp &lup = levelLadder[level - 1]; + int added = NextLevel(); + experience += added; + remain -= added; + ++level; + maxHealth += lup.MaxHealth(); + stats += lup; + + info.push_back(Upgrade(name, Upgrade::LEVEL_UP, level)); + + if (lup.MaxHealth() > 0) { + info.push_back(Upgrade(name, Upgrade::MAX_HEALTH, lup.MaxHealth())); + } + if (lup.Attack() > 0) { + info.push_back(Upgrade(name, Upgrade::ATTACK, lup.Attack())); + } + if (lup.Defense() > 0) { + info.push_back(Upgrade(name, Upgrade::DEFENSE, lup.Defense())); + } + if (lup.Strength() > 0) { + info.push_back(Upgrade(name, Upgrade::STRENGTH, lup.Strength())); + } + if (lup.Agility() > 0) { + info.push_back(Upgrade(name, Upgrade::AGILITY, lup.Agility())); + } + if (lup.Intelligence() > 0) { + info.push_back(Upgrade(name, Upgrade::INTELLIGENCE, lup.Intelligence())); + } + if (lup.Gut() > 0) { + info.push_back(Upgrade(name, Upgrade::GUT, lup.Gut())); + } + if (lup.MagicResistance() > 0) { + info.push_back(Upgrade(name, Upgrade::MAGIC_RESISTANCE, lup.MagicResistance())); + } + + if (level > numLevels) { + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); + return; + } + } + experience += remain; + info.push_back(Upgrade( + name, Upgrade::LEVEL_NEXT, NextLevel())); +} + + void Capsule::UpgradeClass() { ++maxClass; ++curClass; } void Capsule::NextClass() { + if (maxClass == numClasses) { + return; + } ++curClass; if (curClass >= maxClass) { curClass = 0; @@ -93,6 +155,9 @@ void Capsule::NextClass() { } void Capsule::PreviousClass() { + if (maxClass == numClasses) { + return; + } --curClass; if (curClass < 0) { curClass = maxClass - 1; @@ -100,6 +165,9 @@ void Capsule::PreviousClass() { } void Capsule::SetClass(int index) { + if (maxClass == numClasses) { + return; + } curClass = index; if (curClass < 0 ) { curClass = 0; @@ -158,7 +226,7 @@ bool Capsule::IsHungry() const { return HungerEmpty(); } -void Capsule::Feed(const common::Item *) { +void Capsule::Feed(const common::Item *item) { // TODO: find out how to calculate an item's feed value // TODO: an item the capsule favors (changes on every feed and after every // battle) doubles the value @@ -170,6 +238,15 @@ void Capsule::Feed(const common::Item *) { } } +const common::Item *Capsule::UpgradeItem() const { + return GetClass().upgradeItem; +} + +void Capsule::UpgradeSpecial() { + maxClass = GetClass().upgradeClass + 1; + curClass = GetClass().upgradeClass; +} + Capsule::Class::Class() : name(0) @@ -179,6 +256,9 @@ Capsule::Class::Class() , attackAnimation(0) , spellAnimation(0) + +, upgradeItem(0) +, upgradeClass(0) , hunger(32) , hungerFull(0) @@ -209,9 +289,9 @@ void Capsule::CreateTypeDescription() { td.AddField("level", FieldDescription(((char *)&c.level) - ((char *)&c), Interpreter::NUMBER_ID)); td.AddField("experience", FieldDescription(((char *)&c.experience) - ((char *)&c), Interpreter::NUMBER_ID)); - td.AddField("ladder", FieldDescription(((char *)&c.levelLadder) - ((char *)&c), Interpreter::NUMBER_ID).SetReferenced().SetAggregate()); + td.AddField("ladder", FieldDescription(((char *)&c.levelLadder) - ((char *)&c), LevelUp::TYPE_ID).SetAggregate()); - td.AddField("classes", FieldDescription(((char *)&c.classes) - ((char *)&c), Class::TYPE_ID).SetReferenced().SetAggregate()); + td.AddField("classes", FieldDescription(((char *)&c.classes) - ((char *)&c), Class::TYPE_ID).SetAggregate()); td.AddField("class", FieldDescription(((char *)&c.curClass) - ((char *)&c), Interpreter::NUMBER_ID)); td.AddField("maxClass", FieldDescription(((char *)&c.maxClass) - ((char *)&c), Interpreter::NUMBER_ID)); @@ -242,6 +322,8 @@ void Capsule::Class::CreateTypeDescription() { td.AddField("attackAnimation", FieldDescription(((char *)&c.attackAnimation) - ((char *)&c), Animation::TYPE_ID).SetReferenced()); td.AddField("spellAnimation", FieldDescription(((char *)&c.spellAnimation) - ((char *)&c), Animation::TYPE_ID).SetReferenced()); + td.AddField("upgradeItem", FieldDescription(((char *)&c.upgradeItem) - ((char *)&c), common::Item::TYPE_ID).SetReferenced()); + td.AddField("upgradeClass", FieldDescription(((char *)&c.upgradeClass) - ((char *)&c), Interpreter::NUMBER_ID)); td.AddField("hunger", FieldDescription(((char *)&c.hunger) - ((char *)&c), Interpreter::NUMBER_ID)); td.AddField("healthBoost", FieldDescription(((char *)&c.healthBoost) - ((char *)&c), Interpreter::NUMBER_ID));