Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use renderArea of RenderGraph instead of the full window/framebuffer …
Browse files Browse the repository at this point in the history
…extent when creating the compile-context default viewportstate

Nominally, Views are above RenderGraphs in VSG scene graphs, however when a View that takes up a subset of the window/framebuffer extent
contains individual RenderGraphs, the recorded default renderArea (viewportstate) was incorrect and resulted in the scene being
drawn to the entire window area, but scissored to the render graphs renderArea. This change ensures that the default
viewportstate is consistent with the rendergraph being compiled.
theodoregoetz committed Nov 25, 2024
1 parent b35a78f commit 5026aa2
Showing 1 changed file with 3 additions and 8 deletions.
11 changes: 3 additions & 8 deletions src/vsg/app/CompileTraversal.cpp
Original file line number Diff line number Diff line change
@@ -387,14 +387,9 @@ void CompileTraversal::apply(RenderGraph& renderGraph)
auto previousOverridePipelineStates = context->overridePipelineStates;

context->renderPass = renderGraph.getRenderPass();
if (renderGraph.window)
{
mergeGraphicsPipelineStates(context->mask, context->defaultPipelineStates, ViewportState::create(renderGraph.window->extent2D()));
}
else if (renderGraph.framebuffer)
{
mergeGraphicsPipelineStates(context->mask, context->defaultPipelineStates, ViewportState::create(renderGraph.framebuffer->extent2D()));
}
auto const& ra = renderGraph.renderArea;
mergeGraphicsPipelineStates(context->mask, context->defaultPipelineStates,
ViewportState::create(ra.offset.x, ra.offset.y, ra.extent.width, ra.extent.height));

if (context->renderPass)
{

0 comments on commit 5026aa2

Please sign in to comment.