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 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
46 void SkDropShadowImageFilter::flatten(SkWriteBuffer& buffer) const { | 46 void SkDropShadowImageFilter::flatten(SkWriteBuffer& buffer) const { |
47 this->INHERITED::flatten(buffer); | 47 this->INHERITED::flatten(buffer); |
48 buffer.writeScalar(fDx); | 48 buffer.writeScalar(fDx); |
49 buffer.writeScalar(fDy); | 49 buffer.writeScalar(fDy); |
50 buffer.writeScalar(fSigmaX); | 50 buffer.writeScalar(fSigmaX); |
51 buffer.writeScalar(fSigmaY); | 51 buffer.writeScalar(fSigmaY); |
52 buffer.writeColor(fColor); | 52 buffer.writeColor(fColor); |
53 buffer.writeInt(static_cast<int>(fShadowMode)); | 53 buffer.writeInt(static_cast<int>(fShadowMode)); |
54 } | 54 } |
55 | 55 |
56 bool SkDropShadowImageFilter::onFilterImage(Proxy* proxy, const SkBitmap& source
, | 56 bool SkDropShadowImageFilter::onFilterImage(Proxy* proxy, const SkImage* source, |
57 const Context& ctx, | 57 const Context& ctx, |
58 SkBitmap* result, SkIPoint* offset)
const | 58 SkAutoTUnref<const SkImage>& result, |
| 59 SkIPoint* offset) const |
59 { | 60 { |
60 SkBitmap src = source; | 61 SkAutoTUnref<const SkImage> src(SkRef(source)); |
61 SkIPoint srcOffset = SkIPoint::Make(0, 0); | 62 SkIPoint srcOffset = SkIPoint::Make(0, 0); |
62 if (getInput(0) && !getInput(0)->filterImage(proxy, source, ctx, &src, &srcO
ffset)) | 63 if (getInput(0) && !getInput(0)->filterImage(proxy, source, ctx, src, &srcOf
fset)) |
63 return false; | 64 return false; |
64 | 65 |
65 SkIRect bounds; | 66 SkIRect bounds; |
66 if (!this->applyCropRect(ctx, src, srcOffset, &bounds)) { | 67 if (!this->applyCropRect(ctx, src, srcOffset, &bounds)) { |
67 return false; | 68 return false; |
68 } | 69 } |
69 | 70 |
70 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(bounds.width(), bounds
.height())); | 71 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(bounds.width(), bounds
.height())); |
71 if (NULL == device.get()) { | 72 if (NULL == device.get()) { |
72 return false; | 73 return false; |
73 } | 74 } |
74 SkCanvas canvas(device.get()); | 75 SkCanvas canvas(device.get()); |
75 | 76 |
76 SkVector sigma = SkVector::Make(fSigmaX, fSigmaY); | 77 SkVector sigma = SkVector::Make(fSigmaX, fSigmaY); |
77 ctx.ctm().mapVectors(&sigma, 1); | 78 ctx.ctm().mapVectors(&sigma, 1); |
78 sigma.fX = SkMaxScalar(0, sigma.fX); | 79 sigma.fX = SkMaxScalar(0, sigma.fX); |
79 sigma.fY = SkMaxScalar(0, sigma.fY); | 80 sigma.fY = SkMaxScalar(0, sigma.fY); |
80 SkAutoTUnref<SkImageFilter> blurFilter(SkBlurImageFilter::Create(sigma.fX, s
igma.fY)); | 81 SkAutoTUnref<SkImageFilter> blurFilter(SkBlurImageFilter::Create(sigma.fX, s
igma.fY)); |
81 SkAutoTUnref<SkColorFilter> colorFilter( | 82 SkAutoTUnref<SkColorFilter> colorFilter( |
82 SkColorFilter::CreateModeFilter(fColor, SkXfermode::kSrcIn_Mode)); | 83 SkColorFilter::CreateModeFilter(fColor, SkXfermode::kSrcIn_Mode)); |
83 SkPaint paint; | 84 SkPaint paint; |
84 paint.setImageFilter(blurFilter.get()); | 85 paint.setImageFilter(blurFilter.get()); |
85 paint.setColorFilter(colorFilter.get()); | 86 paint.setColorFilter(colorFilter.get()); |
86 paint.setXfermodeMode(SkXfermode::kSrcOver_Mode); | 87 paint.setXfermodeMode(SkXfermode::kSrcOver_Mode); |
87 SkVector offsetVec = SkVector::Make(fDx, fDy); | 88 SkVector offsetVec = SkVector::Make(fDx, fDy); |
88 ctx.ctm().mapVectors(&offsetVec, 1); | 89 ctx.ctm().mapVectors(&offsetVec, 1); |
89 canvas.translate(SkIntToScalar(srcOffset.fX - bounds.fLeft), | 90 canvas.translate(SkIntToScalar(srcOffset.fX - bounds.fLeft), |
90 SkIntToScalar(srcOffset.fY - bounds.fTop)); | 91 SkIntToScalar(srcOffset.fY - bounds.fTop)); |
91 canvas.drawBitmap(src, offsetVec.fX, offsetVec.fY, &paint); | 92 canvas.drawImage(src, offsetVec.fX, offsetVec.fY, &paint); |
92 if (fShadowMode == kDrawShadowAndForeground_ShadowMode) { | 93 if (fShadowMode == kDrawShadowAndForeground_ShadowMode) { |
93 canvas.drawBitmap(src, 0, 0); | 94 canvas.drawImage(src, 0, 0); |
94 } | 95 } |
95 *result = device->accessBitmap(false); | 96 |
| 97 SkImage* image = device->newImageSnapshot(); |
| 98 if (NULL == image) { |
| 99 return false; |
| 100 } |
| 101 result.reset(image); |
| 102 |
96 offset->fX = bounds.fLeft; | 103 offset->fX = bounds.fLeft; |
97 offset->fY = bounds.fTop; | 104 offset->fY = bounds.fTop; |
98 return true; | 105 return true; |
99 } | 106 } |
100 | 107 |
101 void SkDropShadowImageFilter::computeFastBounds(const SkRect& src, SkRect* dst)
const { | 108 void SkDropShadowImageFilter::computeFastBounds(const SkRect& src, SkRect* dst)
const { |
102 if (getInput(0)) { | 109 if (getInput(0)) { |
103 getInput(0)->computeFastBounds(src, dst); | 110 getInput(0)->computeFastBounds(src, dst); |
104 } else { | 111 } else { |
105 *dst = src; | 112 *dst = src; |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
153 "kDrawShadowAndForeground", "kDrawShadowOnly" | 160 "kDrawShadowAndForeground", "kDrawShadowOnly" |
154 }; | 161 }; |
155 | 162 |
156 SK_COMPILE_ASSERT(kShadowModeCount == SK_ARRAY_COUNT(gModeStrings), enum_mis
match); | 163 SK_COMPILE_ASSERT(kShadowModeCount == SK_ARRAY_COUNT(gModeStrings), enum_mis
match); |
157 | 164 |
158 str->appendf(" mode: %s", gModeStrings[fShadowMode]); | 165 str->appendf(" mode: %s", gModeStrings[fShadowMode]); |
159 | 166 |
160 str->append(")"); | 167 str->append(")"); |
161 } | 168 } |
162 #endif | 169 #endif |
OLD | NEW |