1 // Copyright (C) 2007 Tim Moore timoore@redhat.com
3 // This program is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU General Public License as
5 // published by the Free Software Foundation; either version 2 of the
6 // License, or (at your option) any later version.
8 // This program is distributed in the hope that it will be useful, but
9 // WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // General Public License for more details.
13 // You should have received a copy of the GNU General Public License
14 // along with this program; if not, write to the Free Software
15 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 # include <simgear_config.h>
22 #include <osgDB/FileNameUtils>
23 #include <osgDB/Registry>
25 #include <simgear/scene/model/ModelRegistry.hxx>
26 #include <simgear/scene/util/SGReaderWriterOptions.hxx>
27 #include <simgear/math/SGMath.hxx>
29 #include "SGReaderWriterBTG.hxx"
32 using namespace simgear;
34 SGReaderWriterBTG::SGReaderWriterBTG()
36 supportsExtension("btg", "SimGear btg database format");
37 // supportsExtension("btg.gz", "SimGear btg database format");
40 SGReaderWriterBTG::~SGReaderWriterBTG()
44 const char* SGReaderWriterBTG::className() const
46 return "BTG Database reader";
50 SGReaderWriterBTG::acceptsExtension(const std::string& extension) const
52 // trick the osg extensions match algorithm to accept btg.gz files.
53 if (osgDB::convertToLowerCase(extension) == "gz")
55 return osgDB::ReaderWriter::acceptsExtension(extension);
58 osgDB::ReaderWriter::ReadResult
59 SGReaderWriterBTG::readNode(const std::string& fileName,
60 const osgDB::ReaderWriter::Options* options) const
62 SGMaterialLib* matlib = 0;
63 bool useRandomObjects = false;
64 bool useRandomVegetation = false;
65 float vegetation_density = 1.0f;
66 const SGReaderWriterOptions* sgOptions;
67 sgOptions = dynamic_cast<const SGReaderWriterOptions*>(options);
69 matlib = sgOptions->getMaterialLib();
70 SGPropertyNode* propertyNode = sgOptions->getPropertyNode().get();
73 = propertyNode->getBoolValue("/sim/rendering/random-objects",
76 = propertyNode->getBoolValue("/sim/rendering/random-vegetation",
79 = propertyNode->getFloatValue("/sim/rendering/vegetation-density",
84 osg::Node* result = SGLoadBTG(fileName, matlib,
91 return ReadResult::FILE_NOT_HANDLED;
95 typedef ModelRegistryCallback<DefaultProcessPolicy, NoCachePolicy,
97 NoSubstitutePolicy, BuildGroupBVHPolicy>
102 ModelRegistryCallbackProxy<BTGCallback> g_btgCallbackProxy("btg");