Empty content…
Empty title 004
data:image/s3,"s3://crabby-images/69f65/69f65655c300bc0948c316a891771b4857c13497" alt=""
data:image/s3,"s3://crabby-images/69f65/69f65655c300bc0948c316a891771b4857c13497" 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/ce4af/ce4af0d0d1795b20f22f202bf246b730fbee21a7" 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/f446f/f446f29677bc1e046f73de5516dfd0a3d42d0406" alt=""