diff options
author | Aki <please@ignore.pl> | 2022-04-01 21:23:39 +0200 |
---|---|---|
committer | Aki <please@ignore.pl> | 2022-04-01 21:23:39 +0200 |
commit | 3c487c5cd69c53d6fea948643c0a76df03516605 (patch) | |
tree | 72730c7b8b26a5ef8fc9a987ec4c16129efd5aac /StarsEx/ConfirmDlg.cpp | |
parent | 8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff) | |
download | starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.zip starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.gz starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.bz2 |
Moved Stars45 to StarsEx
Diffstat (limited to 'StarsEx/ConfirmDlg.cpp')
-rw-r--r-- | StarsEx/ConfirmDlg.cpp | 148 |
1 files changed, 148 insertions, 0 deletions
diff --git a/StarsEx/ConfirmDlg.cpp b/StarsEx/ConfirmDlg.cpp new file mode 100644 index 0000000..4e528f5 --- /dev/null +++ b/StarsEx/ConfirmDlg.cpp @@ -0,0 +1,148 @@ +/* Starshatter: The Open Source Project + Copyright (c) 2021-2022, Starshatter: The Open Source Project Contributors + Copyright (c) 2011-2012, Starshatter OpenSource Distribution Contributors + Copyright (c) 1997-2006, Destroyer Studios LLC. + + AUTHOR: John DiCamillo + + + OVERVIEW + ======== + General-purpose confirmation dialog class +*/ + +#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(); +} + +// +--------------------------------------------------------------------+ |