OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2013 The Android Open Source Project | 2 * Copyright 2013 The Android Open Source Project |
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 "SkXfermodeImageFilter.h" | 8 #include "SkXfermodeImageFilter.h" |
9 | 9 |
10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
88 | 88 |
89 #if SK_SUPPORT_GPU | 89 #if SK_SUPPORT_GPU |
90 if (source->isTextureBacked()) { | 90 if (source->isTextureBacked()) { |
91 return this->filterImageGPU(source, | 91 return this->filterImageGPU(source, |
92 background, backgroundOffset, | 92 background, backgroundOffset, |
93 foreground, foregroundOffset, | 93 foreground, foregroundOffset, |
94 bounds, ctx.outputProperties()); | 94 bounds, ctx.outputProperties()); |
95 } | 95 } |
96 #endif | 96 #endif |
97 | 97 |
98 const SkImageInfo info = SkImageInfo::MakeN32(bounds.width(), bounds.height(
), | 98 sk_sp<SkSpecialSurface> surf(source->makeSurface(ctx.outputProperties(), bou
nds.size())); |
99 kPremul_SkAlphaType); | |
100 sk_sp<SkSpecialSurface> surf(source->makeSurface(info)); | |
101 if (!surf) { | 99 if (!surf) { |
102 return nullptr; | 100 return nullptr; |
103 } | 101 } |
104 | 102 |
105 SkCanvas* canvas = surf->getCanvas(); | 103 SkCanvas* canvas = surf->getCanvas(); |
106 SkASSERT(canvas); | 104 SkASSERT(canvas); |
107 | 105 |
108 canvas->clear(0x0); // can't count on background to fully clear the backgrou
nd | 106 canvas->clear(0x0); // can't count on background to fully clear the backgrou
nd |
109 | 107 |
110 canvas->translate(SkIntToScalar(-bounds.left()), SkIntToScalar(-bounds.top()
)); | 108 canvas->translate(SkIntToScalar(-bounds.left()), SkIntToScalar(-bounds.top()
)); |
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
256 matrix.setTranslate(SkIntToScalar(-bounds.left()), SkIntToScalar(-bounds.top
())); | 254 matrix.setTranslate(SkIntToScalar(-bounds.left()), SkIntToScalar(-bounds.top
())); |
257 drawContext->drawRect(GrNoClip(), paint, matrix, SkRect::Make(bounds)); | 255 drawContext->drawRect(GrNoClip(), paint, matrix, SkRect::Make(bounds)); |
258 | 256 |
259 return SkSpecialImage::MakeFromGpu(SkIRect::MakeWH(bounds.width(), bounds.he
ight()), | 257 return SkSpecialImage::MakeFromGpu(SkIRect::MakeWH(bounds.width(), bounds.he
ight()), |
260 kNeedNewImageUniqueID_SpecialImage, | 258 kNeedNewImageUniqueID_SpecialImage, |
261 drawContext->asTexture(), | 259 drawContext->asTexture(), |
262 sk_ref_sp(drawContext->getColorSpace())); | 260 sk_ref_sp(drawContext->getColorSpace())); |
263 } | 261 } |
264 | 262 |
265 #endif | 263 #endif |
OLD | NEW |