| Index: samplecode/SampleXfermodesBlur.cpp
|
| diff --git a/samplecode/SampleXfermodesBlur.cpp b/samplecode/SampleXfermodesBlur.cpp
|
| index ef25114cf01d2cbabd39932fad2c88e86293060e..fe07c9b5671a904ad5ebdf22ebe52e93e00abfe7 100644
|
| --- a/samplecode/SampleXfermodesBlur.cpp
|
| +++ b/samplecode/SampleXfermodesBlur.cpp
|
| @@ -37,8 +37,7 @@ class XfermodesBlurView : public SampleView {
|
| SkBitmap fBG;
|
| SkBitmap fSrcB, fDstB;
|
|
|
| - void draw_mode(SkCanvas* canvas, sk_sp<SkXfermode> mode, int alpha,
|
| - SkScalar x, SkScalar y) {
|
| + void draw_mode(SkCanvas* canvas, SkBlendMode mode, int alpha, SkScalar x, SkScalar y) {
|
| SkPaint p;
|
| p.setMaskFilter(SkBlurMaskFilter::Make(kNormal_SkBlurStyle,
|
| SkBlurMask::ConvertRadiusToSigma(5),
|
| @@ -55,7 +54,7 @@ class XfermodesBlurView : public SampleView {
|
| r.offset(x, y);
|
| canvas->drawOval(r, p);
|
|
|
| - p.setXfermode(std::move(mode));
|
| + p.setBlendMode(mode);
|
|
|
| // draw a square overlapping the circle
|
| // in the lower right of the canvas
|
| @@ -110,34 +109,23 @@ protected:
|
| }
|
|
|
| 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" },*/
|
| + { 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" },
|
| };
|
|
|
| const SkScalar w = SkIntToScalar(W);
|
| @@ -168,8 +156,7 @@ protected:
|
| canvas->drawRect(r, p);
|
|
|
| canvas->saveLayer(&r, nullptr);
|
| - draw_mode(canvas, SkXfermode::Make(gModes[i].fMode),
|
| - twice ? 0x88 : 0xFF, r.fLeft, r.fTop);
|
| + draw_mode(canvas, gModes[i].fMode, twice ? 0x88 : 0xFF, r.fLeft, r.fTop);
|
| canvas->restore();
|
|
|
| r.inset(-SK_ScalarHalf, -SK_ScalarHalf);
|
|
|