diff options
| author | 2011-12-14 19:23:32 -0800 | |
|---|---|---|
| committer | 2011-12-14 19:23:32 -0800 | |
| commit | 8f85e80b64b89fd38cc23b129f61ec36ddde7f15 (patch) | |
| tree | bac2bd06357532f524277551c7606ad2471f7be8 | |
| parent | 2d4fd364843d3efc6e6ee59ccc5beb513a86d789 (diff) | |
Generate even fewer GL commands
Change-Id: I0f4dcacb03ef5ee7f6ebd501df98bfead5f0a7f8
| -rwxr-xr-x | core/java/android/content/res/Resources.java | 3 | ||||
| -rw-r--r-- | libs/hwui/Caches.cpp | 13 | ||||
| -rw-r--r-- | libs/hwui/Caches.h | 10 | ||||
| -rw-r--r-- | libs/hwui/OpenGLRenderer.cpp | 9 | ||||
| -rw-r--r-- | libs/hwui/Rect.h | 10 | 
5 files changed, 39 insertions, 6 deletions
| diff --git a/core/java/android/content/res/Resources.java b/core/java/android/content/res/Resources.java index 4f190108971c..d38b8da7a82a 100755 --- a/core/java/android/content/res/Resources.java +++ b/core/java/android/content/res/Resources.java @@ -1889,8 +1889,7 @@ public class Resources {          if (cs != null) {              dr = cs.newDrawable(this);          } else { -            if (value.type >= TypedValue.TYPE_FIRST_COLOR_INT && -                    value.type <= TypedValue.TYPE_LAST_COLOR_INT) { +            if (isColorDrawable) {                  dr = new ColorDrawable(value.data);              } diff --git a/libs/hwui/Caches.cpp b/libs/hwui/Caches.cpp index c3bac5d2eedb..f2205f65974e 100644 --- a/libs/hwui/Caches.cpp +++ b/libs/hwui/Caches.cpp @@ -79,6 +79,8 @@ void Caches::init() {      mTexCoordsArrayEnabled = false; +    mScissorX = mScissorY = mScissorWidth = mScissorHeight = 0; +      glActiveTexture(gTextureUnits[0]);      mTextureUnit = 0; @@ -312,6 +314,17 @@ void Caches::activeTexture(GLuint textureUnit) {      }  } +void Caches::setScissor(GLint x, GLint y, GLint width, GLint height) { +    if (x != mScissorX || y != mScissorY || width != mScissorWidth || height != mScissorHeight) { +        glScissor(x, y, width, height); + +        mScissorX = x; +        mScissorY = y; +        mScissorWidth = width; +        mScissorHeight = height; +    } +} +  TextureVertex* Caches::getRegionMesh() {      // Create the mesh, 2 triangles and 4 vertices per rectangle in the region      if (!mRegionMesh) { diff --git a/libs/hwui/Caches.h b/libs/hwui/Caches.h index edf3a4707ae8..d264971b372c 100644 --- a/libs/hwui/Caches.h +++ b/libs/hwui/Caches.h @@ -188,6 +188,11 @@ public:      void activeTexture(GLuint textureUnit);      /** +     * Sets the scissor for the current surface. +     */ +    void setScissor(GLint x, GLint y, GLint width, GLint height); + +    /**       * Returns the mesh used to draw regions. Calling this method will       * bind a VBO of type GL_ELEMENT_ARRAY_BUFFER that contains the       * indices for the region mesh. @@ -240,6 +245,11 @@ private:      GLuint mTextureUnit; +    GLint mScissorX; +    GLint mScissorY; +    GLint mScissorWidth; +    GLint mScissorHeight; +      // Used to render layers      TextureVertex* mRegionMesh;      GLuint mRegionMeshIndices; diff --git a/libs/hwui/OpenGLRenderer.cpp b/libs/hwui/OpenGLRenderer.cpp index cbfd77869c5d..75c6d0aebf49 100644 --- a/libs/hwui/OpenGLRenderer.cpp +++ b/libs/hwui/OpenGLRenderer.cpp @@ -155,7 +155,7 @@ void OpenGLRenderer::prepareDirty(float left, float top, float right, float bott      mSaveCount = 1;      glViewport(0, 0, mWidth, mHeight); -    glScissor(left, mSnapshot->height - bottom, right - left, bottom - top); +    mCaches.setScissor(left, mSnapshot->height - bottom, right - left, bottom - top);      mSnapshot->setClip(left, top, right, bottom);      mDirtyClip = false; @@ -550,7 +550,7 @@ bool OpenGLRenderer::createFboLayer(Layer* layer, Rect& bounds, sp<Snapshot> sna  #endif      // Clear the FBO, expand the clear region by 1 to get nice bilinear filtering -    glScissor(clip.left - 1.0f, bounds.getHeight() - clip.bottom - 1.0f, +    mCaches.setScissor(clip.left - 1.0f, bounds.getHeight() - clip.bottom - 1.0f,              clip.getWidth() + 2.0f, clip.getHeight() + 2.0f);      glClear(GL_COLOR_BUFFER_BIT); @@ -965,7 +965,10 @@ void OpenGLRenderer::concatMatrix(SkMatrix* matrix) {  void OpenGLRenderer::setScissorFromClip() {      Rect clip(*mSnapshot->clipRect);      clip.snapToPixelBoundaries(); -    glScissor(clip.left, mSnapshot->height - clip.bottom, clip.getWidth(), clip.getHeight()); + +    mCaches.setScissor(clip.left, mSnapshot->height - clip.bottom, +            clip.getWidth(), clip.getHeight()); +      mDirtyClip = false;  } diff --git a/libs/hwui/Rect.h b/libs/hwui/Rect.h index fb76717fbf9b..fff9f6c4d812 100644 --- a/libs/hwui/Rect.h +++ b/libs/hwui/Rect.h @@ -112,7 +112,8 @@ public:      }      bool intersect(float l, float t, float r, float b) { -        Rect tmp(intersectWith(l, t, r, b)); +        Rect tmp(l, t, r, b); +        intersectWith(tmp);          if (!tmp.isEmpty()) {              set(tmp);              return true; @@ -173,6 +174,13 @@ private:      static inline float min(float a, float b) { return (a < b) ? a : b; }      static inline float max(float a, float b) { return (a > b) ? a : b; } +    void intersectWith(Rect& tmp) const { +        tmp.left = max(left, tmp.left); +        tmp.top = max(top, tmp.top); +        tmp.right = min(right, tmp.right); +        tmp.bottom = min(bottom, tmp.bottom); +    } +      Rect intersectWith(float l, float t, float r, float b) const {          Rect tmp;          tmp.left = max(left, l); |