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.
|
2012-01-30 19:53:17 +00:00
|
|
|
**/
|
2010-07-17 12:01:47 +00:00
|
|
|
|
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>
|
2012-01-29 15:31:18 +00:00
|
|
|
#include <openengine/ogre/renderer.hpp>
|
|
|
|
#include <openengine/gui/manager.hpp>
|
2010-07-27 13:59:41 +00:00
|
|
|
#include "../mwmechanics/stat.hpp"
|
2012-03-16 16:09:31 +00:00
|
|
|
#include "../mwworld/ptr.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;
|
2012-01-30 14:38:43 +00:00
|
|
|
class World;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWMechanics
|
|
|
|
{
|
|
|
|
class MechanicsManager;
|
2010-07-20 21:21:48 +00:00
|
|
|
}
|
|
|
|
|
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;
|
2011-11-28 15:51:11 +00:00
|
|
|
class JournalWindow;
|
2012-01-30 14:38:43 +00:00
|
|
|
class CharacterCreation;
|
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-11-03 20:21:08 +00:00
|
|
|
class DialogueWindow;
|
2011-06-14 16:29:55 +00:00
|
|
|
class MessageBoxManager;
|
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;
|
|
|
|
|
2012-02-03 10:24:28 +00:00
|
|
|
WindowManager(MWWorld::Environment& environment, const Compiler::Extensions& extensions, int fpsLevel, bool newGame, OEngine::Render::OgreRenderer *mOgre, const std::string logpath);
|
2010-07-17 12:01:47 +00:00
|
|
|
virtual ~WindowManager();
|
|
|
|
|
2010-10-22 20:53:34 +00:00
|
|
|
void setGuiMode(GuiMode newMode);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Should be called each frame to update windows/gui elements.
|
|
|
|
* This could mean updating sizes of gui elements or opening
|
|
|
|
* new dialogs.
|
|
|
|
*/
|
|
|
|
void update();
|
|
|
|
|
2011-12-29 16:58:58 +00:00
|
|
|
MWWorld::Environment& getEnvironment();
|
|
|
|
|
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; }
|
|
|
|
|
2012-01-30 19:53:17 +00:00
|
|
|
bool isGuiMode() const { return getMode() != GM_Game; } // Everything that is not game mode is considered "gui mode"
|
2010-07-17 12:01:47 +00:00
|
|
|
|
|
|
|
// 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();
|
|
|
|
}
|
|
|
|
|
2012-02-05 09:54:56 +00:00
|
|
|
MWGui::DialogueWindow* getDialogueWindow() {return dialogueWindow;}
|
|
|
|
|
2010-07-17 12:01:47 +00:00
|
|
|
MyGUI::Gui* getGui() const { return gui; }
|
2010-07-28 16:48:01 +00:00
|
|
|
|
2012-01-16 18:16:33 +00:00
|
|
|
void wmUpdateFps(float fps, size_t triangleCount, size_t batchCount)
|
2012-01-16 15:33:21 +00:00
|
|
|
{
|
|
|
|
mFPS = fps;
|
|
|
|
mTriangleCount = triangleCount;
|
|
|
|
mBatchCount = batchCount;
|
|
|
|
}
|
2011-02-18 14:46:24 +00:00
|
|
|
|
2012-02-03 10:24:28 +00:00
|
|
|
// MWMechanics::DynamicStat<int> getValue(const std::string& id);
|
2010-07-28 16:48:01 +00:00
|
|
|
|
2010-09-18 16:04:53 +00:00
|
|
|
///< Set value for the given ID.
|
2012-01-30 19:53:17 +00:00
|
|
|
void setValue (const std::string& id, const MWMechanics::Stat<int>& value);
|
|
|
|
void setValue(const ESM::Skill::SkillEnum parSkill, const MWMechanics::Stat<float>& value);
|
2010-07-28 16:48:01 +00:00
|
|
|
void setValue (const std::string& id, const MWMechanics::DynamicStat<int>& value);
|
2010-09-15 10:22:06 +00:00
|
|
|
void setValue (const std::string& id, const std::string& value);
|
2010-09-15 13:32:35 +00:00
|
|
|
void setValue (const std::string& id, int value);
|
2010-09-17 23:30:23 +00:00
|
|
|
|
2012-01-30 19:53:17 +00:00
|
|
|
void setPlayerClass (const ESM::Class &class_); ///< set current class of player
|
|
|
|
void configureSkills (const SkillList& major, const SkillList& minor); ///< configure skill groups, each set contains the skill ID for that group.
|
|
|
|
void setFactions (const FactionList& factions); ///< set faction and rank to display on stat window, use an empty vector to disable
|
|
|
|
void setBirthSign (const std::string &signId); ///< set birth sign to display on stat window, use an empty string to disable.
|
|
|
|
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-18 00:24:42 +00:00
|
|
|
|
2012-03-16 16:09:31 +00:00
|
|
|
void changeCell(MWWorld::Ptr::CellStore* cell); ///< change the active cell
|
2012-03-23 07:16:04 +00:00
|
|
|
void setPlayerPos(const float x, const float y); ///< set player position in map space
|
2012-03-23 14:00:48 +00:00
|
|
|
void setPlayerDir(const float x, const float y); ///< set player view direction in map space
|
2012-03-17 12:59:51 +00:00
|
|
|
|
|
|
|
void setInteriorMapTexture(const int x, const int y);
|
|
|
|
///< set the index of the map texture that should be used (for interiors)
|
2012-03-10 15:05:12 +00:00
|
|
|
|
2010-10-22 21:14:21 +00:00
|
|
|
template<typename T>
|
2012-01-30 19:53:17 +00:00
|
|
|
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-10-22 21:14:21 +00:00
|
|
|
|
2010-08-22 09:22:10 +00:00
|
|
|
void messageBox (const std::string& message, const std::vector<std::string>& buttons);
|
2012-01-30 19:53:17 +00:00
|
|
|
int readPressedButton (); ///< returns the index of the pressed button or -1 if no button was pressed (->MessageBoxmanager->InteractiveMessageBox)
|
2012-02-03 10:24:28 +00:00
|
|
|
|
2011-06-15 20:53:05 +00:00
|
|
|
void onFrame (float frameDuration);
|
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-04-21 08:49:45 +00:00
|
|
|
const ESMS::ESMStore& getStore() const;
|
2011-02-21 19:36:35 +00:00
|
|
|
|
2010-09-14 17:33:40 +00:00
|
|
|
private:
|
2012-02-03 10:24:28 +00:00
|
|
|
OEngine::GUI::MyGUIManager *mGuiManager;
|
2012-02-02 16:31:28 +00:00
|
|
|
MWWorld::Environment& environment;
|
|
|
|
HUD *hud;
|
|
|
|
MapWindow *map;
|
|
|
|
MainMenu *menu;
|
|
|
|
StatsWindow *stats;
|
|
|
|
MessageBoxManager *mMessageBoxManager;
|
|
|
|
Console *console;
|
|
|
|
JournalWindow* mJournal;
|
|
|
|
DialogueWindow *dialogueWindow;
|
2010-11-03 20:21:08 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
CharacterCreation* mCharGen;
|
2012-02-03 10:24:28 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
// Various stats about player as needed by window manager
|
|
|
|
ESM::Class playerClass;
|
|
|
|
std::string playerName;
|
|
|
|
std::string playerRaceId;
|
|
|
|
std::string 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;
|
2010-11-03 20:21:08 +00:00
|
|
|
|
2010-09-14 21:17:08 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
MyGUI::Gui *gui; // Gui
|
|
|
|
GuiMode mode; // Current gui mode
|
|
|
|
GuiMode nextMode; // Next mode to activate in update()
|
|
|
|
bool needModeChange; //Whether a mode change is needed in update() [will use nextMode]
|
2010-09-19 02:29:22 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
std::vector<OEngine::GUI::Layout*> garbageDialogs;
|
|
|
|
void cleanupGarbage();
|
2010-10-09 22:42:56 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
GuiWindow shown; // Currently shown windows in inventory mode
|
2010-10-09 22:42:56 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
/* 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().
|
2010-09-21 10:34:47 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
The setting should also affect visibility of certain HUD
|
|
|
|
elements, but this is not done yet.
|
|
|
|
*/
|
|
|
|
GuiWindow allowed;
|
2010-10-10 00:43:44 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
void updateVisible(); // Update visibility of all windows based on mode, shown and allowed settings
|
2010-10-20 19:40:32 +00:00
|
|
|
|
2012-02-02 16:31:28 +00:00
|
|
|
int showFPSLevel;
|
|
|
|
float mFPS;
|
|
|
|
size_t mTriangleCount;
|
|
|
|
size_t mBatchCount;
|
2011-01-02 23:57:40 +00:00
|
|
|
|
2010-11-03 20:21:08 +00:00
|
|
|
void onDialogueWindowBye();
|
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
|