OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "SkDropShadowImageFilter.h" | 8 #include "SkDropShadowImageFilter.h" |
9 | 9 |
10 #include "SkBitmap.h" | 10 #include "SkBitmap.h" |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
70 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(bounds.width(), bounds .height())); | 70 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(bounds.width(), bounds .height())); |
71 if (nullptr == device.get()) { | 71 if (nullptr == device.get()) { |
72 return false; | 72 return false; |
73 } | 73 } |
74 SkCanvas canvas(device.get()); | 74 SkCanvas canvas(device.get()); |
75 | 75 |
76 SkVector sigma = SkVector::Make(fSigmaX, fSigmaY); | 76 SkVector sigma = SkVector::Make(fSigmaX, fSigmaY); |
77 ctx.ctm().mapVectors(&sigma, 1); | 77 ctx.ctm().mapVectors(&sigma, 1); |
78 sigma.fX = SkMaxScalar(0, sigma.fX); | 78 sigma.fX = SkMaxScalar(0, sigma.fX); |
79 sigma.fY = SkMaxScalar(0, sigma.fY); | 79 sigma.fY = SkMaxScalar(0, sigma.fY); |
80 SkAutoTUnref<SkImageFilter> blurFilter(SkBlurImageFilter::Create(sigma.fX, s igma.fY)); | 80 SkAutoTUnref<SkImageFilter> blurFilter; |
81 if (sigma.fX != 0 || sigma.fY != 0) | |
reed1
2015/12/10 13:36:49
It seems that for the most part, if the sigmas are
Stephen White
2015/12/10 14:57:18
If it's drawing shadow & foreground, an offset may
xidachen
2015/12/10 15:16:41
Done.
| |
82 blurFilter = SkAutoTUnref<SkImageFilter>(SkBlurImageFilter::Create(sigma .fX, sigma.fY)); | |
81 SkAutoTUnref<SkColorFilter> colorFilter( | 83 SkAutoTUnref<SkColorFilter> colorFilter( |
82 SkColorFilter::CreateModeFilter(fColor, SkXfermode::kSrcIn_Mode)); | 84 SkColorFilter::CreateModeFilter(fColor, SkXfermode::kSrcIn_Mode)); |
83 SkPaint paint; | 85 SkPaint paint; |
84 paint.setImageFilter(blurFilter.get()); | 86 if (blurFilter) |
reed1
2015/12/10 13:36:49
This check seems unnecessary, since line 87 will e
xidachen
2015/12/10 15:16:41
Done.
| |
87 paint.setImageFilter(blurFilter.get()); | |
88 else | |
89 paint.setImageFilter(nullptr); | |
85 paint.setColorFilter(colorFilter.get()); | 90 paint.setColorFilter(colorFilter.get()); |
86 paint.setXfermodeMode(SkXfermode::kSrcOver_Mode); | 91 paint.setXfermodeMode(SkXfermode::kSrcOver_Mode); |
87 SkVector offsetVec = SkVector::Make(fDx, fDy); | 92 SkVector offsetVec = SkVector::Make(fDx, fDy); |
88 ctx.ctm().mapVectors(&offsetVec, 1); | 93 ctx.ctm().mapVectors(&offsetVec, 1); |
89 canvas.translate(SkIntToScalar(srcOffset.fX - bounds.fLeft), | 94 canvas.translate(SkIntToScalar(srcOffset.fX - bounds.fLeft), |
90 SkIntToScalar(srcOffset.fY - bounds.fTop)); | 95 SkIntToScalar(srcOffset.fY - bounds.fTop)); |
91 canvas.drawBitmap(src, offsetVec.fX, offsetVec.fY, &paint); | 96 canvas.drawBitmap(src, offsetVec.fX, offsetVec.fY, &paint); |
92 if (fShadowMode == kDrawShadowAndForeground_ShadowMode) { | 97 if (fShadowMode == kDrawShadowAndForeground_ShadowMode) { |
93 canvas.drawBitmap(src, 0, 0); | 98 canvas.drawBitmap(src, 0, 0); |
94 } | 99 } |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
151 "kDrawShadowAndForeground", "kDrawShadowOnly" | 156 "kDrawShadowAndForeground", "kDrawShadowOnly" |
152 }; | 157 }; |
153 | 158 |
154 static_assert(kShadowModeCount == SK_ARRAY_COUNT(gModeStrings), "enum_mismat ch"); | 159 static_assert(kShadowModeCount == SK_ARRAY_COUNT(gModeStrings), "enum_mismat ch"); |
155 | 160 |
156 str->appendf(" mode: %s", gModeStrings[fShadowMode]); | 161 str->appendf(" mode: %s", gModeStrings[fShadowMode]); |
157 | 162 |
158 str->append(")"); | 163 str->append(")"); |
159 } | 164 } |
160 #endif | 165 #endif |
OLD | NEW |