Fix logic error when drawing path as nested rects
Bug: chromium:732350 Change-Id: I42770e9fa8c201780f16ce8df58b208e08aef640 Reviewed-on: https://skia-review.googlesource.com/20158 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Brian Salomon <bsalomon@google.com>
This commit is contained in:
parent
7a808d618e
commit
5f970fe6be
@ -23,9 +23,11 @@ GrProcessorSet::GrProcessorSet(GrPaint&& paint) : fXP(paint.getXPFactory()) {
|
||||
fFragmentProcessors.reset(paint.numTotalFragmentProcessors());
|
||||
int i = 0;
|
||||
for (auto& fp : paint.fColorFragmentProcessors) {
|
||||
SkASSERT(fp.get());
|
||||
fFragmentProcessors[i++] = fp.release();
|
||||
}
|
||||
for (auto& fp : paint.fCoverageFragmentProcessors) {
|
||||
SkASSERT(fp.get());
|
||||
fFragmentProcessors[i++] = fp.release();
|
||||
}
|
||||
} else {
|
||||
|
@ -1546,12 +1546,12 @@ void GrRenderTargetContext::drawPath(const GrClip& clip,
|
||||
if (fills_as_nested_rects(viewMatrix, path, rects)) {
|
||||
std::unique_ptr<GrDrawOp> op =
|
||||
GrRectOpFactory::MakeAAFillNestedRects(std::move(paint), viewMatrix, rects);
|
||||
if (!op) {
|
||||
if (op) {
|
||||
this->addDrawOp(clip, std::move(op));
|
||||
}
|
||||
// A null return indicates that there is nothing to draw in this case.
|
||||
return;
|
||||
}
|
||||
this->addDrawOp(clip, std::move(op));
|
||||
}
|
||||
}
|
||||
SkRect ovalRect;
|
||||
bool isOval = path.isOval(&ovalRect);
|
||||
|
Loading…
Reference in New Issue
Block a user