|
|
@ -9,8 +9,6 @@ namespace MWRender
|
|
|
|
{
|
|
|
|
{
|
|
|
|
PingPongCanvas::PingPongCanvas(Shader::ShaderManager& shaderManager)
|
|
|
|
PingPongCanvas::PingPongCanvas(Shader::ShaderManager& shaderManager)
|
|
|
|
: mFallbackStateSet(new osg::StateSet)
|
|
|
|
: mFallbackStateSet(new osg::StateSet)
|
|
|
|
, mQueuedDispatchArray(std::nullopt)
|
|
|
|
|
|
|
|
, mQueuedDispatchFrameId(0)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
setUseDisplayList(false);
|
|
|
|
setUseDisplayList(false);
|
|
|
|
setUseVertexBufferObjects(true);
|
|
|
|
setUseVertexBufferObjects(true);
|
|
|
@ -37,9 +35,6 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
void PingPongCanvas::setCurrentFrameData(size_t frameId, fx::DispatchArray&& data)
|
|
|
|
void PingPongCanvas::setCurrentFrameData(size_t frameId, fx::DispatchArray&& data)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mQueuedDispatchArray = fx::DispatchArray(data);
|
|
|
|
|
|
|
|
mQueuedDispatchFrameId = !frameId;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mBufferData[frameId].data = std::move(data);
|
|
|
|
mBufferData[frameId].data = std::move(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -65,20 +60,12 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
auto& bufferData = mBufferData[frameId];
|
|
|
|
auto& bufferData = mBufferData[frameId];
|
|
|
|
|
|
|
|
|
|
|
|
if (mQueuedDispatchArray && mQueuedDispatchFrameId == frameId)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mBufferData[frameId].data = std::move(mQueuedDispatchArray.value());
|
|
|
|
|
|
|
|
mQueuedDispatchArray = std::nullopt;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const auto& data = bufferData.data;
|
|
|
|
const auto& data = bufferData.data;
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<size_t> filtered;
|
|
|
|
std::vector<size_t> filtered;
|
|
|
|
|
|
|
|
|
|
|
|
filtered.reserve(data.size());
|
|
|
|
filtered.reserve(data.size());
|
|
|
|
|
|
|
|
|
|
|
|
const fx::DispatchNode::SubPass* resolvePass = nullptr;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < data.size(); ++i)
|
|
|
|
for (size_t i = 0; i < data.size(); ++i)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
const auto& node = data[i];
|
|
|
|
const auto& node = data[i];
|
|
|
@ -86,15 +73,6 @@ namespace MWRender
|
|
|
|
if (bufferData.mask & node.mFlags)
|
|
|
|
if (bufferData.mask & node.mFlags)
|
|
|
|
continue;
|
|
|
|
continue;
|
|
|
|
|
|
|
|
|
|
|
|
for (auto it = node.mPasses.crbegin(); it != node.mPasses.crend(); ++it)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!(*it).mRenderTarget)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
resolvePass = &(*it);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
filtered.push_back(i);
|
|
|
|
filtered.push_back(i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -113,10 +91,9 @@ namespace MWRender
|
|
|
|
else
|
|
|
|
else
|
|
|
|
mLoggedLastError = false;
|
|
|
|
mLoggedLastError = false;
|
|
|
|
|
|
|
|
|
|
|
|
mFallbackStateSet->setTextureAttributeAndModes(0, bufferData.sceneTex);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
state.pushStateSet(mFallbackStateSet);
|
|
|
|
state.pushStateSet(mFallbackStateSet);
|
|
|
|
state.apply();
|
|
|
|
state.apply();
|
|
|
|
|
|
|
|
state.applyTextureAttribute(0, bufferData.sceneTex);
|
|
|
|
viewport->apply(state);
|
|
|
|
viewport->apply(state);
|
|
|
|
|
|
|
|
|
|
|
|
drawGeometry(renderInfo);
|
|
|
|
drawGeometry(renderInfo);
|
|
|
@ -223,7 +200,7 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
lastApplied = pass.mRenderTarget->getHandle(state.getContextID());;
|
|
|
|
lastApplied = pass.mRenderTarget->getHandle(state.getContextID());;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (&pass == resolvePass)
|
|
|
|
else if (pass.mResolve && index == filtered.back())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
bindDestinationFbo();
|
|
|
|
bindDestinationFbo();
|
|
|
|
}
|
|
|
|
}
|
|
|
|