aboutsummaryrefslogtreecommitdiff
path: root/gui
diff options
context:
space:
mode:
authorMax Horn2002-07-07 22:44:30 +0000
committerMax Horn2002-07-07 22:44:30 +0000
commit10d86be56456b57392cca05d5a2135408289223c (patch)
treeca7d19195a38b260fbd625e9f634a71843c1c4bf /gui
parentc90ade1f10d3ff0c2f7e429ec5d688b7db8637c9 (diff)
downloadscummvm-rg350-10d86be56456b57392cca05d5a2135408289223c.tar.gz
scummvm-rg350-10d86be56456b57392cca05d5a2135408289223c.tar.bz2
scummvm-rg350-10d86be56456b57392cca05d5a2135408289223c.zip
added options dialog; added NewGui TODO list;
svn-id: r4485
Diffstat (limited to 'gui')
-rw-r--r--gui/dialog.cpp73
-rw-r--r--gui/dialog.h19
2 files changed, 72 insertions, 20 deletions
diff --git a/gui/dialog.cpp b/gui/dialog.cpp
index 36694ab8ff..a4491d0c07 100644
--- a/gui/dialog.cpp
+++ b/gui/dialog.cpp
@@ -56,6 +56,15 @@ void Dialog::handleMouseMoved(int x, int y, int button)
}
+void Dialog::handleCommand(uint32 cmd)
+{
+ switch (cmd) {
+ case kCloseCmd:
+ close();
+ break;
+ }
+}
+
/*
* Determine the widget at location (x,y) if any. Assumes the coordinates are
* in the local coordinate system, i.e. relative to the top left of the dialog.
@@ -80,7 +89,7 @@ void Dialog::close()
void Dialog::addResText(int x, int y, int w, int h, int resID)
{
// Get the string
- const char *str = _gui->queryString(resID);
+ const char *str = _gui->queryResString(resID);
if (!str)
str = "Dummy!";
new StaticTextWidget(this, x, y, w, h, str);
@@ -92,17 +101,9 @@ void Dialog::addButton(int x, int y, int w, int h, char hotkey, const char *labe
// TODO - handle hotkey
}
-void Dialog::addButton(int x, int y, int w, int h, char hotkey, int resID, uint32 cmd)
-{
- // Get the string
- const char *label = _gui->queryString(resID);
- if (!label)
- label = "Dummy!";
- addButton(x, y, w, h, hotkey, label, cmd);
-}
-
#pragma mark -
+
enum {
kSaveCmd = 'SAVE',
kLoadCmd = 'LOAD',
@@ -118,11 +119,11 @@ SaveLoadDialog::SaveLoadDialog(NewGui *gui)
// addResText(10, 7, 240, 16, 2);
// addResText(10, 7, 240, 16, 3);
- addButton(200, 20, 54, 16, 'S', 4, kSaveCmd); // Save
- addButton(200, 40, 54, 16, 'L', 5, kLoadCmd); // Load
- addButton(200, 60, 54, 16, 'P', 6, kPlayCmd); // Play
- addButton(200, 80, 54, 16, 'O', 17, kOptionsCmd); // Options
- addButton(200, 100, 54, 16, 'Q', 8, kQuitCmd); // Quit
+ addButton(200, 20, 54, 16, 'S', RES_STRING(4), kSaveCmd); // Save
+ addButton(200, 40, 54, 16, 'L', RES_STRING(5), kLoadCmd); // Load
+ addButton(200, 60, 54, 16, 'P', RES_STRING(6), kPlayCmd); // Play
+ addButton(200, 80, 54, 16, 'O', CUSTOM_STRING(17), kOptionsCmd); // Options
+ addButton(200, 100, 54, 16, 'Q', RES_STRING(8), kQuitCmd); // Quit
}
void SaveLoadDialog::handleCommand(uint32 cmd)
@@ -131,17 +132,55 @@ void SaveLoadDialog::handleCommand(uint32 cmd)
case kSaveCmd:
break;
case kLoadCmd:
- // FIXME HACK - just to demo the nesting ability
- _gui->pauseDialog();
break;
case kPlayCmd:
close();
break;
case kOptionsCmd:
+ _gui->optionsDialog();
break;
case kQuitCmd:
exit(1);
break;
+ default:
+ Dialog::handleCommand(cmd);
+ }
+}
+
+
+#pragma mark -
+
+enum {
+ kSoundCmd = 'SOUN',
+ kKeysCmd = 'KEYS',
+ kAboutCmd = 'ABOU',
+ kMiscCmd = 'OPTN'
+};
+
+OptionsDialog::OptionsDialog(NewGui *gui)
+ : Dialog (gui, 50, 80, 210, 60)
+{
+ addButton( 10, 10, 40, 15, 'S', CUSTOM_STRING(5), kSoundCmd); // Sound
+ addButton( 80, 10, 40, 15, 'K', CUSTOM_STRING(6), kKeysCmd); // Keys
+ addButton(150, 10, 40, 15, 'A', CUSTOM_STRING(7), kAboutCmd); // About
+ addButton( 10, 35, 40, 15, 'M', CUSTOM_STRING(18), kMiscCmd); // Misc
+ addButton(150, 35, 40, 15, 'C', CUSTOM_STRING(23), kCloseCmd); // Close dialog - FIXME
+}
+
+void OptionsDialog::handleCommand(uint32 cmd)
+{
+ switch (cmd) {
+ case kSoundCmd:
+ break;
+ case kKeysCmd:
+ break;
+ case kAboutCmd:
+ _gui->aboutDialog();
+ break;
+ case kMiscCmd:
+ break;
+ default:
+ Dialog::handleCommand(cmd);
}
}
diff --git a/gui/dialog.h b/gui/dialog.h
index a164cc0185..9d7756a2c4 100644
--- a/gui/dialog.h
+++ b/gui/dialog.h
@@ -27,6 +27,14 @@
class Widget;
class NewGui;
+#define RES_STRING(id) _gui->queryResString(id)
+#define CUSTOM_STRING(id) _gui->queryCustomString(id)
+
+// Some "common" commands sent to handleCommand()
+enum {
+ kCloseCmd = 'clos'
+};
+
class Dialog {
friend class Widget;
friend class StaticTextWidget;
@@ -48,8 +56,7 @@ public:
virtual void handleKey(char key, int modifiers) // modifiers = alt/shift/ctrl etc.
{ if (key == 27) close(); }
virtual void handleMouseMoved(int x, int y, int button);
- virtual void handleCommand(uint32 cmd)
- {}
+ virtual void handleCommand(uint32 cmd);
protected:
Widget* findWidget(int x, int y); // Find the widget at pos x,y if any
@@ -57,7 +64,6 @@ protected:
void addResText(int x, int y, int w, int h, int resID);
void addButton(int x, int y, int w, int h, char hotkey, const char *label, uint32 cmd);
- void addButton(int x, int y, int w, int h, char hotkey, int resID, uint32 cmd);
};
class SaveLoadDialog : public Dialog {
@@ -67,6 +73,13 @@ public:
virtual void handleCommand(uint32 cmd);
};
+class OptionsDialog : public Dialog {
+public:
+ OptionsDialog(NewGui *gui);
+
+ virtual void handleCommand(uint32 cmd);
+};
+
class PauseDialog : public Dialog {
public:
PauseDialog(NewGui *gui);