OGRE 2.1
Object-Oriented Graphics Rendering Engine
|
The main containing class for a chunk of terrain. More...
#include <OgreTerrain.h>
Classes | |
class | DefaultGpuBufferAllocator |
Standard implementation of a buffer allocator which re-uses buffers. More... | |
class | GpuBufferAllocator |
Interface used to by the Terrain instance to allocate GPU buffers. More... | |
struct | ImportData |
Structure encapsulating import data that you may use to bootstrap the terrain without loading from a native data stream. More... | |
struct | LayerInstance |
An instance of a layer, with specific texture names. More... | |
Public Types | |
enum | Alignment { ALIGN_X_Z = 0 , ALIGN_X_Y = 1 , ALIGN_Y_Z = 2 } |
The alignment of the terrain. More... | |
typedef vector< LayerInstance >::type | LayerInstanceList |
enum | NeighbourIndex { NEIGHBOUR_EAST = 0 , NEIGHBOUR_NORTHEAST = 1 , NEIGHBOUR_NORTH = 2 , NEIGHBOUR_NORTHWEST = 3 , NEIGHBOUR_WEST = 4 , NEIGHBOUR_SOUTHWEST = 5 , NEIGHBOUR_SOUTH = 6 , NEIGHBOUR_SOUTHEAST = 7 , NEIGHBOUR_COUNT = 8 } |
Neighbour index enumeration - indexed anticlockwise from East like angles. More... | |
typedef vector< Real >::type | RealVector |
enum | Space { WORLD_SPACE = 0 , LOCAL_SPACE = 1 , TERRAIN_SPACE = 2 , POINT_SPACE = 3 } |
Enumeration of relative spaces that you might want to use to address the terrain. More... | |
Public Member Functions | |
Terrain (SceneManager *sm) | |
Constructor. | |
virtual | ~Terrain () |
void | _dirtyCompositeMapRect (const Rect &rect) |
Mark a region of the terrain composite map as dirty. | |
void | _dumpTextures (const String &prefix, const String &suffix) |
Dump textures to files. | |
const MaterialPtr & | _getCompositeMapMaterial () const |
Internal getting of material for the terrain composite map. | |
const String & | _getDerivedResourceGroup () const |
Get the final resource group to use when loading / saving. | |
const MaterialPtr & | _getMaterial () const |
Internal getting of material. | |
bool | _getMorphRequired () const |
Get whether LOD morphing is needed. | |
SceneNode * | _getRootSceneNode () const |
Get the root scene node for the terrain (internal use only) | |
bool | _getUseVertexCompression () const |
Whether we're using vertex compression or not. | |
void | _setCompositeMapRequired (bool compositeMap) |
Request internal implementation options for the terrain material to use, in this case a terrain-wide composite map. | |
void | _setLightMapRequired (bool lightMap, bool shadowsOnly=false) |
Request internal implementation options for the terrain material to use, in this case a terrain-wide normal map. | |
void | _setMorphRequired (bool morph) |
Request internal implementation options for the terrain material to use, in this case vertex morphing information. | |
void | _setNormalMapRequired (bool normalMap) |
Request internal implementation options for the terrain material to use, in this case a terrain-wide normal map. | |
void | addLayer (Real worldSize=0, const StringVector *textureNames=0) |
Add a new layer to this terrain. | |
void | addLayer (uint8 index, Real worldSize=0, const StringVector *textureNames=0) |
Add a new layer to this terrain at a specific index. | |
void | addQueryFlags (uint32 flags) |
As setQueryFlags, except the flags passed as parameters are appended to the existing flags on this object. | |
Rect | calculateHeightDeltas (const Rect &rect) |
Calculate (or recalculate) the delta values of heights between a vertex in its recorded position, and the place it will end up in the LOD in which it is removed. | |
PixelBox * | calculateLightmap (const Rect &rect, const Rect &extraTargetRect, Rect &outFinalRect) |
Calculate (or recalculate) the terrain lightmap. | |
PixelBox * | calculateNormals (const Rect &rect, Rect &outFinalRect) |
Calculate (or recalculate) the normals on the terrain. | |
bool | canHandleRequest (const WorkQueue::Request *req, const WorkQueue *srcQ) |
WorkQueue::RequestHandler override. | |
bool | canHandleResponse (const WorkQueue::Response *res, const WorkQueue *srcQ) |
WorkQueue::ResponseHandler override. | |
Vector3 | convertDirection (Space inSpace, const Vector3 &inDir, Space outSpace) const |
Convert a direction from one space to another with respect to this terrain. | |
void | convertDirection (Space inSpace, const Vector3 &inDir, Space outSpace, Vector3 &outDir) const |
Convert a direction from one space to another with respect to this terrain. | |
Vector3 | convertPosition (Space inSpace, const Vector3 &inPos, Space outSpace) const |
Convert a position from one space to another with respect to this terrain. | |
void | convertPosition (Space inSpace, const Vector3 &inPos, Space outSpace, Vector3 &outPos) const |
Convert a position from one space to another with respect to this terrain. | |
void | decreaseLodLevel () |
Removes highest LOD level loaded. | |
void | dirty () |
Mark the entire terrain as dirty. | |
void | dirtyLightmap () |
Mark a the entire lightmap as dirty. | |
void | dirtyLightmapRect (const Rect &rect) |
Mark a region of the lightmap as dirty. | |
void | dirtyRect (const Rect &rect) |
Mark a region of the terrain as dirty. | |
void | finaliseHeightDeltas (const Rect &rect, bool cpuData) |
Finalise the height deltas. | |
void | finaliseLightmap (const Rect &rect, PixelBox *lightmapBox) |
Finalise the lightmap. | |
void | finaliseNormals (const Rect &rect, PixelBox *normalsBox) |
Finalise the normals. | |
virtual bool | frameEnded (const FrameEvent &evt) |
Called just after a frame has been rendered. | |
virtual bool | frameRenderingQueued (const FrameEvent &evt) |
Called after all render targets have had their rendering commands issued, but before render windows have been asked to flip their buffers over. | |
virtual bool | frameStarted (const FrameEvent &evt) |
Called when a frame is about to begin rendering. | |
void | freeTemporaryResources () |
Free as many resources as possible for optimal run-time memory use. | |
const AxisAlignedBox & | getAABB () const |
Get the AABB (local coords) of the entire terrain. | |
Alignment | getAlignment () const |
Get the alignment of the terrain. | |
uint8 | getBlendTextureCount () const |
Get the number of blend textures in use. | |
uint8 | getBlendTextureCount (uint8 numLayers) const |
Get the number of blend textures needed for a given number of layers. | |
uint8 | getBlendTextureIndex (uint8 layerIndex) const |
Get the index of the blend texture that a given layer uses. | |
const String & | getBlendTextureName (uint8 textureIndex) const |
Get the name of the packed blend texture at a specific index. | |
Real | getBoundingRadius () const |
Get the bounding radius of the entire terrain. | |
const TexturePtr & | getCompositeMap () const |
Get access to the composite map, if enabled (as requested by the material generator) | |
const MaterialPtr & | getCompositeMapMaterial () const |
Get the material being used for the terrain composite map. | |
uint16 | getCompositeMapSize () const |
Get the requested size of composite map for this terrain. | |
const float * | getDeltaData () const |
Get a pointer to all the delta data for this terrain. | |
const float * | getDeltaData (long x, long y) const |
Get a pointer to the delta data for a given point. | |
const TexturePtr & | getGlobalColourMap () const |
Get access to the global colour map, if enabled. | |
bool | getGlobalColourMapEnabled () const |
Get whether a global colour map is enabled on this terrain. | |
uint16 | getGlobalColourMapSize () const |
Get the size of the global colour map (if used) | |
GpuBufferAllocator * | getGpuBufferAllocator () |
Get the current buffer allocator. | |
float | getHeightAtPoint (long x, long y) const |
Get the height data for a given terrain point. | |
float | getHeightAtTerrainPosition (Real x, Real y) const |
Get the height data for a given terrain position. | |
float | getHeightAtWorldPosition (const Vector3 &pos) const |
Get the height data for a given world position (projecting the point down on to the terrain). | |
float | getHeightAtWorldPosition (Real x, Real y, Real z) const |
Get the height data for a given world position (projecting the point down on to the terrain). | |
float * | getHeightData () const |
Get a pointer to all the height data for this terrain. | |
float * | getHeightData (long x, long y) const |
Get a pointer to the height data for a given point. | |
int | getHighestLodLoaded () const |
int | getHighestLodPrepared () const |
TerrainLayerBlendMap * | getLayerBlendMap (uint8 layerIndex) |
Retrieve the layer blending map for a given layer, which may be used to edit the blending information for that layer. | |
uint16 | getLayerBlendMapSize () const |
Get the requested size of the blend maps used to blend between layers for this terrain. | |
const TexturePtr & | getLayerBlendTexture (uint8 index) const |
Get a blend texture with a given index. | |
std::pair< uint8, uint8 > | getLayerBlendTextureIndex (uint8 layerIndex) const |
Get the texture index and colour channel of the blend information for a given layer. | |
uint8 | getLayerCount () const |
Get the number of layers in this terrain. | |
const TerrainLayerDeclaration & | getLayerDeclaration () const |
Get the declaration which describes the layers in this terrain. | |
const String & | getLayerTextureName (uint8 layerIndex, uint8 samplerIndex) const |
Get the name of the texture bound to a given index within a given layer. | |
Real | getLayerUVMultiplier (uint8 index) const |
Get the layer UV multiplier. | |
Real | getLayerWorldSize (uint8 index) const |
How large an area in world space the texture in a terrain layer covers before repeating. | |
const TexturePtr & | getLightmap () const |
Get access to the lightmap, if enabled (as requested by the material generator) | |
uint16 | getLightmapSize () const |
Get the requested size of lightmap for this terrain. | |
uint16 | getLODLevelWhenVertexEliminated (long rowOrColulmn) const |
Utility method, get the first LOD Level at which this vertex is no longer included. | |
uint16 | getLODLevelWhenVertexEliminated (long x, long y) const |
Utility method, get the first LOD Level at which this vertex is no longer included. | |
const MaterialPtr & | getMaterial () const |
Get the material being used for the terrain. | |
const String & | getMaterialName () const |
Get the name of the material being used for the terrain. | |
uint16 | getMaxBatchSize () const |
Get the maximum size in vertices along one side of a batch. | |
Real | getMaxHeight () const |
Get the maximum height of the terrain. | |
uint8 | getMaxLayers () const |
Get the maximum number of layers supported with the current options. | |
uint16 | getMinBatchSize () const |
Get the minimum size in vertices along one side of a batch. | |
Real | getMinHeight () const |
Get the minimum height of the terrain. | |
Terrain * | getNeighbour (NeighbourIndex index) const |
Retrieve the terrain's neighbour, or null if not present. | |
uint16 | getNumLodLevels () const |
Get the total number of LOD levels in the terrain. | |
uint16 | getNumLodLevelsPerLeaf () const |
Get the number of LOD levels in a leaf of the terrain quadtree. | |
void | getPoint (long x, long y, float height, Vector3 *outpos) const |
Get a Vector3 of the world-space point on the terrain, supplying the height data manually (can be more optimal). | |
void | getPoint (long x, long y, Vector3 *outpos) const |
Get a Vector3 of the world-space point on the terrain, aligned as per options. | |
void | getPointFromSelfOrNeighbour (long x, long y, Vector3 *outpos) const |
Get a Vector3 of the world-space point on the terrain, aligned as per options. | |
void | getPointTransform (Matrix4 *outXform) const |
Get a transform which converts Vector4(xindex, yindex, height, 1) into an object-space position including scalings and alignment. | |
const Vector3 & | getPosition () const |
Get the world position of the terrain centre. | |
void | getPosition (const Vector3 &TSpos, Vector3 *outWSpos) const |
Convert a position from terrain basis space to world space. | |
void | getPosition (Real x, Real y, Real z, Vector3 *outWSpos) const |
Convert a position from terrain basis space to world space. | |
void | getPositionAlign (const Vector3 &TSpos, Alignment align, Vector3 *outWSpos) const |
Convert a position from terrain basis space to world space based on a specified alignment. | |
void | getPositionAlign (Real x, Real y, Real z, Alignment align, Vector3 *outWSpos) const |
Convert a position from terrain basis space to world space based on a specified alignment. | |
TerrainQuadTreeNode * | getQuadTree () |
Get the top level of the quad tree which is used to divide up the terrain. | |
uint32 | getQueryFlags (void) const |
Get the query flags for this terrain. | |
uint8 | getRenderQueueGroup (void) const |
Get the render queue group that this terrain will be rendered into. | |
uint16 | getResolutionAtLod (uint16 lodLevel) const |
Gets the resolution of the entire terrain (down one edge) at a given LOD level. | |
const String & | getResourceGroup () const |
Get the resource group to use when loading / saving. | |
SceneManager * | getSceneManager () const |
uint16 | getSize () const |
Get the size of the terrain in vertices along one side. | |
Real | getSkirtSize () const |
The default size of 'skirts' used to hide terrain cracks (default 10, set for new Terrain using TerrainGlobalOptions) | |
int | getTargetLodLevel () const |
TexturePtr | getTerrainNormalMap () const |
Get the (global) normal map texture. | |
void | getTerrainPosition (const Vector3 &WSpos, Vector3 *outTSpos) const |
Convert a position from world space to terrain basis space. | |
void | getTerrainPosition (Real x, Real y, Real z, Vector3 *outTSpos) const |
Convert a position from world space to terrain basis space. | |
void | getTerrainPositionAlign (const Vector3 &WSpos, Alignment align, Vector3 *outTSpos) const |
Convert a position from world space to terrain basis space based on a specified alignment. | |
void | getTerrainPositionAlign (Real x, Real y, Real z, Alignment align, Vector3 *outTSpos) const |
Convert a position from world space to terrain basis space based on a specified alignment. | |
void | getTerrainVector (const Vector3 &inVec, Vector3 *outVec) const |
Translate a vector from world space to local terrain space based on the alignment options. | |
void | getTerrainVector (Real x, Real y, Real z, Vector3 *outVec) const |
Translate a vector from world space to local terrain space based on the alignment options. | |
void | getTerrainVectorAlign (const Vector3 &inVec, Alignment align, Vector3 *outVec) const |
Translate a vector from world space to local terrain space based on a specified alignment. | |
void | getTerrainVectorAlign (Real x, Real y, Real z, Alignment align, Vector3 *outVec) const |
Translate a vector from world space to local terrain space based on a specified alignment. | |
void | getVector (const Vector3 &inVec, Vector3 *outVec) const |
Translate a vector into world space based on the alignment options. | |
void | getVector (Real x, Real y, Real z, Vector3 *outVec) const |
Translate a vector into world space based on the alignment options. | |
void | getVectorAlign (const Vector3 &inVec, Alignment align, Vector3 *outVec) const |
Translate a vector into world space based on a specified alignment. | |
void | getVectorAlign (Real x, Real y, Real z, Alignment align, Vector3 *outVec) const |
Translate a vector into world space based on a specified alignment. | |
uint32 | getVisibilityFlags (void) const |
Get the visibility flags for this terrain. | |
AxisAlignedBox | getWorldAABB () const |
Get the AABB (world coords) of the entire terrain. | |
Real | getWorldSize () const |
Get the size of the terrain in world units. | |
void | handleGenerateMaterialResponse (const WorkQueue::Response *res, const WorkQueue *srcQ) |
Handler for GenerateMaterial. | |
WorkQueue::Response * | handleRequest (const WorkQueue::Request *req, const WorkQueue *srcQ) |
WorkQueue::RequestHandler override. | |
void | handleResponse (const WorkQueue::Response *res, const WorkQueue *srcQ) |
WorkQueue::ResponseHandler override. | |
void | increaseLodLevel (bool synchronous=false) |
Increase Terrain's LOD level by 1. | |
bool | isDerivedDataUpdateInProgress () const |
Query whether a derived data update is in progress or not. | |
bool | isHeightDataModified () const |
Returns whether terrain heights have been modified since the terrain was first loaded / defined. | |
bool | isLoaded () const |
Return whether the terrain is loaded. | |
bool | isModified () const |
Returns whether this terrain has been modified since it was first loaded / defined. | |
void | load (const String &filename) |
Prepare and load the terrain in one simple call from a standalone file. | |
void | load (int lodLevel=0, bool synchronous=true) |
Load the terrain based on the data already populated via prepare methods. | |
void | load (StreamSerialiser &stream) |
Prepare and load the terrain in one simple call from a stream. | |
void | neighbourModified (NeighbourIndex index, const Rect &edgerect, const Rect &shadowrect) |
Notify that a neighbour has just finished updating and that this change affects this tile. | |
void | notifyNeighbours () |
Tell this instance to notify all neighbours that will be affected by a height change that has taken place. | |
OGRE_RW_MUTEX (mNeighbourMutex) | |
void | operator delete (void *ptr) |
void | operator delete (void *ptr, const char *, int, const char *) |
void | operator delete (void *ptr, void *) |
void | operator delete[] (void *ptr) |
void | operator delete[] (void *ptr, const char *, int, const char *) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, const char *file, int line, const char *func) |
operator new, with debug line info | |
void * | operator new (size_t sz, void *ptr) |
placement operator new | |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, const char *file, int line, const char *func) |
array operator new, with debug line info | |
virtual void | postFindVisibleObjects (SceneManager *source, IlluminationRenderStage irs, Viewport *v) |
Called after searching for visible objects in this SceneManager. | |
void | preFindVisibleObjects (SceneManager *source, SceneManager::IlluminationRenderStage irs, Viewport *v) |
Overridden from SceneManager::Listener. | |
bool | prepare (const ImportData &importData) |
Prepare the terrain from some import data rather than loading from native data. | |
bool | prepare (const String &filename) |
Prepare the terrain from a standalone file. | |
bool | prepare (DataStreamPtr &stream) |
Prepare terrain data from saved data. | |
bool | prepare (StreamSerialiser &stream) |
Prepare terrain data from saved data. | |
std::pair< bool, Vector3 > | rayIntersects (const Ray &ray, bool cascadeToNeighbours=false, Real distanceLimit=0) |
Test for intersection of a given ray with the terrain. | |
Terrain * | raySelectNeighbour (const Ray &ray, Real distanceLimit=0) |
Utility method to pick a neighbour based on a ray. | |
void | removeLayer (uint8 index) |
Remove a layer from the terrain. | |
void | removeQueryFlags (uint32 flags) |
void | replaceLayer (uint8 index, bool keepBlends, Real worldSize=0, const StringVector *textureNames=0) |
Replace an existing terrain layer, optionally preserving all other layer blend maps. | |
void | save (const String &filename) |
Save terrain data in native form to a standalone file. | |
void | save (StreamSerialiser &stream) |
Save terrain data in native form to a serializing stream. | |
void | sceneManagerDestroyed (SceneManager *source) |
Overridden from SceneManager::Listener. | |
void | setGlobalColourMapEnabled (bool enabled, uint16 size=0) |
Set whether a global colour map is enabled. | |
void | setGpuBufferAllocator (GpuBufferAllocator *alloc) |
Tell this instance to use the given GpuBufferAllocator. | |
void | setHeightAtPoint (long x, long y, float h) |
Set the height data for a given terrain point. | |
void | setLayerTextureName (uint8 layerIndex, uint8 samplerIndex, const String &textureName) |
Set the name of the texture bound to a given index within a given layer. | |
void | setLayerWorldSize (uint8 index, Real size) |
How large an area in world space the texture in a terrain layer covers before repeating. | |
void | setNeighbour (NeighbourIndex index, Terrain *neighbour, bool recalculate=false, bool notifyOther=true) |
Set a terrain's neighbour, or null to detach one. | |
void | setPosition (const Vector3 &pos) |
Set the position of the terrain centre in world coordinates. | |
void | setQueryFlags (uint32 flags) |
Set the query flags for this terrain. | |
void | setRenderQueueGroup (uint8 grp) |
Set the render queue group that this terrain will be rendered into. | |
void | setResourceGroup (const String &resGroup) |
Set the resource group to use when loading / saving. | |
void | setSize (uint16 newSize) |
Set the size of terrain in vertices along one side. | |
void | setVisibilityFlags (uint32 flags) |
Set the visibility flags for this terrain. | |
void | setWorldSize (Real newWorldSize) |
Set the world size of terrain. | |
virtual void | shadowTextureCasterPreViewProj (const Light *light, Camera *camera, size_t iteration) |
This event occurs just before the view & projection matrices are set for rendering into a shadow texture. | |
virtual void | shadowTexturesUpdated (size_t numberOfShadowTextures) |
Event raised after all shadow textures have been rendered into for all queues / targets but before any other geometry has been rendered (including main scene geometry). | |
virtual bool | sortLightsAffectingFrustum (LightList &lightList) |
Hook to allow the listener to override the ordering of lights for the entire frustum. | |
void | unload () |
Unload the terrain and free GPU resources. | |
void | unprepare () |
Free CPU resources created during prepare methods. | |
void | update (bool synchronous=false) |
Trigger the update process for the terrain. | |
void | updateCompositeMap () |
Performs an update on the terrain composite map based on its dirty region. | |
void | updateCompositeMapWithDelay (Real delay=2) |
Performs an update on the terrain composite map based on its dirty region, but only at a maximum frequency. | |
void | updateDerivedData (bool synchronous=false, uint8 typeMask=0xFF) |
Updates derived data for the terrain (LOD, lighting) to reflect changed height data, in a separate thread if threading is enabled (OGRE_THREAD_SUPPORT). | |
void | updateGeometry () |
Performs an update on the terrain geometry based on the dirty region. | |
void | updateGeometryWithoutNotifyNeighbours () |
Performs an update on the terrain geometry based on the dirty region. | |
void | widenRectByVector (const Vector3 &vec, const Rect &inRect, Real minHeight, Real maxHeight, Rect &outRect) |
Widen a rectangular area of terrain to take into account an extrusion vector, but specify the min / max heights to extrude manually. | |
void | widenRectByVector (const Vector3 &vec, const Rect &inRect, Rect &outRect) |
Widen a rectangular area of terrain to take into account an extrusion vector. | |
Static Public Member Functions | |
static uint16 | _calcSkirtVertexIndex (uint16 mainIndex, uint16 vdatasize, bool isCol, uint16 numSkirtRowsCols, uint16 skirtRowColSkip) |
Utility method to calculate the skirt index for a given original vertex index. | |
static size_t | _getNumIndexesForBatchSize (uint16 batchSize) |
Utility method to get the number of indexes required to render a given batch. | |
static void | _populateIndexBuffer (uint16 *pIndexes, uint16 batchSize, uint16 vdatasize, size_t vertexIncrement, uint16 xoffset, uint16 yoffset, uint16 numSkirtRowsCols, uint16 skirtRowColSkip) |
Utility method to populate a (locked) index buffer. | |
static void | convertTerrainToWorldAxes (Alignment align, const Vector3 &terrainVec, Vector3 *worldVec) |
Utility method to convert axes from terrain space (xy terrain, z up) tp world space. | |
static void | convertWorldToTerrainAxes (Alignment align, const Vector3 &worldVec, Vector3 *terrainVec) |
Utility method to convert axes from world space to terrain space (xy terrain, z up) | |
static NeighbourIndex | getNeighbourIndex (long offsetx, long offsety) |
Get the neighbour enum for a given offset in a grid (signed). | |
static NeighbourIndex | getOppositeNeighbour (NeighbourIndex index) |
Get the opposite neighbour relationship (useful for finding the neighbour index from the perspective of the tile the other side of the boundary). | |
static bool | readLayerDeclaration (StreamSerialiser &ser, TerrainLayerDeclaration &targetdecl) |
Utility method to read a layer declaration from a stream. | |
static bool | readLayerInstanceList (StreamSerialiser &ser, size_t numSamplers, Terrain::LayerInstanceList &targetlst) |
Utility method to read a layer instance list from a stream. | |
static void | writeLayerDeclaration (const TerrainLayerDeclaration &decl, StreamSerialiser &ser) |
Utility method to write a layer declaration to a stream. | |
static void | writeLayerInstanceList (const Terrain::LayerInstanceList &lst, StreamSerialiser &ser) |
Utility method to write a layer instance list to a stream. | |
Friends | |
class | TerrainLodManager |
The main containing class for a chunk of terrain.
Name | Type | Description |
Terrain orientation | uint8 | The orientation of the terrain; XZ = 0, XY = 1, YZ = 2 |
Terrain size | uint16 | The number of vertices along one side of the terrain |
Terrain world size | Real | The world size of one side of the terrain |
Max batch size | uint16 | The maximum batch size in vertices along one side |
Min batch size | uint16 | The minimum batch size in vertices along one side |
Position | Vector3 | The location of the centre of the terrain |
Height data | float[size*size] | List of floating point heights |
LayerDeclaration | LayerDeclaration* | The layer declaration for this terrain (see below) |
Layer count | uint8 | The number of layers in this terrain |
LayerInstance list | LayerInstance* | A number of LayerInstance definitions based on layer count (see below) |
Layer blend map size | uint16 | The size of the layer blend maps as stored in this file |
Packed blend texture data | uint8* | layerCount-1 sets of blend texture data interleaved as either RGB or RGBA depending on layer count |
Optional derived map data | TerrainDerivedMap list | 0 or more sets of map data derived from the original terrain |
Delta data | float[size*size] | At each vertex, delta information for the LOD at which this vertex disappears |
Quadtree delta data | float[quadtrees*lods] | At each quadtree node, for each lod a record of the max delta value in the region |
Name | Type | Description |
TerrainLayerSampler Count | uint8 | Number of samplers in this declaration |
TerrainLayerSampler List | TerrainLayerSampler* | List of TerrainLayerSampler structures |
Sampler Element Count | uint8 | Number of sampler elements in this declaration |
TerrainLayerSamplerElement List | TerrainLayerSamplerElement* | List of TerrainLayerSamplerElement structures |
Name | Type | Description |
Alias | String | Alias name of this sampler |
Format | uint8 | Desired pixel format |
Name | Type | Description |
Source | uint8 | Sampler source index |
Semantic | uint8 | Semantic interpretation of this element |
Element start | uint8 | Start of this element in the sampler |
Element count | uint8 | Number of elements in the sampler used by this entry |
Name | Type | Description |
World size | Real | The world size of this layer (determines UV scaling) |
Texture list | String* | List of texture names corresponding to the number of samplers in the layer declaration |
Name | Type | Description |
Derived data type name | String | Name of the derived data type ('normalmap', 'lightmap', 'colourmap', 'compositemap') |
Size | uint16 | Size of the data along one edge |
Data | varies based on type | The data |
Enumeration of relative spaces that you might want to use to address the terrain.
Ogre::Terrain::Terrain | ( | SceneManager * | sm | ) |
Constructor.
sm | The SceneManager to use. |
|
virtual |
|
static |
Utility method to calculate the skirt index for a given original vertex index.
Mark a region of the terrain composite map as dirty.
Dump textures to files.
|
inline |
Internal getting of material for the terrain composite map.
Get the final resource group to use when loading / saving.
|
inline |
Internal getting of material.
|
inline |
Get whether LOD morphing is needed.
Utility method to get the number of indexes required to render a given batch.
SceneNode * Ogre::Terrain::_getRootSceneNode | ( | ) | const |
Get the root scene node for the terrain (internal use only)
bool Ogre::Terrain::_getUseVertexCompression | ( | ) | const |
Whether we're using vertex compression or not.
|
static |
Utility method to populate a (locked) index buffer.
pIndexes | Pointer to an index buffer to populate |
batchSize | The number of vertices down one side of the batch |
vdatasize | The number of vertices down one side of the vertex data being referenced |
vertexIncrement | The number of vertices to increment for each new indexed row / column |
xoffset | The x offset from the start of the vertex data being referenced |
yoffset | The y offset from the start of the vertex data being referenced |
numSkirtRowsCols | Number of rows and columns of skirts |
skirtRowColSkip | The number of rows / cols to skip in between skirts |
Request internal implementation options for the terrain material to use, in this case a terrain-wide composite map.
The TerrainMaterialGenerator should call this method to specify the options it would like to use when creating a material. Not all the data is guaranteed to be up to date on return from this method - for example some maps may be generated in the background. However, on return from this method all the features that are requested will be referenceable by materials, the data may just take a few frames to be fully populated.
compositeMap | Whether a terrain-wide composite map is needed. A composite map is a texture with all of the blending and lighting baked in, such that at distance this texture can be used as an approximation of the multi-layer blended material. It is actually up to the material generator to render this composite map, because obviously precisely what it looks like depends on what the main material looks like. For this reason, the composite map is one piece of derived terrain data that is always calculated in the render thread, and usually on the GPU. It is expected that if this option is requested, the material generator will use it to construct distant LOD techniques. |
Request internal implementation options for the terrain material to use, in this case a terrain-wide normal map.
The TerrainMaterialGenerator should call this method to specify the options it would like to use when creating a material. Not all the data is guaranteed to be up to date on return from this method - for example some maps may be generated in the background. However, on return from this method all the features that are requested will be referenceable by materials, the data may just take a few frames to be fully populated.
lightMap | Whether a terrain-wide lightmap including precalculated lighting is required (light direction in TerrainGlobalOptions) |
shadowsOnly | If true, the lightmap contains only shadows, no directional lighting intensity |
Request internal implementation options for the terrain material to use, in this case vertex morphing information.
The TerrainMaterialGenerator should call this method to specify the options it would like to use when creating a material. Not all the data is guaranteed to be up to date on return from this method - for example som maps may be generated in the background. However, on return from this method all the features that are requested will be referenceable by materials, the data may just take a few frames to be fully populated.
morph | Whether LOD morphing information is required to be calculated |
Request internal implementation options for the terrain material to use, in this case a terrain-wide normal map.
The TerrainMaterialGenerator should call this method to specify the options it would like to use when creating a material. Not all the data is guaranteed to be up to date on return from this method - for example some maps may be generated in the background. However, on return from this method all the features that are requested will be referenceable by materials, the data may just take a few frames to be fully populated.
normalMap | Whether a terrain-wide normal map is requested. This is usually mutually exclusive with the lightmap option. |
void Ogre::Terrain::addLayer | ( | Real | worldSize = 0 , |
const StringVector * | textureNames = 0 |
||
) |
Add a new layer to this terrain.
worldSize | The size of the texture in this layer in world units. Default to zero to use the default |
textureNames | A list of textures to assign to the samplers in this layer. Leave blank to provide these later. |
void Ogre::Terrain::addLayer | ( | uint8 | index, |
Real | worldSize = 0 , |
||
const StringVector * | textureNames = 0 |
||
) |
Add a new layer to this terrain at a specific index.
index | The index at which to insert this layer (existing layers are shifted forwards) |
worldSize | The size of the texture in this layer in world units. Default to zero to use the default |
textureNames | A list of textures to assign to the samplers in this layer. Leave blank to provide these later. |
As setQueryFlags, except the flags passed as parameters are appended to the existing flags on this object.
Calculate (or recalculate) the delta values of heights between a vertex in its recorded position, and the place it will end up in the LOD in which it is removed.
rect | Rectangle describing the area in which heights have altered |
PixelBox * Ogre::Terrain::calculateLightmap | ( | const Rect & | rect, |
const Rect & | extraTargetRect, | ||
Rect & | outFinalRect | ||
) |
Calculate (or recalculate) the terrain lightmap.
rect | Rectangle describing the area of heights that were changed |
extraTargetRect | Rectangle describing a target area of the terrain that needs to be calculated additionally (e.g. from a neighbour) |
outFinalRect | Output rectangle describing the area updated in the lightmap |
Calculate (or recalculate) the normals on the terrain.
rect | Rectangle describing the area of heights that were changed |
outFinalRect | Output rectangle describing the area updated |
|
virtual |
WorkQueue::RequestHandler override.
Reimplemented from Ogre::WorkQueue::RequestHandler.
|
virtual |
WorkQueue::ResponseHandler override.
Reimplemented from Ogre::WorkQueue::ResponseHandler.
Vector3 Ogre::Terrain::convertDirection | ( | Space | inSpace, |
const Vector3 & | inDir, | ||
Space | outSpace | ||
) | const |
Convert a direction from one space to another with respect to this terrain.
inSpace | The space that inDir is expressed as |
inDir | The incoming direction |
outSpace | The space which outDir should be expressed as |
void Ogre::Terrain::convertDirection | ( | Space | inSpace, |
const Vector3 & | inDir, | ||
Space | outSpace, | ||
Vector3 & | outDir | ||
) | const |
Convert a direction from one space to another with respect to this terrain.
inSpace | The space that inDir is expressed as |
inDir | The incoming direction |
outSpace | The space which outDir should be expressed as |
outDir | The output direction to be populated |
Vector3 Ogre::Terrain::convertPosition | ( | Space | inSpace, |
const Vector3 & | inPos, | ||
Space | outSpace | ||
) | const |
Convert a position from one space to another with respect to this terrain.
inSpace | The space that inPos is expressed as |
inPos | The incoming position |
outSpace | The space which outPos should be expressed as |
void Ogre::Terrain::convertPosition | ( | Space | inSpace, |
const Vector3 & | inPos, | ||
Space | outSpace, | ||
Vector3 & | outPos | ||
) | const |
Convert a position from one space to another with respect to this terrain.
inSpace | The space that inPos is expressed as |
inPos | The incoming position |
outSpace | The space which outPos should be expressed as |
outPos | The output position to be populated |
|
static |
Utility method to convert axes from terrain space (xy terrain, z up) tp world space.
|
static |
Utility method to convert axes from world space to terrain space (xy terrain, z up)
void Ogre::Terrain::decreaseLodLevel | ( | ) |
Removes highest LOD level loaded.
void Ogre::Terrain::dirty | ( | ) |
Mark the entire terrain as dirty.
By marking a section of the terrain as dirty, you are stating that you have changed the height data within this rectangle. This rectangle will be merged with any existing outstanding changes. To finalise the changes, you must call update(), updateGeometry(), or updateDerivedData().
void Ogre::Terrain::dirtyLightmap | ( | ) |
Mark a the entire lightmap as dirty.
Mark a region of the lightmap as dirty.
Mark a region of the terrain as dirty.
By marking a section of the terrain as dirty, you are stating that you have changed the height data within this rectangle. This rectangle will be merged with any existing outstanding changes. To finalise the changes, you must call update(), updateGeometry(), or updateDerivedData().
rect | A rectangle expressed in vertices describing the dirty region; left < right, top < bottom, left & top are inclusive, right & bottom exclusive |
Finalise the height deltas.
Calculated height deltas are kept in a separate calculation field to make them safe to perform in a background thread. This call promotes those calculations to the runtime values, and must be called in the main thread.
rect | Rectangle describing the area to finalise |
cpuData | When updating vertex data, update the CPU copy (background) |
Finalise the lightmap.
Calculating lightmaps is kept in a separate calculation area to make it safe to perform in a background thread. This call promotes those calculations to the runtime values, and must be called in the main thread.
rect | Rectangle describing the area to finalise |
lightmapBox | Pointer to a PixelBox full of normals |
Finalise the normals.
Calculated normals are kept in a separate calculation area to make them safe to perform in a background thread. This call promotes those calculations to the runtime values, and must be called in the main thread.
rect | Rectangle describing the area to finalise |
normalsBox | Pointer to a PixelBox full of normals |
|
inlinevirtualinherited |
Called just after a frame has been rendered.
Reimplemented in Ogre::FrameTimeControllerValue.
|
inlinevirtualinherited |
Called after all render targets have had their rendering commands issued, but before render windows have been asked to flip their buffers over.
|
virtual |
Called when a frame is about to begin rendering.
Reimplemented from Ogre::FrameListener.
void Ogre::Terrain::freeTemporaryResources | ( | ) |
Free as many resources as possible for optimal run-time memory use.
const AxisAlignedBox & Ogre::Terrain::getAABB | ( | ) | const |
Get the AABB (local coords) of the entire terrain.
Alignment Ogre::Terrain::getAlignment | ( | ) | const |
Get the alignment of the terrain.
uint8 Ogre::Terrain::getBlendTextureCount | ( | ) | const |
Get the number of blend textures in use.
Get the number of blend textures needed for a given number of layers.
Get the index of the blend texture that a given layer uses.
layerIndex | The layer index, must be >= 1 and less than the number of layers |
Get the name of the packed blend texture at a specific index.
textureIndex | This is the blend texture index, not the layer index (multiple layers will share a blend texture) |
Real Ogre::Terrain::getBoundingRadius | ( | ) | const |
Get the bounding radius of the entire terrain.
|
inline |
Get access to the composite map, if enabled (as requested by the material generator)
const MaterialPtr & Ogre::Terrain::getCompositeMapMaterial | ( | ) | const |
Get the material being used for the terrain composite map.
|
inline |
Get the requested size of composite map for this terrain.
Note that where hardware limits this, the actual texture may be lower resolution. This option is derived from TerrainGlobalOptions when the terrain is created.
Get a pointer to all the delta data for this terrain.
Get a pointer to the delta data for a given point.
|
inline |
Get access to the global colour map, if enabled.
|
inline |
Get whether a global colour map is enabled on this terrain.
|
inline |
Get the size of the global colour map (if used)
GpuBufferAllocator * Ogre::Terrain::getGpuBufferAllocator | ( | ) |
Get the current buffer allocator.
Get the height data for a given terrain point.
x,y | Discrete coordinates in terrain vertices, values from 0 to size-1, left/right bottom/top |
Get the height data for a given terrain position.
x,y | Position in terrain space, values from 0 to 1 left/right bottom/top |
Get the height data for a given world position (projecting the point down on to the terrain).
pos | Position in world space. Positions will be clamped to the edge of the terrain |
Get the height data for a given world position (projecting the point down on to the terrain).
x,y,z | Position in world space. Positions will be clamped to the edge of the terrain |
float * Ogre::Terrain::getHeightData | ( | ) | const |
Get a pointer to all the height data for this terrain.
Get a pointer to the height data for a given point.
|
inline |
|
inline |
TerrainLayerBlendMap * Ogre::Terrain::getLayerBlendMap | ( | uint8 | layerIndex | ) |
Retrieve the layer blending map for a given layer, which may be used to edit the blending information for that layer.
layerIndex | The layer index, which should be 1 or higher (since the bottom layer has no blending). |
|
inline |
Get the requested size of the blend maps used to blend between layers for this terrain.
Note that where hardware limits this, the actual blend maps may be lower resolution. This option is derived from TerrainGlobalOptions when the terrain is created.
const TexturePtr & Ogre::Terrain::getLayerBlendTexture | ( | uint8 | index | ) | const |
Get a blend texture with a given index.
index | The blend texture index (note: not layer index; derive the texture index from getLayerBlendTextureIndex) |
Get the texture index and colour channel of the blend information for a given layer.
layerIndex | The index of the layer (1 or higher, layer 0 has no blend data) |
|
inline |
Get the number of layers in this terrain.
|
inline |
Get the declaration which describes the layers in this terrain.
Get the name of the texture bound to a given index within a given layer.
See the LayerDeclaration for a list of sampelrs within a layer.
layerIndex | The layer index. |
samplerIndex | The sampler index within a layer |
Get the layer UV multiplier.
index | The layer index. |
How large an area in world space the texture in a terrain layer covers before repeating.
index | The layer index. |
|
inline |
Get access to the lightmap, if enabled (as requested by the material generator)
|
inline |
Get the requested size of lightmap for this terrain.
Note that where hardware limits this, the actual lightmap may be lower resolution. This option is derived from TerrainGlobalOptions when the terrain is created.
Utility method, get the first LOD Level at which this vertex is no longer included.
Utility method, get the first LOD Level at which this vertex is no longer included.
const MaterialPtr & Ogre::Terrain::getMaterial | ( | ) | const |
Get the material being used for the terrain.
Get the name of the material being used for the terrain.
uint16 Ogre::Terrain::getMaxBatchSize | ( | ) | const |
Get the maximum size in vertices along one side of a batch.
Real Ogre::Terrain::getMaxHeight | ( | ) | const |
Get the maximum height of the terrain.
uint8 Ogre::Terrain::getMaxLayers | ( | ) | const |
Get the maximum number of layers supported with the current options.
uint16 Ogre::Terrain::getMinBatchSize | ( | ) | const |
Get the minimum size in vertices along one side of a batch.
Real Ogre::Terrain::getMinHeight | ( | ) | const |
Get the minimum height of the terrain.
Terrain * Ogre::Terrain::getNeighbour | ( | NeighbourIndex | index | ) | const |
Retrieve the terrain's neighbour, or null if not present.
index | The index of the neighbour |
|
static |
Get the neighbour enum for a given offset in a grid (signed).
|
inline |
Get the total number of LOD levels in the terrain.
|
inline |
Get the number of LOD levels in a leaf of the terrain quadtree.
|
static |
Get the opposite neighbour relationship (useful for finding the neighbour index from the perspective of the tile the other side of the boundary).
Get a Vector3 of the world-space point on the terrain, supplying the height data manually (can be more optimal).
Get a Vector3 of the world-space point on the terrain, aligned as per options.
Get a Vector3 of the world-space point on the terrain, aligned as per options.
Cascades into neighbours if out of bounds.
Get a transform which converts Vector4(xindex, yindex, height, 1) into an object-space position including scalings and alignment.
Get the world position of the terrain centre.
Convert a position from terrain basis space to world space.
TSpos | Terrain space position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
outWSpos | World space output position (setup according to current alignment). |
Convert a position from terrain basis space to world space.
x,y,z | Terrain space position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
outWSpos | World space output position (setup according to current alignment). |
void Ogre::Terrain::getPositionAlign | ( | const Vector3 & | TSpos, |
Alignment | align, | ||
Vector3 * | outWSpos | ||
) | const |
Convert a position from terrain basis space to world space based on a specified alignment.
TSpos | Terrain space position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
outWSpos | World space output position (setup according to alignment). |
void Ogre::Terrain::getPositionAlign | ( | Real | x, |
Real | y, | ||
Real | z, | ||
Alignment | align, | ||
Vector3 * | outWSpos | ||
) | const |
Convert a position from terrain basis space to world space based on a specified alignment.
x,y,z | Terrain space position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
outWSpos | World space output position (setup according to alignment). |
|
inline |
Get the top level of the quad tree which is used to divide up the terrain.
Get the render queue group that this terrain will be rendered into.
Gets the resolution of the entire terrain (down one edge) at a given LOD level.
Get the resource group to use when loading / saving.
If this is blank, the default in TerrainGlobalOptions will be used.
|
inline |
uint16 Ogre::Terrain::getSize | ( | ) | const |
Get the size of the terrain in vertices along one side.
|
inline |
The default size of 'skirts' used to hide terrain cracks (default 10, set for new Terrain using TerrainGlobalOptions)
|
inline |
|
inline |
Get the (global) normal map texture.
Convert a position from world space to terrain basis space.
WSpos | World space position (setup according to current alignment). |
outTSpos | Terrain space output position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
Convert a position from world space to terrain basis space.
x,y,z | World space position (setup according to current alignment). |
outTSpos | Terrain space output position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
void Ogre::Terrain::getTerrainPositionAlign | ( | const Vector3 & | WSpos, |
Alignment | align, | ||
Vector3 * | outTSpos | ||
) | const |
Convert a position from world space to terrain basis space based on a specified alignment.
WSpos | World space position (setup according to alignment). |
outTSpos | Terrain space output position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
void Ogre::Terrain::getTerrainPositionAlign | ( | Real | x, |
Real | y, | ||
Real | z, | ||
Alignment | align, | ||
Vector3 * | outTSpos | ||
) | const |
Convert a position from world space to terrain basis space based on a specified alignment.
x,y,z | World space position (setup according to alignment). |
outTSpos | Terrain space output position, where (0,0) is the bottom-left of the terrain, and (1,1) is the top-right. The Z coordinate is in absolute height units. |
Translate a vector from world space to local terrain space based on the alignment options.
inVec | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
Translate a vector from world space to local terrain space based on the alignment options.
x,y,z | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
void Ogre::Terrain::getTerrainVectorAlign | ( | const Vector3 & | inVec, |
Alignment | align, | ||
Vector3 * | outVec | ||
) | const |
Translate a vector from world space to local terrain space based on a specified alignment.
inVec | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
void Ogre::Terrain::getTerrainVectorAlign | ( | Real | x, |
Real | y, | ||
Real | z, | ||
Alignment | align, | ||
Vector3 * | outVec | ||
) | const |
Translate a vector from world space to local terrain space based on a specified alignment.
x,y,z | The vector in world space, where x/y represents the terrain plane and z represents the up vector |
Translate a vector into world space based on the alignment options.
inVec | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
Translate a vector into world space based on the alignment options.
x,y,z | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
void Ogre::Terrain::getVectorAlign | ( | const Vector3 & | inVec, |
Alignment | align, | ||
Vector3 * | outVec | ||
) | const |
Translate a vector into world space based on a specified alignment.
inVec | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
void Ogre::Terrain::getVectorAlign | ( | Real | x, |
Real | y, | ||
Real | z, | ||
Alignment | align, | ||
Vector3 * | outVec | ||
) | const |
Translate a vector into world space based on a specified alignment.
x,y,z | The vector in basis space, where x/y represents the terrain plane and z represents the up vector |
Get the visibility flags for this terrain.
AxisAlignedBox Ogre::Terrain::getWorldAABB | ( | ) | const |
Get the AABB (world coords) of the entire terrain.
Real Ogre::Terrain::getWorldSize | ( | ) | const |
Get the size of the terrain in world units.
void Ogre::Terrain::handleGenerateMaterialResponse | ( | const WorkQueue::Response * | res, |
const WorkQueue * | srcQ | ||
) |
Handler for GenerateMaterial.
|
virtual |
WorkQueue::RequestHandler override.
Implements Ogre::WorkQueue::RequestHandler.
|
virtual |
WorkQueue::ResponseHandler override.
Implements Ogre::WorkQueue::ResponseHandler.
Increase Terrain's LOD level by 1.
synchronous | Run synchronously |
|
inline |
Query whether a derived data update is in progress or not.
|
inline |
Returns whether terrain heights have been modified since the terrain was first loaded / defined.
|
inline |
Return whether the terrain is loaded.
|
inline |
Returns whether this terrain has been modified since it was first loaded / defined.
Prepare and load the terrain in one simple call from a standalone file.
Load the terrain based on the data already populated via prepare methods.
lodLevel | Load the specified LOD level |
synchronous | Load type |
void Ogre::Terrain::load | ( | StreamSerialiser & | stream | ) |
Prepare and load the terrain in one simple call from a stream.
void Ogre::Terrain::neighbourModified | ( | NeighbourIndex | index, |
const Rect & | edgerect, | ||
const Rect & | shadowrect | ||
) |
Notify that a neighbour has just finished updating and that this change affects this tile.
index | The neighbour index (from this tile's perspective) |
edgerect | The area at the edge of this tile that needs height / normal recalculation (may be null) |
shadowrect | The area on this tile where shadows need recalculating (may be null) |
void Ogre::Terrain::notifyNeighbours | ( | ) |
Tell this instance to notify all neighbours that will be affected by a height change that has taken place.
Ogre::Terrain::OGRE_RW_MUTEX | ( | mNeighbourMutex | ) |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator new, with debug line info
placement operator new
|
inlineinherited |
|
inlineinherited |
array operator new, with debug line info
|
inlinevirtualinherited |
Called after searching for visible objects in this SceneManager.
source | The SceneManager instance raising this event. |
irs | The stage of illumination being dealt with. IRS_NONE for a regular render, IRS_RENDER_TO_TEXTURE for a shadow caster render. |
v | The viewport being updated. You can get the camera from here. |
|
virtual |
Overridden from SceneManager::Listener.
Reimplemented from Ogre::SceneManager::Listener.
bool Ogre::Terrain::prepare | ( | const ImportData & | importData | ) |
Prepare the terrain from some import data rather than loading from native data.
Prepare the terrain from a standalone file.
bool Ogre::Terrain::prepare | ( | DataStreamPtr & | stream | ) |
Prepare terrain data from saved data.
bool Ogre::Terrain::prepare | ( | StreamSerialiser & | stream | ) |
Prepare terrain data from saved data.
std::pair< bool, Vector3 > Ogre::Terrain::rayIntersects | ( | const Ray & | ray, |
bool | cascadeToNeighbours = false , |
||
Real | distanceLimit = 0 |
||
) |
Test for intersection of a given ray with the terrain.
If the ray hits the terrain, the point of intersection is returned.
ray | The ray to test for intersection |
cascadeToNeighbours | Whether the ray will be projected onto neighbours if no intersection is found |
distanceLimit | The distance from the ray origin at which we will stop looking, 0 indicates no limit |
Utility method to pick a neighbour based on a ray.
ray | The ray in world space |
distanceLimit | Limit beyond which we want to ignore neighbours (0 for infinite) |
|
static |
Utility method to read a layer declaration from a stream.
|
static |
Utility method to read a layer instance list from a stream.
void Ogre::Terrain::replaceLayer | ( | uint8 | index, |
bool | keepBlends, | ||
Real | worldSize = 0 , |
||
const StringVector * | textureNames = 0 |
||
) |
Replace an existing terrain layer, optionally preserving all other layer blend maps.
index | The 0 based index of the terrain layer to replace |
keepBlends | True to keep using the existing blend maps. False to reset the blend map for the layer. Irrelevant if index == 0 |
worldSize | The size of the texture in this layer in world units. Default to zero to use the default |
textureNames | A list of textures to assign to the samplers in this layer. Leave blank to provide these later. |
Save terrain data in native form to a standalone file.
filename | The name of the file to save to. If this is a filename with no path elements, then it is saved in the first writeable location available in the resource group you have chosen to use for this terrain. If the filename includes path specifiers then it is saved directly instead (but note that it may not be reloadable via the resource system if the location is not on the path). |
void Ogre::Terrain::save | ( | StreamSerialiser & | stream | ) |
Save terrain data in native form to a serializing stream.
|
virtual |
Overridden from SceneManager::Listener.
Reimplemented from Ogre::SceneManager::Listener.
Set whether a global colour map is enabled.
enabled | Whether the global colour map is enabled or not |
size | The resolution of the colour map. A value of zero means 'no change' and the default is set in TerrainGlobalOptions. |
void Ogre::Terrain::setGpuBufferAllocator | ( | GpuBufferAllocator * | alloc | ) |
Tell this instance to use the given GpuBufferAllocator.
Set the height data for a given terrain point.
x,y | Discrete coordinates in terrain vertices, values from 0 to size-1, left/right bottom/top |
h | The new height |
void Ogre::Terrain::setLayerTextureName | ( | uint8 | layerIndex, |
uint8 | samplerIndex, | ||
const String & | textureName | ||
) |
Set the name of the texture bound to a given index within a given layer.
See the LayerDeclaration for a list of sampelrs within a layer.
layerIndex | The layer index. |
samplerIndex | The sampler index within a layer |
textureName | The name of the texture to use |
How large an area in world space the texture in a terrain layer covers before repeating.
index | The layer index. |
size | The world size of the texture before repeating |
void Ogre::Terrain::setNeighbour | ( | NeighbourIndex | index, |
Terrain * | neighbour, | ||
bool | recalculate = false , |
||
bool | notifyOther = true |
||
) |
Set a terrain's neighbour, or null to detach one.
index | The index of the neighbour |
neighbour | The terrain instance to become the neighbour, or null to reset. |
recalculate | If true, this terrain instance will recalculate elements that could be affected by the connection of this tile (e.g. matching heights, calcaulting normals, calculating shadows crossing the boundary). If false, this terrain's state is assumed to be up to date already (e.g. was calculated with this tile present before and the state saved). |
notifyOther | Whether the neighbour should also be notified (recommended to leave this at the default so relationships are up to date before background updates are triggered) |
Set the position of the terrain centre in world coordinates.
Set the query flags for this terrain.
Set the render queue group that this terrain will be rendered into.
Set the resource group to use when loading / saving.
resGroup | Resource group name - you can set this to blank to use the default in TerrainGlobalOptions. |
Set the size of terrain in vertices along one side.
newSize | the new size of the terrain |
Set the visibility flags for this terrain.
Set the world size of terrain.
newWorldSize | the new world size of the terrain |
|
inlinevirtualinherited |
This event occurs just before the view & projection matrices are set for rendering into a shadow texture.
light | Pointer to the light for which shadows are being rendered |
camera | Pointer to the camera being used to render |
iteration | For lights that use multiple shadow textures, the iteration number |
|
inlinevirtualinherited |
Event raised after all shadow textures have been rendered into for all queues / targets but before any other geometry has been rendered (including main scene geometry).
numberOfShadowTextures | The number of shadow textures in use |
|
inlinevirtualinherited |
Hook to allow the listener to override the ordering of lights for the entire frustum.
lightList | The list of lights within range of the frustum which you may sort. |
void Ogre::Terrain::unload | ( | ) |
Unload the terrain and free GPU resources.
void Ogre::Terrain::unprepare | ( | ) |
Free CPU resources created during prepare methods.
Trigger the update process for the terrain.
You can also separate the timing of updating the geometry, LOD and the lighting information if you want, by calling updateGeometry() and updateDerivedData() separately.
synchronous | If true, all updates will happen immediately and not in a separate thread. |
void Ogre::Terrain::updateCompositeMap | ( | ) |
Performs an update on the terrain composite map based on its dirty region.
Performs an update on the terrain composite map based on its dirty region, but only at a maximum frequency.
Updates derived data for the terrain (LOD, lighting) to reflect changed height data, in a separate thread if threading is enabled (OGRE_THREAD_SUPPORT).
If threading is enabled, on return from this method the derived data will not necessarily be updated immediately, the calculation may be done in the background. Only one update will run in the background at once. This derived data can typically survive being out of sync for a few frames which is why it is not done synchronously
synchronous | If true, the update will happen immediately and not in a separate thread. |
typeMask | Mask indicating the types of data we should generate |
void Ogre::Terrain::updateGeometry | ( | ) |
Performs an update on the terrain geometry based on the dirty region.
void Ogre::Terrain::updateGeometryWithoutNotifyNeighbours | ( | ) |
Performs an update on the terrain geometry based on the dirty region.
void Ogre::Terrain::widenRectByVector | ( | const Vector3 & | vec, |
const Rect & | inRect, | ||
Real | minHeight, | ||
Real | maxHeight, | ||
Rect & | outRect | ||
) |
Widen a rectangular area of terrain to take into account an extrusion vector, but specify the min / max heights to extrude manually.
vec | A vector in world space |
inRect | Input rectangle |
minHeight,maxHeight | The extents of the height to extrude |
outRect | Output rectangle |
Widen a rectangular area of terrain to take into account an extrusion vector.
vec | A vector in world space |
inRect | Input rectangle |
outRect | Output rectangle |
|
static |
Utility method to write a layer declaration to a stream.
|
static |
Utility method to write a layer instance list to a stream.
|
friend |