aboutsummaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorJuan Linietsky2015-04-12 18:58:05 -0300
committerJuan Linietsky2015-04-12 18:58:05 -0300
commitf9906eeac8d97e9b495ce7dae24d6820313d4291 (patch)
treef2227fbddc6ccf9c1cc43f2741265a34107c30b8 /drivers
parent3e20391bf607dc7c452b056854aed4a8c99ba0f6 (diff)
downloadgodot-f9906eeac8d97e9b495ce7dae24d6820313d4291.tar.gz
godot-f9906eeac8d97e9b495ce7dae24d6820313d4291.tar.zst
godot-f9906eeac8d97e9b495ce7dae24d6820313d4291.zip
-Fixed screen capture for viewports, added a screen capture demo, fixes #1529
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gles2/rasterizer_gles2.cpp20
1 files changed, 12 insertions, 8 deletions
diff --git a/drivers/gles2/rasterizer_gles2.cpp b/drivers/gles2/rasterizer_gles2.cpp
index 3c7026daf..412def40f 100644
--- a/drivers/gles2/rasterizer_gles2.cpp
+++ b/drivers/gles2/rasterizer_gles2.cpp
@@ -4270,17 +4270,21 @@ void RasterizerGLES2::capture_viewport(Image* r_capture) {
glReadPixels( viewport.x, window_size.height-(viewport.height+viewport.y), viewport.width,viewport.height,GL_RGBA,GL_UNSIGNED_BYTE,w.ptr());
}
- uint32_t *imgptr = (uint32_t*)w.ptr();
- for(int y=0;y<(viewport.height/2);y++) {
+ bool flip = current_rt==NULL;
- uint32_t *ptr1 = &imgptr[y*viewport.width];
- uint32_t *ptr2 = &imgptr[(viewport.height-y-1)*viewport.width];
+ if (flip) {
+ uint32_t *imgptr = (uint32_t*)w.ptr();
+ for(int y=0;y<(viewport.height/2);y++) {
- for(int x=0;x<viewport.width;x++) {
+ uint32_t *ptr1 = &imgptr[y*viewport.width];
+ uint32_t *ptr2 = &imgptr[(viewport.height-y-1)*viewport.width];
- uint32_t tmp = ptr1[x];
- ptr1[x]=ptr2[x];
- ptr2[x]=tmp;
+ for(int x=0;x<viewport.width;x++) {
+
+ uint32_t tmp = ptr1[x];
+ ptr1[x]=ptr2[x];
+ ptr2[x]=tmp;
+ }
}
}