summaryrefslogtreecommitdiffhomepage
path: root/Stars45/ConfirmDlg.cpp
diff options
context:
space:
mode:
authorFWoltermann@gmail.com <FWoltermann@gmail.com@076cb2c4-205e-83fd-5cf3-1be9aa105544>2011-12-08 14:53:40 +0000
committerFWoltermann@gmail.com <FWoltermann@gmail.com@076cb2c4-205e-83fd-5cf3-1be9aa105544>2011-12-08 14:53:40 +0000
commite33e19d0587146859d48a134ec9fd94e7b7ba5cd (patch)
tree69d048c8801858d2756ab3a487090a7a1b74bf14 /Stars45/ConfirmDlg.cpp
downloadstarshatter-e33e19d0587146859d48a134ec9fd94e7b7ba5cd.zip
starshatter-e33e19d0587146859d48a134ec9fd94e7b7ba5cd.tar.gz
starshatter-e33e19d0587146859d48a134ec9fd94e7b7ba5cd.tar.bz2
Initial upload
Diffstat (limited to 'Stars45/ConfirmDlg.cpp')
-rw-r--r--Stars45/ConfirmDlg.cpp150
1 files changed, 150 insertions, 0 deletions
diff --git a/Stars45/ConfirmDlg.cpp b/Stars45/ConfirmDlg.cpp
new file mode 100644
index 0000000..858faee
--- /dev/null
+++ b/Stars45/ConfirmDlg.cpp
@@ -0,0 +1,150 @@
+/* Project Starshatter 4.5
+ Destroyer Studios LLC
+ Copyright © 1997-2004. All Rights Reserved.
+
+ SUBSYSTEM: Stars.exe
+ FILE: ConfirmDlg.cpp
+ AUTHOR: John DiCamillo
+
+
+ OVERVIEW
+ ========
+ General-purpose confirmation dialog class
+*/
+
+#include "MemDebug.h"
+#include "ConfirmDlg.h"
+#include "MenuScreen.h"
+#include "Starshatter.h"
+#include "FormatUtil.h"
+
+#include "Game.h"
+#include "Keyboard.h"
+#include "Button.h"
+
+// +--------------------------------------------------------------------+
+// DECLARE MAPPING FUNCTIONS:
+
+DEF_MAP_CLIENT(ConfirmDlg, OnApply);
+DEF_MAP_CLIENT(ConfirmDlg, OnCancel);
+
+// +--------------------------------------------------------------------+
+
+ConfirmDlg::ConfirmDlg(Screen* s, FormDef& def, MenuScreen* mgr)
+ : FormWindow(s, 0, 0, s->Width(), s->Height()), manager(mgr),
+ parent_control(0), btn_apply(0), btn_cancel(0)
+{
+ Init(def);
+}
+
+ConfirmDlg::~ConfirmDlg()
+{
+}
+
+void
+ConfirmDlg::RegisterControls()
+{
+ if (btn_apply)
+ return;
+
+ btn_apply = (Button*) FindControl(1);
+ REGISTER_CLIENT(EID_CLICK, btn_apply, ConfirmDlg, OnApply);
+
+ btn_cancel = (Button*) FindControl(2);
+ REGISTER_CLIENT(EID_CLICK, btn_cancel, ConfirmDlg, OnCancel);
+
+ lbl_title = FindControl(100);
+ lbl_message = FindControl(101);
+}
+
+// +--------------------------------------------------------------------+
+
+ActiveWindow*
+ConfirmDlg::GetParentControl()
+{
+ return parent_control;
+}
+
+void
+ConfirmDlg::SetParentControl(ActiveWindow* p)
+{
+ parent_control = p;
+}
+
+Text
+ConfirmDlg::GetTitle()
+{
+ if (lbl_title)
+ return lbl_title->GetText();
+
+ return "";
+}
+
+void
+ConfirmDlg::SetTitle(const char* t)
+{
+ if (lbl_title)
+ lbl_title->SetText(t);
+}
+
+Text
+ConfirmDlg::GetMessage()
+{
+ if (lbl_message)
+ return lbl_message->GetText();
+
+ return "";
+}
+
+void
+ConfirmDlg::SetMessage(const char* m)
+{
+ if (lbl_message)
+ lbl_message->SetText(m);
+}
+
+// +--------------------------------------------------------------------+
+
+void
+ConfirmDlg::ExecFrame()
+{
+ if (Keyboard::KeyDown(VK_RETURN)) {
+ OnApply(0);
+ }
+
+ if (Keyboard::KeyDown(VK_ESCAPE)) {
+ OnCancel(0);
+ }
+}
+
+// +--------------------------------------------------------------------+
+
+void
+ConfirmDlg::Show()
+{
+ if (!IsShown()) {
+ Button::PlaySound(Button::SND_CONFIRM);
+ }
+
+ FormWindow::Show();
+ SetFocus();
+}
+
+// +--------------------------------------------------------------------+
+
+void
+ConfirmDlg::OnApply(AWEvent* event)
+{
+ manager->HideConfirmDlg();
+
+ if (parent_control)
+ parent_control->ClientEvent(EID_USER_1);
+}
+
+void
+ConfirmDlg::OnCancel(AWEvent* event)
+{
+ manager->HideConfirmDlg();
+}
+
+// +--------------------------------------------------------------------+