Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1037)

Side by Side Diff: include/effects/SkXfermodeImageFilter.h

Issue 24157005: Moving 4 SkImageFilter derived classes from blink to skia (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Merged new filters into existing ones Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 #ifndef SkXfermodeImageFilter_DEFINED 8 #ifndef SkXfermodeImageFilter_DEFINED
9 #define SkXfermodeImageFilter_DEFINED 9 #define SkXfermodeImageFilter_DEFINED
10 10
11 #include "SkImageFilter.h" 11 #include "SkImageFilter.h"
12 12
13 class SkBitmap; 13 class SkBitmap;
14 class SkXfermode; 14 class SkXfermode;
15 15
16 class SK_API SkXfermodeImageFilter : public SkImageFilter { 16 class SK_API SkXfermodeImageFilter : public SkImageFilter {
17 /** 17 /**
18 * This filter takes an xfermode, and uses it to composite the foreground 18 * This filter takes an xfermode, and uses it to composite the foreground
19 * over the background. If foreground or background is NULL, the input 19 * over the background. If foreground or background is NULL, the input
20 * bitmap (src) is used instead. 20 * bitmap (src) is used instead.
21 */ 21 */
22 22
23 public: 23 public:
24 SkXfermodeImageFilter(SkXfermode* mode, SkImageFilter* background, 24 SkXfermodeImageFilter(SkXfermode* mode, SkImageFilter* background,
25 SkImageFilter* foreground = NULL); 25 SkImageFilter* foreground = NULL, const SkIRect* cropR ect = 0);
mtklein 2013/09/24 20:30:34 = 0 -> = NULL?
sugoi1 2013/09/25 15:41:08 Done.
26 26
27 virtual ~SkXfermodeImageFilter(); 27 virtual ~SkXfermodeImageFilter();
28 28
29 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkXfermodeImageFilter) 29 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkXfermodeImageFilter)
30 30
31 virtual bool onFilterImage(Proxy* proxy, 31 virtual bool onFilterImage(Proxy* proxy,
32 const SkBitmap& src, 32 const SkBitmap& src,
33 const SkMatrix& ctm, 33 const SkMatrix& ctm,
34 SkBitmap* dst, 34 SkBitmap* dst,
35 SkIPoint* offset) SK_OVERRIDE; 35 SkIPoint* offset) SK_OVERRIDE;
36 #if SK_SUPPORT_GPU 36 #if SK_SUPPORT_GPU
37 virtual bool canFilterImageGPU() const SK_OVERRIDE { return true; } 37 virtual bool canFilterImageGPU() const SK_OVERRIDE { return cropRect().isLar gest(); }
sugoi1 2013/09/24 20:08:17 Are crop rects supported by default in GPU ? I con
Stephen White 2013/09/24 23:14:13 No, they're not. It looks like you've implemented
38 virtual bool filterImageGPU(Proxy* proxy, const SkBitmap& src, const SkMatri x& ctm, 38 virtual bool filterImageGPU(Proxy* proxy, const SkBitmap& src, const SkMatri x& ctm,
39 SkBitmap* result, SkIPoint* offset) SK_OVERRIDE; 39 SkBitmap* result, SkIPoint* offset) SK_OVERRIDE;
40 #endif 40 #endif
41 41
42 protected: 42 protected:
43 explicit SkXfermodeImageFilter(SkFlattenableReadBuffer& buffer); 43 explicit SkXfermodeImageFilter(SkFlattenableReadBuffer& buffer);
44 virtual void flatten(SkFlattenableWriteBuffer&) const SK_OVERRIDE; 44 virtual void flatten(SkFlattenableWriteBuffer&) const SK_OVERRIDE;
45 45
46 private: 46 private:
47 SkXfermode* fMode; 47 SkXfermode* fMode;
48 typedef SkImageFilter INHERITED; 48 typedef SkImageFilter INHERITED;
49 }; 49 };
50 50
51 #endif 51 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698