Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c70629f1 authored by Romain Guy's avatar Romain Guy Committed by Android Git Automerger
Browse files

am 583ed765: Merge "Take shadow bounds into account for quick rejects Bug #8634346" into klp-dev

* commit '583ed765':
  Take shadow bounds into account for quick rejects Bug #8634346
parents 2d1716a8 583ed765
Loading
Loading
Loading
Loading
+12 −3
Original line number Diff line number Diff line
@@ -249,11 +249,16 @@ public:
    }

    // default empty constructor for bounds, to be overridden in child constructor body
    DrawBoundedOp(SkPaint* paint)
            : DrawOp(paint) {}
    DrawBoundedOp(SkPaint* paint): DrawOp(paint) { }

    bool getLocalBounds(Rect& localBounds) {
        localBounds.set(mLocalBounds);
        if (state.mDrawModifiers.mHasShadow) {
            Rect shadow(mLocalBounds);
            shadow.translate(state.mDrawModifiers.mShadowDx, state.mDrawModifiers.mShadowDy);
            shadow.outset(state.mDrawModifiers.mShadowRadius);
            localBounds.unionWith(shadow);
        }
        return true;
    }

@@ -1442,8 +1447,10 @@ public:
    }

    virtual status_t applyDraw(OpenGLRenderer& renderer, Rect& dirty) {
        Rect bounds;
        getLocalBounds(bounds);
        return renderer.drawText(mText, mBytesCount, mCount, mX, mY,
                mPositions, getPaint(renderer), mTotalAdvance, mLocalBounds);
                mPositions, getPaint(renderer), mTotalAdvance, bounds);
    }

    virtual status_t multiDraw(OpenGLRenderer& renderer, Rect& dirty,
@@ -1454,6 +1461,8 @@ public:
            renderer.restoreDisplayState(ops[i]->state, true); // restore all but the clip

            DrawTextOp& op = *((DrawTextOp*)ops[i]);
            // quickReject() will not occure in drawText() so we can use mLocalBounds
            // directly, we do not need to account for shadow by calling getLocalBounds()
            status |= renderer.drawText(op.mText, op.mBytesCount, op.mCount, op.mX, op.mY,
                    op.mPositions, op.getPaint(renderer), op.mTotalAdvance, op.mLocalBounds,
                    drawOpMode);
+8 −0
Original line number Diff line number Diff line
@@ -464,10 +464,12 @@ void DisplayListRenderer::setupColorFilter(SkiaColorFilter* filter) {

void DisplayListRenderer::resetShadow() {
    addStateOp(new (alloc()) ResetShadowOp());
    OpenGLRenderer::resetShadow();
}

void DisplayListRenderer::setupShadow(float radius, float dx, float dy, int color) {
    addStateOp(new (alloc()) SetupShadowOp(radius, dx, dy, color));
    OpenGLRenderer::setupShadow(radius, dx, dy, color);
}

void DisplayListRenderer::resetPaintFilter() {
@@ -503,11 +505,17 @@ void DisplayListRenderer::addStateOp(StateOp* op) {

void DisplayListRenderer::addDrawOp(DrawOp* op) {
    Rect localBounds;
    if (mDrawModifiers.mHasShadow) {
        op->state.mDrawModifiers = mDrawModifiers;
    }
    if (op->getLocalBounds(localBounds)) {
        bool rejected = quickRejectNoScissor(localBounds.left, localBounds.top,
                localBounds.right, localBounds.bottom);
        op->setQuickRejected(rejected);
    }
    if (mDrawModifiers.mHasShadow) {
        op->state.mDrawModifiers.reset();
    }
    mHasDrawOps = true;
    addOpInternal(op);
}
+8 −0
Original line number Diff line number Diff line
@@ -52,6 +52,14 @@ namespace android {
namespace uirenderer {

struct DrawModifiers {
    DrawModifiers() {
        reset();
    }

    void reset() {
        memset(this, 0, sizeof(DrawModifiers));
    }

    SkiaShader* mShader;
    SkiaColorFilter* mColorFilter;
    float mOverrideLayerAlpha;