diff --git a/components/terrain/chunkmanager.cpp b/components/terrain/chunkmanager.cpp index 85f7e26c9c..e4a7c2d682 100644 --- a/components/terrain/chunkmanager.cpp +++ b/components/terrain/chunkmanager.cpp @@ -201,12 +201,14 @@ osg::ref_ptr ChunkManager::createChunk(float chunkSize, const osg::Ve mCompositeMapRenderer->addCompositeMap(compositeMap.get(), false); - std::vector > passes2; - passes2.push_back(new osg::StateSet); - passes2[0]->setTextureAttributeAndModes(0, compositeMap->mTexture, osg::StateAttribute::ON); - geometry->setPasses(passes2); - transform->getOrCreateUserDataContainer()->setUserData(compositeMap); + + TextureLayer layer; + layer.mDiffuseMap = compositeMap->mTexture; + layer.mParallax = false; + layer.mSpecular = false; + geometry->setPasses(::Terrain::createPasses(mSceneManager->getForceShaders() || !mSceneManager->getClampLighting(), mSceneManager->getForcePerPixelLighting(), + mSceneManager->getClampLighting(), &mSceneManager->getShaderManager(), std::vector(1, layer), std::vector >(), 1.f, 1.f)); } else { diff --git a/components/terrain/material.cpp b/components/terrain/material.cpp index e3e6f6de30..8aec54835b 100644 --- a/components/terrain/material.cpp +++ b/components/terrain/material.cpp @@ -81,7 +81,8 @@ namespace Terrain { stateset->setTextureAttributeAndModes(texunit, it->mDiffuseMap); - stateset->setTextureAttributeAndModes(texunit, getLayerTexMat(layerTileSize), osg::StateAttribute::ON); + if (layerTileSize != 1.f) + stateset->setTextureAttributeAndModes(texunit, getLayerTexMat(layerTileSize), osg::StateAttribute::ON); stateset->addUniform(new osg::Uniform("diffuseMap", texunit)); @@ -147,7 +148,8 @@ namespace Terrain osg::ref_ptr tex = it->mDiffuseMap; stateset->setTextureAttributeAndModes(texunit, tex.get()); - stateset->setTextureAttributeAndModes(texunit, getLayerTexMat(layerTileSize), osg::StateAttribute::ON); + if (layerTileSize != 1.f) + stateset->setTextureAttributeAndModes(texunit, getLayerTexMat(layerTileSize), osg::StateAttribute::ON); } firstLayer = false;