Chromium Code Reviews| Index: gm/image.cpp |
| diff --git a/gm/image.cpp b/gm/image.cpp |
| index 8fe96d118521a9b92b15c66ea8a424a30dc593d5..d980cb7562e2f67d9862f6c64c1b552180f44b51 100644 |
| --- a/gm/image.cpp |
| +++ b/gm/image.cpp |
| @@ -6,10 +6,11 @@ |
| */ |
| #include "gm.h" |
| -#include "SkSurface.h" |
| +#include "SkData.h" |
| #include "SkCanvas.h" |
| +#include "SkRandom.h" |
| #include "SkStream.h" |
| -#include "SkData.h" |
| +#include "SkSurface.h" |
| #if SK_SUPPORT_GPU |
| #include "GrContext.h" |
| @@ -196,3 +197,95 @@ private: |
| }; |
| DEF_GM( return new ImageGM; ) |
| +class ImageResizeGM : public skiagm::GM { |
| + enum { |
| + W = 100, |
| + H = 100, |
| + }; |
| +public: |
| + ImageResizeGM() {} |
| + |
| +protected: |
| + SkString onShortName() SK_OVERRIDE { return SkString("image-resize"); } |
| + |
| + SkISize onISize() SK_OVERRIDE { return SkISize::Make(510, 480); } |
| + |
| + void drawIntoImage(SkCanvas* canvas) { |
|
scroggo
2015/01/22 20:05:14
Can all these functions be static?
reed1
2015/01/22 21:52:52
At the moment, yes, but earlier they used some int
|
| + SkPaint paint; |
| + paint.setAntiAlias(true); |
| + paint.setStyle(SkPaint::kStroke_Style); |
| + paint.setStrokeWidth(3); |
| + SkRandom rand; |
| + for (int i = 0; i < 60; ++i) { |
| + paint.setColor(rand.nextU()); |
| + SkScalar x = rand.nextUScalar1() * W; |
| + SkScalar y = rand.nextUScalar1() * H; |
| + SkScalar r = rand.nextUScalar1() * W / 2; |
| + canvas->drawCircle(x, y, r, paint); |
| + } |
| + } |
| + |
| + SkImage* makeImage(SkCanvas* canvas) { |
| + const SkImageInfo info = SkImageInfo::MakeN32Premul(W, H); |
| + SkAutoTUnref<SkSurface> surface(canvas->newSurface(info)); |
| + if (!surface) { |
| + surface.reset(SkSurface::NewRaster(info)); |
| + } |
| + this->drawIntoImage(surface->getCanvas()); |
| + return surface->newImageSnapshot(); |
| + } |
| + |
| + void drawResized(SkCanvas* canvas, SkImage* image, int newW, int newH, const SkIRect* subset, |
| + SkFilterQuality fq) { |
| + // canvas method |
| + SkPaint paint; |
| + paint.setFilterQuality(fq); |
| + SkRect dstR = SkRect::MakeWH(SkIntToScalar(newW), SkIntToScalar(newH)); |
| + SkRect srcR; |
| + if (subset) { |
| + srcR.set(*subset); |
| + } |
| + canvas->drawImageRect(image, subset ? &srcR : NULL, dstR, &paint); |
| + canvas->translate(newW + 20.0f, 0); |
| + |
| + // image method |
| + SkAutoTUnref<SkImage> image2(image->newImage(newW, newH, subset, fq)); |
| + canvas->drawImage(image2, 0, 0, NULL); |
| + canvas->translate(image2->width() + 20.0f, 0); |
| + } |
| + |
| + void drawImage(SkCanvas* canvas, SkImage* image, SkFilterQuality fq) { |
| + |
| + canvas->drawImage(image, 0, 0, NULL); |
| + canvas->translate(image->width() + 20.0f, 0); |
| + this->drawResized(canvas, image, image->width()*4/10, image->height()*4/10, NULL, fq); |
| + |
| + SkIRect subset = SkIRect::MakeLTRB(W/4, H/4, W/2, H/2); |
| + this->drawResized(canvas, image, W, H, &subset, fq); |
| + } |
| + |
| + void onDraw(SkCanvas* canvas) SK_OVERRIDE { |
| + canvas->translate(10, 10); |
| + |
| + SkAutoTUnref<SkImage> image(this->makeImage(canvas)); |
| + |
| + const SkFilterQuality fq[] = { |
| + kNone_SkFilterQuality, |
| + kLow_SkFilterQuality, |
| + kMedium_SkFilterQuality, |
| + kHigh_SkFilterQuality, |
| + }; |
| + for (size_t i = 0; i < SK_ARRAY_COUNT(fq); ++i) { |
| + { |
| + SkAutoCanvasRestore acr(canvas, true); |
| + this->drawImage(canvas, image, fq[i]); |
| + } |
| + canvas->translate(0, image->height() + 20.0f); |
| + } |
| + } |
| + |
| +private: |
| + typedef skiagm::GM INHERITED; |
| +}; |
| +DEF_GM( return new ImageResizeGM; ) |
| + |