1
#include <osgTerrain/Layer>
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 HeightFieldLayer_readLocalData(osg::Object &obj, osgDB::Input &fr);
17
bool HeightFieldLayer_writeLocalData(const osg::Object &obj, osgDB::Output &fw);
19
osgDB::RegisterDotOsgWrapperProxy HeightFieldLayer_Proxy
21
new osgTerrain::HeightFieldLayer,
23
"Object Layer HeightFieldLayer",
24
HeightFieldLayer_readLocalData,
25
HeightFieldLayer_writeLocalData
28
bool HeightFieldLayer_readLocalData(osg::Object& obj, osgDB::Input &fr)
30
osgTerrain::HeightFieldLayer& layer = static_cast<osgTerrain::HeightFieldLayer&>(obj);
32
bool itrAdvanced = false;
34
if (fr.matchSequence("file %w") || fr.matchSequence("file %s"))
38
osgTerrain::extractSetNameAndFileName(fr[1].getStr(),setname, filename);
39
if (!filename.empty())
41
osg::ref_ptr<osg::HeightField> hf = osgDB::readHeightFieldFile(filename);
44
layer.setName(setname);
45
layer.setFileName(filename);
46
layer.setHeightField(hf.get());
53
osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osg::HeightField>());
54
if (readObject.valid()) itrAdvanced = true;
56
osg::HeightField* hf = dynamic_cast<osg::HeightField*>(readObject.get());
59
layer.setHeightField(hf);
65
bool HeightFieldLayer_writeLocalData(const osg::Object& obj, osgDB::Output& fw)
67
const osgTerrain::HeightFieldLayer& layer = static_cast<const osgTerrain::HeightFieldLayer&>(obj);
69
if (!layer.getFileName().empty())
71
std::string str = osgTerrain::createCompondSetNameAndFileName(layer.getName(), layer.getFileName());
72
fw.indent()<<"file "<< str << std::endl;
76
if (layer.getHeightField())
78
fw.writeObject(*layer.getHeightField());