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/MsnNavDlg.cpp | |
parent | 8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff) | |
download | starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.zip starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.gz starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.bz2 |
Moved Stars45 to StarsEx
Diffstat (limited to 'StarsEx/MsnNavDlg.cpp')
-rw-r--r-- | StarsEx/MsnNavDlg.cpp | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/StarsEx/MsnNavDlg.cpp b/StarsEx/MsnNavDlg.cpp new file mode 100644 index 0000000..7858aaf --- /dev/null +++ b/StarsEx/MsnNavDlg.cpp @@ -0,0 +1,102 @@ +/* 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 + ======== + Mission Briefing Dialog Active Window class +*/ + +#include "MsnNavDlg.h" +#include "PlanScreen.h" +#include "Campaign.h" +#include "Mission.h" +#include "Instruction.h" +#include "Ship.h" +#include "ShipDesign.h" +#include "StarSystem.h" + +#include "Keyboard.h" + +// +--------------------------------------------------------------------+ +// DECLARE MAPPING FUNCTIONS: +DEF_MAP_CLIENT(MsnNavDlg, OnCommit); +DEF_MAP_CLIENT(MsnNavDlg, OnCancel); +DEF_MAP_CLIENT(MsnNavDlg, OnTabButton); + +// +--------------------------------------------------------------------+ + +MsnNavDlg::MsnNavDlg(Screen* s, FormDef& def, PlanScreen* mgr) +: NavDlg(s, def, mgr), MsnDlg(mgr) +{ + RegisterControls(); +} + +MsnNavDlg::~MsnNavDlg() +{ +} + +// +--------------------------------------------------------------------+ + +void +MsnNavDlg::RegisterControls() +{ + RegisterMsnControls(this); + + if (commit) + REGISTER_CLIENT(EID_CLICK, commit, MsnNavDlg, OnCommit); + + if (cancel) + REGISTER_CLIENT(EID_CLICK, cancel, MsnNavDlg, OnCancel); + + if (sit_button) + REGISTER_CLIENT(EID_CLICK, sit_button, MsnNavDlg, OnTabButton); + + if (pkg_button) + REGISTER_CLIENT(EID_CLICK, pkg_button, MsnNavDlg, OnTabButton); + + if (nav_button) + REGISTER_CLIENT(EID_CLICK, nav_button, MsnNavDlg, OnTabButton); + + if (wep_button) + REGISTER_CLIENT(EID_CLICK, wep_button, MsnNavDlg, OnTabButton); +} + +// +--------------------------------------------------------------------+ + +void +MsnNavDlg::Show() +{ + NavDlg::Show(); + ShowMsnDlg(); +} + +void +MsnNavDlg::ExecFrame() +{ + NavDlg::ExecFrame(); + + if (Keyboard::KeyDown(VK_RETURN)) { + OnCommit(0); + } +} + +// +--------------------------------------------------------------------+ + +void +MsnNavDlg::OnCommit(AWEvent* event) +{ + MsnDlg::OnCommit(event); + NavDlg::OnCommit(event); +} + +void +MsnNavDlg::OnCancel(AWEvent* event) +{ + MsnDlg::OnCancel(event); + NavDlg::OnCancel(event); +} |