mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-12 12:38:02 +00:00
e27437f8ed
- Consistent triangle alignment, fixes a noticable crack near the census and excise office. Note that alignment is still not the same as vanilla. Vanilla uses a weird diagonal pattern. I hope there aren't more trouble spots that will force us to replicate vanilla, but at least we can do that now. - Fixes several blending issues and cell border seams - Fix map render to use the terrain bounding box instead of an arbitrary height - Different LODs are now properly connected instead of using skirts - Support self shadowing - Normals and colors are stored in the vertices instead of a texture, this enables per-vertex lighting which should improve performance, fix compatibility issues due to the PS getting too large and mimic vanilla better - Support a fixed function fallback (though the splatting shader usually performs better) - Designed for distant land support - test: https://www.youtube.com/watch?v=2wnd9EuPJIY - we can't really enable this yet due to depth precision issues when using a large view distance
126 lines
4.0 KiB
C++
126 lines
4.0 KiB
C++
#ifndef _GAME_RENDER_LOCALMAP_H
|
|
#define _GAME_RENDER_LOCALMAP_H
|
|
|
|
#include <openengine/ogre/renderer.hpp>
|
|
|
|
#include <OgreAxisAlignedBox.h>
|
|
#include <OgreColourValue.h>
|
|
|
|
namespace MWWorld
|
|
{
|
|
class CellStore;
|
|
}
|
|
|
|
namespace MWRender
|
|
{
|
|
class RenderingManager;
|
|
|
|
///
|
|
/// \brief Local map rendering
|
|
///
|
|
class LocalMap
|
|
{
|
|
public:
|
|
LocalMap(OEngine::Render::OgreRenderer*, MWRender::RenderingManager* rendering);
|
|
~LocalMap();
|
|
|
|
/**
|
|
* Request the local map for an exterior cell.
|
|
* @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.
|
|
* @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);
|
|
|
|
/**
|
|
* Set the position & direction of the player.
|
|
* @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)
|
|
*/
|
|
void updatePlayer (const Ogre::Vector3& position, const Ogre::Quaternion& orientation);
|
|
|
|
/**
|
|
* 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::CellStore* cell);
|
|
|
|
/**
|
|
* Get the interior map texture index and normalized position
|
|
* on this texture, given a world position (in ogre coordinates)
|
|
*/
|
|
void getInteriorMapPosition (Ogre::Vector2 pos, float& nX, float& nY, int& x, int& y);
|
|
|
|
/**
|
|
* 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;
|
|
MWRender::RenderingManager* mRenderingManager;
|
|
|
|
// 1024*1024 pixels for a cell
|
|
static const int sMapResolution = 512;
|
|
|
|
// 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;
|
|
Ogre::SceneNode* mCameraNode;
|
|
Ogre::SceneNode* mCameraPosNode;
|
|
Ogre::SceneNode* mCameraRotNode;
|
|
|
|
// directional light from a fixed angle
|
|
Ogre::Light* mLight;
|
|
|
|
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);
|
|
|
|
void saveTexture(const std::string& texname, const std::string& filename);
|
|
|
|
std::string coordStr(const int x, const int y);
|
|
|
|
// 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.
|
|
std::map <std::string, std::vector<Ogre::uint32> > mBuffers;
|
|
|
|
void deleteBuffers();
|
|
|
|
bool mInterior;
|
|
int mCellX, mCellY;
|
|
Ogre::AxisAlignedBox mBounds;
|
|
std::string mInteriorName;
|
|
};
|
|
|
|
}
|
|
#endif
|