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

Side by Side Diff: src/effects/SkTestImageFilters.cpp

Issue 920513003: Make filters use SkImage instead of SkBitmap Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 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
« no previous file with comments | « src/effects/SkRectShaderImageFilter.cpp ('k') | src/effects/SkTileImageFilter.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 1
2 #include "SkTestImageFilters.h" 2 #include "SkTestImageFilters.h"
3 #include "SkCanvas.h" 3 #include "SkCanvas.h"
4 #include "SkDevice.h" 4 #include "SkDevice.h"
5 #include "SkReadBuffer.h" 5 #include "SkReadBuffer.h"
6 #include "SkWriteBuffer.h" 6 #include "SkWriteBuffer.h"
7 7
8 // Simple helper canvas that "takes ownership" of the provided device, so that 8 bool SkDownSampleImageFilter::onFilterImage(Proxy* proxy, const SkImage* src,
9 // when this canvas goes out of scope, so will its device. Could be replaced
10 // with the following:
11 //
12 // SkCanvas canvas(device);
13 // SkAutoTUnref<SkBaseDevice> aur(device);
14 //
15 class OwnDeviceCanvas : public SkCanvas {
16 public:
17 OwnDeviceCanvas(SkBaseDevice* device) : SkCanvas(device) {
18 SkSafeUnref(device);
19 }
20 };
21
22 ///////////////////////////////////////////////////////////////////////////////
23
24 bool SkDownSampleImageFilter::onFilterImage(Proxy* proxy, const SkBitmap& src,
25 const Context&, 9 const Context&,
26 SkBitmap* result, SkIPoint*) const { 10 SkAutoTUnref<const SkImage>& result, SkIPoint*) const {
27 SkScalar scale = fScale; 11 SkScalar scale = fScale;
28 if (scale > SK_Scalar1 || scale <= 0) { 12 if (scale > SK_Scalar1 || scale <= 0) {
29 return false; 13 return false;
30 } 14 }
31 15
32 int dstW = SkScalarRoundToInt(src.width() * scale); 16 int dstW = SkScalarRoundToInt(src->width() * scale);
33 int dstH = SkScalarRoundToInt(src.height() * scale); 17 int dstH = SkScalarRoundToInt(src->height() * scale);
34 if (dstW < 1) { 18 if (dstW < 1) {
35 dstW = 1; 19 dstW = 1;
36 } 20 }
37 if (dstH < 1) { 21 if (dstH < 1) {
38 dstH = 1; 22 dstH = 1;
39 } 23 }
40 24
41 SkBitmap tmp; 25 SkAutoTUnref<const SkImage> tmp;
42 26
43 // downsample 27 // downsample
44 { 28 {
45 SkBaseDevice* dev = proxy->createDevice(dstW, dstH); 29 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(dstW, dstH));
46 if (NULL == dev) { 30 if (NULL == device) {
47 return false; 31 return false;
48 } 32 }
49 OwnDeviceCanvas canvas(dev); 33 SkCanvas canvas(device);
50 SkPaint paint; 34 SkPaint paint;
51 35
52 paint.setFilterQuality(kLow_SkFilterQuality); 36 paint.setFilterQuality(kLow_SkFilterQuality);
53 canvas.scale(scale, scale); 37 canvas.scale(scale, scale);
54 canvas.drawBitmap(src, 0, 0, &paint); 38 canvas.drawImage(src, 0, 0, &paint);
55 tmp = dev->accessBitmap(false); 39
40 tmp.reset(device->newImageSnapshot());
41 if (NULL == tmp) {
42 return false;
43 }
56 } 44 }
57 45
58 // upscale 46 // upscale
59 { 47 {
60 SkBaseDevice* dev = proxy->createDevice(src.width(), src.height()); 48 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(src->width(), src- >height()));
61 if (NULL == dev) { 49 if (NULL == device) {
62 return false; 50 return false;
63 } 51 }
64 OwnDeviceCanvas canvas(dev); 52 SkCanvas canvas(device);
65 53 SkScalar scaleX = SkIntToScalar(src->width()) / SkIntToScalar(dstW);
66 SkRect r = SkRect::MakeWH(SkIntToScalar(src.width()), 54 SkScalar scaleY = SkIntToScalar(src->height()) / SkIntToScalar(dstH);
67 SkIntToScalar(src.height())); 55 canvas.scale(scaleX, scaleY);
68 canvas.drawBitmapRect(tmp, NULL, r, NULL); 56 canvas.drawImage(tmp, 0, 0, NULL);
69 *result = dev->accessBitmap(false); 57 SkImage* image = device->newImageSnapshot();
58 if (NULL == image) {
59 return false;
60 }
61 result.reset(image);
70 } 62 }
71 return true; 63 return true;
72 } 64 }
73 65
74 SkFlattenable* SkDownSampleImageFilter::CreateProc(SkReadBuffer& buffer) { 66 SkFlattenable* SkDownSampleImageFilter::CreateProc(SkReadBuffer& buffer) {
75 SK_IMAGEFILTER_UNFLATTEN_COMMON(common, 1); 67 SK_IMAGEFILTER_UNFLATTEN_COMMON(common, 1);
76 return Create(buffer.readScalar(), common.getInput(0)); 68 return Create(buffer.readScalar(), common.getInput(0));
77 } 69 }
78 70
79 void SkDownSampleImageFilter::flatten(SkWriteBuffer& buffer) const { 71 void SkDownSampleImageFilter::flatten(SkWriteBuffer& buffer) const {
80 this->INHERITED::flatten(buffer); 72 this->INHERITED::flatten(buffer);
81 buffer.writeScalar(fScale); 73 buffer.writeScalar(fScale);
82 } 74 }
83 75
84 #ifndef SK_IGNORE_TO_STRING 76 #ifndef SK_IGNORE_TO_STRING
85 void SkDownSampleImageFilter::toString(SkString* str) const { 77 void SkDownSampleImageFilter::toString(SkString* str) const {
86 str->appendf("SkDownSampleImageFilter: ("); 78 str->appendf("SkDownSampleImageFilter: (");
87 str->append(")"); 79 str->append(")");
88 } 80 }
89 #endif 81 #endif
OLDNEW
« no previous file with comments | « src/effects/SkRectShaderImageFilter.cpp ('k') | src/effects/SkTileImageFilter.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698