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

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

Powered by Google App Engine
This is Rietveld 408576698