diff options
author | 2009-06-16 18:08:29 -0700 | |
---|---|---|
committer | 2009-06-16 18:08:29 -0700 | |
commit | 4d63fb113b542f0474c16d8f2c8a1240b44f0ca2 (patch) | |
tree | c995cc6242e41e6991d4b6bb77c492dd2baebad7 /opengl/libagl/copybit.cpp | |
parent | 69f066c8fc42b9f0acc5c41f8ffd972f8d6d0584 (diff) |
fix a scissor bug in the GLES-on-top-of copybit code
Diffstat (limited to 'opengl/libagl/copybit.cpp')
-rw-r--r-- | opengl/libagl/copybit.cpp | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/opengl/libagl/copybit.cpp b/opengl/libagl/copybit.cpp index a539a2bdd5d7..d57a6e429081 100644 --- a/opengl/libagl/copybit.cpp +++ b/opengl/libagl/copybit.cpp @@ -52,28 +52,25 @@ static void textureToCopyBitImage( } struct clipRectRegion : public copybit_region_t { - clipRectRegion(ogles_context_t* c) { - next = iterate; - int x = c->viewport.scissor.x; - int y = c->viewport.scissor.y; - r.l = x; - r.t = y; - r.r = x + c->viewport.scissor.w; - r.b = y + c->viewport.scissor.h; - firstTime = true; + clipRectRegion(ogles_context_t* c) + { + scissor_t const* scissor = &c->rasterizer.state.scissor; + r.l = scissor->left; + r.t = scissor->top; + r.r = scissor->right; + r.b = scissor->bottom; + next = iterate; } private: static int iterate(copybit_region_t const * self, copybit_rect_t* rect) { - clipRectRegion* myself = (clipRectRegion*) self; - if (myself->firstTime) { - myself->firstTime = false; - *rect = myself->r; - return 1; - } + *rect = static_cast<clipRectRegion const*>(self)->r; + const_cast<copybit_region_t *>(self)->next = iterate_done; + return 1; + } + static int iterate_done(copybit_region_t const *, copybit_rect_t*) { return 0; } - mutable copybit_rect_t r; - mutable bool firstTime; + copybit_rect_t r; }; static bool supportedCopybitsFormat(int format) { |