diff options
author | Chris Craik <ccraik@google.com> | 2014-06-10 17:22:31 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-06-10 17:22:31 +0000 |
commit | 1e5cf9aced40e6e14262e542d0ed0e24cda877a0 (patch) | |
tree | 1b42070defc0a41277e27ae37c92748dec18fc99 /libs/hwui/DisplayListOp.h | |
parent | f1d758867aa878fb956af7c66bd2d3122adf72a0 (diff) | |
parent | 9a9d1d5ad2591f04881a401da0ad89a95eeddd00 (diff) | |
download | frameworks_base-1e5cf9aced40e6e14262e542d0ed0e24cda877a0.zip frameworks_base-1e5cf9aced40e6e14262e542d0ed0e24cda877a0.tar.gz frameworks_base-1e5cf9aced40e6e14262e542d0ed0e24cda877a0.tar.bz2 |
am b1c76a1a: Merge "Tessellate on worker threads" into lmp-preview-dev
* commit 'b1c76a1abcfb2f33e12fef37ec71d20724863b5e':
Tessellate on worker threads
Diffstat (limited to 'libs/hwui/DisplayListOp.h')
-rw-r--r-- | libs/hwui/DisplayListOp.h | 29 |
1 files changed, 27 insertions, 2 deletions
diff --git a/libs/hwui/DisplayListOp.h b/libs/hwui/DisplayListOp.h index 9212b9d..233f3f0 100644 --- a/libs/hwui/DisplayListOp.h +++ b/libs/hwui/DisplayListOp.h @@ -1114,6 +1114,15 @@ public: OP_LOG("Draw RoundRect " RECT_STRING ", rx %f, ry %f", RECT_ARGS(mLocalBounds), mRx, mRy); } + virtual void onDefer(OpenGLRenderer& renderer, DeferInfo& deferInfo, + const DeferredDisplayState& state) { + DrawStrokableOp::onDefer(renderer, deferInfo, state); + if (!mPaint->getPathEffect()) { + renderer.getCaches().tessellationCache.precacheRoundRect(state.mMatrix, + mLocalBounds.getWidth(), mLocalBounds.getHeight(), mRx, mRy, mPaint); + } + } + virtual const char* name() { return "DrawRoundRect"; } private: @@ -1533,9 +1542,23 @@ public: } } + virtual void onDefer(OpenGLRenderer& renderer, DeferInfo& deferInfo, + const DeferredDisplayState& state) { + renderer.getCaches().tessellationCache.precacheShadows(&state.mMatrix, + renderer.getLocalClipBounds(), isCasterOpaque(), &mOutline, + &mTransformXY, &mTransformZ, renderer.getLightCenter(), renderer.getLightRadius()); + } + virtual status_t applyDraw(OpenGLRenderer& renderer, Rect& dirty) { - return renderer.drawShadow(mTransformXY, mTransformZ, - mCasterAlpha, mCasterUnclipped, &mOutline); + TessellationCache::vertexBuffer_pair_t buffers; + Matrix4 drawTransform; + renderer.getMatrix(&drawTransform); + renderer.getCaches().tessellationCache.getShadowBuffers(&drawTransform, + renderer.getLocalClipBounds(), isCasterOpaque(), &mOutline, + &mTransformXY, &mTransformZ, renderer.getLightCenter(), renderer.getLightRadius(), + buffers); + + return renderer.drawShadow(mCasterAlpha, buffers.first, buffers.second); } virtual void output(int level, uint32_t logFlags) const { @@ -1545,6 +1568,8 @@ public: virtual const char* name() { return "DrawShadow"; } private: + bool isCasterOpaque() { return mCasterAlpha >= 1.0f && mCasterUnclipped; } + const mat4 mTransformXY; const mat4 mTransformZ; const float mCasterAlpha; |