Archive 19/01/2023.

Empty title 004

vram32

Empty content…

vmost

Looks like you’d have to write a custom function. Hold on… this doesn’t work since resize calls the SharedPtr destructor and GetViewport() returns a raw pointer not a smart pointer… hmm. Unless, does the intrusive reference counting keep it alive?

void RemoveViewportCustom(unsigned index)
{
    Renderer* ren{GetSubsystem<Renderer>()};
    unsigned num_viewports{ren->GetNumViewports()};

    if (index >= num_viewports || num_viewports == 0)
        return;

    // swap the viewport to remove with the last viewport
    if (num_viewports > 1 && index + 1 != num_viewports)
        ren->SetViewport(index, ren->GetViewport(num_viewports - 1));

    // resize the view port count to get rid of last element
    ren->SetNumViewports(num_viewports - 1);
}
Avagrande

Viewports are managed by the Renderer by keeping a list of shared pointers which point to the viewports including yours.
To remove a viewport you need to get the shared pointer reference count to 0.
So:

  • change the viewport count using renderer->SetViewportNum()
  • set a different viewport using renderer->SetViewport() in the same index
  • set the shared ptr you are using to null

Once you do this the viewport will be removed provided you are not using it somewhere else.

Personally I encountered this while in Lua whereby setting the viewports would destroy them as shared pointers do not translate to Lua well. Everytime I would call SetViewport for sorting my viewports dynamically, it would destroy my viewport causing a seg fault when I try to set it to a different index. Same goes for setting another viewport in the index your viewport is set to.

weitjong