Index: gm/xfermodeimagefilter.cpp |
diff --git a/gm/xfermodeimagefilter.cpp b/gm/xfermodeimagefilter.cpp |
index a0677c796afa2a5b7c8aba8df10389831a05fb0c..91908599ff87de44ded4e5de357b402d3babbf20 100644 |
--- a/gm/xfermodeimagefilter.cpp |
+++ b/gm/xfermodeimagefilter.cpp |
@@ -48,46 +48,45 @@ protected: |
SkPaint paint; |
const struct { |
- SkXfermode::Mode fMode; |
- const char* fLabel; |
+ SkBlendMode fMode; |
+ const char* fLabel; |
} gModes[] = { |
- { SkXfermode::kClear_Mode, "Clear" }, |
- { SkXfermode::kSrc_Mode, "Src" }, |
- { SkXfermode::kDst_Mode, "Dst" }, |
- { SkXfermode::kSrcOver_Mode, "SrcOver" }, |
- { SkXfermode::kDstOver_Mode, "DstOver" }, |
- { SkXfermode::kSrcIn_Mode, "SrcIn" }, |
- { SkXfermode::kDstIn_Mode, "DstIn" }, |
- { SkXfermode::kSrcOut_Mode, "SrcOut" }, |
- { SkXfermode::kDstOut_Mode, "DstOut" }, |
- { SkXfermode::kSrcATop_Mode, "SrcATop" }, |
- { SkXfermode::kDstATop_Mode, "DstATop" }, |
- { SkXfermode::kXor_Mode, "Xor" }, |
- |
- { SkXfermode::kPlus_Mode, "Plus" }, |
- { SkXfermode::kModulate_Mode, "Modulate" }, |
- { SkXfermode::kScreen_Mode, "Screen" }, |
- { SkXfermode::kOverlay_Mode, "Overlay" }, |
- { SkXfermode::kDarken_Mode, "Darken" }, |
- { SkXfermode::kLighten_Mode, "Lighten" }, |
- { SkXfermode::kColorDodge_Mode, "ColorDodge" }, |
- { SkXfermode::kColorBurn_Mode, "ColorBurn" }, |
- { SkXfermode::kHardLight_Mode, "HardLight" }, |
- { SkXfermode::kSoftLight_Mode, "SoftLight" }, |
- { SkXfermode::kDifference_Mode, "Difference" }, |
- { SkXfermode::kExclusion_Mode, "Exclusion" }, |
- { SkXfermode::kMultiply_Mode, "Multiply" }, |
- { SkXfermode::kHue_Mode, "Hue" }, |
- { SkXfermode::kSaturation_Mode, "Saturation" }, |
- { SkXfermode::kColor_Mode, "Color" }, |
- { SkXfermode::kLuminosity_Mode, "Luminosity" }, |
+ { SkBlendMode::kClear, "Clear" }, |
+ { SkBlendMode::kSrc, "Src" }, |
+ { SkBlendMode::kDst, "Dst" }, |
+ { SkBlendMode::kSrcOver, "SrcOver" }, |
+ { SkBlendMode::kDstOver, "DstOver" }, |
+ { SkBlendMode::kSrcIn, "SrcIn" }, |
+ { SkBlendMode::kDstIn, "DstIn" }, |
+ { SkBlendMode::kSrcOut, "SrcOut" }, |
+ { SkBlendMode::kDstOut, "DstOut" }, |
+ { SkBlendMode::kSrcATop, "SrcATop" }, |
+ { SkBlendMode::kDstATop, "DstATop" }, |
+ { SkBlendMode::kXor, "Xor" }, |
+ |
+ { SkBlendMode::kPlus, "Plus" }, |
+ { SkBlendMode::kModulate, "Modulate" }, |
+ { SkBlendMode::kScreen, "Screen" }, |
+ { SkBlendMode::kOverlay, "Overlay" }, |
+ { SkBlendMode::kDarken, "Darken" }, |
+ { SkBlendMode::kLighten, "Lighten" }, |
+ { SkBlendMode::kColorDodge, "ColorDodge" }, |
+ { SkBlendMode::kColorBurn, "ColorBurn" }, |
+ { SkBlendMode::kHardLight, "HardLight" }, |
+ { SkBlendMode::kSoftLight, "SoftLight" }, |
+ { SkBlendMode::kDifference, "Difference" }, |
+ { SkBlendMode::kExclusion, "Exclusion" }, |
+ { SkBlendMode::kMultiply, "Multiply" }, |
+ { SkBlendMode::kHue, "Hue" }, |
+ { SkBlendMode::kSaturation, "Saturation" }, |
+ { SkBlendMode::kColor, "Color" }, |
+ { SkBlendMode::kLuminosity, "Luminosity" }, |
}; |
int x = 0, y = 0; |
sk_sp<SkImageFilter> background(SkImageSource::Make(fCheckerboard)); |
for (size_t i = 0; i < SK_ARRAY_COUNT(gModes); i++) { |
- paint.setImageFilter(SkXfermodeImageFilter::Make(SkXfermode::Make(gModes[i].fMode), |
- background)); |
+ paint.setImageFilter(SkXfermodeImageFilter::Make(gModes[i].fMode, background)); |
DrawClippedBitmap(canvas, fBitmap, paint, x, y); |
x += fBitmap.width() + MARGIN; |
if (x + fBitmap.width() > WIDTH) { |
@@ -104,7 +103,7 @@ protected: |
y += fBitmap.height() + MARGIN; |
} |
// Test nullptr mode |
- paint.setImageFilter(SkXfermodeImageFilter::Make(nullptr, background)); |
+ paint.setImageFilter(SkXfermodeImageFilter::Make(SkBlendMode::kSrcOver, background)); |
DrawClippedBitmap(canvas, fBitmap, paint, x, y); |
x += fBitmap.width() + MARGIN; |
if (x + fBitmap.width() > WIDTH) { |
@@ -122,11 +121,10 @@ protected: |
sk_sp<SkImageFilter> offsetBackground(SkOffsetImageFilter::Make(SkIntToScalar(4), |
SkIntToScalar(4), |
background)); |
- paint.setImageFilter(SkXfermodeImageFilter::Make( |
- SkXfermode::Make(SkXfermode::kSrcOver_Mode), |
- offsetBackground, |
- offsetForeground, |
- nullptr)); |
+ paint.setImageFilter(SkXfermodeImageFilter::Make(SkBlendMode::kSrcOver, |
+ offsetBackground, |
+ offsetForeground, |
+ nullptr)); |
DrawClippedPaint(canvas, clipRect, paint, x, y); |
x += fBitmap.width() + MARGIN; |
if (x + fBitmap.width() > WIDTH) { |
@@ -134,7 +132,7 @@ protected: |
y += fBitmap.height() + MARGIN; |
} |
// Test offsets on Darken (uses shader blend) |
- paint.setImageFilter(SkXfermodeImageFilter::Make(SkXfermode::Make(SkXfermode::kDarken_Mode), |
+ paint.setImageFilter(SkXfermodeImageFilter::Make(SkBlendMode::kDarken, |
offsetBackground, |
offsetForeground, |
nullptr)); |
@@ -146,9 +144,9 @@ protected: |
} |
// Test cropping |
constexpr size_t nbSamples = 3; |
- SkXfermode::Mode sampledModes[nbSamples] = {SkXfermode::kOverlay_Mode, |
- SkXfermode::kSrcOver_Mode, |
- SkXfermode::kPlus_Mode}; |
+ const SkBlendMode sampledModes[nbSamples] = { |
+ SkBlendMode::kOverlay, SkBlendMode::kSrcOver, SkBlendMode::kPlus |
+ }; |
int offsets[nbSamples][4] = {{ 10, 10, -16, -16}, |
{ 10, 10, 10, 10}, |
{-10, -10, -6, -6}}; |
@@ -158,7 +156,7 @@ protected: |
fBitmap.width() + offsets[i][2], |
fBitmap.height() + offsets[i][3]); |
SkImageFilter::CropRect rect(SkRect::Make(cropRect)); |
- paint.setImageFilter(SkXfermodeImageFilter::Make(SkXfermode::Make(sampledModes[i]), |
+ paint.setImageFilter(SkXfermodeImageFilter::Make(sampledModes[i], |
offsetBackground, |
offsetForeground, |
&rect)); |
@@ -170,7 +168,7 @@ protected: |
} |
} |
// Test small bg, large fg with Screen (uses shader blend) |
- auto mode = SkXfermode::Make(SkXfermode::kScreen_Mode); |
+ SkBlendMode mode = SkBlendMode::kScreen; |
SkImageFilter::CropRect cropRect(SkRect::MakeXYWH(10, 10, 60, 60)); |
sk_sp<SkImageFilter> cropped(SkOffsetImageFilter::Make(0, 0, foreground, &cropRect)); |
paint.setImageFilter(SkXfermodeImageFilter::Make(mode, cropped, background, nullptr)); |
@@ -191,7 +189,7 @@ protected: |
// Test small fg, large bg with SrcIn with a crop that forces it to full size. |
// This tests that SkXfermodeImageFilter correctly applies the compositing mode to |
// the region outside the foreground. |
- mode = SkXfermode::Make(SkXfermode::kSrcIn_Mode); |
+ mode = SkBlendMode::kSrcIn; |
SkImageFilter::CropRect cropRectFull(SkRect::MakeXYWH(0, 0, 80, 80)); |
paint.setImageFilter(SkXfermodeImageFilter::Make(mode, background, |
cropped, &cropRectFull)); |