diff options
author | robertphillips@google.com <robertphillips@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-09-26 13:10:19 +0000 |
---|---|---|
committer | robertphillips@google.com <robertphillips@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2012-09-26 13:10:19 +0000 |
commit | 21a95f16c9b73f3ecd23b9abfb6fc04e069de010 (patch) | |
tree | bd04132d5c0893f8749d8846af9061f4b6ade31c /gm | |
parent | 373ebc634573364c27b1ebd35bb537ef1285cba4 (diff) |
Added more drawBitmapRectToRect tests
http://codereview.appspot.com/6564053/
git-svn-id: http://skia.googlecode.com/svn/trunk@5688 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'gm')
-rw-r--r-- | gm/bitmaprect.cpp | 146 |
1 files changed, 144 insertions, 2 deletions
diff --git a/gm/bitmaprect.cpp b/gm/bitmaprect.cpp index 42f043e058..15d452066f 100644 --- a/gm/bitmaprect.cpp +++ b/gm/bitmaprect.cpp @@ -58,7 +58,6 @@ protected: SkPaint paint; paint.setStyle(SkPaint::kStroke_Style); -// paint.setColor(SK_ColorGREEN); SkBitmap bitmap; make_bitmap(&bitmap); @@ -71,7 +70,7 @@ protected: srcR.set(src[i]); canvas->drawBitmap(bitmap, 0, 0, &paint); - if (fUseIRect) { + if (!fUseIRect) { canvas->drawBitmapRectToRect(bitmap, &srcR, dstR, &paint); } else { canvas->drawBitmapRect(bitmap, &src[i], dstR, &paint); @@ -89,9 +88,152 @@ private: }; ////////////////////////////////////////////////////////////////////////////// +static void make_3x3_bitmap(SkBitmap* bitmap) { + + static const int gXSize = 3; + static const int gYSize = 3; + + SkColor textureData[gXSize][gYSize] = { + SK_ColorRED, SK_ColorWHITE, SK_ColorBLUE, + SK_ColorGREEN, SK_ColorBLACK, SK_ColorCYAN, + SK_ColorYELLOW, SK_ColorGRAY, SK_ColorMAGENTA + }; + + + bitmap->setConfig(SkBitmap::kARGB_8888_Config, gXSize, gYSize); + bitmap->allocPixels(); + + SkAutoLockPixels lock(*bitmap); + for (int y = 0; y < gYSize; y++) { + for (int x = 0; x < gXSize; x++) { + *bitmap->getAddr32(x, y) = textureData[x][y]; + } + } +} + +// This GM attempts to make visible any issues drawBitmapRectToRect may have +// with partial source rects. In this case the eight pixels on the border +// should be half the width/height of the central pixel, i.e.: +// __|____|__ +// | | +// __|____|__ +// | | +class DrawBitmapRect3 : public skiagm::GM { +public: + DrawBitmapRect3() { + this->setBGColor(SK_ColorBLACK); + } + +protected: + virtual SkString onShortName() SK_OVERRIDE { + SkString str; + str.printf("3x3bitmaprect"); + return str; + } + + virtual SkISize onISize() SK_OVERRIDE { + return SkISize::Make(640, 480); + } + + virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { + + SkBitmap bitmap; + make_3x3_bitmap(&bitmap); + + SkRect srcR = { 0.5f, 0.5f, 2.5f, 2.5f }; + SkRect dstR = { 100, 100, 300, 200 }; + + canvas->drawBitmapRectToRect(bitmap, &srcR, dstR, NULL); + } + +private: + typedef skiagm::GM INHERITED; +}; + +////////////////////////////////////////////////////////////////////////////// +static void make_big_bitmap(SkBitmap* bitmap) { + + static const int gXSize = 4096; + static const int gYSize = 4096; + static const int gBorderWidth = 10; + + bitmap->setConfig(SkBitmap::kARGB_8888_Config, gXSize, gYSize); + bitmap->allocPixels(); + + SkAutoLockPixels lock(*bitmap); + for (int y = 0; y < gYSize; ++y) { + for (int x = 0; x < gXSize; ++x) { + if (x <= gBorderWidth || x >= gXSize-gBorderWidth || + y <= gBorderWidth || y >= gYSize-gBorderWidth) { + *bitmap->getAddr32(x, y) = 0x88FFFFFF; + } else { + *bitmap->getAddr32(x, y) = 0x88FF0000; + } + } + } +} + +// This GM attempts to reveal any issues we may have when the GPU has to +// break up a large texture in order to draw it. The XOR transfer mode will +// create stripes in the image if there is imprecision in the destination +// tile placement. +class DrawBitmapRect4 : public skiagm::GM { + bool fUseIRect; +public: + DrawBitmapRect4(bool useIRect) : fUseIRect(useIRect) { + this->setBGColor(0x88444444); + } + +protected: + virtual SkString onShortName() SK_OVERRIDE { + SkString str; + str.printf("bigbitmaprect_%s", fUseIRect ? "i" : "s"); + return str; + } + + virtual SkISize onISize() SK_OVERRIDE { + return SkISize::Make(640, 480); + } + + virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { + + SkXfermode* mode = SkXfermode::Create(SkXfermode::kXor_Mode); + + SkPaint paint; + paint.setAlpha(128); + paint.setXfermode(mode); + + SkBitmap bitmap; + make_big_bitmap(&bitmap); + + SkRect srcR = { 0.0f, 0.0f, 4096.0f, 2040.0f }; + SkRect dstR = { 10.1f, 10.1f, 629.9f, 469.9f }; + + if (!fUseIRect) { + canvas->drawBitmapRectToRect(bitmap, &srcR, dstR, &paint); + } else { + canvas->drawBitmapRect(bitmap, NULL, dstR, &paint); + } + } + +private: + typedef skiagm::GM INHERITED; +}; + +////////////////////////////////////////////////////////////////////////////// static skiagm::GM* MyFactory0(void*) { return new DrawBitmapRect2(false); } static skiagm::GM* MyFactory1(void*) { return new DrawBitmapRect2(true); } +static skiagm::GM* MyFactory2(void*) { return new DrawBitmapRect3(); } + +static skiagm::GM* MyFactory3(void*) { return new DrawBitmapRect4(false); } +static skiagm::GM* MyFactory4(void*) { return new DrawBitmapRect4(true); } + static skiagm::GMRegistry reg0(MyFactory0); static skiagm::GMRegistry reg1(MyFactory1); + +static skiagm::GMRegistry reg2(MyFactory2); + +static skiagm::GMRegistry reg3(MyFactory3); +static skiagm::GMRegistry reg4(MyFactory4); |