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/CmdOrdersDlg.cpp | |
parent | 8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff) | |
download | starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.zip starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.gz starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.bz2 |
Moved Stars45 to StarsEx
Diffstat (limited to 'StarsEx/CmdOrdersDlg.cpp')
-rw-r--r-- | StarsEx/CmdOrdersDlg.cpp | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/StarsEx/CmdOrdersDlg.cpp b/StarsEx/CmdOrdersDlg.cpp new file mode 100644 index 0000000..7fd4183 --- /dev/null +++ b/StarsEx/CmdOrdersDlg.cpp @@ -0,0 +1,138 @@ +/* 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 + ======== + Operational Command Dialog (Campaign Orders Tab) +*/ + +#include "CmdOrdersDlg.h" +#include "CmdDlg.h" +#include "CmpnScreen.h" +#include "Starshatter.h" +#include "Campaign.h" +#include "Combatant.h" +#include "CombatGroup.h" +#include "CombatUnit.h" +#include "ShipDesign.h" + +#include "Game.h" +#include "ContentBundle.h" +#include "DataLoader.h" +#include "Button.h" +#include "ComboBox.h" +#include "ListBox.h" +#include "Slider.h" +#include "Video.h" +#include "Keyboard.h" +#include "Mouse.h" +#include "ParseUtil.h" +#include "FormatUtil.h" + +// +--------------------------------------------------------------------+ +// DECLARE MAPPING FUNCTIONS: + +DEF_MAP_CLIENT(CmdOrdersDlg, OnMode); +DEF_MAP_CLIENT(CmdOrdersDlg, OnSave); +DEF_MAP_CLIENT(CmdOrdersDlg, OnExit); + +// +--------------------------------------------------------------------+ + +CmdOrdersDlg::CmdOrdersDlg(Screen* s, FormDef& def, CmpnScreen* mgr) + : FormWindow(s, 0, 0, s->Width(), s->Height()), CmdDlg(mgr), manager(mgr), + lbl_orders(0), stars(0), campaign(0) +{ + stars = Starshatter::GetInstance(); + campaign = Campaign::GetCampaign(); + + Init(def); +} + +CmdOrdersDlg::~CmdOrdersDlg() +{ +} + +// +--------------------------------------------------------------------+ + +void +CmdOrdersDlg::RegisterControls() +{ + lbl_orders = FindControl(400); + + RegisterCmdControls(this); + + if (btn_save) + REGISTER_CLIENT(EID_CLICK, btn_save, CmdOrdersDlg, OnSave); + + if (btn_exit) + REGISTER_CLIENT(EID_CLICK, btn_exit, CmdOrdersDlg, OnExit); + + for (int i = 0; i < 5; i++) { + if (btn_mode[i]) + REGISTER_CLIENT(EID_CLICK, btn_mode[i], CmdOrdersDlg, OnMode); + } +} + +// +--------------------------------------------------------------------+ + +void +CmdOrdersDlg::Show() +{ + mode = MODE_ORDERS; + + FormWindow::Show(); + ShowCmdDlg(); + + campaign = Campaign::GetCampaign(); + + if (campaign && lbl_orders) { + Text orders("<font Limerick12><color ffff80>"); + orders += ContentBundle::GetInstance()->GetText("CmdOrdersDlg.situation"); + orders += "\n<font Verdana><color ffffff>"; + if (*campaign->Situation()) + orders += campaign->Situation(); + else + orders += campaign->Description(); + + orders += "\n\n<font Limerick12><color ffff80>"; + orders += ContentBundle::GetInstance()->GetText("CmdOrdersDlg.orders"); + orders += "\n<font Verdana><color ffffff>"; + orders += campaign->Orders(); + + lbl_orders->SetText(orders); + } +} + +// +--------------------------------------------------------------------+ + +void +CmdOrdersDlg::ExecFrame() +{ + CmdDlg::ExecFrame(); +} + +// +--------------------------------------------------------------------+ + +void +CmdOrdersDlg::OnSave(AWEvent* event) +{ + CmdDlg::OnSave(event); +} + +void +CmdOrdersDlg::OnExit(AWEvent* event) +{ + CmdDlg::OnExit(event); +} + +void +CmdOrdersDlg::OnMode(AWEvent* event) +{ + CmdDlg::OnMode(event); +} + |