1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-07 03:54:40 +00:00
OpenMW/apps/openmw/mwrender/localmap.hpp

144 lines
4.7 KiB
C++
Raw Normal View History

#ifndef GAME_RENDER_LOCALMAP_H
#define GAME_RENDER_LOCALMAP_H
#include <openengine/ogre/renderer.hpp>
#include <OgreAxisAlignedBox.h>
2013-02-03 19:06:03 +00:00
#include <OgreColourValue.h>
#include <OgreResource.h>
namespace MWWorld
{
class CellStore;
}
namespace ESM
{
class FogTexture;
}
namespace MWRender
{
2012-04-02 17:37:24 +00:00
class RenderingManager;
///
/// \brief Local map rendering
///
class LocalMap : public Ogre::ManualResourceLoader
{
public:
LocalMap(OEngine::Render::OgreRenderer*, MWRender::RenderingManager* rendering);
2012-03-14 16:44:19 +00:00
~LocalMap();
virtual void loadResource(Ogre::Resource* resource);
/**
* Clear all savegame-specific data (i.e. fog of war textures)
*/
void clear();
/**
* Request the local map for an exterior cell.
2012-03-14 13:51:58 +00:00
* @remarks It will either be loaded from a disk cache,
* or rendered if it is not already cached.
* @param cell exterior cell
* @param zMin min height of objects or terrain in cell
* @param zMax max height of objects or terrain in cell
*/
void requestMap (MWWorld::CellStore* cell, float zMin, float zMax);
/**
* Request the local map for an interior cell.
2012-03-14 13:51:58 +00:00
* @remarks It will either be loaded from a disk cache,
* or rendered if it is not already cached.
* @param cell interior cell
* @param bounds bounding box of the cell
*/
void requestMap (MWWorld::CellStore* cell,
Ogre::AxisAlignedBox bounds);
2012-03-14 13:51:58 +00:00
/**
2012-03-23 14:00:48 +00:00
* Set the position & direction of the player.
2012-03-14 13:51:58 +00:00
* @remarks This is used to draw a "fog of war" effect
* to hide areas on the map the player has not discovered yet.
*/
void updatePlayer (const Ogre::Vector3& position, const Ogre::Quaternion& orientation);
2012-03-14 13:51:58 +00:00
/**
* Save the fog of war for this cell to its CellStore.
* @remarks This should be called when unloading a cell, and for all active cells prior to saving the game.
*/
void saveFogOfWar(MWWorld::CellStore* cell);
2012-08-28 15:30:34 +00:00
/**
* Get the interior map texture index and normalized position
* on this texture, given a world position
2012-08-28 15:30:34 +00:00
*/
void worldToInteriorMapPosition (Ogre::Vector2 pos, float& nX, float& nY, int& x, int& y);
Ogre::Vector2 interiorMapToWorldPosition (float nX, float nY, int x, int y);
2012-08-28 15:30:34 +00:00
/**
* Check if a given position is explored by the player (i.e. not obscured by fog of war)
*/
bool isPositionExplored (float nX, float nY, int x, int y, bool interior);
private:
OEngine::Render::OgreRenderer* mRendering;
2012-04-02 17:37:24 +00:00
MWRender::RenderingManager* mRenderingManager;
2012-11-16 21:26:00 +00:00
static const int sMapResolution = 512;
2012-03-18 19:44:56 +00:00
// the dynamic texture is a bottleneck, so don't set this too high
static const int sFogOfWarResolution = 32;
// frames to skip before rendering fog of war
static const int sFogOfWarSkip = 2;
// size of a map segment (for exteriors, 1 cell)
static const int sSize = 8192;
Ogre::Camera* mCellCamera;
2012-03-29 16:16:11 +00:00
Ogre::SceneNode* mCameraNode;
Ogre::SceneNode* mCameraPosNode;
2012-03-29 16:16:11 +00:00
Ogre::SceneNode* mCameraRotNode;
// directional light from a fixed angle
Ogre::Light* mLight;
2012-04-02 17:37:24 +00:00
float mAngle;
const Ogre::Vector2 rotatePoint(const Ogre::Vector2& p, const Ogre::Vector2& c, const float angle);
/// @param force Always render, even if we already have a cached map
void render(const float x, const float y,
const float zlow, const float zhigh,
const float xw, const float yw,
const std::string& texture, bool force=false);
2012-03-14 13:51:58 +00:00
// Creates a fog of war texture and initializes it to full black
void createFogOfWar(const std::string& texturePrefix);
// Loads a fog of war texture from its ESM struct
void loadFogOfWar(const std::string& texturePrefix, ESM::FogTexture& esm); // FogTexture not const because MemoryDataStream doesn't accept it
Ogre::TexturePtr createFogOfWarTexture(const std::string& name);
std::string coordStr(const int x, const int y);
// A buffer for the "fog of war" textures of the current cell.
// Both interior and exterior maps are possibly divided into multiple textures.
2012-03-26 22:18:09 +00:00
std::map <std::string, std::vector<Ogre::uint32> > mBuffers;
2012-03-14 16:44:19 +00:00
// The render texture we will use to create the map images
Ogre::TexturePtr mRenderTexture;
Ogre::RenderTarget* mRenderTarget;
2012-03-14 16:44:19 +00:00
bool mInterior;
int mCellX, mCellY;
2012-03-14 16:44:19 +00:00
Ogre::AxisAlignedBox mBounds;
std::string mInteriorName;
};
}
#endif