2010-07-17 12:01:47 +00:00
|
|
|
#ifndef MWGUI_WINDOWMANAGER_H
|
|
|
|
#define MWGUI_WINDOWMANAGER_H
|
|
|
|
|
|
|
|
/**
|
|
|
|
This class owns and controls all the MW specific windows in the
|
|
|
|
GUI. It can enable/disable Gui mode, and is responsible for sending
|
|
|
|
and retrieving information from the Gui.
|
|
|
|
|
|
|
|
MyGUI should be initialized separately before creating instances of
|
|
|
|
this class.
|
|
|
|
*/
|
|
|
|
|
2010-07-26 09:15:38 +00:00
|
|
|
#include <string>
|
2010-08-22 09:22:10 +00:00
|
|
|
#include <vector>
|
2010-09-17 23:30:23 +00:00
|
|
|
#include <set>
|
2010-07-26 09:15:38 +00:00
|
|
|
|
2010-10-21 07:28:09 +00:00
|
|
|
#include <components/esm_store/store.hpp>
|
2010-07-27 13:59:41 +00:00
|
|
|
#include "../mwmechanics/stat.hpp"
|
2010-09-15 12:48:19 +00:00
|
|
|
#include "mode.hpp"
|
2010-07-27 13:59:41 +00:00
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
namespace MyGUI
|
|
|
|
{
|
|
|
|
class Gui;
|
2010-10-09 22:42:56 +00:00
|
|
|
class Widget;
|
2010-07-17 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2010-07-20 21:21:48 +00:00
|
|
|
namespace Compiler
|
|
|
|
{
|
|
|
|
class Extensions;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
class Environment;
|
|
|
|
}
|
|
|
|
|
2010-10-22 20:53:34 +00:00
|
|
|
namespace OEngine
|
|
|
|
{
|
|
|
|
namespace GUI
|
|
|
|
{
|
|
|
|
class Layout;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
namespace MWGui
|
|
|
|
{
|
2011-02-21 21:33:29 +00:00
|
|
|
class WindowBase;
|
2010-07-17 12:01:47 +00:00
|
|
|
class HUD;
|
|
|
|
class MapWindow;
|
|
|
|
class MainMenu;
|
|
|
|
class StatsWindow;
|
2010-09-10 01:29:29 +00:00
|
|
|
class InventoryWindow;
|
2010-07-20 19:10:51 +00:00
|
|
|
class Console;
|
2010-07-17 12:01:47 +00:00
|
|
|
|
2010-09-14 21:17:08 +00:00
|
|
|
class TextInputDialog;
|
2010-10-09 22:42:56 +00:00
|
|
|
class InfoBoxDialog;
|
2010-09-12 12:06:10 +00:00
|
|
|
class RaceDialog;
|
2010-11-03 20:21:08 +00:00
|
|
|
class DialogueWindow;
|
2010-10-09 22:42:56 +00:00
|
|
|
class ClassChoiceDialog;
|
2010-10-09 23:52:08 +00:00
|
|
|
class GenerateClassResultDialog;
|
2010-09-19 02:29:22 +00:00
|
|
|
class PickClassDialog;
|
2010-10-10 00:43:44 +00:00
|
|
|
class CreateClassDialog;
|
2010-09-21 10:34:47 +00:00
|
|
|
class BirthDialog;
|
2010-10-20 19:40:32 +00:00
|
|
|
class ReviewDialog;
|
2010-09-12 12:06:10 +00:00
|
|
|
|
2011-01-02 16:42:45 +00:00
|
|
|
struct ClassPoint
|
|
|
|
{
|
|
|
|
const char *id;
|
|
|
|
// Specialization points to match, in order: Stealth, Combat, Magic
|
|
|
|
// Note: Order is taken from http://www.uesp.net/wiki/Morrowind:Class_Quiz
|
|
|
|
unsigned int points[3];
|
|
|
|
};
|
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
class WindowManager
|
|
|
|
{
|
2010-10-21 07:28:09 +00:00
|
|
|
public:
|
|
|
|
typedef std::pair<std::string, int> Faction;
|
|
|
|
typedef std::vector<Faction> FactionList;
|
|
|
|
typedef std::vector<int> SkillList;
|
|
|
|
|
|
|
|
private:
|
2010-09-14 19:27:40 +00:00
|
|
|
MWWorld::Environment& environment;
|
2010-07-17 12:01:47 +00:00
|
|
|
HUD *hud;
|
|
|
|
MapWindow *map;
|
|
|
|
MainMenu *menu;
|
|
|
|
StatsWindow *stats;
|
2010-09-15 11:15:58 +00:00
|
|
|
#if 0
|
2010-09-10 01:29:29 +00:00
|
|
|
InventoryWindow *inventory;
|
2010-09-15 11:15:58 +00:00
|
|
|
#endif
|
2010-07-20 19:10:51 +00:00
|
|
|
Console *console;
|
2010-07-17 12:01:47 +00:00
|
|
|
|
2010-09-14 19:27:40 +00:00
|
|
|
// Character creation
|
2010-09-14 21:17:08 +00:00
|
|
|
TextInputDialog *nameDialog;
|
2010-09-14 19:55:41 +00:00
|
|
|
RaceDialog *raceDialog;
|
2010-11-03 20:21:08 +00:00
|
|
|
DialogueWindow *dialogueWindow;
|
2010-10-09 22:42:56 +00:00
|
|
|
ClassChoiceDialog *classChoiceDialog;
|
|
|
|
InfoBoxDialog *generateClassQuestionDialog;
|
2010-10-09 23:52:08 +00:00
|
|
|
GenerateClassResultDialog *generateClassResultDialog;
|
2010-09-19 02:29:22 +00:00
|
|
|
PickClassDialog *pickClassDialog;
|
2010-10-10 00:43:44 +00:00
|
|
|
CreateClassDialog *createClassDialog;
|
2010-09-21 10:34:47 +00:00
|
|
|
BirthDialog *birthSignDialog;
|
2010-10-20 19:40:32 +00:00
|
|
|
ReviewDialog *reviewDialog;
|
2010-09-12 12:06:10 +00:00
|
|
|
|
2010-10-09 22:42:56 +00:00
|
|
|
// Keeps track of current step in Generate Class dialogs
|
|
|
|
unsigned generateClassStep;
|
2010-10-23 22:45:21 +00:00
|
|
|
// A counter for each specialization which is increased when an answer is chosen, in order: Stealth, Combat, Magic
|
|
|
|
unsigned generateClassSpecializations[3];
|
2010-10-09 23:52:08 +00:00
|
|
|
std::string generateClass;
|
2010-10-09 22:42:56 +00:00
|
|
|
|
2010-10-21 07:28:09 +00:00
|
|
|
// Various stats about player as needed by window manager
|
|
|
|
std::string playerName;
|
|
|
|
ESM::Class playerClass;
|
|
|
|
std::string playerRaceId, playerBirthSignId;
|
|
|
|
std::map<ESM::Attribute::AttributeID, MWMechanics::Stat<int> > playerAttributes;
|
|
|
|
SkillList playerMajorSkills, playerMinorSkills;
|
|
|
|
std::map<ESM::Skill::SkillEnum, MWMechanics::Stat<float> > playerSkillValues;
|
|
|
|
MWMechanics::DynamicStat<int> playerHealth, playerMagicka, playerFatigue;
|
|
|
|
|
|
|
|
// Gui
|
2010-07-17 12:01:47 +00:00
|
|
|
MyGUI::Gui *gui;
|
|
|
|
|
|
|
|
// Current gui mode
|
|
|
|
GuiMode mode;
|
|
|
|
|
2010-10-22 20:53:34 +00:00
|
|
|
/**
|
|
|
|
* Next mode to activate in update().
|
|
|
|
*/
|
|
|
|
GuiMode nextMode;
|
|
|
|
/**
|
|
|
|
* Whether a mode change is needed in update().
|
|
|
|
* Will use @a nextMode as the new mode.
|
|
|
|
*/
|
|
|
|
bool needModeChange;
|
|
|
|
|
|
|
|
std::vector<OEngine::GUI::Layout*> garbageDialogs;
|
2010-10-22 21:21:15 +00:00
|
|
|
void cleanupGarbage();
|
2010-10-22 20:53:34 +00:00
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
// Currently shown windows in inventory mode
|
|
|
|
GuiWindow shown;
|
|
|
|
|
|
|
|
/* Currently ALLOWED windows in inventory mode. This is used at
|
|
|
|
the start of the game, when windows are enabled one by one
|
|
|
|
through script commands. You can manipulate this through using
|
|
|
|
allow() and disableAll().
|
|
|
|
|
|
|
|
The setting should also affect visibility of certain HUD
|
|
|
|
elements, but this is not done yet.
|
|
|
|
*/
|
|
|
|
GuiWindow allowed;
|
|
|
|
|
|
|
|
// Update visibility of all windows based on mode, shown and
|
|
|
|
// allowed settings.
|
|
|
|
void updateVisible();
|
|
|
|
|
2010-10-22 20:53:34 +00:00
|
|
|
void setGuiMode(GuiMode newMode);
|
|
|
|
|
2011-02-18 14:46:24 +00:00
|
|
|
bool showFPSCounter;
|
|
|
|
float mFPS;
|
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
public:
|
|
|
|
/// The constructor needs the main Gui object
|
2010-07-20 21:21:48 +00:00
|
|
|
WindowManager(MyGUI::Gui *_gui, MWWorld::Environment& environment,
|
2011-02-18 14:46:24 +00:00
|
|
|
const Compiler::Extensions& extensions, bool fpsSwitch, bool newGame);
|
2010-07-17 12:01:47 +00:00
|
|
|
virtual ~WindowManager();
|
|
|
|
|
2010-10-22 20:53:34 +00:00
|
|
|
/**
|
|
|
|
* Should be called each frame to update windows/gui elements.
|
|
|
|
* This could mean updating sizes of gui elements or opening
|
|
|
|
* new dialogs.
|
|
|
|
*/
|
|
|
|
void update();
|
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
void setMode(GuiMode newMode)
|
|
|
|
{
|
2010-07-21 08:28:58 +00:00
|
|
|
if (newMode==GM_Inventory && allowed==GW_None)
|
|
|
|
return;
|
2010-07-28 16:48:01 +00:00
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
mode = newMode;
|
|
|
|
updateVisible();
|
|
|
|
}
|
2010-10-22 20:53:34 +00:00
|
|
|
void setNextMode(GuiMode newMode);
|
2010-07-17 12:01:47 +00:00
|
|
|
|
|
|
|
GuiMode getMode() const { return mode; }
|
|
|
|
|
|
|
|
// Everything that is not game mode is considered "gui mode"
|
|
|
|
bool isGuiMode() const { return getMode() != GM_Game; }
|
|
|
|
|
|
|
|
// Disallow all inventory mode windows
|
|
|
|
void disallowAll()
|
|
|
|
{
|
|
|
|
allowed = GW_None;
|
|
|
|
updateVisible();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Allow one or more windows
|
|
|
|
void allow(GuiWindow wnd)
|
|
|
|
{
|
|
|
|
allowed = (GuiWindow)(allowed | wnd);
|
|
|
|
updateVisible();
|
|
|
|
}
|
|
|
|
|
|
|
|
MyGUI::Gui* getGui() const { return gui; }
|
2010-07-28 16:48:01 +00:00
|
|
|
|
2011-02-18 14:46:24 +00:00
|
|
|
void wmSetFPS(float fps) { mFPS = fps; }
|
|
|
|
|
2010-07-27 13:59:41 +00:00
|
|
|
void setValue (const std::string& id, const MWMechanics::Stat<int>& value);
|
|
|
|
///< Set value for the given ID.
|
2010-07-28 16:48:01 +00:00
|
|
|
|
2011-01-02 16:35:03 +00:00
|
|
|
void setValue(const ESM::Skill::SkillEnum parSkill, const MWMechanics::Stat<float>& value);
|
2010-09-18 16:04:53 +00:00
|
|
|
///< Set value for the given ID.
|
|
|
|
|
2010-07-28 16:48:01 +00:00
|
|
|
void setValue (const std::string& id, const MWMechanics::DynamicStat<int>& value);
|
|
|
|
///< Set value for the given ID.
|
2010-08-22 09:22:10 +00:00
|
|
|
|
2010-09-15 10:22:06 +00:00
|
|
|
void setValue (const std::string& id, const std::string& value);
|
|
|
|
///< set value for the given ID.
|
|
|
|
|
2010-09-15 13:32:35 +00:00
|
|
|
void setValue (const std::string& id, int value);
|
|
|
|
///< set value for the given ID.
|
|
|
|
|
2010-10-21 07:28:09 +00:00
|
|
|
void setPlayerClass (const ESM::Class &class_);
|
|
|
|
///< set current class of player
|
|
|
|
|
2010-09-18 17:26:45 +00:00
|
|
|
void configureSkills (const SkillList& major, const SkillList& minor);
|
2010-09-17 23:30:23 +00:00
|
|
|
///< configure skill groups, each set contains the skill ID for that group.
|
|
|
|
|
2010-09-18 16:21:37 +00:00
|
|
|
void setFactions (const FactionList& factions);
|
|
|
|
///< set faction and rank to display on stat window, use an empty vector to disable
|
2010-09-18 00:24:42 +00:00
|
|
|
|
2010-09-18 16:44:20 +00:00
|
|
|
void setBirthSign (const std::string &signId);
|
|
|
|
///< set birth sign to display on stat window, use an empty string to disable.
|
2010-09-18 00:24:42 +00:00
|
|
|
|
|
|
|
void setReputation (int reputation);
|
|
|
|
///< set the current reputation value
|
|
|
|
|
|
|
|
void setBounty (int bounty);
|
|
|
|
///< set the current bounty value
|
|
|
|
|
|
|
|
void updateSkillArea();
|
|
|
|
///< update display of skills, factions, birth sign, reputation and bounty
|
2010-09-17 23:30:23 +00:00
|
|
|
|
2010-10-22 21:14:21 +00:00
|
|
|
template<typename T>
|
|
|
|
void removeDialog(T*& dialog);
|
|
|
|
///< Casts to OEngine::GUI::Layout and calls removeDialog, then resets pointer to nullptr.
|
|
|
|
|
|
|
|
void removeDialog(OEngine::GUI::Layout* dialog);
|
|
|
|
///< Hides dialog and schedules dialog to be deleted.
|
|
|
|
|
2010-08-22 09:22:10 +00:00
|
|
|
void messageBox (const std::string& message, const std::vector<std::string>& buttons);
|
2010-09-14 17:33:40 +00:00
|
|
|
|
2010-09-15 10:41:53 +00:00
|
|
|
/**
|
|
|
|
* Fetches a GMST string from the store, if there is no setting with the given
|
|
|
|
* ID or it is not a string the default string is returned.
|
|
|
|
*
|
|
|
|
* @param id Identifier for the GMST setting, e.g. "aName"
|
|
|
|
* @param default Default value if the GMST setting cannot be used.
|
|
|
|
*/
|
2010-09-15 20:22:27 +00:00
|
|
|
const std::string &getGameSettingString(const std::string &id, const std::string &default_);
|
2010-09-15 10:41:53 +00:00
|
|
|
|
2011-02-21 19:36:35 +00:00
|
|
|
ESMS::ESMStore& getStore();
|
|
|
|
|
2010-09-14 17:33:40 +00:00
|
|
|
private:
|
2010-11-03 20:21:08 +00:00
|
|
|
|
|
|
|
void onDialogueWindowBye();
|
|
|
|
|
2010-09-14 21:17:08 +00:00
|
|
|
// Character generation: Name dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onNameDialogDone(WindowBase* parWindow);
|
2010-09-14 21:17:08 +00:00
|
|
|
|
|
|
|
// Character generation: Race dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onRaceDialogDone(WindowBase* parWindow);
|
2010-09-14 17:33:40 +00:00
|
|
|
void onRaceDialogBack();
|
2010-09-19 02:29:22 +00:00
|
|
|
|
2010-10-09 22:42:56 +00:00
|
|
|
// Character generation: Choose class process
|
2011-01-02 15:23:35 +00:00
|
|
|
void onClassChoice(int _index);
|
2010-10-09 22:42:56 +00:00
|
|
|
|
|
|
|
// Character generation: Generate Class
|
|
|
|
void showClassQuestionDialog();
|
2011-01-02 15:23:35 +00:00
|
|
|
void onClassQuestionChosen(int _index);
|
2010-10-09 23:52:08 +00:00
|
|
|
void onGenerateClassBack();
|
2011-02-21 21:33:29 +00:00
|
|
|
void onGenerateClassDone(WindowBase* parWindow);
|
2010-10-09 22:42:56 +00:00
|
|
|
|
2010-09-19 02:29:22 +00:00
|
|
|
// Character generation: Pick Class dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onPickClassDialogDone(WindowBase* parWindow);
|
2010-09-19 02:29:22 +00:00
|
|
|
void onPickClassDialogBack();
|
2010-09-21 10:34:47 +00:00
|
|
|
|
2010-10-10 00:43:44 +00:00
|
|
|
// Character generation: Create Class dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onCreateClassDialogDone(WindowBase* parWindow);
|
2010-10-10 00:43:44 +00:00
|
|
|
void onCreateClassDialogBack();
|
|
|
|
|
2010-09-21 10:34:47 +00:00
|
|
|
// Character generation: Birth sign dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onBirthSignDialogDone(WindowBase* parWindow);
|
2010-09-21 10:34:47 +00:00
|
|
|
void onBirthSignDialogBack();
|
2010-10-20 19:40:32 +00:00
|
|
|
|
|
|
|
// Character generation: Review dialog
|
2011-02-21 21:33:29 +00:00
|
|
|
void onReviewDialogDone(WindowBase* parWindow);
|
2010-10-20 19:40:32 +00:00
|
|
|
void onReviewDialogBack();
|
2011-01-02 15:43:13 +00:00
|
|
|
void onReviewActivateDialog(int parDialog);
|
2011-01-02 23:57:40 +00:00
|
|
|
|
|
|
|
enum CreationStageEnum
|
|
|
|
{
|
|
|
|
NotStarted,
|
|
|
|
NameChosen,
|
|
|
|
RaceChosen,
|
|
|
|
ClassChosen,
|
|
|
|
BirthSignChosen,
|
|
|
|
ReviewNext
|
|
|
|
};
|
|
|
|
|
|
|
|
// Which state the character creating is in, controls back/next/ok buttons
|
|
|
|
CreationStageEnum creationStage;
|
2010-07-17 12:01:47 +00:00
|
|
|
};
|
2010-10-22 21:14:21 +00:00
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void WindowManager::removeDialog(T*& dialog)
|
|
|
|
{
|
|
|
|
OEngine::GUI::Layout *d = static_cast<OEngine::GUI::Layout*>(dialog);
|
|
|
|
removeDialog(d);
|
2010-10-22 21:34:41 +00:00
|
|
|
dialog = 0;
|
2010-10-22 21:14:21 +00:00
|
|
|
}
|
2010-07-17 12:01:47 +00:00
|
|
|
}
|
2010-10-22 21:14:21 +00:00
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
#endif
|