2006-07-18 23:21:48 +08:00
|
|
|
/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 Robert Osfield
|
2004-05-04 04:42:58 +08:00
|
|
|
*
|
|
|
|
* This library is open source and may be redistributed and/or modified under
|
|
|
|
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
|
|
|
|
* (at your option) any later version. The full license is in LICENSE file
|
|
|
|
* included with this distribution, and on the openscenegraph.org website.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* OpenSceneGraph Public License for more details.
|
|
|
|
*/
|
|
|
|
|
2007-03-14 19:24:04 +08:00
|
|
|
#ifndef OSGTERRAIN_TERRAINNODE
|
|
|
|
#define OSGTERRAIN_TERRAINNODE 1
|
2004-05-04 04:42:58 +08:00
|
|
|
|
|
|
|
#include <osg/Group>
|
|
|
|
#include <osg/CoordinateSystemNode>
|
2007-03-22 00:34:04 +08:00
|
|
|
#include <osg/TransferFunction>
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-14 19:24:04 +08:00
|
|
|
#include <osgTerrain/TerrainTechnique>
|
2007-03-19 18:54:39 +08:00
|
|
|
#include <osgTerrain/Layer>
|
2007-03-22 00:34:04 +08:00
|
|
|
#include <osgTerrain/Locator>
|
2004-05-04 04:42:58 +08:00
|
|
|
|
|
|
|
namespace osgTerrain {
|
|
|
|
|
|
|
|
/** Terrain provides a framework for loosly coupling height field data with height rendering algorithms.
|
2007-03-19 18:54:39 +08:00
|
|
|
* This allows TerrainTechnique's to be pluged in at runtime.*/
|
2007-03-14 19:24:04 +08:00
|
|
|
class OSGTERRAIN_EXPORT TerrainNode : public osg::Group
|
2004-05-04 04:42:58 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2007-03-14 19:24:04 +08:00
|
|
|
TerrainNode();
|
2004-05-04 04:42:58 +08:00
|
|
|
|
|
|
|
/** Copy constructor using CopyOp to manage deep vs shallow copy.*/
|
2007-03-14 19:24:04 +08:00
|
|
|
TerrainNode(const TerrainNode&,const osg::CopyOp& copyop=osg::CopyOp::SHALLOW_COPY);
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-14 19:24:04 +08:00
|
|
|
META_Node(osgTerrain, TerrainNode);
|
2004-05-04 04:42:58 +08:00
|
|
|
|
|
|
|
virtual void traverse(osg::NodeVisitor& nv);
|
|
|
|
|
|
|
|
|
2007-03-19 18:54:39 +08:00
|
|
|
/** Set the TerrainTechnique*/
|
|
|
|
void setTerrainTechnique(osgTerrain::TerrainTechnique* TerrainTechnique);
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-19 18:54:39 +08:00
|
|
|
/** Get the TerrainTechnique*/
|
|
|
|
TerrainTechnique* getTerrainTechnique() { return _terrainTechnique.get(); }
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-19 18:54:39 +08:00
|
|
|
/** Get the const TerrainTechnique*/
|
|
|
|
const TerrainTechnique* getTerrainTechnique() const { return _terrainTechnique.get(); }
|
2004-05-04 04:42:58 +08:00
|
|
|
|
|
|
|
|
2007-03-22 00:34:04 +08:00
|
|
|
/** Set the coordinate frame locator of the terrain node.
|
|
|
|
* The locator takes non-dimensional s,t coordinates into the X,Y,Z world coords and back.*/
|
|
|
|
void setLocator(Locator* locator) { _locator = locator; }
|
|
|
|
|
|
|
|
/** Get the coordinate frame locator of the terrain node.*/
|
|
|
|
Locator* getLocator() { return _locator.get(); }
|
|
|
|
|
|
|
|
/** Get the coordinate frame locator of the terrain node.*/
|
|
|
|
const Locator* getLocator() const { return _locator.get(); }
|
|
|
|
|
2007-04-11 19:20:04 +08:00
|
|
|
/** Set the layer to use to define the elevations of the terrain.*/
|
2007-03-22 00:34:04 +08:00
|
|
|
void setElevationLayer(Layer* layer);
|
2007-04-11 19:20:04 +08:00
|
|
|
|
|
|
|
/** Get the layer to use to define the elevations of the terrain.*/
|
2007-03-22 00:34:04 +08:00
|
|
|
Layer* getElevationLayer() { return _elevationLayer.get(); }
|
2007-04-11 19:20:04 +08:00
|
|
|
|
|
|
|
/** Get the const layer to use to define the elevations of the terrain.*/
|
2007-03-22 00:34:04 +08:00
|
|
|
const Layer* getElevationLayer() const { return _elevationLayer.get(); }
|
2007-04-11 19:20:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
/** Set a color layer with specified layer number.*/
|
|
|
|
void setColorLayer(unsigned int i, osgTerrain::Layer* layer);
|
|
|
|
|
|
|
|
/** Get color layer with specified layer number.*/
|
|
|
|
Layer* getColorLayer(unsigned int i) { return i<_colorLayers.size() ? _colorLayers[i].layer.get() : 0; }
|
|
|
|
|
|
|
|
/** Set const color layer with specified layer number.*/
|
|
|
|
const Layer* getColorLayer(unsigned int i) const { return i<_colorLayers.size() ? _colorLayers[i].layer.get() : 0; }
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-04-11 19:20:04 +08:00
|
|
|
/** Set a color transfer function with specified layer number.*/
|
|
|
|
void setColorTransferFunction(unsigned int i, osg::TransferFunction* tf);
|
|
|
|
|
|
|
|
/** Get color transfer function with specified layer number.*/
|
|
|
|
osg::TransferFunction* getColorTransferFunction(unsigned int i) { return i<_colorLayers.size() ? _colorLayers[i].transferFunction.get() : 0; }
|
|
|
|
|
|
|
|
/** Get const color transfer function with specified layer number.*/
|
|
|
|
const osg::TransferFunction* getColorTransferFunction(unsigned int i) const { return i<_colorLayers.size() ? _colorLayers[i].transferFunction.get() : 0; }
|
|
|
|
|
2007-04-30 17:47:35 +08:00
|
|
|
enum Filter
|
|
|
|
{
|
|
|
|
NEAREST,
|
|
|
|
LINEAR
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Set a color filter with specified layer number.*/
|
|
|
|
void setColorFilter(unsigned int i, Filter filter);
|
|
|
|
|
|
|
|
/** Set const color filter with specified layer number.*/
|
|
|
|
Filter getColorFilter(unsigned int i) const { return i<_colorLayers.size() ? _colorLayers[i].filter : LINEAR; }
|
|
|
|
|
|
|
|
|
|
|
|
/** Get the number of colour layers.*/
|
2007-04-11 19:20:04 +08:00
|
|
|
unsigned int getNumColorLayers() const { return _colorLayers.size(); }
|
|
|
|
|
|
|
|
|
|
|
|
/** Set whether the TerrainTechnique should create per vertex normals for lighting purposes.*/
|
|
|
|
void setRequiresNormals(bool flag) { _requiresNormals = flag; }
|
|
|
|
|
|
|
|
/** Get whether the TerrainTechnique should create per vertex normals for lighting purposes.*/
|
|
|
|
bool getRequiresNormals() const { return _requiresNormals; }
|
|
|
|
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-28 03:27:36 +08:00
|
|
|
/** Compute the bounding volume of the terrain by computing the union of the bounding volumes of all layers.*/
|
|
|
|
virtual osg::BoundingSphere computeBound() const;
|
|
|
|
|
2004-05-04 04:42:58 +08:00
|
|
|
protected:
|
|
|
|
|
2007-03-14 19:24:04 +08:00
|
|
|
virtual ~TerrainNode();
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-04-11 19:20:04 +08:00
|
|
|
struct LayerData
|
|
|
|
{
|
2007-04-30 17:47:35 +08:00
|
|
|
LayerData():
|
|
|
|
filter(LINEAR) {}
|
|
|
|
|
|
|
|
LayerData(const LayerData& rhs):
|
|
|
|
filter(rhs.filter),
|
|
|
|
layer(rhs.layer),
|
|
|
|
transferFunction(rhs.transferFunction) {}
|
|
|
|
|
|
|
|
LayerData& operator = (const LayerData& rhs)
|
|
|
|
{
|
|
|
|
filter = rhs.filter;
|
|
|
|
layer = rhs.layer;
|
|
|
|
transferFunction = rhs.transferFunction;
|
|
|
|
}
|
|
|
|
|
|
|
|
Filter filter;
|
|
|
|
osg::ref_ptr<Layer> layer;
|
2007-04-11 19:20:04 +08:00
|
|
|
osg::ref_ptr<osg::TransferFunction> transferFunction;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef std::vector<LayerData> Layers;
|
|
|
|
|
2007-03-22 00:34:04 +08:00
|
|
|
osg::ref_ptr<TerrainTechnique> _terrainTechnique;
|
|
|
|
osg::ref_ptr<Locator> _locator;
|
2004-05-04 04:42:58 +08:00
|
|
|
|
2007-03-22 00:34:04 +08:00
|
|
|
osg::ref_ptr<Layer> _elevationLayer;
|
|
|
|
|
2007-04-11 19:20:04 +08:00
|
|
|
Layers _colorLayers;
|
|
|
|
|
|
|
|
bool _requiresNormals;
|
2004-05-04 04:42:58 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|