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

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, 10 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 #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
52 paint.setFilterLevel(SkPaint::kLow_FilterLevel); 35 paint.setFilterLevel(SkPaint::kLow_FilterLevel);
53 canvas.scale(scale, scale); 36 canvas.scale(scale, scale);
54 canvas.drawBitmap(src, 0, 0, &paint); 37 canvas.drawImage(src, 0, 0, &paint);
55 tmp = dev->accessBitmap(false); 38
39 tmp.reset(device->newImageSnapshot());
40 if (NULL == tmp) {
41 return false;
42 }
56 } 43 }
57 44
58 // upscale 45 // upscale
59 { 46 {
60 SkBaseDevice* dev = proxy->createDevice(src.width(), src.height()); 47 SkAutoTUnref<SkBaseDevice> device(proxy->createDevice(src->width(), src- >height()));
61 if (NULL == dev) { 48 if (NULL == device) {
62 return false; 49 return false;
63 } 50 }
64 OwnDeviceCanvas canvas(dev); 51 SkCanvas canvas(device);
65 52 SkScalar scaleX = SkIntToScalar(src->width()) / SkIntToScalar(dstW);
66 SkRect r = SkRect::MakeWH(SkIntToScalar(src.width()), 53 SkScalar scaleY = SkIntToScalar(src->height()) / SkIntToScalar(dstH);
67 SkIntToScalar(src.height())); 54 canvas.scale(scaleX, scaleY);
68 canvas.drawBitmapRect(tmp, NULL, r, NULL); 55 canvas.drawImage(tmp, 0, 0, NULL);
69 *result = dev->accessBitmap(false); 56 SkImage* image = device->newImageSnapshot();
57 if (NULL == image) {
58 return false;
59 }
60 result.reset(image);
70 } 61 }
71 return true; 62 return true;
72 } 63 }
73 64
74 SkFlattenable* SkDownSampleImageFilter::CreateProc(SkReadBuffer& buffer) { 65 SkFlattenable* SkDownSampleImageFilter::CreateProc(SkReadBuffer& buffer) {
75 SK_IMAGEFILTER_UNFLATTEN_COMMON(common, 1); 66 SK_IMAGEFILTER_UNFLATTEN_COMMON(common, 1);
76 return Create(buffer.readScalar(), common.getInput(0)); 67 return Create(buffer.readScalar(), common.getInput(0));
77 } 68 }
78 69
79 void SkDownSampleImageFilter::flatten(SkWriteBuffer& buffer) const { 70 void SkDownSampleImageFilter::flatten(SkWriteBuffer& buffer) const {
80 this->INHERITED::flatten(buffer); 71 this->INHERITED::flatten(buffer);
81 buffer.writeScalar(fScale); 72 buffer.writeScalar(fScale);
82 } 73 }
83 74
84 #ifndef SK_IGNORE_TO_STRING 75 #ifndef SK_IGNORE_TO_STRING
85 void SkDownSampleImageFilter::toString(SkString* str) const { 76 void SkDownSampleImageFilter::toString(SkString* str) const {
86 str->appendf("SkDownSampleImageFilter: ("); 77 str->appendf("SkDownSampleImageFilter: (");
87 str->append(")"); 78 str->append(")");
88 } 79 }
89 #endif 80 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698