Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(740)

Unified Diff: third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp

Issue 1879223002: Support mask images for filter-based -webkit-box-reflect. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@reflection-refactor
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp
diff --git a/third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp b/third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp
index 8c6bde04008815ca174b307c0ebd5dae467b0a4f..5ea2a36a6180bd6d32102a1c61e1b422347a074f 100644
--- a/third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp
+++ b/third_party/WebKit/Source/platform/graphics/filters/SkiaImageFilterBuilder.cpp
@@ -35,7 +35,9 @@
#include "platform/graphics/filters/FilterOperations.h"
#include "platform/graphics/filters/SourceGraphic.h"
#include "platform/graphics/skia/SkiaUtils.h"
+#include "third_party/skia/include/core/SkPicture.h"
#include "third_party/skia/include/core/SkXfermode.h"
+#include "third_party/skia/include/effects/SkPictureImageFilter.h"
#include "third_party/skia/include/effects/SkXfermodeImageFilter.h"
namespace blink {
@@ -185,9 +187,16 @@ sk_sp<SkImageFilter> SkiaImageFilterBuilder::buildTransform(const AffineTransfor
sk_sp<SkImageFilter> SkiaImageFilterBuilder::buildBoxReflectFilter(const BoxReflection& reflection, sk_sp<SkImageFilter> input)
{
- sk_sp<SkImageFilter> maskedInput = input;
- // TODO(jbroman): If a mask image is provided, mask!
-
+ sk_sp<SkImageFilter> maskedInput;
+ if (SkPicture* maskPicture = reflection.mask()) {
+ SkImageFilter::CropRect cropRect(maskPicture->cullRect());
Stephen White 2016/04/20 21:33:56 Just wondering why a crop rect is necessary here.
jbroman 2016/04/21 16:52:05 My reading of SXIF is that it unites the source an
Stephen White 2016/04/21 16:59:29 Oh right, that makes sense. Would you log a skia b
+ maskedInput = SkXfermodeImageFilter::Make(
+ SkXfermode::Make(SkXfermode::kSrcIn_Mode),
+ SkPictureImageFilter::Make(sk_ref_sp(maskPicture)),
+ input, &cropRect);
+ } else {
+ maskedInput = input;
+ }
sk_sp<SkImageFilter> flipImageFilter = SkImageFilter::MakeMatrixFilter(
reflection.reflectionMatrix(), kLow_SkFilterQuality, std::move(maskedInput));
return SkXfermodeImageFilter::Make(nullptr, std::move(flipImageFilter), std::move(input), nullptr);

Powered by Google App Engine
This is Rietveld 408576698