Chromium Code Reviews| Index: gm/drawminibitmaprect.cpp |
| diff --git a/gm/drawminibitmaprect.cpp b/gm/drawminibitmaprect.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7617aa5fdf72271b475d0722fb33433dddf67d2f |
| --- /dev/null |
| +++ b/gm/drawminibitmaprect.cpp |
| @@ -0,0 +1,148 @@ |
| +/* |
|
robertphillips
2015/08/13 18:17:52
2015 ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + * Copyright 2011 Google Inc. |
| + * |
| + * Use of this source code is governed by a BSD-style license that can be |
| + * found in the LICENSE file. |
| + */ |
| + |
| +#include "gm.h" |
|
robertphillips
2015/08/13 18:17:51
Do we need the blur headers ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| +#include "SkBlurMask.h" |
| +#include "SkBlurMaskFilter.h" |
| +#include "SkColorPriv.h" |
| +#include "SkGradientShader.h" |
| +#include "SkShader.h" |
| +#include "SkImage.h" |
| +#include "SkRandom.h" |
| + |
| +static SkImage* image_from_bitmap(const SkBitmap& bm) { |
| + SkBitmap b(bm); |
| + b.lockPixels(); |
| + return SkImage::NewRasterCopy(b.info(), b.getPixels(), b.rowBytes()); |
| +} |
| + |
|
robertphillips
2015/08/13 18:17:52
Can we pass the GM's canvas in here and use newSur
|
| +static SkImage* makebm(SkBitmap* bm, int w, int h) { |
| + bm->allocN32Pixels(w, h); |
| + bm->eraseColor(SK_ColorTRANSPARENT); |
| + |
| + SkCanvas canvas(*bm); |
| + |
| + SkScalar wScalar = SkIntToScalar(w); |
| + SkScalar hScalar = SkIntToScalar(h); |
| + |
|
robertphillips
2015/08/13 18:17:52
const ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkPoint pt = { wScalar / 2, hScalar / 2 }; |
| + |
|
robertphillips
2015/08/13 18:17:52
const ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkScalar radius = 4 * SkMaxScalar(wScalar, hScalar); |
| + |
|
robertphillips
2015/08/13 18:17:52
const ?
static ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkColor colors[] = { SK_ColorRED, SK_ColorYELLOW, |
| + SK_ColorGREEN, SK_ColorMAGENTA, |
| + SK_ColorBLUE, SK_ColorCYAN, |
| + SK_ColorRED}; |
| + |
|
robertphillips
2015/08/13 18:17:52
const ?
static ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkScalar pos[] = {0, |
| + SK_Scalar1 / 6, |
| + 2 * SK_Scalar1 / 6, |
| + 3 * SK_Scalar1 / 6, |
| + 4 * SK_Scalar1 / 6, |
| + 5 * SK_Scalar1 / 6, |
| + SK_Scalar1}; |
| + |
|
robertphillips
2015/08/13 18:17:51
SkASSERT(SK_ARRAY_COUNT(colors) == SK_ARRAY_COUNT(
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkPaint paint; |
| + SkRect rect = SkRect::MakeWH(wScalar, hScalar); |
| + SkMatrix mat = SkMatrix::I(); |
| + for (int i = 0; i < 4; ++i) { |
| + paint.setShader(SkGradientShader::CreateRadial( |
| + pt, radius, |
| + colors, pos, |
| + SK_ARRAY_COUNT(colors), |
| + SkShader::kRepeat_TileMode, |
| + 0, &mat))->unref(); |
| + canvas.drawRect(rect, paint); |
| + rect.inset(wScalar / 8, hScalar / 8); |
| + mat.postScale(SK_Scalar1 / 4, SK_Scalar1 / 4); |
| + } |
| + // Let backends know we won't change this, so they don't have to deep copy it defensively. |
| + bm->setImmutable(); |
| + |
| + return image_from_bitmap(*bm); |
| +} |
| + |
| +static const int gSize = 1024; |
| +static const int gBmpSize = 2048; |
| + |
|
robertphillips
2015/08/13 18:17:52
// This GM calls drawImageRect several times using
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| +class DrawMiniBitmapRectGM : public skiagm::GM { |
| +public: |
| + DrawMiniBitmapRectGM(bool antiAlias) : fAA(antiAlias) { |
| + fName.set("drawminibitmaprect"); |
| + if (fAA) { |
| + fName.appendf("_aa"); |
| + } |
| + } |
| + |
| + bool fAA; |
|
robertphillips
2015/08/13 18:17:52
Do we need to keep fLargeBitmap around?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkBitmap fLargeBitmap; |
| + SkAutoTUnref<SkImage> fImage; |
| + SkString fName; |
| + |
| +protected: |
| + SkString onShortName() override { return fName; } |
| + |
| + SkISize onISize() override { return SkISize::Make(gSize, gSize); } |
| + |
| + void onOnceBeforeDraw() override { |
| + fImage.reset(makebm(&fLargeBitmap, gBmpSize, gBmpSize)); |
| + } |
| + |
| + void onDraw(SkCanvas* canvas) override { |
|
robertphillips
2015/08/13 18:17:52
const ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkRect dstRect = { 0, 0, SkIntToScalar(64), SkIntToScalar(64)}; |
| + static const int kMaxSrcRectSize = 1 << (SkNextLog2(gBmpSize) + 2); |
| + |
| + static const int kPadX = 30; |
| + static const int kPadY = 40; |
| + |
| + int rowCount = 0; |
| + canvas->translate(SkIntToScalar(kPadX), SkIntToScalar(kPadY)); |
|
robertphillips
2015/08/13 18:17:52
Is there a restore to match this ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + canvas->save(); |
| + SkRandom random; |
| + |
| + SkPaint paint; |
| + paint.setAntiAlias(fAA); |
| + for (int w = 1; w <= kMaxSrcRectSize; w *= 3) { |
| + for (int h = 1; h <= kMaxSrcRectSize; h *= 3) { |
| + |
|
robertphillips
2015/08/13 18:17:52
const ?
joshualitt
2015/08/13 19:31:27
Acknowledged.
|
| + SkIRect srcRect = SkIRect::MakeXYWH((gBmpSize - w) / 2, (gBmpSize - h) / 2, w, h); |
| + canvas->save(); |
| + switch (random.nextU() % 3) { |
| + case 0: |
| + canvas->rotate(random.nextF() * 10.f); |
| + break; |
| + case 1: |
| + canvas->rotate(-random.nextF() * 10.f); |
| + break; |
| + case 2: |
| + // rect stays rect |
| + break; |
| + } |
| + canvas->drawImageRect(fImage, srcRect, dstRect, &paint, |
| + SkCanvas::kFast_SrcRectConstraint); |
| + canvas->restore(); |
| + |
| + canvas->translate(dstRect.width() + SK_Scalar1 * kPadX, 0); |
| + ++rowCount; |
| + if ((dstRect.width() + 2 * kPadX) * rowCount > gSize) { |
| + canvas->restore(); |
| + canvas->translate(0, dstRect.height() + SK_Scalar1 * kPadY); |
| + canvas->save(); |
| + rowCount = 0; |
| + } |
| + } |
| + } |
| + |
| + } |
| + |
| +private: |
| + typedef skiagm::GM INHERITED; |
| +}; |
| + |
| +DEF_GM( return new DrawMiniBitmapRectGM(true); ) |
| +DEF_GM( return new DrawMiniBitmapRectGM(false); ) |
| + |