1
#include <osgTerrain/TerrainTile>
8
#include <osg/io_utils>
10
#include <osgDB/ReadFile>
11
#include <osgDB/Registry>
12
#include <osgDB/Input>
13
#include <osgDB/Output>
14
#include <osgDB/ParameterOutput>
16
bool TerrainTile_readLocalData(osg::Object &obj, osgDB::Input &fr);
17
bool TerrainTile_writeLocalData(const osg::Object &obj, osgDB::Output &fw);
19
osgDB::RegisterDotOsgWrapperProxy TerrainTile_Proxy
21
new osgTerrain::TerrainTile,
23
"Object Node TerrainTile Group",
24
TerrainTile_readLocalData,
25
TerrainTile_writeLocalData
28
osg::TransferFunction* readTransferFunction(osgDB::Input& fr)
30
osg::ref_ptr<osg::TransferFunction1D> tf = new osg::TransferFunction1D;
32
int entry = fr[0].getNoNestedBrackets();
36
std::vector<osg::Vec4> colours;
38
while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)
40
bool itrAdvanced = false;
41
if (fr.matchSequence("range %f %f"))
43
float minValue,maxValue;
44
fr[1].getFloat(minValue);
45
fr[2].getFloat(maxValue);
47
tf->setInputRange(minValue,maxValue);
53
if (fr.matchSequence("color %f %f %f %f"))
61
colours.push_back(osg::Vec4(r,g,b,a));
67
if (fr.matchSequence("color %f %f %f"))
74
colours.push_back(osg::Vec4(r,g,b,1.0f));
82
if (fr[0].getStr()) osg::notify(osg::NOTICE)<<"TransferFunction - unreconised token : "<<fr[0].getStr() << std::endl;
88
// step over trailing }
93
tf->allocate(colours.size());
94
for(unsigned int i=0; i<colours.size(); ++i)
96
tf->setValue(i, colours[i]);
100
if (tf->getNumberCellsX()==0)
103
tf->setValue(0, osg::Vec4(1.0,1.0,1.0,1.0));
104
tf->setValue(1, osg::Vec4(1.0,0.0,1.0,1.0));
105
tf->setValue(2, osg::Vec4(1.0,0.0,0.0,1.0));
106
tf->setValue(3, osg::Vec4(1.0,1.0,0.0,1.0));
107
tf->setValue(4, osg::Vec4(0.0,1.0,1.0,1.0));
108
tf->setValue(5, osg::Vec4(0.0,1.0,0.0,1.0));
115
bool TerrainTile_readLocalData(osg::Object& obj, osgDB::Input &fr)
117
osgTerrain::TerrainTile& terrainTile = static_cast<osgTerrain::TerrainTile&>(obj);
119
bool itrAdvanced = false;
121
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());
122
if (readObject.valid()) itrAdvanced = true;
124
osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());
125
if (locator) terrainTile.setLocator(locator);
127
if (fr.matchSequence("ElevationLayer {"))
129
int entry = fr[0].getNoNestedBrackets();
132
while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)
134
bool localAdvanced = false;
136
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());
137
osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());
138
if (readObject.valid()) localAdvanced = true;
140
unsigned int minLevel=0;
141
if (fr.read("MinLevel",minLevel))
146
unsigned int maxLevel = MAXIMUM_NUMBER_OF_LEVELS;
147
if (fr.read("MaxLevel",maxLevel))
152
if (fr.matchSequence("ProxyLayer %s") || fr.matchSequence("ProxyLayer %w") )
154
osgTerrain::ProxyLayer* proxyLayer = new osgTerrain::ProxyLayer;
155
proxyLayer->setFileName(fr[1].getStr());
157
if (locator) proxyLayer->setLocator(locator);
158
if (minLevel!=0) proxyLayer->setMinLevel(minLevel);
159
if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) proxyLayer->setMaxLevel(maxLevel);
161
terrainTile.setElevationLayer(proxyLayer);
165
localAdvanced = true;
169
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Layer>());
170
osgTerrain::Layer* readLayer = dynamic_cast<osgTerrain::Layer*>(readObject.get());
173
if (locator) readLayer->setLocator(locator);
174
if (minLevel!=0) readLayer->setMinLevel(minLevel);
175
if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) readLayer->setMaxLevel(maxLevel);
177
terrainTile.setElevationLayer(readLayer);
180
if (readObject.valid()) localAdvanced = true;
183
if (!localAdvanced) ++fr;
189
bool firstMatched = false;
190
if ((firstMatched = fr.matchSequence("ColorLayer %i {")) || fr.matchSequence("ColorLayer {") )
192
unsigned int layerNum = 0;
195
fr[1].getUInt(layerNum);
199
int entry = fr[0].getNoNestedBrackets();
202
while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)
204
bool localAdvanced = false;
206
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());
207
osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());
208
if (readObject.valid()) localAdvanced = true;
210
unsigned int minLevel=0;
211
if (fr.read("MinLevel",minLevel))
216
unsigned int maxLevel = MAXIMUM_NUMBER_OF_LEVELS;
217
if (fr.read("MaxLevel",maxLevel))
222
if (fr.matchSequence("ProxyFile %s") || fr.matchSequence("ProxyFile %w") )
224
osg::ref_ptr<osg::Object> image = osgDB::readObjectFile(std::string(fr[1].getStr())+".gdal");
225
osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<osgTerrain::ProxyLayer*>(image.get());
228
if (locator) proxyLayer->setLocator(locator);
229
if (minLevel!=0) proxyLayer->setMinLevel(minLevel);
230
if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) proxyLayer->setMaxLevel(maxLevel);
232
terrainTile.setColorLayer(layerNum, proxyLayer);
237
localAdvanced = true;
241
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Layer>());
242
osgTerrain::Layer* readLayer = dynamic_cast<osgTerrain::Layer*>(readObject.get());
245
if (locator) readLayer->setLocator(locator);
246
if (minLevel!=0) readLayer->setMinLevel(minLevel);
247
if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) readLayer->setMaxLevel(maxLevel);
249
terrainTile.setColorLayer(layerNum, readLayer);
252
if (readObject.valid()) localAdvanced = true;
255
if (!localAdvanced) ++fr;
262
readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::TerrainTechnique>());
263
if (readObject.valid())
265
terrainTile.setTerrainTechnique(dynamic_cast<osgTerrain::TerrainTechnique*>(readObject.get()));
273
bool TerrainTile_writeLocalData(const osg::Object& obj, osgDB::Output& fw)
275
const osgTerrain::TerrainTile& terrainTile = static_cast<const osgTerrain::TerrainTile&>(obj);
277
int prec = fw.precision();
280
if (terrainTile.getLocator())
282
fw.writeObject(*terrainTile.getLocator());
285
if (terrainTile.getElevationLayer())
287
fw.indent()<<"ElevationLayer {"<<std::endl;
291
const osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<const osgTerrain::ProxyLayer*>(terrainTile.getElevationLayer());
294
if (!proxyLayer->getFileName().empty())
296
const osgTerrain::Locator* locator = proxyLayer->getLocator();
297
if (locator && !locator->getDefinedInFile())
299
fw.writeObject(*locator);
302
if (proxyLayer->getMinLevel()!=0)
304
fw.indent()<<"MinLevel "<<proxyLayer->getMinLevel()<<std::endl;
307
if (proxyLayer->getMaxLevel()!=MAXIMUM_NUMBER_OF_LEVELS)
309
fw.indent()<<"MaxLevel "<<proxyLayer->getMaxLevel()<<std::endl;
312
fw.indent()<<"ProxyLayer "<<proxyLayer->getFileName()<<std::endl;
315
else if (terrainTile.getElevationLayer())
317
fw.writeObject(*terrainTile.getElevationLayer());
322
fw.indent()<<"}"<<std::endl;
325
for(unsigned int i=0; i<terrainTile.getNumColorLayers(); ++i)
327
const osgTerrain::Layer* layer = terrainTile.getColorLayer(i);
332
fw.indent()<<"ColorLayer "<<i<<" {"<<std::endl;
336
fw.indent()<<"ColorLayer {"<<std::endl;
341
const osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<const osgTerrain::ProxyLayer*>(layer);
344
const osgTerrain::Locator* locator = proxyLayer->getLocator();
345
if (locator && !locator->getDefinedInFile())
347
fw.writeObject(*locator);
350
if (proxyLayer->getMinLevel()!=0)
352
fw.indent()<<"MinLevel "<<proxyLayer->getMinLevel()<<std::endl;
355
if (proxyLayer->getMaxLevel()!=MAXIMUM_NUMBER_OF_LEVELS)
357
fw.indent()<<"MaxLevel "<<proxyLayer->getMaxLevel()<<std::endl;
360
if (!proxyLayer->getFileName().empty()) fw.indent()<<"ProxyLayer "<<proxyLayer->getFileName()<<std::endl;
364
fw.writeObject(*terrainTile.getColorLayer(i));
369
fw.indent()<<"}"<<std::endl;
373
if (terrainTile.getTerrainTechnique())
375
fw.writeObject(*terrainTile.getTerrainTechnique());