2012-01-21 16:59:08 +00:00
|
|
|
#ifndef _GAME_RENDER_TERRAIN_H
|
|
|
|
#define _GAME_RENDER_TERRAIN_H
|
|
|
|
|
2012-01-21 17:59:12 +00:00
|
|
|
#include <OgreTerrain.h>
|
|
|
|
|
2012-01-21 16:59:08 +00:00
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
|
|
|
|
namespace Ogre{
|
|
|
|
class SceneManager;
|
|
|
|
class TerrainGroup;
|
|
|
|
class TerrainGlobalOptions;
|
2012-01-21 17:59:12 +00:00
|
|
|
class Terrain;
|
2012-01-21 16:59:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
namespace MWRender{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implements the Morrowind terrain using the Ogre Terrain Component
|
|
|
|
*/
|
|
|
|
class TerrainManager{
|
|
|
|
public:
|
|
|
|
TerrainManager(Ogre::SceneManager*);
|
|
|
|
virtual ~TerrainManager();
|
|
|
|
|
|
|
|
void cellAdded(MWWorld::Ptr::CellStore* store);
|
|
|
|
void cellRemoved(MWWorld::Ptr::CellStore* store);
|
|
|
|
private:
|
|
|
|
Ogre::TerrainGlobalOptions* mTerrainGlobals;
|
|
|
|
Ogre::TerrainGroup* mTerrainGroup;
|
2012-01-21 17:59:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The distance that the current cell should be shaded into the neighbouring
|
|
|
|
* texture. The distance is in terms of the splat size of a texture
|
|
|
|
*/
|
|
|
|
static const float TERRAIN_SHADE_DISTANCE = 0.5;
|
|
|
|
|
|
|
|
/**
|
2012-01-23 17:19:54 +00:00
|
|
|
* Setups up the list of textures for part of a cell, using indexes as
|
|
|
|
* an output to create a mapping of MW LtexIndex to the relevant terrain
|
|
|
|
* layer
|
|
|
|
*
|
2012-01-21 17:59:12 +00:00
|
|
|
* @param terrainData the terrain data to setup the textures for
|
2012-01-23 17:19:54 +00:00
|
|
|
* @param store the cell store for the given terrain cell
|
|
|
|
* @param fromX the ltex index in the current cell to start making the texture from
|
|
|
|
* @param fromY the ltex index in the current cell to start making the texture from
|
|
|
|
* @param size the size (number of splats) to get
|
2012-01-21 17:59:12 +00:00
|
|
|
* @param indexes a mapping of ltex index to the terrain texture layer that
|
|
|
|
* can be used by initTerrainBlendMaps
|
|
|
|
*/
|
|
|
|
void initTerrainTextures(Ogre::Terrain::ImportData* terrainData,
|
|
|
|
MWWorld::Ptr::CellStore* store,
|
2012-01-23 17:19:54 +00:00
|
|
|
int fromX, int fromY, int size,
|
2012-01-21 17:59:12 +00:00
|
|
|
std::map<uint16_t, int>& indexes);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates the blend (splatting maps) for the given terrain from the ltex data.
|
2012-01-23 17:19:54 +00:00
|
|
|
*
|
2012-01-21 17:59:12 +00:00
|
|
|
* @param terrain the terrain object for the current cell
|
2012-01-23 17:19:54 +00:00
|
|
|
* @param store the cell store for the given terrain cell
|
|
|
|
* @param fromX the ltex index in the current cell to start making the texture from
|
|
|
|
* @param fromY the ltex index in the current cell to start making the texture from
|
|
|
|
* @param size the size (number of splats) to get
|
2012-01-21 17:59:12 +00:00
|
|
|
* @param indexes the mapping of ltex to blend map produced by initTerrainTextures
|
|
|
|
*/
|
|
|
|
void initTerrainBlendMaps(Ogre::Terrain* terrain,
|
|
|
|
MWWorld::Ptr::CellStore* store,
|
2012-01-23 17:19:54 +00:00
|
|
|
int fromX, int fromY, int size,
|
2012-01-21 17:59:12 +00:00
|
|
|
const std::map<uint16_t, int>& indexes);
|
2012-01-23 17:19:54 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a LTEX index at the given point, assuming the current cell
|
|
|
|
* starts at (0,0). This supports getting values from the surrounding
|
|
|
|
* cells so negative x, y is acceptable
|
|
|
|
*
|
|
|
|
* @param store the cell store for the current cell
|
|
|
|
* @param x, y the splat position of the ltex index to get relative to the
|
|
|
|
* first splat of the current cell
|
|
|
|
*/
|
|
|
|
int getLtexIndexAt(MWWorld::Ptr::CellStore* store, int x, int y);
|
|
|
|
|
2012-01-21 16:59:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // _GAME_RENDER_TERRAIN_H
|