X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Frenderbuffer.cpp;h=e86a97a50b63393d3220c02dd96e9d0e5037b85c;hp=6d9592b198e44be071fb8a8f421338be11179ec5;hb=bec07999d95b76f4b47cffcc564d0cd0afc0435e;hpb=f14435e58bfa0fa697a06ba9a454bb30cd37d9d8 diff --git a/source/renderbuffer.cpp b/source/renderbuffer.cpp index 6d9592b1..e86a97a5 100644 --- a/source/renderbuffer.cpp +++ b/source/renderbuffer.cpp @@ -1,51 +1,81 @@ -#include "extension.h" -#include "ext_framebuffer_multisample.h" -#include "ext_framebuffer_object.h" +#include +#include +#include +#include "misc.h" #include "renderbuffer.h" +using namespace std; + namespace Msp { namespace GL { Renderbuffer::Renderbuffer() { - static RequireExtension _ext("GL_EXT_framebuffer_object"); + static Require _req(EXT_framebuffer_object); - glGenRenderbuffersEXT(1, &id); + if(ARB_direct_state_access) + glCreateRenderbuffers(1, &id); + else + glGenRenderbuffers(1, &id); } Renderbuffer::~Renderbuffer() { - glDeleteRenderbuffersEXT(1, &id); + glDeleteRenderbuffers(1, &id); +} + +void Renderbuffer::storage(PixelFormat fmt, unsigned wd, unsigned ht) +{ + require_pixelformat(fmt); + width = wd; + height = ht; + if(ARB_direct_state_access) + glNamedRenderbufferStorage(id, fmt, width, height); + else + { + BindRestore _bind(this); + glRenderbufferStorage(GL_RENDERBUFFER, fmt, width, height); + } } -void Renderbuffer::storage(PixelFormat fmt, unsigned w, unsigned h) +unsigned Renderbuffer::get_max_samples() { - Bind _bind(this, true); - width = w; - height = h; - glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, fmt, width, height); + static unsigned max_samples = (EXT_framebuffer_multisample ? get_i(GL_MAX_SAMPLES) : 0); + return max_samples; } -void Renderbuffer::storage_multisample(unsigned samples, PixelFormat fmt, unsigned w, unsigned h) +void Renderbuffer::storage_multisample(unsigned samples, PixelFormat fmt, unsigned wd, unsigned ht) { - static RequireExtension _ext("GL_EXT_framebuffer_multisample"); + if(!samples) + return storage(fmt, wd, ht); + + static Require _req(EXT_framebuffer_multisample); + if(samples>get_max_samples()) + throw out_of_range("Renderbuffer::storage_multisample"); + + require_pixelformat(fmt); - Bind _bind(this, true); - width = w; - height = h; - glRenderbufferStorageMultisampleEXT(GL_RENDERBUFFER_EXT, samples, fmt, width, height); + width = wd; + height = ht; + if(ARB_direct_state_access) + glNamedRenderbufferStorageMultisample(id, samples, fmt, width, height); + else + { + BindRestore _bind(this); + glRenderbufferStorageMultisample(GL_RENDERBUFFER, samples, fmt, width, height); + } } void Renderbuffer::bind() const { if(set_current(this)) - glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, id); + glBindRenderbuffer(GL_RENDERBUFFER, id); } void Renderbuffer::unbind() { if(set_current(0)) - glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, 0); + glBindRenderbuffer(GL_RENDERBUFFER, 0); } } // namespace GL