Vp::Framebuffer 
A utility class for managing an OpenGL FrameBufferObject. More...
#include "Viewport/framebuffer/Framebuffer.h"
Inherits from std::enable_shared_from_this< Framebuffer >
Public Functions 
| Name | |
|---|---|
| Framebuffer * | createDefault(bool multisample, unsigned int samples, bool alpha)<br>Create a basic framebuffer with a single color attachment and a depth-stencil buffer. | 
| Framebuffer * | createDefault(int width, int height, bool multisample, unsigned int samples, bool alpha)<br>Create a basic framebuffer with a single color attachment and a depth-stencil buffer. | 
| Framebuffer()<br>Create an empty framebuffer. | |
| Framebuffer(bool multisample, unsigned int samples)<br>Create an empty framebuffer. | |
| Framebuffer(int width, int height)<br>Create an empty framebuffer. | |
| Framebuffer(int width, int height, bool multisample, unsigned int samples)<br>Create an empty framebuffer. | |
| ~Framebuffer() | |
| void | addColorAttachment(ColorAttachment colorAttachment)<br>Add a color attachment. | 
| void | bind() const<br>Binds the FBO. | 
| void | dispose()<br>Frees up all OpenGL resources used by the framebuffer. | 
| void | end(bool resolveMultisample =true)<br>Finalizes the FBO and unbinds it. | 
| ColorAttachment & | getColorAttachment(unsigned int index) | 
| GLuint | getColorTexture(unsigned int index =0, bool multisampled =false) const<br>Returns the id of the color texture. | 
| std::optional< DepthAttachment > & | getDepthAttachment() | 
| int | getHeight() const | 
| GLuint | getId() const | 
| std::weak_ptr< Framebuffer > | getResolvedFramebuffer()<br>If this framebuffer is multisampled this methods returns a weak pointer to the internal single sampled framebuffer that was used to resolve it. | 
| unsigned int | getSampleCount() const | 
| int | getWidth() const | 
| bool | isInitialized() const | 
| bool | isMultisampled() | 
| void | multisampleResolveColor(unsigned int colorAttachmentIndex)<br>The DEFAULT (0) frame buffer is bound after this call! | 
| void | multisampleResolveColors()<br>The DEFAULT (0) frame buffer is bound after this call! | 
| void | multisampleResolveDepth()<br>The DEFAULT (0) frame buffer is bound after this call! | 
| void | recreate()<br>Completely reinitializes the framebuffer. | 
| void | removeAllColorAttachments() | 
| void | removeDepthAttachment() | 
| void | setDepthAttachment(DepthAttachment depthAttachment)<br>Set a depth attachment. | 
| void | setDrawBuffers() | 
| void | setDrawBuffers(std::vector< unsigned int > indices) | 
| void | setMultisampled(bool multisample, unsigned int samples) | 
| void | start()<br>Binds the FBO, clears it and resizes glViewport. | 
| void | start(int width, int height)<br>Binds the FBO and resizes glViewport. | 
| void | update(int width, int height)<br>Ensure the fbo has the specified size. | 
Detailed Description 
class Vp::Framebuffer;class Vp::Framebuffer;A utility class for managing an OpenGL FrameBufferObject.
Usage:
- //Create fbo object
- fbo.start(); //The fbo is lazily initialized here if necessary
- //Render stuff
- fbo.end(); //The fbo is unbound by BINDING THE DEFAULT (0) FRAMEBUFFER!
- //Multisampling is resolved here unless fbo.end(false) is called
- //Get color texture using fbo.getColorTexture()
Supports multi sampled antialiasing (MSAA) which can be enabled in the constructor. When MSAA is enabled, the framebuffer creates a second intermediate framebuffer instance which is used to "resolve" the multisampled framebuffer into a regular one.
Multisampled framebuffers with multiple color attachments are also supported. In that case the intermediate framebuffer creates equivalent single-sampled color attachment(s) for each multisampled one.
Note that the framebuffer sampling settings overwrite any attachment settings as all attachments must have the same sample count and either be all multisampled or none.
After resolving multisampling the resolved framebuffer can be accessed using getResolvedFramebuffer() and further used.
Public Functions Documentation 
function createDefault 
static Framebuffer * createDefault(
    bool multisample,
    unsigned int samples,
    bool alpha
)static Framebuffer * createDefault(
    bool multisample,
    unsigned int samples,
    bool alpha
)Create a basic framebuffer with a single color attachment and a depth-stencil buffer.
Parameters:
- multisample Whether MSAA should be enabled
- samples Amount of MSAA samples
- alpha Whether the color buffer should have an alpha component
Return: Raw unmanaged pointer to the newly created Framebuffer.
function createDefault 
static Framebuffer * createDefault(
    int width,
    int height,
    bool multisample,
    unsigned int samples,
    bool alpha
)static Framebuffer * createDefault(
    int width,
    int height,
    bool multisample,
    unsigned int samples,
    bool alpha
)Create a basic framebuffer with a single color attachment and a depth-stencil buffer.
Parameters:
- width Width of the framebuffer in pixels
- height Height of the framebuffer in pixels
- multisample Whether MSAA should be enabled
- samples Amount of MSAA samples
- alpha Whether the color buffer should have an alpha component
Return: Raw unmanaged pointer to the newly created Framebuffer.
function Framebuffer 
Framebuffer()Framebuffer()Create an empty framebuffer.
function Framebuffer 
Framebuffer(
    bool multisample,
    unsigned int samples
)Framebuffer(
    bool multisample,
    unsigned int samples
)Create an empty framebuffer.
Parameters:
- multisample Whether MSAA should be enabled
- samples Amount of MSAA samples
function Framebuffer 
Framebuffer(
    int width,
    int height
)Framebuffer(
    int width,
    int height
)Create an empty framebuffer.
Parameters:
- width Width of the framebuffer in pixels
- height Height of the framebuffer in pixels
function Framebuffer 
Framebuffer(
    int width,
    int height,
    bool multisample,
    unsigned int samples
)Framebuffer(
    int width,
    int height,
    bool multisample,
    unsigned int samples
)Create an empty framebuffer.
Parameters:
- width Width of the framebuffer in pixels
- height Height of the framebuffer in pixels
- multisample Whether MSAA should be enabled
- samples Amount of MSAA samples
function ~Framebuffer 
~Framebuffer()~Framebuffer()function addColorAttachment 
void addColorAttachment(
    ColorAttachment colorAttachment
)void addColorAttachment(
    ColorAttachment colorAttachment
)Add a color attachment.
Parameters:
- colorAttachment
Color attachment index is set to its current order in the color attachments list. Multisampling settings are synced with the framebuffer multisampling settings.
Note that color attachments are meant to be setup before using the framebuffer.
function bind 
void bind() constvoid bind() constBinds the FBO.
function dispose 
void dispose()void dispose()Frees up all OpenGL resources used by the framebuffer.
The framebuffer is considered uninitialized after this call.
function end 
void end(
    bool resolveMultisample =true
)void end(
    bool resolveMultisample =true
)Finalizes the FBO and unbinds it.
Parameters:
- resolveMultisample If the fbo is multisampled and this argument is true this call resolves the multisampled buffer into an intermediate regular (single sampled) one. Whose color texture is then returned via getColorTexture(). Note that only the first (index 0) color attachment gets resolved by this call. To resolve multiple color buffers or the depth buffer you can use the multisampleResolveXXX() methods.
The DEFAULT (0) frame buffer is bound after this call!
function getColorAttachment 
ColorAttachment & getColorAttachment(
    unsigned int index
)ColorAttachment & getColorAttachment(
    unsigned int index
)function getColorTexture 
GLuint getColorTexture(
    unsigned int index =0,
    bool multisampled =false
) constGLuint getColorTexture(
    unsigned int index =0,
    bool multisampled =false
) constReturns the id of the color texture.
Parameters:
- index Optional index of the color attachment
- multisampled Optional flag specifying if the multisampled or resolved single sampled texture should be returned. If multisampling is disabled the single sampled texture will be always returned.
function getDepthAttachment 
std::optional< DepthAttachment > & getDepthAttachment()std::optional< DepthAttachment > & getDepthAttachment()function getHeight 
int getHeight() constint getHeight() constfunction getId 
GLuint getId() constGLuint getId() constReturn: The id of the Frame Buffer Object
function getResolvedFramebuffer 
std::weak_ptr< Framebuffer > getResolvedFramebuffer()std::weak_ptr< Framebuffer > getResolvedFramebuffer()If this framebuffer is multisampled this methods returns a weak pointer to the internal single sampled framebuffer that was used to resolve it.
Otherwise it just returns a weak pointer to itself.
function getSampleCount 
unsigned int getSampleCount() constunsigned int getSampleCount() constfunction getWidth 
int getWidth() constint getWidth() constfunction isInitialized 
bool isInitialized() constbool isInitialized() constfunction isMultisampled 
bool isMultisampled()bool isMultisampled()function multisampleResolveColor 
void multisampleResolveColor(
    unsigned int colorAttachmentIndex
)void multisampleResolveColor(
    unsigned int colorAttachmentIndex
)The DEFAULT (0) frame buffer is bound after this call!
function multisampleResolveColors 
void multisampleResolveColors()void multisampleResolveColors()The DEFAULT (0) frame buffer is bound after this call!
function multisampleResolveDepth 
void multisampleResolveDepth()void multisampleResolveDepth()The DEFAULT (0) frame buffer is bound after this call!
function recreate 
void recreate()void recreate()Completely reinitializes the framebuffer.
All associated OpenGL resources are freed and can no longer be used. New resources are allocated.
function removeAllColorAttachments 
void removeAllColorAttachments()void removeAllColorAttachments()function removeDepthAttachment 
void removeDepthAttachment()void removeDepthAttachment()function setDepthAttachment 
void setDepthAttachment(
    DepthAttachment depthAttachment
)void setDepthAttachment(
    DepthAttachment depthAttachment
)Set a depth attachment.
Parameters:
- depthAttachment
Multisampling settings are synced with the framebuffer multisampling settings.
function setDrawBuffers 
void setDrawBuffers()void setDrawBuffers()function setDrawBuffers 
void setDrawBuffers(
    std::vector< unsigned int > indices
)void setDrawBuffers(
    std::vector< unsigned int > indices
)function setMultisampled 
void setMultisampled(
    bool multisample,
    unsigned int samples
)void setMultisampled(
    bool multisample,
    unsigned int samples
)function start 
void start()void start()Binds the FBO, clears it and resizes glViewport.
The FBO is also initialised if necessary. Uses previously set width and height. **Don't forget to call glClear after this call!**glViewport is set to the fbo's dimensions.
function start 
void start(
    int width,
    int height
)void start(
    int width,
    int height
)Binds the FBO and resizes glViewport.
The FBO is also initialised if necessary. **Don't forget to call glClear after this call!**glViewport is set to the fbo's dimensions.
function update 
void update(
    int width,
    int height
)void update(
    int width,
    int height
)Ensure the fbo has the specified size.
Fbo is initialized and/or resized accordingly. Has no effect if fbo is already initialized and sized as requested.
Updated on 2025-09-07 at 16:13:51 +0000