⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 terraintile.cpp

📁 最新osg包
💻 CPP
字号:
#include <osgTerrain/TerrainTile>#include <iostream>#include <string>#include <osg/Vec3>#include <osg/Vec4>#include <osg/io_utils>#include <osgDB/ReadFile>#include <osgDB/Registry>#include <osgDB/Input>#include <osgDB/Output>#include <osgDB/ParameterOutput>bool TerrainTile_readLocalData(osg::Object &obj, osgDB::Input &fr);bool TerrainTile_writeLocalData(const osg::Object &obj, osgDB::Output &fw);osgDB::RegisterDotOsgWrapperProxy TerrainTile_Proxy(    new osgTerrain::TerrainTile,    "TerrainTile",    "Object Node TerrainTile Group",    TerrainTile_readLocalData,    TerrainTile_writeLocalData);osg::TransferFunction* readTransferFunction(osgDB::Input& fr){    osg::ref_ptr<osg::TransferFunction1D> tf = new osg::TransferFunction1D;        int entry = fr[0].getNoNestedBrackets();    fr += 2;    std::vector<osg::Vec4> colours;    while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)    {        bool itrAdvanced = false;        if (fr.matchSequence("range %f %f"))        {            float minValue,maxValue;            fr[1].getFloat(minValue);            fr[2].getFloat(maxValue);                    tf->setInputRange(minValue,maxValue);                        fr += 3;            itrAdvanced = true;        }        if (fr.matchSequence("color %f %f %f %f"))        {            float r,g,b,a;            fr[1].getFloat(r);            fr[2].getFloat(g);            fr[3].getFloat(b);            fr[4].getFloat(a);                    colours.push_back(osg::Vec4(r,g,b,a));                        fr += 5;            itrAdvanced = true;        }        if (fr.matchSequence("color %f %f %f"))        {            float r,g,b;            fr[1].getFloat(r);            fr[2].getFloat(g);            fr[3].getFloat(b);                    colours.push_back(osg::Vec4(r,g,b,1.0f));                        fr += 5;            itrAdvanced = true;        }        if (!itrAdvanced)        {            if (fr[0].getStr()) osg::notify(osg::NOTICE)<<"TransferFunction - unreconised token : "<<fr[0].getStr() << std::endl;            ++fr;        }    }        // step over trailing }    ++fr;        if (!colours.empty())    {        tf->allocate(colours.size());        for(unsigned int i=0; i<colours.size(); ++i)        {            tf->setValue(i, colours[i]);        }    }    if (tf->getNumberCellsX()==0)    {        tf->allocate(6);        tf->setValue(0, osg::Vec4(1.0,1.0,1.0,1.0));        tf->setValue(1, osg::Vec4(1.0,0.0,1.0,1.0));        tf->setValue(2, osg::Vec4(1.0,0.0,0.0,1.0));        tf->setValue(3, osg::Vec4(1.0,1.0,0.0,1.0));        tf->setValue(4, osg::Vec4(0.0,1.0,1.0,1.0));        tf->setValue(5, osg::Vec4(0.0,1.0,0.0,1.0));    }    return tf.release();}bool TerrainTile_readLocalData(osg::Object& obj, osgDB::Input &fr){    osgTerrain::TerrainTile& terrainTile = static_cast<osgTerrain::TerrainTile&>(obj);    bool itrAdvanced = false;    osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());    if (readObject.valid()) itrAdvanced = true;    osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());    if (locator) terrainTile.setLocator(locator);    if (fr.matchSequence("ElevationLayer {"))    {        int entry = fr[0].getNoNestedBrackets();        fr += 2;        while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)        {            bool localAdvanced = false;            osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());            osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());            if (readObject.valid()) localAdvanced = true;            unsigned int minLevel=0;            if (fr.read("MinLevel",minLevel))            {                itrAdvanced = true;            }            unsigned int maxLevel = MAXIMUM_NUMBER_OF_LEVELS;            if (fr.read("MaxLevel",maxLevel))            {                itrAdvanced = true;            }            if (fr.matchSequence("ProxyLayer %s") || fr.matchSequence("ProxyLayer %w") )            {                osgTerrain::ProxyLayer* proxyLayer = new osgTerrain::ProxyLayer;                proxyLayer->setFileName(fr[1].getStr());                if (locator) proxyLayer->setLocator(locator);                if (minLevel!=0) proxyLayer->setMinLevel(minLevel);                if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) proxyLayer->setMaxLevel(maxLevel);                terrainTile.setElevationLayer(proxyLayer);                            fr += 2;                localAdvanced = true;            }            else            {                osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Layer>());                osgTerrain::Layer* readLayer = dynamic_cast<osgTerrain::Layer*>(readObject.get());                if (readLayer)                {                    if (locator) readLayer->setLocator(locator);                    if (minLevel!=0) readLayer->setMinLevel(minLevel);                    if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) readLayer->setMaxLevel(maxLevel);                    terrainTile.setElevationLayer(readLayer);                }                if (readObject.valid()) localAdvanced = true;            }            if (!localAdvanced) ++fr;        }        itrAdvanced = true;    }    bool firstMatched = false;    if ((firstMatched = fr.matchSequence("ColorLayer %i {")) || fr.matchSequence("ColorLayer {") )    {        unsigned int layerNum = 0;        if (firstMatched)        {            fr[1].getUInt(layerNum);                    ++fr;        }        int entry = fr[0].getNoNestedBrackets();        fr += 2;        while (!fr.eof() && fr[0].getNoNestedBrackets()>entry)        {            bool localAdvanced = false;            osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Locator>());            osgTerrain::Locator* locator = dynamic_cast<osgTerrain::Locator*>(readObject.get());            if (readObject.valid()) localAdvanced = true;            unsigned int minLevel=0;            if (fr.read("MinLevel",minLevel))            {                itrAdvanced = true;            }            unsigned int maxLevel = MAXIMUM_NUMBER_OF_LEVELS;            if (fr.read("MaxLevel",maxLevel))            {                itrAdvanced = true;            }            if (fr.matchSequence("ProxyFile %s") || fr.matchSequence("ProxyFile %w") )            {                osg::ref_ptr<osg::Object> image = osgDB::readObjectFile(std::string(fr[1].getStr())+".gdal");                osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<osgTerrain::ProxyLayer*>(image.get());                if (proxyLayer)                {                    if (locator) proxyLayer->setLocator(locator);                    if (minLevel!=0) proxyLayer->setMinLevel(minLevel);                    if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) proxyLayer->setMaxLevel(maxLevel);                    terrainTile.setColorLayer(layerNum, proxyLayer);                }                                            fr += 2;                localAdvanced = true;            }            else            {                osg::ref_ptr<osg::Object> readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::Layer>());                osgTerrain::Layer* readLayer = dynamic_cast<osgTerrain::Layer*>(readObject.get());                if (readLayer)                {                    if (locator) readLayer->setLocator(locator);                    if (minLevel!=0) readLayer->setMinLevel(minLevel);                    if (maxLevel!=MAXIMUM_NUMBER_OF_LEVELS) readLayer->setMaxLevel(maxLevel);                    terrainTile.setColorLayer(layerNum, readLayer);                }                if (readObject.valid()) localAdvanced = true;            }            if (!localAdvanced) ++fr;        }        itrAdvanced = true;    }    readObject = fr.readObjectOfType(osgDB::type_wrapper<osgTerrain::TerrainTechnique>());    if (readObject.valid())    {        terrainTile.setTerrainTechnique(dynamic_cast<osgTerrain::TerrainTechnique*>(readObject.get()));        itrAdvanced = true;    }    if (osgTerrain::TerrainTile::getTileLoadedCallback().valid())         osgTerrain::TerrainTile::getTileLoadedCallback()->loaded(&terrainTile, fr.getOptions());    return itrAdvanced;}bool TerrainTile_writeLocalData(const osg::Object& obj, osgDB::Output& fw){    const osgTerrain::TerrainTile& terrainTile = static_cast<const osgTerrain::TerrainTile&>(obj);    int prec = fw.precision();    fw.precision(15);    if (terrainTile.getLocator())    {        fw.writeObject(*terrainTile.getLocator());    }    if (terrainTile.getElevationLayer())    {        fw.indent()<<"ElevationLayer {"<<std::endl;        fw.moveIn();                const osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<const osgTerrain::ProxyLayer*>(terrainTile.getElevationLayer());        if (proxyLayer)        {            if (!proxyLayer->getFileName().empty())            {                const osgTerrain::Locator* locator = proxyLayer->getLocator();                if (locator && !locator->getDefinedInFile())                {                    fw.writeObject(*locator);                }                if (proxyLayer->getMinLevel()!=0)                {                    fw.indent()<<"MinLevel "<<proxyLayer->getMinLevel()<<std::endl;                }                 if (proxyLayer->getMaxLevel()!=MAXIMUM_NUMBER_OF_LEVELS)                {                    fw.indent()<<"MaxLevel "<<proxyLayer->getMaxLevel()<<std::endl;                }                 fw.indent()<<"ProxyLayer "<<proxyLayer->getFileName()<<std::endl;            }        }        else if (terrainTile.getElevationLayer())        {            fw.writeObject(*terrainTile.getElevationLayer());        }        fw.moveOut();        fw.indent()<<"}"<<std::endl;    }    for(unsigned int i=0; i<terrainTile.getNumColorLayers(); ++i)    {        const osgTerrain::Layer* layer = terrainTile.getColorLayer(i);        if (layer)        {            if (i>0)            {                fw.indent()<<"ColorLayer "<<i<<" {"<<std::endl;            }            else            {                fw.indent()<<"ColorLayer {"<<std::endl;            }            fw.moveIn();                        const osgTerrain::ProxyLayer* proxyLayer = dynamic_cast<const osgTerrain::ProxyLayer*>(layer);            if (proxyLayer)            {                const osgTerrain::Locator* locator = proxyLayer->getLocator();                if (locator && !locator->getDefinedInFile())                {                    fw.writeObject(*locator);                }                if (proxyLayer->getMinLevel()!=0)                {                    fw.indent()<<"MinLevel "<<proxyLayer->getMinLevel()<<std::endl;                }                 if (proxyLayer->getMaxLevel()!=MAXIMUM_NUMBER_OF_LEVELS)                {                    fw.indent()<<"MaxLevel "<<proxyLayer->getMaxLevel()<<std::endl;                }                 if (!proxyLayer->getFileName().empty()) fw.indent()<<"ProxyLayer "<<proxyLayer->getFileName()<<std::endl;            }            else if (layer)            {                fw.writeObject(*terrainTile.getColorLayer(i));            }            fw.moveOut();            fw.indent()<<"}"<<std::endl;        }    }    if (terrainTile.getTerrainTechnique())    {        fw.writeObject(*terrainTile.getTerrainTechnique());    }        fw.precision(prec);        return true;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -