mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 09:35:28 +00:00
Mask out water in global map overlay
This commit is contained in:
parent
7b5f3e3cdc
commit
48a23d61b2
@ -7,6 +7,7 @@
|
||||
#include <osg/Group>
|
||||
#include <osg/Geometry>
|
||||
#include <osg/Depth>
|
||||
#include <osg/TexEnvCombine>
|
||||
|
||||
#include <osgDB/WriteFile>
|
||||
|
||||
@ -144,6 +145,10 @@ namespace MWRender
|
||||
image->allocateImage(mWidth, mHeight, 1, GL_RGB, GL_UNSIGNED_BYTE);
|
||||
unsigned char* data = image->data();
|
||||
|
||||
osg::ref_ptr<osg::Image> alphaImage = new osg::Image;
|
||||
alphaImage->allocateImage(mWidth, mHeight, 1, GL_ALPHA, GL_UNSIGNED_BYTE);
|
||||
unsigned char* alphaData = alphaImage->data();
|
||||
|
||||
for (int x = mMinX; x <= mMaxX; ++x)
|
||||
{
|
||||
for (int y = mMinY; y <= mMaxY; ++y)
|
||||
@ -208,6 +213,8 @@ namespace MWRender
|
||||
data[texelY * mWidth * 3 + texelX * 3] = r;
|
||||
data[texelY * mWidth * 3 + texelX * 3+1] = g;
|
||||
data[texelY * mWidth * 3 + texelX * 3+2] = b;
|
||||
|
||||
alphaData[texelY * mWidth+ texelX] = (y2 < 0) ? static_cast<unsigned char>(0) : static_cast<unsigned char>(255);
|
||||
}
|
||||
}
|
||||
loadingListener->increaseProgress();
|
||||
@ -224,6 +231,14 @@ namespace MWRender
|
||||
mBaseTexture->setImage(image);
|
||||
mBaseTexture->setResizeNonPowerOfTwoHint(false);
|
||||
|
||||
mAlphaTexture = new osg::Texture2D;
|
||||
mAlphaTexture->setWrap(osg::Texture::WRAP_S, osg::Texture::CLAMP_TO_EDGE);
|
||||
mAlphaTexture->setWrap(osg::Texture::WRAP_T, osg::Texture::CLAMP_TO_EDGE);
|
||||
mAlphaTexture->setFilter(osg::Texture::MIN_FILTER, osg::Texture::LINEAR);
|
||||
mAlphaTexture->setFilter(osg::Texture::MAG_FILTER, osg::Texture::LINEAR);
|
||||
mAlphaTexture->setImage(alphaImage);
|
||||
mAlphaTexture->setResizeNonPowerOfTwoHint(false);
|
||||
|
||||
clear();
|
||||
|
||||
loadingListener->loadingOff();
|
||||
@ -299,6 +314,23 @@ namespace MWRender
|
||||
stateset->setTextureAttributeAndModes(0, texture, osg::StateAttribute::ON);
|
||||
stateset->setMode(GL_LIGHTING, osg::StateAttribute::OFF);
|
||||
stateset->setMode(GL_DEPTH_TEST, osg::StateAttribute::OFF);
|
||||
|
||||
if (mAlphaTexture)
|
||||
{
|
||||
osg::ref_ptr<osg::Vec2Array> texcoords = new osg::Vec2Array;
|
||||
texcoords->push_back(osg::Vec2f(0.f, 0.f));
|
||||
texcoords->push_back(osg::Vec2f(0.f, 1.f));
|
||||
texcoords->push_back(osg::Vec2f(1.f, 1.f));
|
||||
texcoords->push_back(osg::Vec2f(1.f, 0.f));
|
||||
geom->setTexCoordArray(1, texcoords, osg::Array::BIND_PER_VERTEX);
|
||||
|
||||
stateset->setTextureAttributeAndModes(1, mAlphaTexture, osg::StateAttribute::ON);
|
||||
osg::ref_ptr<osg::TexEnvCombine> texEnvCombine = new osg::TexEnvCombine;
|
||||
texEnvCombine->setCombine_RGB(osg::TexEnvCombine::REPLACE);
|
||||
texEnvCombine->setSource0_RGB(osg::TexEnvCombine::PREVIOUS);
|
||||
stateset->setTextureAttributeAndModes(1, texEnvCombine);
|
||||
}
|
||||
|
||||
camera->addChild(geom);
|
||||
}
|
||||
|
||||
|
@ -107,6 +107,7 @@ namespace MWRender
|
||||
std::vector< std::pair<int,int> > mExploredCells;
|
||||
|
||||
osg::ref_ptr<osg::Texture2D> mBaseTexture;
|
||||
osg::ref_ptr<osg::Texture2D> mAlphaTexture;
|
||||
|
||||
// GPU copy of overlay
|
||||
// Note, uploads are pushed through a Camera, instead of through mOverlayImage
|
||||
|
Loading…
x
Reference in New Issue
Block a user