1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00
OpenMW/apps/openmw/mwrender/localmap.hpp

104 lines
3.3 KiB
C++
Raw Normal View History

#ifndef _GAME_RENDER_LOCALMAP_H
#define _GAME_RENDER_LOCALMAP_H
#include "../mwworld/ptr.hpp"
#include <openengine/ogre/renderer.hpp>
namespace MWRender
{
2012-04-02 19:37:24 +02:00
class RenderingManager;
///
/// \brief Local map rendering
///
class LocalMap
{
public:
LocalMap(OEngine::Render::OgreRenderer*, MWRender::RenderingManager* rendering);
2012-03-14 17:44:19 +01:00
~LocalMap();
/**
* Request the local map for an exterior cell.
2012-03-14 14:51:58 +01:00
* @remarks It will either be loaded from a disk cache,
* or rendered if it is not already cached.
* @param exterior cell
*/
void requestMap (MWWorld::Ptr::CellStore* cell);
/**
* Request the local map for an interior cell.
2012-03-14 14:51:58 +01:00
* @remarks It will either be loaded from a disk cache,
* or rendered if it is not already cached.
* @param interior cell
* @param bounding box of the cell
*/
void requestMap (MWWorld::Ptr::CellStore* cell,
Ogre::AxisAlignedBox bounds);
2012-03-14 14:51:58 +01:00
/**
2012-03-23 15:00:48 +01:00
* Set the position & direction of the player.
2012-03-14 14:51:58 +01:00
* @remarks This is used to draw a "fog of war" effect
* to hide areas on the map the player has not discovered yet.
* @param position (OGRE coordinates)
* @param camera orientation (OGRE coordinates)
2012-03-14 14:51:58 +01:00
*/
void updatePlayer (const Ogre::Vector3& position, const Ogre::Quaternion& orientation);
2012-03-14 14:51:58 +01:00
/**
* Save the fog of war for the current cell to disk.
* @remarks This should be called before loading a
* new cell, as well as when the game is quit.
* @param current cell
*/
void saveFogOfWar(MWWorld::Ptr::CellStore* cell);
private:
OEngine::Render::OgreRenderer* mRendering;
2012-04-02 19:37:24 +02:00
MWRender::RenderingManager* mRenderingManager;
2012-03-18 20:44:56 +01:00
// 1024*1024 pixels for a cell
static const int sMapResolution = 1024;
// 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 18:16:11 +02:00
Ogre::SceneNode* mCameraNode;
Ogre::SceneNode* mCameraPosNode;
2012-03-29 18:16:11 +02:00
Ogre::SceneNode* mCameraRotNode;
2012-04-02 19:37:24 +02:00
float mAngle;
const Ogre::Vector2 rotatePoint(const Ogre::Vector2& p, const Ogre::Vector2& c, const float angle);
void render(const float x, const float y,
const float zlow, const float zhigh,
const float xw, const float yw,
const std::string& texture);
2012-03-14 14:51:58 +01:00
void saveTexture(const std::string& texname, const std::string& filename);
std::string coordStr(const int x, const int y);
2012-03-14 14:51:58 +01:00
// a buffer for the "fog of war" texture of the current cell.
// interior cells could be divided into multiple textures,
// so we store in a map.
2012-03-27 00:18:09 +02:00
std::map <std::string, std::vector<Ogre::uint32> > mBuffers;
2012-03-14 17:44:19 +01:00
void deleteBuffers();
bool mInterior;
int mCellX, mCellY;
2012-03-14 17:44:19 +01:00
Ogre::AxisAlignedBox mBounds;
std::string mInteriorName;
};
}
#endif