make quickReject treat empty rects and paths the same

Change-Id: Ie334a2f0aa354ea3b52f6143e2659fd74fdd6185
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/334100
Reviewed-by: Mike Klein <mtklein@google.com>
Commit-Queue: Mike Reed <reed@google.com>
This commit is contained in:
Mike Reed 2020-11-11 12:47:26 -05:00 committed by Skia Commit-Bot
parent e9bbbfe057
commit d986835a6c
2 changed files with 12 additions and 1 deletions

View File

@ -1784,6 +1784,10 @@ bool SkCanvas::quickReject(const SkRect& src) const {
SkASSERT(fIsScaleTranslate == SkMatrixPriv::IsScaleTranslateAsM33(fMCRec->fMatrix)); SkASSERT(fIsScaleTranslate == SkMatrixPriv::IsScaleTranslateAsM33(fMCRec->fMatrix));
#endif #endif
if (src.isEmpty()) {
return true;
}
if (!fIsScaleTranslate) { if (!fIsScaleTranslate) {
return quick_reject_slow_path(src, fDeviceClipBounds, fMCRec->fMatrix.asM33()); return quick_reject_slow_path(src, fDeviceClipBounds, fMCRec->fMatrix.asM33());
} }
@ -1812,7 +1816,7 @@ bool SkCanvas::quickReject(const SkRect& src) const {
} }
bool SkCanvas::quickReject(const SkPath& path) const { bool SkCanvas::quickReject(const SkPath& path) const {
return path.isEmpty() || this->quickReject(path.getBounds()); return this->quickReject(path.getBounds());
} }
SkRect SkCanvas::getLocalClipBounds() const { SkRect SkCanvas::getLocalClipBounds() const {

View File

@ -760,3 +760,10 @@ DEF_TEST(canvas_markctm, reporter) {
// found the previous one // found the previous one
REPORTER_ASSERT(reporter, canvas.findMarkedCTM(id_a, &m) && m == a1); REPORTER_ASSERT(reporter, canvas.findMarkedCTM(id_a, &m) && m == a1);
} }
DEF_TEST(Canvas_quickreject_empty, reporter) {
SkCanvas canvas(10, 10);
REPORTER_ASSERT(reporter, canvas.quickReject({0,0,0,0}));
REPORTER_ASSERT(reporter, canvas.quickReject(SkPath()));
}