aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/xeen/party.h10
-rw-r--r--engines/xeen/resources.cpp7
-rw-r--r--engines/xeen/resources.h2
-rw-r--r--engines/xeen/town.cpp124
-rw-r--r--engines/xeen/town.h2
5 files changed, 126 insertions, 19 deletions
diff --git a/engines/xeen/party.h b/engines/xeen/party.h
index 0b7572cccf..883b378e55 100644
--- a/engines/xeen/party.h
+++ b/engines/xeen/party.h
@@ -218,7 +218,7 @@ public:
int _day;
int _year;
int _minutes;
- int _food;
+ uint _food;
int _lightCount;
int _torchCount;
int _fireResistence;
@@ -228,10 +228,10 @@ public:
int _deathCount;
int _winCount;
int _lossCount;
- int _gold;
- int _gems;
- int _bankGold;
- int _bankGems;
+ uint _gold;
+ uint _gems;
+ uint _bankGold;
+ uint _bankGems;
int _totalTime;
bool _rested;
bool _gameFlags[512];
diff --git a/engines/xeen/resources.cpp b/engines/xeen/resources.cpp
index cab6e2643d..3be2617e6b 100644
--- a/engines/xeen/resources.cpp
+++ b/engines/xeen/resources.cpp
@@ -657,6 +657,13 @@ const char *const GOLD_GEMS =
"\x0C""37o\x0C""dld\x09""040G\x0C\x03""7e"
"\x0C""dms\x09""067ESC\x01";
+const char *const GOLD_GEMS_2 =
+ "\x09""000\x0B""000\x03""c%s\x03l\n"
+ "\n"
+ "\x04""077Gold\x03r\x09""000%s\x03l\n"
+ "\x04""077Gems\x03r\x09""000%s\x03l\x09""000\x0B""051\x04""077\n"
+ "\x04""077";
+
const char *const DEPOSIT_WITHDRAWL[2] = { "Deposit", "Withdrawl" };
const char *const NOT_ENOUGH_X_IN_THE_Y =
diff --git a/engines/xeen/resources.h b/engines/xeen/resources.h
index 7461888c05..5dbc32174a 100644
--- a/engines/xeen/resources.h
+++ b/engines/xeen/resources.h
@@ -184,6 +184,8 @@ extern const char *const TRAINING_TEXT;
extern const char *const GOLD_GEMS;
+extern const char *const GOLD_GEMS_2;
+
extern const char *const DEPOSIT_WITHDRAWL[2];
extern const char *const NOT_ENOUGH_X_IN_THE_Y;
diff --git a/engines/xeen/town.cpp b/engines/xeen/town.cpp
index dceb79c354..9e1f04785f 100644
--- a/engines/xeen/town.cpp
+++ b/engines/xeen/town.cpp
@@ -21,6 +21,7 @@
*/
#include "xeen/town.h"
+#include "xeen/dialogs_input.h"
#include "xeen/resources.h"
#include "xeen/xeen.h"
@@ -322,7 +323,6 @@ void Town::dwarfEvent() {
}
Common::String Town::createTownText(Character &ch) {
- Interface &intf = *_vm->_interface;
Party &party = *_vm->_party;
Common::String msg;
@@ -507,7 +507,7 @@ void Town::depositWithdrawl(int choice) {
}
for (uint idx = 0; idx < _buttons.size(); ++idx)
- _buttons[idx]._sprites = &_icons1;
+ _buttons[idx]._sprites = &_icons2;
_buttons[0]._value = Common::KEYCODE_o;
_buttons[1]._value = Common::KEYCODE_e;
_buttons[2]._value = Common::KEYCODE_ESCAPE;
@@ -523,45 +523,141 @@ void Town::depositWithdrawl(int choice) {
screen._windows[35].update();
sound.playSample(nullptr, 0);
- File f("coina.voc");
- bool flag;
+ File voc("coina.voc");
+ bool flag = false;
do {
- bool flag;
switch (townWait()) {
case Common::KEYCODE_o:
- continue;
+ flag = false;
+ break;
case Common::KEYCODE_e:
- flag = 1;
+ flag = true;
break;
- default:
- flag = 0;
+ case Common::KEYCODE_ESCAPE:
break;
+ default:
+ continue;
}
if ((choice && !party._bankGems && flag) ||
(choice && !party._bankGold && !flag) ||
- (choice && !party._gems && flag) ||
- (choice && !party._gold && !flag)) {
+ (!choice && !party._gems && flag) ||
+ (!choice && !party._gold && !flag)) {
notEnough(flag, choice, 1, WT_2);
} else {
screen._windows[35].writeString(AMOUNT);
+ int amount = NumericInput::show(_vm, 35, 10, 77);
+
+ if (amount) {
+ if (flag) {
+ if (subtract(true, amount, choice, WT_2)) {
+ if (choice) {
+ party._gems += amount;
+ } else {
+ party._bankGems += amount;
+ }
+ }
+ } else {
+ if (subtract(false, amount, choice, WT_2)) {
+ if (choice) {
+ party._gold += amount;
+ } else {
+ party._bankGold += amount;
+ }
+ }
+ }
+ }
- // TODO
+ uint gold, gems;
+ if (choice) {
+ gold = party._bankGold;
+ gems = party._bankGems;
+ } else {
+ gold = party._gold;
+ gems = party._gems;
+ }
+
+ sound.playSample(&voc, 0);
+ msg = Common::String::format(GOLD_GEMS_2, DEPOSIT_WITHDRAWL[choice],
+ XeenEngine::printMil(gold), XeenEngine::printMil(gems));
+ screen._windows[35].writeString(msg);
+ screen._windows[35].update();
}
// TODO
} while (!_vm->shouldQuit() && _buttonValue != Common::KEYCODE_ESCAPE);
+ for (uint idx = 0; idx < _buttons.size(); ++idx)
+ _buttons[idx]._sprites = &_icons1;
+ _buttons[0]._value = Common::KEYCODE_d;
+ _buttons[1]._value = Common::KEYCODE_w;
+ _buttons[2]._value = Common::KEYCODE_ESCAPE;
}
void Town::notEnough(int consumableId, int whereId, bool mode, ErrorWaitType wait) {
- SoundManager &sound = *_vm->_sound;
-
Common::String msg = Common::String::format(
mode ? NO_X_IN_THE_Y : NOT_ENOUGH_X_IN_THE_Y,
CONSUMABLE_NAMES[consumableId], WHERE_NAMES[whereId]);
ErrorScroll::show(_vm, msg, wait);
}
+int Town::subtract(int mode, uint amount, int whereId, ErrorWaitType wait) {
+ Party &party = *_vm->_party;
+
+ switch (mode) {
+ case 0:
+ // Gold
+ if (whereId) {
+ if (amount <= party._bankGold) {
+ party._bankGold -= amount;
+ } else {
+ notEnough(0, whereId, false, wait);
+ return false;
+ }
+ } else {
+ if (amount <= party._gold) {
+ party._gold -= amount;
+ } else {
+ notEnough(0, whereId, false, wait);
+ return false;
+ }
+ }
+ break;
+
+ case 1:
+ // Gems
+ if (whereId) {
+ if (amount <= party._bankGems) {
+ party._bankGems -= amount;
+ } else {
+ notEnough(0, whereId, false, wait);
+ return false;
+ }
+ } else {
+ if (amount <= party._gems) {
+ party._gems -= amount;
+ } else {
+ notEnough(0, whereId, false, wait);
+ return false;
+ }
+ }
+ break;
+
+ case 2:
+ // Food
+ if (amount > party._food) {
+ party._food -= amount;
+ } else {
+ notEnough(5, 0, 0, wait);
+ return false;
+ }
+ break;
+
+ default:
+ break;
+ }
+
+ return true;
+}
} // End of namespace Xeen
diff --git a/engines/xeen/town.h b/engines/xeen/town.h
index 068cc8252b..df754d5cef 100644
--- a/engines/xeen/town.h
+++ b/engines/xeen/town.h
@@ -79,6 +79,8 @@ private:
void depositWithdrawl(int choice);
void notEnough(int consumableId, int whereId, bool mode, ErrorWaitType wait);
+
+ int subtract(int mode, uint amount, int whereId, ErrorWaitType wait);
public:
Town(XeenEngine *vm);