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

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

Issue 1831323003: Swap SkPictureImageFilter's factories over to smart pointers (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 4 years, 9 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
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 SkPictureImageFilter_DEFINED 8 #ifndef SkPictureImageFilter_DEFINED
9 #define SkPictureImageFilter_DEFINED 9 #define SkPictureImageFilter_DEFINED
10 10
11 #include "SkImageFilter.h" 11 #include "SkImageFilter.h"
12 #include "SkPicture.h" 12 #include "SkPicture.h"
13 13
14 class SK_API SkPictureImageFilter : public SkImageFilter { 14 class SK_API SkPictureImageFilter : public SkImageFilter {
15 public: 15 public:
16 /** 16 /**
17 * Refs the passed-in picture. 17 * Refs the passed-in picture.
18 */ 18 */
19 static SkImageFilter* Create(const SkPicture* picture) { 19 static sk_sp<SkImageFilter> Make(sk_sp<SkPicture> picture) {
reed1 2016/03/25 19:32:36 This style is fine. However, at some point, I'd l
robertphillips 2016/03/28 12:02:22 The picture image filter is actually defined to wo
f(malita) 2016/03/28 13:00:08 I don't recall the image filter specifics, but tha
20 return new SkPictureImageFilter(picture); 20 return sk_sp<SkImageFilter>(new SkPictureImageFilter(std::move(picture)) );
21 } 21 }
22 22
23 /** 23 /**
24 * Refs the passed-in picture. cropRect can be used to crop or expand the d estination rect when 24 * Refs the passed-in picture. cropRect can be used to crop or expand the d estination rect when
25 * the picture is drawn. (No scaling is implied by the dest rect; only the CTM is applied.) 25 * the picture is drawn. (No scaling is implied by the dest rect; only the CTM is applied.)
26 */ 26 */
27 static SkImageFilter* Create(const SkPicture* picture, const SkRect& cropRec t) { 27 static sk_sp<SkImageFilter> Make(sk_sp<SkPicture> picture, const SkRect& cro pRect) {
28 return new SkPictureImageFilter(picture, cropRect, kDeviceSpace_PictureR esolution, 28 return sk_sp<SkImageFilter>(new SkPictureImageFilter(std::move(picture),
29 kLow_SkFilterQuality); 29 cropRect,
30 kDeviceSpace_Pictur eResolution,
31 kLow_SkFilterQualit y));
30 } 32 }
31 33
32 /** 34 /**
33 * Refs the passed-in picture. The picture is rasterized at a resolution th at matches the 35 * Refs the passed-in picture. The picture is rasterized at a resolution th at matches the
34 * local coordinate space. If the picture needs to be resampled for drawing it into the 36 * local coordinate space. If the picture needs to be resampled for drawing it into the
35 * destination canvas, bilinear filtering will be used. cropRect can be use d to crop or 37 * destination canvas, bilinear filtering will be used. cropRect can be use d to crop or
36 * expand the destination rect when the picture is drawn. (No scaling is im plied by the 38 * expand the destination rect when the picture is drawn. (No scaling is im plied by the
37 * dest rect; only the CTM is applied.) 39 * dest rect; only the CTM is applied.)
38 */ 40 */
41 static sk_sp<SkImageFilter> MakeForLocalSpace(sk_sp<SkPicture> picture,
42 const SkRect& cropRect,
43 SkFilterQuality filterQuality) {
44 return sk_sp<SkImageFilter>(new SkPictureImageFilter(std::move(picture),
45 cropRect,
46 kLocalSpace_Picture Resolution,
47 filterQuality));
48 }
49
50 #ifdef SK_SUPPORT_LEGACY_IMAGEFILTER_PTR
51 static SkImageFilter* Create(const SkPicture* picture) {
52 return Make(sk_ref_sp(const_cast<SkPicture*>(picture))).release();
53 }
54 static SkImageFilter* Create(const SkPicture* picture, const SkRect& cropRec t) {
55 return Make(sk_ref_sp(const_cast<SkPicture*>(picture)), cropRect).releas e();
56 }
39 static SkImageFilter* CreateForLocalSpace(const SkPicture* picture, 57 static SkImageFilter* CreateForLocalSpace(const SkPicture* picture,
40 const SkRect& cropRect, 58 const SkRect& cropRect,
41 SkFilterQuality filterQuali ty) { 59 SkFilterQuality filterQuality) {
42 return new SkPictureImageFilter(picture, cropRect, kLocalSpace_PictureRe solution, 60 return MakeForLocalSpace(sk_ref_sp(const_cast<SkPicture*>(picture)),
43 filterQuality); 61 cropRect,
62 filterQuality).release();
44 } 63 }
64 #endif
45 65
46 SK_TO_STRING_OVERRIDE() 66 SK_TO_STRING_OVERRIDE()
47 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkPictureImageFilter) 67 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkPictureImageFilter)
48 68
49 protected: 69 protected:
50 enum PictureResolution { 70 enum PictureResolution {
51 kDeviceSpace_PictureResolution, 71 kDeviceSpace_PictureResolution,
52 kLocalSpace_PictureResolution 72 kLocalSpace_PictureResolution
53 }; 73 };
54 74
55 virtual ~SkPictureImageFilter();
56
57 /* Constructs an SkPictureImageFilter object from an SkReadBuffer. 75 /* Constructs an SkPictureImageFilter object from an SkReadBuffer.
58 * Note: If the SkPictureImageFilter object construction requires bitmap 76 * Note: If the SkPictureImageFilter object construction requires bitmap
59 * decoding, the decoder must be set on the SkReadBuffer parameter by calli ng 77 * decoding, the decoder must be set on the SkReadBuffer parameter by calli ng
60 * SkReadBuffer::setBitmapDecoder() before calling this constructor. 78 * SkReadBuffer::setBitmapDecoder() before calling this constructor.
61 * @param SkReadBuffer Serialized picture data. 79 * @param SkReadBuffer Serialized picture data.
62 */ 80 */
63 void flatten(SkWriteBuffer&) const override; 81 void flatten(SkWriteBuffer&) const override;
64 bool onFilterImageDeprecated(Proxy*, const SkBitmap& src, const Context&, Sk Bitmap* result, 82 bool onFilterImageDeprecated(Proxy*, const SkBitmap& src, const Context&, Sk Bitmap* result,
65 SkIPoint* offset) const override; 83 SkIPoint* offset) const override;
66 84
67 private: 85 private:
68 explicit SkPictureImageFilter(const SkPicture* picture); 86 explicit SkPictureImageFilter(sk_sp<SkPicture> picture);
69 SkPictureImageFilter(const SkPicture* picture, const SkRect& cropRect, 87 SkPictureImageFilter(sk_sp<SkPicture> picture, const SkRect& cropRect,
70 PictureResolution, SkFilterQuality); 88 PictureResolution, SkFilterQuality);
71 89
72 void drawPictureAtDeviceResolution(SkBaseDevice*, const SkIRect& deviceBound s, 90 void drawPictureAtDeviceResolution(SkBaseDevice*, const SkIRect& deviceBound s,
73 const Context&) const; 91 const Context&) const;
74 void drawPictureAtLocalResolution(Proxy*, SkBaseDevice*, const SkIRect& devi ceBounds, 92 void drawPictureAtLocalResolution(Proxy*, SkBaseDevice*, const SkIRect& devi ceBounds,
75 const Context&) const; 93 const Context&) const;
76 94
77 const SkPicture* fPicture; 95 sk_sp<SkPicture> fPicture;
78 SkRect fCropRect; 96 SkRect fCropRect;
79 PictureResolution fPictureResolution; 97 PictureResolution fPictureResolution;
80 SkFilterQuality fFilterQuality; 98 SkFilterQuality fFilterQuality;
81 99
82 typedef SkImageFilter INHERITED; 100 typedef SkImageFilter INHERITED;
83 }; 101 };
84 102
85 #endif 103 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698