Empty content…
Empty title 004
data:image/s3,"s3://crabby-images/4a5d7/4a5d7201d65464d975cb818feb13cbfd80f5af35" alt=""
data:image/s3,"s3://crabby-images/d182f/d182f8d1fb6e3aad9f8f1d7147cf4c3ff31e9054" alt=""
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);
}
data:image/s3,"s3://crabby-images/9fddf/9fddf57da97ede7ff290cb50e1a3f6fc408ce418" alt=""
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.
data:image/s3,"s3://crabby-images/04542/04542d0756edac496c2620172f17306ae24ba6f1" alt=""