X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Frenderbuffer.cpp;h=17d36846e696cdccb36d4b5a28e14d2e301b6025;hp=b2b25a0890212b41bc08251845d80385abf7451a;hb=08e19bc2b4eba572bc7699378cf55cd8772ac67e;hpb=b2c8b2238877f76cdea184cca70336b15ddb78d9 diff --git a/source/renderbuffer.cpp b/source/renderbuffer.cpp index b2b25a08..17d36846 100644 --- a/source/renderbuffer.cpp +++ b/source/renderbuffer.cpp @@ -1,3 +1,4 @@ +#include #include #include #include "renderbuffer.h" @@ -9,7 +10,10 @@ Renderbuffer::Renderbuffer() { static Require _req(EXT_framebuffer_object); - glGenRenderbuffers(1, &id); + if(ARB_direct_state_access) + glCreateRenderbuffers(1, &id); + else + glGenRenderbuffers(1, &id); } Renderbuffer::~Renderbuffer() @@ -20,10 +24,15 @@ Renderbuffer::~Renderbuffer() void Renderbuffer::storage(PixelFormat fmt, unsigned wd, unsigned ht) { require_pixelformat(fmt); - BindRestore _bind(this); width = wd; height = ht; - glRenderbufferStorage(GL_RENDERBUFFER, fmt, width, height); + if(ARB_direct_state_access) + glNamedRenderbufferStorage(id, fmt, width, height); + else + { + BindRestore _bind(this); + glRenderbufferStorage(GL_RENDERBUFFER, fmt, width, height); + } } void Renderbuffer::storage_multisample(unsigned samples, PixelFormat fmt, unsigned wd, unsigned ht) @@ -31,10 +40,15 @@ void Renderbuffer::storage_multisample(unsigned samples, PixelFormat fmt, unsign static Require _req(EXT_framebuffer_multisample); require_pixelformat(fmt); - BindRestore _bind(this); width = wd; height = ht; - glRenderbufferStorageMultisample(GL_RENDERBUFFER, samples, fmt, width, height); + 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