aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/wage/gui.h2
-rw-r--r--engines/wage/menu.cpp48
-rw-r--r--engines/wage/menu.h5
3 files changed, 43 insertions, 12 deletions
diff --git a/engines/wage/gui.h b/engines/wage/gui.h
index 7e91479b07..8ba9ce904d 100644
--- a/engines/wage/gui.h
+++ b/engines/wage/gui.h
@@ -105,9 +105,9 @@ public:
bool _cursorOff;
bool _builtInFonts;
+ WageEngine *_engine;
private:
- WageEngine *_engine;
Graphics::Surface _console;
Menu *_menu;
Scene *_scene;
diff --git a/engines/wage/menu.cpp b/engines/wage/menu.cpp
index c89ec83372..fab8d04ebb 100644
--- a/engines/wage/menu.cpp
+++ b/engines/wage/menu.cpp
@@ -48,18 +48,51 @@
#include "common/system.h"
#include "wage/wage.h"
+#include "wage/entities.h"
#include "wage/design.h"
#include "wage/gui.h"
#include "wage/menu.h"
+#include "wage/world.h"
namespace Wage {
-static const char *menuItems[] = {
- "\xf0", "File", "Edit", "Commands", "Weapons", 0
+struct MenuSubItem {
+ Common::String text;
+ int style;
+ char shortcut;
+ bool enabled;
+
+ MenuSubItem(Common::String &t, int s, char sh) : text(t), style(s), shortcut(sh), enabled(true) {}
+};
+
+struct MenuItem {
+ Common::String name;
+ Common::Array<MenuSubItem *> subitems;
+
+ MenuItem(const char *n) : name(n) {}
};
static byte fillPattern[8] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
+Menu::Menu(Gui *gui) : _gui(gui) {
+ MenuItem *about = new MenuItem(_gui->_builtInFonts ? "\xa9" : "\xf0"); // (c) Symbol as the most resembling apple
+ _items.push_back(about);
+
+ MenuItem *file = new MenuItem("File");
+ _items.push_back(file);
+
+ MenuItem *edit = new MenuItem("Edit");
+ _items.push_back(edit);
+
+ MenuItem *commands = new MenuItem("Commands");
+ _items.push_back(commands);
+
+ if (!_gui->_engine->_world->_weaponMenuDisabled) {
+ MenuItem *weapons = new MenuItem("Weapons");
+ _items.push_back(weapons);
+ }
+}
+
const Graphics::Font *Menu::getMenuFont() {
return _gui->getFont("Chicago-12", Graphics::FontManager::kBigGUIFont);
}
@@ -79,14 +112,9 @@ void Menu::render() {
int y = _gui->_builtInFonts ? 3 : 2;
int x = 18;
- for (int i = 0; menuItems[i]; i++) {
- const char *s = menuItems[i];
-
- if (i == 0 && _gui->_builtInFonts)
- s = "\xa9"; // (c) Symbol as the most resembling apple
-
- int w = font->getStringWidth(s);
- font->drawString(&_gui->_screen, s, x, y, w, kColorBlack);
+ for (int i = 0; i < _items.size(); i++) {
+ int w = font->getStringWidth(_items[i]->name);
+ font->drawString(&_gui->_screen, _items[i]->name, x, y, w, kColorBlack);
x += w + 13;
}
diff --git a/engines/wage/menu.h b/engines/wage/menu.h
index 9831814ccb..aec92cf5e1 100644
--- a/engines/wage/menu.h
+++ b/engines/wage/menu.h
@@ -50,9 +50,11 @@
namespace Wage {
+struct MenuItem;
+
class Menu {
public:
- Menu(Gui *gui) : _gui(gui) {}
+ Menu(Gui *gui);
void render();
@@ -61,6 +63,7 @@ private:
private:
const Graphics::Font *getMenuFont();
+ Common::Array<MenuItem *> _items;
};
} // End of namespace Wage