mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-01 23:18:44 +00:00
XEEN: Implemented weapon variation of equipItem
This commit is contained in:
parent
7ea32f3333
commit
a983d9abce
@ -21,6 +21,7 @@
|
||||
*/
|
||||
|
||||
#include "xeen/character.h"
|
||||
#include "xeen/dialogs_error.h"
|
||||
#include "xeen/resources.h"
|
||||
#include "xeen/xeen.h"
|
||||
|
||||
@ -110,12 +111,25 @@ bool InventoryItems::passRestrictions(int itemId, bool showError) const {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the bare name of a given inventory item
|
||||
*/
|
||||
Common::String InventoryItems::getName(int itemIndex) {
|
||||
int id = operator[](itemIndex)._id;
|
||||
return _names[id];
|
||||
}
|
||||
|
||||
/**
|
||||
* Discard an item from the inventory
|
||||
*/
|
||||
void InventoryItems::discardItem(int itemIndex) {
|
||||
operator[](itemIndex).clear();
|
||||
sort();
|
||||
}
|
||||
|
||||
/**
|
||||
* Sorts the items list, removing any empty item slots to the end of the array
|
||||
*/
|
||||
void InventoryItems::sort() {
|
||||
for (uint idx = 0; idx < size(); ++idx) {
|
||||
if (operator[](idx)._id == 0) {
|
||||
@ -135,14 +149,89 @@ void InventoryItems::sort() {
|
||||
}
|
||||
}
|
||||
|
||||
void InventoryItems::equipItem(int itemIndex) {
|
||||
error("TODO");
|
||||
}
|
||||
|
||||
void InventoryItems::removeItem(int itemIndex) {
|
||||
error("TODO");
|
||||
}
|
||||
|
||||
void InventoryItems::equipError(int itemIndex1, ItemCategory category1, int itemIndex2,
|
||||
ItemCategory category2) {
|
||||
XeenEngine *vm = Party::_vm;
|
||||
|
||||
if (itemIndex1 >= 0) {
|
||||
Common::String itemName1 = _character->_items[category1].getName(itemIndex1);
|
||||
Common::String itemName2 = _character->_items[category2].getName(itemIndex2);
|
||||
|
||||
ErrorDialog::show(vm, Common::String::format(REMOVE_X_TO_EQUIP_Y,
|
||||
itemName1.c_str(), itemName2.c_str()));
|
||||
} else {
|
||||
ErrorDialog::show(vm, Common::String::format(EQUIPPED_ALL_YOU_CAN,
|
||||
(itemIndex1 == -1) ? RING : MEDAL));
|
||||
}
|
||||
}
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void WeaponItems::equipItem(int itemIndex) {
|
||||
XeenItem &item = operator[](itemIndex);
|
||||
|
||||
if (item._id <= 17) {
|
||||
if (passRestrictions(item._id, false)) {
|
||||
for (uint idx = 0; idx < size(); ++idx) {
|
||||
XeenItem &i = operator[](idx);
|
||||
if (i._frame == 13 || i._frame == 1) {
|
||||
equipError(itemIndex, CATEGORY_WEAPON, idx, CATEGORY_WEAPON);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
item._frame = 1;
|
||||
}
|
||||
} else if (item._id >= 30 && item._id <= 33) {
|
||||
if (passRestrictions(item._id, false)) {
|
||||
for (uint idx = 0; idx < size(); ++idx) {
|
||||
XeenItem &i = operator[](idx);
|
||||
if (i._frame == 4) {
|
||||
equipError(itemIndex, CATEGORY_WEAPON, idx, CATEGORY_WEAPON);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
item._frame = 4;
|
||||
}
|
||||
} else {
|
||||
if (passRestrictions(item._id, false)) {
|
||||
for (uint idx = 0; idx < size(); ++idx) {
|
||||
XeenItem &i = operator[](idx);
|
||||
if (i._frame == 13 || i._frame == 1) {
|
||||
equipError(itemIndex, CATEGORY_WEAPON, idx, CATEGORY_WEAPON);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
for (uint idx = 0; idx < size(); ++idx) {
|
||||
XeenItem &i = _character->_armor[idx];
|
||||
if (i._frame == 2) {
|
||||
equipError(itemIndex, CATEGORY_ARMOR, idx, CATEGORY_WEAPON);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
item._frame = 13;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void ArmorItems::equipItem(int itemIndex) {
|
||||
error("TODO");
|
||||
}
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void AccessoryItems::equipItem(int itemIndex) {
|
||||
error("TODO");
|
||||
}
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
InventoryItemsGroup::InventoryItemsGroup(InventoryItems &weapons, InventoryItems &armor,
|
||||
@ -174,8 +263,7 @@ AttributePair::AttributePair() {
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
Character::Character():
|
||||
_weapons(this, CATEGORY_WEAPON), _armor(this, CATEGORY_ARMOR),
|
||||
_accessories(this, CATEGORY_ACCESSORY), _misc(this, CATEGORY_MISC),
|
||||
_weapons(this), _armor(this), _accessories(this), _misc(this),
|
||||
_items(_weapons, _armor, _accessories, _misc) {
|
||||
_sex = MALE;
|
||||
_race = HUMAN;
|
||||
|
@ -95,24 +95,52 @@ public:
|
||||
};
|
||||
|
||||
class InventoryItems : public Common::Array<XeenItem> {
|
||||
private:
|
||||
protected:
|
||||
Character *_character;
|
||||
ItemCategory _category;
|
||||
const char *const *_names;
|
||||
|
||||
void equipError(int itemIndex1, ItemCategory category1, int itemIndex2,
|
||||
ItemCategory category2);
|
||||
public:
|
||||
InventoryItems(Character *character, ItemCategory category);
|
||||
|
||||
bool passRestrictions(int itemId, bool showError) const;
|
||||
|
||||
Common::String getName(int itemIndex);
|
||||
|
||||
void discardItem(int itemIndex);
|
||||
|
||||
void equipItem(int itemIndex);
|
||||
virtual void equipItem(int itemIndex) {}
|
||||
|
||||
void removeItem(int itemIndex);
|
||||
|
||||
void sort();
|
||||
};
|
||||
|
||||
class WeaponItems: public InventoryItems {
|
||||
public:
|
||||
WeaponItems(Character *character) : InventoryItems(character, CATEGORY_WEAPON) {}
|
||||
virtual void equipItem(int itemIndex);
|
||||
};
|
||||
|
||||
class ArmorItems : public InventoryItems {
|
||||
public:
|
||||
ArmorItems(Character *character) : InventoryItems(character, CATEGORY_ARMOR) {}
|
||||
virtual void equipItem(int itemIndex);
|
||||
};
|
||||
|
||||
class AccessoryItems : public InventoryItems {
|
||||
public:
|
||||
AccessoryItems(Character *character) : InventoryItems(character, CATEGORY_ACCESSORY) {}
|
||||
virtual void equipItem(int itemIndex);
|
||||
};
|
||||
|
||||
class MiscItems : public InventoryItems {
|
||||
public:
|
||||
MiscItems(Character *character) : InventoryItems(character, CATEGORY_MISC) {}
|
||||
};
|
||||
|
||||
class InventoryItemsGroup {
|
||||
private:
|
||||
InventoryItems *_itemSets[4];
|
||||
@ -162,10 +190,10 @@ public:
|
||||
int _currentSpell;
|
||||
int _quickOption;
|
||||
InventoryItemsGroup _items;
|
||||
InventoryItems _weapons;
|
||||
InventoryItems _armor;
|
||||
InventoryItems _accessories;
|
||||
InventoryItems _misc;
|
||||
WeaponItems _weapons;
|
||||
ArmorItems _armor;
|
||||
AccessoryItems _accessories;
|
||||
MiscItems _misc;
|
||||
int _lloydSide;
|
||||
AttributePair _fireResistence;
|
||||
AttributePair _coldResistence;
|
||||
|
@ -27,29 +27,19 @@
|
||||
|
||||
namespace Xeen {
|
||||
|
||||
void ErrorScroll::show(XeenEngine *vm, const Common::String &msg, ErrorWaitType waitType) {
|
||||
ErrorScroll *dlg = new ErrorScroll(vm);
|
||||
void ErrorDialog::show(XeenEngine *vm, const Common::String &msg, ErrorWaitType waitType) {
|
||||
ErrorDialog *dlg = new ErrorDialog(vm);
|
||||
dlg->execute(msg, waitType);
|
||||
delete dlg;
|
||||
}
|
||||
|
||||
void ErrorScroll::execute(const Common::String &msg, ErrorWaitType waitType) {
|
||||
void ErrorDialog::execute(const Common::String &msg, ErrorWaitType waitType) {
|
||||
Screen &screen = *_vm->_screen;
|
||||
EventsManager &events = *_vm->_events;
|
||||
Window &w = screen._windows[6];
|
||||
|
||||
Common::String s;
|
||||
if (waitType == WT_UNFORMATTED) {
|
||||
// This type isn't technically a waiting type, but it saved on adding
|
||||
// yet another parameter
|
||||
waitType = WT_FREEZE_WAIT;
|
||||
s = msg;
|
||||
} else {
|
||||
s = Common::String::format("\x03c\v010\t000%s", msg.c_str());
|
||||
}
|
||||
|
||||
w.open();
|
||||
w.writeString(s);
|
||||
w.writeString(msg);
|
||||
w.update();
|
||||
|
||||
switch (waitType) {
|
||||
@ -83,4 +73,11 @@ void ErrorScroll::execute(const Common::String &msg, ErrorWaitType waitType) {
|
||||
}
|
||||
}
|
||||
|
||||
/*------------------------------------------------------------------------*/
|
||||
|
||||
void ErrorScroll::show(XeenEngine *vm, const Common::String &msg, ErrorWaitType waitType) {
|
||||
Common::String s = Common::String::format("\x03c\v010\t000%s", msg.c_str());
|
||||
ErrorDialog::show(vm, s, waitType);
|
||||
}
|
||||
|
||||
} // End of namespace Xeen
|
||||
|
@ -24,17 +24,18 @@
|
||||
#define XEEN_DIALOGS_ERROR_H
|
||||
|
||||
#include "xeen/dialogs.h"
|
||||
#include "xeen/character.h"
|
||||
|
||||
namespace Xeen {
|
||||
|
||||
enum ErrorWaitType { WT_FREEZE_WAIT = 0, WT_NONFREEZED_WAIT = 1,
|
||||
WT_2 = 2, WT_3 = 3, WT_UNFORMATTED = 9 };
|
||||
WT_2 = 2, WT_3 = 3 };
|
||||
|
||||
class ErrorScroll: public ButtonContainer {
|
||||
class ErrorDialog : public ButtonContainer {
|
||||
private:
|
||||
XeenEngine *_vm;
|
||||
|
||||
ErrorScroll(XeenEngine *vm) : ButtonContainer(), _vm(vm) {}
|
||||
ErrorDialog(XeenEngine *vm) : ButtonContainer(), _vm(vm) {}
|
||||
|
||||
void execute(const Common::String &msg, ErrorWaitType waitType);
|
||||
public:
|
||||
@ -42,6 +43,12 @@ public:
|
||||
ErrorWaitType waitType = WT_FREEZE_WAIT);
|
||||
};
|
||||
|
||||
class ErrorScroll {
|
||||
public:
|
||||
static void show(XeenEngine *vm, const Common::String &msg,
|
||||
ErrorWaitType waitType = WT_FREEZE_WAIT);
|
||||
};
|
||||
|
||||
} // End of namespace Xeen
|
||||
|
||||
#endif /* XEEN_DIALOGS_ERROR_H */
|
||||
|
@ -1125,4 +1125,9 @@ const char *const NO_SPECIAL_ABILITIES = "\v005\x3""c%s\fdhas no special abiliti
|
||||
|
||||
const char *const CANT_CAST_WHILE_ENGAGED = "\x03c\v007Can't cast %s while engaged!";
|
||||
|
||||
const char *const EQUIPPED_ALL_YOU_CAN = "\x3""c\v007You have equipped all the %ss you can!";
|
||||
const char *const REMOVE_X_TO_EQUIP_Y = "\x3""c\v007You must remove %sto equip %s\x8!";
|
||||
const char *const RING = "ring";
|
||||
const char *const MEDAL = "medal";
|
||||
|
||||
} // End of namespace Xeen
|
||||
|
@ -398,6 +398,11 @@ extern const char *const NO_SPECIAL_ABILITIES;
|
||||
|
||||
extern const char *const CANT_CAST_WHILE_ENGAGED;
|
||||
|
||||
extern const char *const EQUIPPED_ALL_YOU_CAN;
|
||||
extern const char *const REMOVE_X_TO_EQUIP_Y;
|
||||
extern const char *const RING;
|
||||
extern const char *const MEDAL;
|
||||
|
||||
} // End of namespace Xeen
|
||||
|
||||
#endif /* XEEN_RESOURCES_H */
|
||||
|
@ -100,8 +100,8 @@ void Spells::doSpell(int spellId) {
|
||||
if (_vm->_mode == MODE_InCombat) {
|
||||
if (spellId == 15 || spellId == 20 || spellId == 27 || spellId == 41
|
||||
|| spellId == 47 || spellId == 54 || spellId == 57) {
|
||||
ErrorScroll::show(_vm, Common::String::format(CANT_CAST_WHILE_ENGAGED,
|
||||
_spellNames[spellId].c_str()), WT_UNFORMATTED);
|
||||
ErrorDialog::show(_vm, Common::String::format(CANT_CAST_WHILE_ENGAGED,
|
||||
_spellNames[spellId].c_str()));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user